

## cNos DIGITAL DATA BOOK



## Part of the Harris Spectrum of Integrated Circuits

## 4 <br> HARRIS

# 1984 Harris CMOS Digital Data Book 


#### Abstract

Harris Semiconductor CMOS Digital Products Division's products represent state-of-the-art in density and high performance. The HARRIS expertise in CMOS design and processing offers the user the most reliable product available in a wide choice of formats, options, and package types. With continuing research and development and the introduction of new products, Harris will provide its customers with the most advanced CMOS technology.


This book describes Harris Semiconductor CMOS Digital Products Division's complete line of digital products and includes a complete set of product specifications and data sheets. Also included are sections on reliaiblity, programming, and packaging.

Please fill out the registration card at the back of this book and return it to us so we may keep you informed of our latest new product developments over the next year.

If you need more information on these and other HARRIS products, please contact the nearest HARRIS sales office listed in the back of this data book.

Harris Semiconductor's products are sold by description only. HARRIS reserves the right to make changes in circuit design, specifications and other information at any time without prior notice. Accordingly, the reader is cautioned to verify that data sheets and other information in this publication are current before placing orders. Information contained in application notes is intended soley for general guidance; use of the information for user's specific appiication is at user's risk. Reference to products of other manufacturers are solely for convenience of comparison and do not imply total equivalency of design, performance, or otherwise.

## 1984 Digital Data Book

General Information1CMOS Memory2CMOS 80C86 Family3
CMOS 12-Bit Microprocessors \& Peripherals4
CMOS Data Communication ..... 5
Harris Reliability and Quality ..... 6
Hi-Reliability \& Military Products ..... 7
Article Reprints ..... 8
Custom - Semi-Custom CMOS IC Information ..... 9
Ordering and Packaging ..... 10
DICE Information11Appendices12

## Table of Contents

PAGE
SECTION 1 GENERAL INFORMATION
Sector Capabilities ..... 1-2
CMOS Alpha-Numeric Index ..... 1-3
CMOS Devices by Families ..... 1-4
Classification of Literature ..... 1-6
Symbols and Abbrevations ..... 1-6
SECTION 2 CMOS MEMORY
CMOS Memory Product Index ..... 2-2
Low Voltage Data Retention ..... 2-3
Industry CMOS RAM Cross-Reference ..... 2-4
1 K CMOS RAM Data Sheets ..... 2-5
4K CMOS RAM Data Sheets ..... 2-29
16K CMOS RAM Data Sheets ..... 2-51
CMOS RAM Module Data Sheets ..... 2-85
CMOS PROM Data Sheets ..... 2-113
Preview of CMOS PROM Products ..... 2-126
Programming Format for Harris PROMs ..... 2-127
Preview of Future CMOS HPL Circuits ..... 2-130
SECTION 3 CMOS 80C86 FAMILY
CMOS 80C86 Family Product Index ..... 3-2
CMOS 80C86 Family Cross Reference ..... 3-3
Harris 80C86 Family Data Sheets ..... 3-4
Preview of Future Harris 80C86 Family Products ..... 3-96
SECTION 4 CMOS 12 BIT MICROPROCESSORS AND PERIPHERALS
CMOS 12 Bit Microprocessor and Peripheral Product Index ..... 4-2
CMOS Microprocessor Data Sheets ..... 4-3
CMOS Peripheral Data Sheets ..... 4-59
SECTION 5 CMOS DATA COMMUNICATIONS
CMOS Data Communications Product Index ..... 5-2
CMOS Data Communications Data Sheets ..... 5-3
SECTION 6 HARRIS RELIABILITY AND QUALITY
Harris Reliability and Quality Table of Contents ..... 6-1
SECTION 7 HARRIS HI-REL AND MILITARY PRODUCTS
Harris Hi-Rel and Military Products Table of Contents ..... 7-1
SECTION 8 ARTICLE REPRINTS
Article Reprints Table of Contents ..... 8-2
SECTION 9 CUSTOM - SEMI-CUSTOM CMOS IC INFORMATION
Custom - Semi-Custom CMOS IC Information Table of Contents ..... 9-1
SECTION 10 ORDERING AND PACKAGING
Ordering and Packaging Information ..... 10-1
SECTION 11 DICE INFORMATION
Dice Information ..... 11-1
SECTION 12 APPENDICES
Sector Alpha-Numeric Product Index ..... 12-3
Harris Sales Locations ..... 12-8
Sector Capabilities ..... 1-2
CMOS Alpha-Numeric Index ..... 1-3
CMOS Devices by Families ..... 1-4
Classification of Literature ..... $1-6$
Symbols and Abbreviations ..... $1-6$

## Harris Semiconductor

## Sector Capabilities

Harris Semiconductor is one of the five management groups of Harris Corporation, a producer of high-technology communication and information processing systems sold in over 160 countries. Five main operations of Harris Semiconductor produce standard and custom semiconductor devices. These operations are:

## ANALOG PRODUCTS DIVISION

Harris is a major force in analog integrated circuitry, offering a broad line of products including: analog-to-digital converters, digital-toanalog converters, switches, multiplexers, voltage references, operational amplifiers, telecommunications and speech processing products.

## BIPOLAR DIGITAL PRODUCTS DIVISION

Harris introduced the industry's first bipolar programmable read only memory in 1970 and has continued as a leader in the field of bipolar PROMs. Harris offers a complete spectrum of bipolar PROMs from 256 bits to 64 K bits. Also, offered is a new family of programmable logic products featuring on-chip testability.

## CMOS DIGITAL PRODUCTS DIVISION

Harris is a pioneer in developing and producing digital CMOS products including: CMOS RAMs, CMOS PROMs, CMOS microprocessors, CMOS peripherals, CMOS data communications products, and this year introducing a full line of 80 C 86 microprocessors and peripherals.

## CUSTOM INTEGRATED CIRCUITS DIVISION

Harris designs, develops and manufactures custom analog, digital bipolar, radiation-hardened, and CMOS circuits for specialized military and commercial applications.

MICROWAVE SEMICONDUCTOR, INC.
Harris Microwave Semiconductor, Inc. develops and manufactures gallium arsenide transistors, integrated circuits and microwave amplifiers.

# CMOS Alpha-Numeric Index 

| PRODUCT | DESCRIPTION | PAGE NO. |
| :---: | :---: | :---: |
| HD-15530 | Manchester Encoder-Decoder | 5-3 |
| HD-15531 | Manchester Encoder-Decoder | 5-10 |
| HD-4702 | Programmable Bit Rate Generator | 5-56 |
| HD-6101 | Parallel Interface Element | 4-51 |
| HD-6120 | 12 Bit High Performance Microprocessor | 4-3 |
| HD-6121 | I/O Controller | 4-22 |
| HD-6402 | LSI Universal Asynchronous Receiver Transmitter | 5-51 |
| HD-6406 | Programmable Asynchronous Communication Interface | 5-39 |
| HD-6408 | Asynchronous Manchester Adapter | 5-25 |
| HD-6409 | Manchester Encoder-Decoder | 5-30 |
| HD-6431 | Hex Latching Bus Driver | 4-59 |
| HD-6432 | Hex Bi-directional Bus Driver | 4-62 |
| HD-6433 | Quad Bus Separator/Driver | 4-65 |
| HD-6434 | Octal Resettable Latch | 4-68 |
| HD-6436 | Octal Bus Buffer/Driver | 4-71 |
| HD-6440 | Latch Decoder/Driver | 4-74 |
| HD-6495 | Hex Bus Driver | 4-78 |
| HM-6100 | 12 Bit Static Microprocessor | 4-30 |
| HM-6504 | 4K X 1 Synchronous RAM | 2-29 |
| HM-6508 | $1 \mathrm{~K} \times 1$ Synchronous RAM | 2-5 |
| HM-6514 | $1 \mathrm{~K} \times 4$ Synchronous RAM | 2-40 |
| HM-6516 | 2K $\times 8$ Synchronous RAM | 2-51 |
| HM-65162 | $2 \mathrm{~K} \times 8$ Asynchronous RAM | 2-57 |
| HM-65172 | 2K X 8 Asynchronous RAM | 2-70 |
| HM-6518 | $1 \mathrm{~K} \times 1$ Synchronous RAM | 2-11 |
| HM-65262 | 16K $\times 1$ Asynchronous RAM | 2-83 |
| HM-6551 | $256 \times 4$ Synchronous RAM | 2-17 |
| HM-6561 | $256 \times 4$ Synchronous RAM | 2-23 |
| HM-6564 | 64K Synchronous RAM Module | 2-85 |
| HM-6616 | $2 \mathrm{~K} \times 8$ Fuse Link PROM | 2-118 |
| HM-6641 | $512 \times 8$ PROM | 2-113 |
| HM-6664 | 8K X 8 Fuse Link PROM | 2-126 |
| HM-92560 | 256K Synchronous RAM Module | 2-96 |
| HM-92570 | 256K Synchronous RAM Module | 2-104 |
| HPL- 16LC8 | Programmable Logic | 2-130 |
| HPL-16RC4 | Programmable Logic | 2-132 |
| HPL-16RC6 | Programmable Logic | 2-132 |
| HPL-16RC8 | Programmable Logic | 2-132 |
| $80 \mathrm{C86}$ | 16 Bit Microprocessor | 3-4 |
| 80C88 | 8 Bit Microprocessor | 3-96 |
| 82C37A | High Performance Programmable DMA Controller | 3-97 |
| 82C52 | Full Duplex UART | 3-27 |
| 82C54 | Programmable Interval Timer | 3-28 |
| 82C55A | Programmable Peripheral Interface | 3-43 |
| 82C59A | Priority Interrupt Controller | 3-62 |
| 82C82 | Octal Latch | 3-77 |
| 82C83 | Octal Latching Inverting Bus Driver | 3-98 |
| 82C84A | Clock Generator/Driver | 3-82 |
| 82C84B | Clock Generator Driver | 3-99 |
| 82C86 | Octal Bus Transceiver | 3-100 |
| $82 \mathrm{C87}$ | Octal Bus Transceiver | 3-101 |
| 82C88 | Bus Controller | 3-89 |
| 82C89 | Bus Arbiter | 3-102 |

## CMOS Devices by Families

CMOS Microprocessor and Support Circuits ..... PAGE
8/16 BIT MICROPROCESSORS
80C86 $\quad 16$ Bit CMOS Microprocessor ..... 3-4
80C88 8 Bit CMOS Microprocessor ..... 3-96
80C86/88 PERIPHERAL CIRCUITS
82C37A CMOS DMA Controller ..... 3-97
82 C52 CMOS Serial Communication Interface ..... 3-27
82 C54 CMOS Programmable Interval Timer ..... 3-28
82C55A CMOS Programmable Peripheral Interface ..... 3-43
82C59A CMOS Priority Interrupt Controller ..... 3-62
80C86/88 BUS SUPPORT CIRCUITS
82C82 CMOS Octal Latching Bus Driver ..... 3-77
82C83 CMOS Octal Latching Inverting Bus Driver ..... 3-98
82C84A CMOS Clock Generator Driver ..... 3-82
82C84B CMOS Clock Generator Driver ..... 3-99
82C86 CMOS Octal Bus Transceiver ..... 3-100
82C87 CMOS Octal Inverting Bus Transceiver ..... 3-101
82C88 CMOS Bus Controller ..... 3-89
82C89 CMOS Bus Arbiter ..... 3-102
12 BIT MICROPROCESSORS
HM-6100 CMOS 12 Bit Microprocessor ..... 4-30
HD-6120 CMOS High Performance 12 Bit Microprocessor ..... 4-3
12 BIT PERIPHERAL CONTROLLERS
HD-6101 CMOS Parallel Interface Element (PIE) ..... 4-51
HD-6121 CMOS I/O Controller (IOC) ..... 4-22 ..... 4-22
BUS SUPPORT CIRCUITS
HD-6431 CMOS Hex Latching Bus Driver ..... 4-59
HD-6432 CMOS Hex Bi-directional Bus Driver ..... 4-62
HD-6433 CMOS Quad Bus Separator/Driver ..... 4-65
HD-6434 CMOS Octal Bus Driver W/Reset ..... 4-68
HD-6436 CMOS Octal Bus Buffer/Driver ..... 4-71
HD-6440 CMOS Latched 3 to 8 Line Decoder/Driver ..... 4-74
HD-6495 CMOS Hex Bus Driver ..... 4-78
SERIAL COMMUNICATION CIRCUITS
HD-4702 CMOS Bit Rate Generator ..... 5-56
HD-6402 CMOS UART ..... 5-51
HD-6406 CMOS Prog. Async. Communication Interface ..... 5-39
HD-6408 CMOS Async. Serial Manchester Adapter (ASMA) ..... 5-25
HD-6409 CMOS Manchester Encoder-Decoder ..... 5-30
HD-15530 CMOS Manchester Encoder-Decoder ..... 5-3
HD-15531 CMOS Manchester Encoder-Decoder ..... 5-10

## CMOS Devices by Families

## (continued)

CMOS Static RAMS ..... PAGE
1K - SYNCHRONOUS
HM-6508 $1 \mathrm{~K} \times 1$ ..... 2-5
HM-6518 $1 \mathrm{~K} \times 1$ ..... 2-11
HM-655 $256 \times 4$ ..... 2-17
HM-6561 $256 \times 4$ ..... 2-25
4K - SYNCHRONOUS
HM-6504 $4 \mathrm{~K} \times 1$ ..... 2-29
HM-6514 $1 \mathrm{~K} \times 4$ ..... 2-40
16K-SYNCHRONOUS
HM-6516 $2 \mathrm{~K} \times 8$ ..... 2-51
16K- ASYNCHRONOUS
HM-65162 2K X 8 ..... 2-57
HM-65172 $2 \mathrm{~K} \times 8$ ..... 2-70
HM-65262 16K X 1 ..... 2-83
CMOS RAM MODULES
HM-6564 64K ..... 2-85
HM-92560 256K ..... 2-96
HM-92570 Buffered 256K ..... 2-104
CMOS RADIATION HARDENED RAMS
HS-6504RH $4 \mathrm{~K} \times 1$ ..... 9-18
HS-6508RH $1 \mathrm{~K} \times 1$ ..... 9-19
HS-6514RH $1 \mathrm{~K} \times 4$ ..... 9-20
HS-6551RH $256 \times 4$ ..... 9-21
HS-6564RH $\quad 16 \mathrm{~K} \times 4$ or $8 \mathrm{~K} \times 8$ ..... 9-2
CMOS Fuse Link PROMS
HM-6641 $512 \times 8$ ..... 2-113
HM-6616 2K X 8 ..... 2-118
HM-6664 8K X8 ..... 2-126
CMOS Programmable Logic
HPL-16LC8 Programmable Logic ..... 2-130
HPL-16RC4 Programmable Logic ..... 2-132
HPL-16RC6 Programmable Logic ..... 2-132
HPL-16RC8 Programmable Logic ..... 2-132

## Classification of Literature

| CLASSIFICATION | PRODUCT STAGE | DISCLAIMERS |
| :--- | :--- | :--- |
| Preview <br> DATA <br> SHEET | Formative or <br> Design | This document contains the design specifications <br> for product under development. Specifications <br> may be changed in any manner without notice. |
| Advance <br> Information <br> DATA SHEET | Sampling or <br> Pre-Production | This is advanced information, and specifications <br> are subject to change without notice. |
| Preliminary <br> DATA SHEET | First Production | Supplementary data may be published at a <br> later date. <br> Harris reserves the right to make changes at any- <br> time without notice, in order to improve design <br> and supply the best product possible. |

## Symbols \& Abbreviations

This data book utilizes a new set of specification nomenclature. This new format is an IEEE and JEDEC supported standard for semiconductor memories. It is intended to clarify the symbols, abbreviations and definitions, and to make all memory data sheets consistent. We believe that, once acclimated, you will find this standardized format easy to read and use.

ELECTRICAL PARAMETER ABBREVIATIONS
All abbreviations use upper case letters with no subscripts. The initial symbol is one of these four characters:

| V | (Voltage) |
| :--- | :--- |
| I | (Current) |
| P | (Power) |
| C | (Capacitance) |

The second letter specifies input (I) or output ( O ), and the third letter indicates the high $(H)$, low $(L)$ or off $(Z)$ state of the pin during measurements. Examples:

> VIL - Input Low Voltage
> IOZ - Output Leakage Current

## TIMING PARAMETER ABBREVIATIONS

All timing abbreviations use upper case characters with no subscripts. The initial character is always T and is followed by four descriptors. These characters specify two signal points arranged in a "from-to" sequence that define a timing interval. The two descriptors for each signal point specify the signal name and the signal transitions. Thus the format is:


Signal Definitions:
$A=$ Address
$\mathrm{D}=$ Data $\ln$
Q = Data Out
W = Write Enable
$E=$ Chip Enable
S = Chip Select
G = Output Enable

## Transition Definitions:

$\mathrm{H}=$ Transition to High
$\mathrm{L}=$ Transition to Low
$\mathrm{V}=$ Transition to Valid
$\mathrm{X}=$ Transition to Invalid or Don't Care
$\mathrm{Z}=$ Transition to Off (High Impedance)

EXAMPLE:


The example shows Write pulse setup time defined as TWLEH-Time from Write enable Low to chip Enable High.

## TIMING LIMITS

The table of timing values shows either a minimum or a maximum limit for each parameter. Input requirements are specified from the external system point of view. Thus, address set-up time is shown as a minimum since the system must supply at least that much time (even though most devices do not require it). On the other hand, responses from the memory are specified from the device point of view. Thus, the access time is shown as a maximum since the device never provides data later than that time.
WAVEFORMS


Product Index ..... 2-2
Low Voltage Data Retention ..... 2-3
Industry CMOS RAM
Cross-Reference ..... $2-4$
Product Information ..... 2-5

## CMOS Memory Product Index

PAGE
1K CMOS RAM DATA SHEETS
HM-6508 $1 \mathrm{~K} \times 1$ Synchronous RAM ..... 2-5
HM-6518 $\quad 1 \mathrm{~K} \times 1$ Synchronous RAM ..... 2-11
HM-6551 $256 \times 4$ Synchronous RAM ..... 2-17
HM-6561 $256 \times 4$ Synchronous RAM ..... 2-23
4K CMOS RAM DATA SHEETS
HM-6504 $4 \mathrm{~K} \times 1$ Synchronous RAM ..... 2-29
HM-6514 $1 \mathrm{~K} \times 4$ Synchronous RAM ..... 2-40
16K CMOS RAM DATA SHEETS
HM-6516 $2 \mathrm{~K} \times 8$ Synchronous RAM ..... 2-51
HM-65162 2K $\times 8$ Asynchronous RAM ..... 2-57
HM-65172 2K $\times 8$ Asynchronous RAM ..... 2-70
PREVIEW OF FUTURE CMOS RAM PRODUCTS
HM-65262 16K $\times 1$ Asynchronous RAM ..... 2-83
CMOS RAM MODULE DATA SHEETS
HM-6564 64K Synchronous RAM Module ..... 2-85
HM-92560 256K Synchronous RAM Module ..... 2-96
HM-92570 256K Synchronous RAM Module ..... 2-104
CMOS PROM DATA SHEETS
HM-6641 $512 \times 8$ Fuse Link PROM ..... 2-113
HM-6616 $2 \mathrm{~K} \times 8$ Fuse Link PROM ..... 2-118
PREVIEW OF FUTURE CMOS PROM PRODUCTS
HM-6664 $8 \mathrm{~K} \times 8$ Fuse Link PROM ..... 2-126
PROGRAMMING FORMAT FOR HARRIS PROMs ..... 2-128
PREVIEW OF FUTURE CMOS HPL CIRCUITS
HPL-16LC8 Programmable Logic ..... 2-130
HPL-16RC4 Programmable Logic ..... 2-132
HPL-16RC6 Programmable Logic ..... 2-132
HPL-16RC8 Programmable Logic ..... 2-132

## Low Voltage Data Retention

HARRIS CMOS RAMs are designed with battery backup in mind. Data retention voltage and supply current are guaranteed over temperature. The following rules insure data retention:

1. Chip Enable ( $\bar{E}$ ) must be held high during data retention; within VCC to VCC +0.3 V
2. On RAMs which have selects or output enables (e.g. $\overline{\mathrm{S}}, \overline{\mathrm{G}}$ ), one of the selects or output enables should be held in the deselected state to keep the RAM outputs high impedance, minimizing power dissipation.
3. All other inputs should be held either high (at CMOS VCC) or at ground to minimize ICCDR.
4. Inputs which are to be held high (e.g. $\bar{E}$ ) must be kept between VCC +0.3 V and $70 \%$ of VCC during the power up and power down transitions.
5. The RAM can begin operation one TEHEL (for synchronous RAMs) and $>55 \mathrm{~ns}$ (for asynchronous RAMs) after VCC reaches the minimum operating voltage ( 4.5 volts).

DATA RETENTION TIMING


HARRIS CMOS/NMOS RAM Cross-Reference


Features

- LOW STANDBY POWER

LOW OPERATING POWER
FAST ACCESS TIME

- DATA RETENTION VOLTAGE
- TTL COMPATIBLE IN/OUT
- HIGH OUTPUT DRIVE - 2 TTL LOADS
- HIGH NOISE IMMUNITY
- ON CHIP ADDRESS REGISTER
- MILITARY TEMPERATURE RANGE
- INDUSTRIAL TEMPERATURE RANGE
- THREE-STATE OUTPUTS
- 16 PIN PACKAGE FOR HIGH DENSITY


## Description

The HM-6508 is a 1024 by 1 static CMOS RAM fabricated using selfaligned silicon gate technology. Synchronous circuit design techniques are employed to achieve high performance and low power operation.

On chip latches are provided for address allowing efficient interfacing with microprocessor systems. The data output buffers can be forced to a high impedance state for use in expanded memory arrays.

The HM-6508 is a fully static RAM and may be maintained in any state for an indefinite period of time. Data retention supply voltage and supply current are guaranteed over temperature.

## Pinout

top VIEW


Logic Symbol


## Functional Diagram



CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

| ABSOLUTE MAXIMUM RATINGS |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V | Operating Supply Voltage -VCC Military (-2) | 4.5 V to 5.5 V |
| Input or Output Voltage Applied | $\begin{array}{r} \text { (GND -0.3V) } \\ \text { to (VCC }+0.3 \mathrm{~V}) \end{array}$ | Industrial (-9) | 4.5 V to 5.5 V |
| Storage Temperature | $-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Operating Temperature Military (-2) Industrial (-9) | $\begin{array}{r} -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{array}$ |

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \text { TEMP. } & =25^{\circ} \mathrm{C}(1) \\ \text { VCC } & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 10 | 0.1 | $\mu \mathrm{A}$ | $\begin{aligned} & I O=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 5 | 0.01 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0,10=0 \\ & \mathrm{~V} 1=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | v | $\mathrm{E}=\mathrm{VCC}$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VO} \leqslant \mathrm{vcc}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | $v$ |  |
| VIH | Input High Voltage | VCC -2.0 | Vcc +0.3 | 2.0 | $v$ |  |
| VOL | Output Low Voltage |  | 0.4 | 0.2 | v | $10=3.2 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.5 | $\checkmark$ | $10=-0.4 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 6 | 4 | pF | $\begin{aligned} & \mathrm{VI}=\mathrm{VCC} \text { or } G N D \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| co | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=v C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| telav | Chip Enable Access Time |  | 180 | 100 | ns | (4) |
| tavov | Address Access Time |  | 180 | 90 | ns | (4) |
| telox | Chip Enable Output Enable Time | 20 | 120 | 40 | ns | (4) |
| twLoz | Write Enable Output Disable Time |  | 120 | 40 | ns | (4) |
| TEHQZ | Chip Enable Output Disable Time |  | 120 | 40 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 180 |  | 100 | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 100 |  | 50 | ns | (4) |
| tavel | Address Setup Time | 0 |  | -10 | ns | (4) |
| telax | Address Hold Time | 40 |  | 20 | ns | (4) |
| TDVWH | Data Setup Time | 80 |  | 40 | ns | (4) |
| TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
| TWLEH | Chip Enable Write Pulse Setup Time | 100 |  | 50 | ns | (4) |
| TELWH | Chip Enable Write Pulse Hold Time | 100 |  | 50 | ns | (4) |
| TWLWH | Write Enable Pulse Width | 100 |  | 50 | ns | (4) |
| TELEL | Read or Write Cycle Time | 280 |  | 150 | ns | (4) |

NOTES: 1. All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
2. Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
3. Capacitance sampled and guaranteed - not $100 \%$ tested.
4. AC Test Conditions: Inputs - TRISE $=$ TFALL $=20$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

| ABSOLUTE MAXIMUM RATINGS |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC - GND) | -0.3 V to +8.0 V | Operating Supply Voltage -VCC Military (-2) | 4.5 V to 5.5 V |
| Input or Output Voltage Applied | $\begin{array}{r} \text { (GND -0.3V) } \\ \text { to (GND +0.3V) } \end{array}$ | Industrial (-9) | 4.5 V to 5.5 V |
| Storage Temperature | $-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Operating Temperature Military (-2) Industrial (-9) | $\begin{array}{r} -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{array}$ |

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \text { TEMP. } & =250^{\circ} \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 10 | 0.1 | $\mu \mathrm{A}$ | $\begin{aligned} & I O=0 \\ & V I=V C C \text { or GND } \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, \mathrm{IO}=0 \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 10 | 0.01 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0,10=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V | $E=V C C$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VO} \leqslant \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | V |  |
| VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=3.2 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.5 | $\checkmark$ | $10=-0.4 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 250 | 110 | ns | (4) |
| TAVQV | Address Access Time |  | 250 | 100 | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 20 | 160 | 60 | ns | (4) |
| TWLOZ | Write Enable Output Disable Time |  | 160 | 60 | ns | (4) |
| TEHQZ | Chip Enable Output Disable Time |  | 160 | 60 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 250 |  | 110 | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 100 |  | 50 | ns | (4) |
| TAVEL | Address Setup Time | 0 |  | -10 | ns | (4) |
| TELAX | Address Hold Time | 50 |  | 30 | ns | (4) |
| TDVWH | Data Setup Time | 110 |  | 50 | ns | (4) |
| TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
| TWLEH | Chip Enable Write Pulse Setup Time | 130 |  | 60 | ns | (4) |
| TELWH | Chip Enable Write Pulse Hold Time | 130 |  | 60 | ns | (4) |
| TWLWH | Write Enable Pulse Width | 130 |  | 60 | ns | (4) |
| TELEL | Read or Write Cycle Time | 350 |  | 160 | ns | (4) |

A.C.

NOTES: 1. All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
2. Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
3. Capacitance sampled and guaranteed - not $100 \%$ tested.
4. AC Test Conditions: Inputs - TRISE $=$ TFALL $=20$ nsec; Outputs $-C L O A D=50 p F$. All timing measurements at 1.5 V reference level.

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage -(VCC -GND) | -0.3 V to +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | (GND -0.3 V ) <br> to (VCC $+0.3 \mathrm{~V})$ |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+1500^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage -VCC Commercial
4.5 V to 5.5 V

Operating Temperature Commercial
$0^{\circ} \mathrm{C}$ to $+700^{\circ} \mathrm{C}$

## ELECTRICAL CHARACTERISTICS

|  |  |  | TEMP. OPER RA | VCC = TING GE | $\begin{aligned} \text { TEMP. } & =25^{\circ} \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ |  | ES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SYMBOL | PARAMETER | MIN | MAX | TYPICAL | UNITS | CONDITIONS |
| D.C. | ICCSB ICCOP | Standby Supply Current <br> Operating Supply Current |  | 100 4 | 10 1.5 | $\mu \mathrm{A}$ mA | $\begin{aligned} & I O=0 \\ & V I=V C C \text { or GND } \\ & f=1 \mathrm{MHz}, 1 O=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 100 | 1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0,10=0 \\ & V I=V C C \text { or } G N D \\ & E=V C C \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  |  | V |  |
|  | 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
|  | 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VO} \leqslant \mathrm{VCC}$ |
|  | VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | V |  |
|  | VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
|  | VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=1.6 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | 4.5 | V | $10=-0.2 \mathrm{~mA}$ |
|  | Cl | Input Capacitance |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 M H z \end{aligned}$ |
|  | CO | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| A.C. | TELQV | Chip Enable Access Time |  | 300 | 160 | ns | (4) |
|  | TAVQV | Address Access Time |  | 310 | 160 | ns | (4) |
|  | TELQX | Chip Enable Output Enable Time | 20 | 200 | 60 | ns | (4) |
|  | TWLQZ | Write Enable Output Disable Time |  | 200 | 60 | ns | (4) |
|  | TEHQZ | Chip Enable Output Disable Time |  | 200 | 60 | ns | (4) |
|  | TELEH | Chip Enable Pulse Negative Width | 300 |  | 160 | ns | (4) |
|  | TEHEL | Chip Enable Pulse Positive Width | 150 |  | 90 | ns | (4) |
|  | TAVEL | Address Setup Time | 10 |  | 0 | ns | (4) |
|  | TELAX | Address Hold Time | 70 |  | 40 | ns | (4) |
|  | TDVWH | Data Setup Time | 130 |  | 80 | ns | (4) |
|  | TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
|  | TWLEH | Chip Enable Write Pulse Setup Time | 160 |  | 100 | ns | (4) |
|  | TELWH | Chip Enable Write Pulse Hold Time | 160 |  | 100 | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 160 |  | 100 | ns | (4) |
|  | TELEL | Read or Write Cycle Time | 450 |  | 250 | ns | (4) |

NOTES: 1. All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
2. Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
3. Capacitance sampled and guaranteed - not $100 \%$ tested.
4. AC Test Conditions: Inputs - TRISE $=$ TFALL $=20 \mathrm{nsec}$; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

## Read Cycle



TRUTH TABLE

| TIME | INPUTS |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| REFERENCE | $\bar{E}$ | $\bar{W}$ | $A$ | $D$ | Q |$)$

In the HM-6508 Read Cycle, the address information is latched into the on chip registers on the falling edge of $\bar{E}(T=0)$. Minimum address setup and hold time requirements must be met. After the required hold time, the addresses may change state without affecting device operation. During time ( $T=1$ ) the data output becomes enabled; however, the data is not valid until during time
( $T=2$ ). $\bar{W}$ must remain high for the read cycle. After the output data has been read, $\bar{E}$ may return high ( $T=3$ ). This will disable the chip and force the output buffer to a high impedance state. After the required $\overline{\mathrm{E}}$ high time (TEHEL) the RAM is ready for the next memory cycle ( $\mathrm{T}=4$ ).

Write Cycle


TRUTH TABLE

| TIME | INPUTS |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| REFERENCE | E | $\bar{W}$ | A | D | Q | FUNCTION

The write cycle is initiated by the falling edge of $\bar{E}$ which latches the address information into the on chip registers. The write portion of the cycle is defined as both $\bar{E}$ and $\bar{W}$ being low simultaneously. $\bar{W}$ may go low anytime during the cycle provided that the write enable pulse setup time (TWLEH) is met. The write portion of the cycle is terminated by the first rising edge of either $\bar{E}$ or $\bar{W}$. Data setup and hold times must be referenced to the terminating signal.

If a series of consecutive write cycles are to be performed, the $\bar{W}$ line may remain low until all desired locations have been written. When this method is used, data setup and hold times must be referenced to the rising edge of $\bar{E}$. By
positioning the $\bar{W}$ pulse at different times within the $\bar{E}$ low time (TELEH), various types of write cycles may be performed.

If the $\bar{E}$ low time (TELEH) is greater than the $\bar{W}$ pulse (TWLWH) plus an output enable time (TELQX), a combination read write cycle is executed. Data may be modified an indefinite number of times during any write cycle (TELEH). The data input and data output pins may be tied together for use with a common I/O data bus structure. When using the RAM in this method allow a minimum of one output disable time (TWLQZ) after $\bar{W}$ goes low before applying input data to the bus. This will insure that the output buffers are not active.

## HM-6518

## Features

- HM-6100 COMPATIBLE
- LOW STANDBY POWER
- LOW OPERATING POWER
- FAST ACCESS TIME
- DATA RETENTION VOLTAGE
- TTL COMPATIBLE IN/OUT
- HIGH OUTPUT DRIVE - 2 TTL LOADS
- HIGH NOISE IMMUNITY
- ON CHIP ADDRESS REGISTER
- TWO CHIP SELECTS FOR EASY ARRAY EXPANSION
- THREE STATE OUTPUTS
- MILITARY TEMPERATURE RANGE
- INDUSTRIAL TEMPERATURE RANGE


## Description

The HM-6518 is a 1024 by 1 static CMOS RAM fabricated using selfaligned silicon gate technology. Synchronous circuit design techniques are employed to achieve high performance and low power operation.

On chip latches are provided for address and data outputs allowing efficient interfacing with microprocessor systems. The data output buffers can be forced to a high impedance state for use in expanded memory arrays.

The HM-6518 is a fully static RAM and may be maintained in any state for an indefinite period of time. Data retention supply voltage and supply current are guaranteed over temperature.

## Pinout

TOP VIEW
S1
E

A-Address input $\bar{w}$-write enable $\bar{E}$ - CHIP ENABLE D -DATA INPUT $\bar{S}$-CHIP SELECT $Q$-DATA OUTPUT

## Logic Symbol



## Functional Diagram



CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

| ABSOLUTE MAXIMUM RATINGS |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V | Operating Supply Voltage -VCC Military (-2) | 4.5 V to 5.5 V |
| Input or Output Voltage Applied | $\begin{aligned} & \text { (GND -0.3V) } \\ & \text { to (VCC +0.3V) } \end{aligned}$ | Industrial (-9) | 4.5 V to 5.5 V |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150{ }^{\circ} \mathrm{C}$ | Operating Temperature Military (-2) Industrial (-9) | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ |

## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \text { TEMP. } & =\mathbf{2 5}{ }^{\circ} \mathrm{C}(1) \\ \mathrm{VCC} & =\mathbf{5 . 0 \mathrm { V }} \end{aligned}$ |  | TES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | TYPICAL | UNITS | CONDITIONS |
| D.C. | ICCSB | Standby Supply Current |  | 10 | 0.1 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & V I=V C C \text { or GND } \end{aligned}$ |
|  | ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, \mathrm{IO}=0 \\ & \mathrm{VI}=\mathrm{VCC} \text { or } G N D \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 5 | 0.01 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0,10=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V | $\bar{E}=\mathrm{VCC}$ |
|  | 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
|  | 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VO} \leqslant \mathrm{VCC}$ |
|  | VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | V |  |
|  | VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
|  | VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=3.2 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | 4.5 | V | $10=-0.4 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 \mathrm{MHz} \end{aligned}$ |
|  | CO | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| A.C. | TELQV | Chip Enable Access Time |  | 180 | 100 | ns | (4) |
|  | TAVQV | Address Access Time |  | 180 | 90 | ns | (4) |
|  | TSLQX | Chip Select Output Enable Time | 20 | 120 | 40 | ns | (4) |
|  | TWLQX | Write Enable Output Disable Time |  | 120 | 40 | ns | (4) |
|  | TSHQX | Chip Select Output Disable Time |  | 120 | 40 | ns | (4) |
|  | TELEH | Chip Enable Pulse Negative Width | 180 |  | 100 | ns | (4) |
|  | TEHEL | Chip Enable Pulse Positive Width | 100 |  | 50 | ns | (4) |
|  | TAVEL | Address Setup Time | 0 |  | -10 | ns | (4) |
|  | TELAX | Address Hold Time | 40 |  | 20 | ns | (4) |
|  | TDVWH | Data Setup Time | 80 |  | 30 | ns | (4) |
|  | TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
|  | TWLSH | Chip Select Write Pulse Setup Time | 100 |  | 50 | ns | (4) |
|  | TWLEH | Chip Enable Write Pulse Setup Time | 100 |  | 50 | ns | (4) |
|  | TSLWH | Chip Select Write Pulse Hold Time | 100 |  | 50 | ns | (4) |
|  | TELWH | Chip Enable Write Pulse Hold Time | 100 |  | 50 | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 100 |  | 50 | ns | (4) |
|  | TELEL | Read or Write Cycle Time | 280 |  | 150 | ns | (4) |

NOTES (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed,
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=20$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage -(VCC - GND) | -0.3 V to +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | (GND -0.3 V ) <br> to (GND +0.3 V ) |
| Storage Temperature | $-650^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage -VCC Military (-2) Industrial (-9) 4.5 V to 5.5 V 4.5 V to 5.5 V

Operating Temperature
Military (-2) $-55{ }^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Industrial (-9) $-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$

## ELECTRICAL CHARACTERISTICS

D.C.
A.C.

| SYMBOL | PARAMETER | TEMP. \& VCC $=$ OPERATING RANGE |  | $\begin{aligned} \text { TEMP. } & =25^{\circ} \mathrm{C} \\ \text { VCC } & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 10 | 0.1 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & V I=V C C \text { or GND } \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, \mathrm{IO}=0 \\ & \mathrm{VI}=\mathrm{VCC} \text { or } G N D \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 10 | 0.01 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0,10=0 \\ & \underline{V I}=V C C \text { or } G N D \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V | $E=V C C$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
| 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VO} \leqslant \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | $v$ |  |
| VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=3.2 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.5 | V | $10=-0.4 \mathrm{~mA}$ |
| Cl | Input Capacitance |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 250 | 110 | ns | (4) |
| TAVQV | Address Access Time |  | 250 | 100 | ns | (4) |
| TSLQX | Chip Select Output Enable Time | 20 | 160 | 60 | ns | (4) |
| TWLQX | Write Enable Output Disable Time |  | 160 | 60 | ns | (4) |
| TSHQX | Chip Select Output Disable Time |  | 160 | 60 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 250 |  | 110 | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 100 |  | 50 | ns | (4) |
| TAVEL | Address Setup Time | 0 |  | -10 | ns | (4) |
| TELAX | Address Hold Time | 50 |  | 30 | ns | (4) |
| TDVWH | Data Setup Time | 110 |  | 50 | ns | (4) |
| TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
| TWLSH | Chip Select Write Pulse Setup Time | 130 |  | 60 | ns | (4) |
| TWLEH | Chip Enable Write Pulse Setup Time | 130 |  | 60 | ns | (4) |
| TSLWH | Chip Select Write Pulse Hold Time | 130 |  | 60 | ns | (4) |
| TELWH | Chip Enable Write Pulse Hold Time | 130 |  | 60 | ns | (4) |
| TWLWH | Write Enable Pulse Width | 130 |  | 60 | ns | (4) |
| TELEL | Read or Write Cycle Time | 350 |  | 160 | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - i.Jt guaranteed.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=20 \mathrm{nsec}$; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage -(VCC -GND) | -0.3 V to +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied |  |
| (GND -0.3V) |  | | to (VCC +0.3 V ) |
| ---: |
| Storage Temperature |
| $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage -VCC Commercial
4.5 V to 5.5 V

Operating Temperature
Commercial
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

## ELECTRICAL CHARACTERISTICS

## D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \text { TEMP. } & =25^{\circ} \mathrm{C} \\ \text { VCC } & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 100 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & I O=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, 10=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 100 | 1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0,1 O=0 \\ & V I=V C C \text { or } G N D \\ & \bar{E}=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  |  | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu A$ | GND $\leqslant$ VI $\leqslant$ VCC |
| 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VO} \leqslant \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | V |  |
| VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.5 | V | $10=-0.2 \mathrm{~mA}$ |
| Cl | Input Capacitance |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |


| TELQV | Chip Enable Access Time |  | 300 | 160 | ns | (4) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tavov | Address Access Time |  | 310 | 160 | ns | (4) |
| tslax | Chip Select Output Enable Time | 20 | 200 | 60 | ns | (4) |
| TWLQX | Write Enable Output Disable Time |  | 200 | 60 | ns | (4) |
| TSHOX | Chip Select Output Disable Time |  | 200 | 60 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  | 160 | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 150 |  | 90 | ns | (4) |
| tavel | Address Setup Time | 10 |  | 0 | ns | (4) |
| telax | Address Hold Time | 50 |  | 30 | ns | (4) |
| TDVWH | Data Setup Time | 130 |  | 80 | ns | (4) |
| TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
| TWLSH | Chip Select Write Pulse Setup Time | 160 |  | 100 | ns | (4) |
| TWLEH | Chip Enable Write Pulse Setup Time | 160 |  | 100 | ns | (4) |
| TSLWH | Chip Select Write Pulse Hold Time | 160 |  | 100 | ns | (4) |
| TELWH | Chip Enable Write Pulse Hold Time | 160 |  | 100 | ns | (4) |
| TWLWH | Write Enable Pulse Width | 160 |  | 100 | ns | (4) |
| TELEL | Read or Write Cycle Time | 450 |  | 250 | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed. Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=20 \mathrm{nsec}$; Outputs $-\mathrm{CLOAD}=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
Read Cycle

TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  |  | OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}}$ | $\overline{\text { S }}$ ( | $\overline{\text { w }}$ | A | D | Q |  |
| -1 |  | H | $\times$ | $\times$ | $\times$ | $z$ | MEMORY DISABLED |
| 0 |  | $\times$ |  | v | ${ }^{x}$ | $z$ | CYCLE BEGINS, ADDRESSES ARE LATCHED |
| 1 | L |  |  | $\times$ | $\times$ | $\times$ | OUTPUT ENABLED |
| 2 |  | L |  | $\times$ | $\times$ | V | OUTPUT VALID |
| 3 |  | L |  | $\times$ | x | v | OUTPUT LATCHED |
| 4 |  | H | $\times$ | $\times$ | $x$ | $z$ | DEVICE DISABLED, PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 5 | 2 | $\times$ | H | V | $\times$ | $z$ | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS 0) |

NOTES: (1) Device selected only if both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ are low, and deselected if either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S} 2}$ are high.

In the HM-6518 read cycle the address information is latched into the on chip registers on the falling edge of $\bar{E}$ ( $\mathrm{T}=0$ ). Minimum address setup and hold time requirements must be met. After the required hold time the addresses may change state without affecting device operation. In order for the output to be read $\overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2}$, and $\overline{\mathrm{E}}$
must be low, $\bar{W}$ must be high. When $\bar{E}$ goes high the output data is latched into an on chip register. Taking either or both $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S} 2}$ high forces the output buffer to a high impedance state. The output data may be re-enabled at any time by taking $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ low. On the falling edge of $\vec{E}$ the data will be unlatched.


TRUTH TABLE

| TIME <br> REFERENCE | INPUTS |  |  |  |  | OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\overline{\text { w }}$ | 亏'1 | A | D | Q |  |
| -1 |  | + | $\times$ | $\times$ | $\times$ | $z$ | MEMORY DISABLED |
| 0 |  | X |  | $v$ | $\times$ | $z$ | CYCLE BEGINS, ADDRESSES ARE LATCHED |
| 1 |  | L | L | $\times$ | V | z | WRITE MODE HAS BEGUN |
| 2 |  | $r$ | L | $\times$ | v | z | DATA IS WRITTEN |
| 3 |  | $x$ | $\times$ | $\times$ | $\times$ | $z$ | WRITE COMPLETED |
| 4 |  | + | $\times$ | $\times$ | $\times$ | z | PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 5 |  | - $\times$ | $\times$ | $v$ | $\times$ | z | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS 0) |

NOTES: (1) Device selected only if both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ are low, and deselected if either $\overline{\mathrm{S1}}$ or $\overline{\mathrm{S} 2}$ are high.

The write cycle is initiated by the falling edge of $\bar{E}$ which latches the address information into the on chip registers. The write portion of the cycle is defined as $\bar{E}, \bar{W}, \overline{\mathrm{~S} 1}$, and $\overline{\mathrm{S} 2}$ being low simultaneously. $\overline{\mathrm{W}}$ may go low anytime during the cycle provided that the write enable pulse setup time (TWLEH) is met. The write portion of the cycle is terminated by the first rising edge of either $\bar{E}, \bar{W}, \overline{S 1}$ or $\overline{\mathrm{S} 2}$. Data setup and hold times must be referenced to the terminating signal.

If a series of consecutive write cycles are to be performed, the $\bar{W}$ line may remain low until all desired locations have been written. When this method is used data setup and hold times must be referenced to the rising edge of $\overline{\mathrm{E}}$.

By positioning the $\bar{W}$ pulse at different times within the $\bar{E}$ low time (TELEH), various types of write cycles may be performed. If the $\bar{E}$ low time (TELEH) is greater than the $\bar{W}$ pulse (TWLWH) plus an output enable time (TSLQX), a combination read-write cycle is executed. Data may be modified an indefinite number of times during any write cycle (TELEH).

The data input and data output pins may be tied together for use with a common I/O data bus structure. When using the RAM in this method allow a minimum of one output disable time (TWLOZ) after $\bar{W}$ goes low before applying input data to the bus. This will insure that the output buffers are not active.

## Features

- LOW STANDBY POWER
- Low operating power
- FAST ACCESS TIME
- DATA RETENTION VOLTAGE
- tTL COMPATIBLE IN/OUT
- HIGH OUTPUT DRVIE - 1 TTL LOAD
- internal Latched chip select
- HIGH NOISE IMMUNITY
- ON CHIP ADDRESS REGISTERS
- LATCHED OUTPUTS
- three state outputs
- MILITARY AND INDUSTRIAL TEMPERATURE RANGES


## Description

The HM-6551 is a 256 by 4 static CMOS RAM fabricated using selfaligned silicon gate technology. Synchronous circuit design techniques are employed to achieve high performance and low power operation.

On chip latches are provided for addresses and data outputs allowing efficient interfacing with microprocessor systems. The data output buffers can be forced to a high impedance state for use in expanded memory arrays.

The HM-6551 is a fully static RAM and may be maintained in any state for an indefinite period of time. Data retention supply voltage and supply current are guaranteed over temperature.


## Logic Symbol



## Functional Diagram



CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

| ABSOLUTE MAXIMUM RATINGS |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage -(VCC -GND) | -0.3 V to +8.0V | Operating Supply Voltage -VCC Military (-2) | 4.5 V to 5.5 V |
| Applied Input or Output Voltage | $\begin{array}{r} \text { (GND -0.3V) } \\ \text { to (GND +0.3V) } \end{array}$ | Industrial (-9) | 4.5 V to 5.5 V |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Operating Temperature Military (-2) Industrial (-9) | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ |

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \text { TEMP. } & =25^{\circ} \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 10 | 0.1 | $\mu \mathrm{A}$ | $10=0$ |
| ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $V I=V C C$ or GND $f=1 \mathrm{MHz}, 10=0$ |
|  |  |  |  |  |  | $\mathrm{VI}=\mathrm{VCC}$ or GND $\mathrm{W}=\mathrm{GND}$ |
| ICCDR | Data Retention Supply Current |  | 10 | 0.01 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0,10=0 \\ & \underline{V I}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V | $\bar{E}=\mathrm{VCC}$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant$ VI $\leqslant \mathrm{VCC}$ |
| 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VO} \leqslant \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | V |  |
| VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.5 | V | $10=-0.4 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 M H z \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=V C C \text { or } G N D \\ & f=1 \mathrm{MHz} \end{aligned}$ |

A.C.

| TELQV | Chip Enable Access Time |  | 220 | 120 | ns | (4) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TAVQV | Address Access Time |  | 220 | 110 | ns | (4) |
| TS1LQX | Chip Select 1 Output Enable Time | 20 | 130 | 50 | ns | (4) |
| TWLQZ | Write Enable Output Disable Time |  | 130 | 50 | ns | (4) |
| TS1HQZ | Chip Select 1 Output Disable Time |  | 130 | 50 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 220 |  | 120 | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 100 |  | 50 | ns | (4) |
| TAVEL | Address Setup Time | 0 |  | -10 | ns | (4) |
| TS2LEL | Chip Select 2 Setup Time | 0 |  | -10 | ns | (4) |
| TELAX | Address Hold Time | 40 |  | 20 | ns | (4) |
| TELS2X | Chip Select 2 Hold Time | 40 |  | 20 | ns | (4) |
| TDVWH | Data Setup Time | 100 |  | 50 | ns | (4) |
| TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
| TWLS1H | Chip Select 1 Write Pulse Setup Time | 120 |  | 60 | ns | (4) |
| TWLEH | Chip Enable Write Pulse Setup Time | 120 |  | 60 | ns | (4) |
| TS1LWH | Chip Select 1 Write Pulse Hold Time | 120 |  | 60 | ns | (4) |
| TELWH | Chip Enable Write Pulse Hold Time | 120 |  | 60 | ns | (4) |
| TWLWH | Write Enable Pulse Width | 120 |  | 60 | ns | (4) |
| TELEL | Read or Write Cycle Time | 320 |  | 170 | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=20$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

| ABSOLUTE MAXIMUM RATINGS |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage -(VCC - GND) | -0.3 V to +8.0 V | Operating Supply Voltage -VCC Military (-2) | 4.5 V to 5.5 V |
| Applied Input or Output Voltage | $\begin{aligned} & \text { (GND -0.3V) } \\ & \text { to (VCC +0.3V) } \end{aligned}$ | Industrial (-9) | 4.5 V to 5.5 V |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Operating Temperature Military (-2) Industrial (-9) | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ |

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \text { TEMP. } & =250^{\circ} \mathrm{C} \\ \text { VCC } & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 10 | 0.1 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & \mathrm{VI}=\mathrm{VCC} \text { or } G N D \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 10 | 0.01 | $\mu \mathrm{A}$ | $\begin{aligned} & \bar{W}=G N D \\ & V C C=2.0,10=0 \\ & \underline{V} 1=V C C \text { or } G N D \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V | $\overline{\mathrm{E}}=\mathrm{VCC}$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant$ VO $\leqslant V C C$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | V |  |
| VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.5 | V | $10=-0.4 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=V C C \text { or } G N D \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 300 | 160 | ns | (4) |
| TAVQV | Address Access Time |  | 300 | 150 | ns | (4) |
| TS1LQX | Chip Select 1 Output Enable Time | 20 | 150 | 60 | ns | (4) |
| TWLQZ | Write Enable Output Disable Time |  | 150 | 60 | ns | (4) |
| TS1HOZ | Chip Select 1 Output Disable Time |  | 150 | 60 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  | 160 | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 100 |  | 50 | ns | (4) |
| TAVEL | Address Setup Time | 0 |  | -10 | ns | (4) |
| TS2LEL | Chip Select 2 Setup Time | 0 |  | -10 | ns | (4) |
| TELAX | Address Hold Time | 50 |  | 30 | ns | (4) |
| TELS2X | Chip Select 2 Hold Time | 50 |  | 30 | ns | (4) |
| TDVWH | Data Setup Time | 150 |  | 100 | ns | (4) |
| TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
| TWLS1H | Chip Select 1 Write Pulse Setup Time | 180 |  | 120 | ns | (4) |
| TWLEH | Chip Enable Write Pulse Setup Time | 180 |  | 120 | ns | (4) |
| TS1LWH | Chip Select 1 Write Pulse Hold Time | 180 |  | 120 | ns | (4) |
| TELWH | Chip Enable Write Pulse Hold Time | 180 |  | 120 | ns | (4) |
| TWLWH | Write Enable Pulse Width | 180 |  | 120 | ns | (4) |
| TELEL | Read or Write Cycle Time | 400 |  | 170 | ns | (4) |

A.C.

TS2LEL
Chip Select 2 Setup Time
Address Hold Time

TDVWH
TWHDX Datap Time

Chip Select 1 Write Pulse Setup Time Chip Enable Write Pulse Setup Time Chip Select 1 Write Pulse Hold Time Write Enable Pulse Width Read or Write Cycle Time

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not 100\% tested.
(4) AC Test Conditions: Inputs - TRISE = TFALL $=20$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V <br> Applied Input or Output Voltage <br> (GND -0.3 V ) <br> to (GND +0.3 V ) |
| :--- | ---: |
| Storage Temperature | $-650^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage -VCC Commercial
4.5 V to 5.5 V

Operating Temperature
Commercial
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

## ELECTRICAL CHARACTERISTICS

|  |  |  | TEMP. OPER $\qquad$ | $\begin{aligned} & \text { VCC }= \\ & \text { ATING } \end{aligned}$ <br> GE | $\begin{aligned} \text { TEMP. } & =\mathbf{2 5 0} \times 1 \\ \text { VCC } & =5.0 \mathrm{~V} \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SYMBOL | PARAMETER | MIN | MAX | TYPICAL | UNITS | CONDITIONS |
|  | ICCSB | Standby Supply Current |  | 100 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} 10 & =0 \\ \mathrm{VI} & =\mathrm{VCC} \text { or GND } \end{aligned}$ |
|  | ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, \mathrm{IO}=0 \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 100 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{VCC}=2.0,10=0$ |
| D.C. | vCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V | $V I=V C C ~ o r ~ G N D ~$ $E=V C C$ |
|  | 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | $G N D \leqslant V I \leqslant V C C$ |
|  | 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant$ VO $\leqslant$ VCC |
|  | VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | v |  |
|  | VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | $v$ |  |
|  | VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=1.6 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | 4.5 | $v$ | $10=-0.2 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 \mathrm{MHz} \end{aligned}$ |
|  | co | Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V O=V C C \text { or } G N D \\ & f=1 M H z \end{aligned}$ |
|  | TELQV | Chip Enable Access Time |  | 350 | 200 | ns | (4) |
|  | tavov | Address Access Time |  | 360 | 200 | ns | (4) |
|  | TS1LOX | Chip Select 1 Output Enable 7 ime | 20 | 180 | 80 | ns | (4) |
|  | TWLQz | Write Enable Output Disable Time |  | 180 | 80 | ns | (4) |
|  | TS1HQZ | Chip Select 1 Output Disable Time |  | 180 | 80 | ns | (4) |
|  | TELEH | Chip Enable Pulse Negative Width | 350 |  | 200 | ns | (4) |
|  | TEHEL | Chip Enable Pulse Positive Width | 150 |  | 90 | ns | (4) |
|  | TAVEL | Address Setup Time | 10 |  | 0 | ns | (4) |
| A.C. | TS2LEL | Chip Select 2 Setup Time | 10 |  | 0 | ns | (4) |
|  | telax | Address Hold Time | 70 |  | 40 | ns | (4) |
|  | TELS2X | Chip Select 2 Hold Time | 70 |  | 40 | ns | (4) |
|  | TDVWH | Data Setup Time | 170 |  | 120 | ns | (4) |
|  | TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
|  | TWLS1H | Chip Select 1 Write Pulse Setup Time | 210 |  | 150 | ns | (4) |
|  | TWLEH | Chip Enable Write Pulse Setup Time | 210 |  | 150 | ns | (4) |
|  | TS1LWH | Chip Select 1 Write Pulse Hold Time | 210 |  | 150 | ns | (4) |
|  | TELWH | Chip Enable Write Pulse Hold Time | 210 |  | 150 | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 210 |  | 150 | ns | (4) |
|  | TELEL | Read or Write Cycle Time | 500 |  | 290 | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Fxample: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=20$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

## Read Cycle



TRUTH TABLE


The HM-6551 Read Cycle is initiated by the falling edge of $\bar{E}$. This signal latches the input address word and $\overline{\mathrm{S} 2}$ into on chip registers providing that minimum setup and hold times are met. After the required hold time, these inputs may change state without affecting device operation. $\overline{\mathrm{S} 2}$ acts as a high order address and simplifies decoding. For the output to be read, $\overline{\mathrm{E}}, \overline{\mathrm{S} 1}$ must be low and $\bar{W}$ must be high. $\overline{\text { S2 }}$ must have been latched low on the falling edge of $\overline{\mathrm{E}}$. The output data will be valid at access time (TELQV).

The HM-6551 has output data latches that are controlled by $\overline{\mathrm{E}}$. On the rising edge of $\overline{\mathrm{E}}$ the present data is latched and remains in that state until $\bar{E}$ falls. Also on the rising edge of $\bar{E}, \overline{S 2}$ unlatches and controls the outputs along with $\overline{\mathrm{S} 1}$. Either or both $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S} 2}$ may be used to force the output buffers into a high impedance state.

## Write Cycle



TRUTH TABLE


In the Write Cycle the falling edge of $\bar{E}$ latches the addresses and $\overline{\mathrm{S} 2}$ into on chip registers. $\overline{\mathrm{S} 2}$ must be latched in the low state to enable the device. The write portion of the cycle is defined as $\bar{E}, \bar{W}, \overline{S 1}$ being low and $\overline{S 2}$ being latched low simultaneously. The $\bar{W}$ line may go low at any time during the cycle providing that the write pulse setup times (TWLEH and TWLS1H) are met. The write portion of the cycle is terminated on the first rising edge of either $\overline{\mathrm{E}}, \overline{\mathrm{W}}$, or $\overline{\mathrm{S} 1}$.

If a series of consecutive write cycles are to be executed, the $\bar{W}$ line may be held low until all desired locations have been written. If this method is used, data setup and hold times must be referenced to the first rising edge of $\overline{\mathrm{E}}$ or $\overline{\mathrm{S} 1}$. By positioning the write pulse at different
times within the $\bar{E}$ and $\overline{\mathrm{S} 1}$ low time (TELEH) various types of write cycles may be performed. If the $\overline{\mathrm{S} 1}$ low time (TS1LS1H) is greater than the $\bar{W}$ pulse plus an output enable time (TS1LQX), a combination read-write cycle is executed. Data may be modified an indefinite number of times during any write cycle (TELEH).

The HM-6551 may be used on a common I/O bus structure by tying the input and output pins together. The multiplexing is accomplished internally by the $\bar{W}$ line. In the write cycle, when $\bar{W}$ goes low, the output buffers are forced to a high impedance state. One output disable time delay (TWLOZ) must be allowed before applying input data to the bus.

## Features

- HM-6100 COMPATIBLE
- LOW STANDBY POWER
- Low operating power
- fast access time
- data retention voltage
- tTL COMPATIBLE in/OUT
- HIGH OUTPUT DRIVE - 1 TTL LOAD
- ON CHIP ADDRESS REGISTERS
- COMMON DATA IN/OUT
- three state outputs
- EASY MICROPROCESSOR INTERFACING
- MILITARY TEMPERATURE RANGE
- INDUSTRIAL TEMPERATURE RANGE


## Description

The HM-6561 is a 256 by 4 static CMOS RAM fabricated using selfaligned silicon gate technology. Synchronous circuit design techniques are employed to achieve high performance and low power operation.
On chip latches are provided for address and data outputs allowing efficient interfacing with microprocessor systems. The data output buffers can be forced to a high impedance state for use in expanded memory arrays. The data inputs and outputs are multiplexed internally for common I/O bus compatibility.
The HM-6561 is a fully static RAM and may be maintained in any state for an indefinite period of time. Data retention supply voltage and supply current are guaranteed over temperature.

## Pinout

TOP VIEW
$20 \mathrm{~mW} / \mathrm{MHz}$ MAX
220nsec MAX
2.0 VOLTS MIN


Logic Symbol


## Functional Diagram

ALL Lines positive logic - active high
THREE STATE BUFFERS:
A HIGH $\rightarrow$ OUTPUT ACTIVE
dATA LATCHES:
LHIOH $\rightarrow$ O=D
Q LATCHES ON FALLING EDGE OF L
address latches and gated decoders: LATCH ON FALLING EDGE OF $\bar{E}$ GATE ON FALLING EDGE OF $\bar{E}$


CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

| ABSOLUTE MAXIMUM RATINGS |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC - GND) | -0.3 V to +8.0 V | Operating Supply Voltage -VCC Military (-2) | 4.5 V to 5.5 V |
| Input or Output Voltage Applied | $\begin{aligned} & \text { (GND -0.3V) } \\ & \text { to }(\mathrm{VCC}+0.3 \mathrm{~V}) \end{aligned}$ | Industrial (-9) | 4.5 V to 5.5 V |
| Storage Temperature | $-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Operating Temperature Military (-2) Industrial (-9) | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ |

ELECTRICAL CHARACTERISTICS


NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=20$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

| ABSOLUTE MAXIMUM RATINGS |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC - GND) | -0.3 V to +8.0 V | Operating Supply Voltage -VCC Military (-2) | 4.5 V to 5.5 V |
| Input or Output Voltage Applied | $\begin{aligned} & \text { (GND -0.3V) } \\ & \text { to (VCC }+0.3 \mathrm{~V}) \end{aligned}$ | Industrial (-9) | 4.5 V to 5.5 V |
| Storage Temperature | $-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Operating Temperature Military (-2) Industrial (-9) | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+1250^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85{ }^{\circ} \mathrm{C} \end{aligned}$ |

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{gathered} \text { TEMP. }=25^{\circ} \mathrm{C} \\ \mathrm{VCC}=5.0 \mathrm{~V} \end{gathered}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 10 | 0.1 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 4 | 1.5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, I O=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 10 | 0.01 | $\mu \mathrm{A}$ | $\begin{aligned} & \bar{W}=G N D \\ & V C C=2.0,10=0 \\ & V I=V C C \text { or } G N D \\ & \bar{F}=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V | $E=V C C$ |
| II | - Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
| HOZ | Input/Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leqslant$ VIO $\leqslant \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | V |  |
| VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.2 | V | $10=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.5 | V | $10=-0.4 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 6 | 4 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 M H z \end{aligned}$ |
| ClO | Input/Output Capacitance (3) |  | 10 | 6 | pF | $\begin{aligned} & V I O=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 300 | 160 | ns | (4) |
| TAVQV | Address Access Time |  | 300 | 150 | ns | (4) |
| TSLQX | Chip Select Output Enable Time | 20 | 150 | 60 | ns | (4) |
| TWLQZ | Write Enable Output Disable Time |  | 150 | 60 | ns | (4) |
| TSHQZ | Chip Select Output Disable Time |  | 150 | 60 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  | 160 | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 100 |  | 50 | ns | (4) |
| TAVEL | Address Setup Time | 0 |  | -10 | ns | (4) |
| TELAX | Address Hold Time | 50 |  | 30 | ns | (4) |
| TDVWH | Data Setup Time | 150 |  | 100 | ns | (4) |
| TWHDX | Data Hold Time | 0 |  | 0 | ns | (4) |
| TWLDV | Write Data Delay Time | 150 |  | 60 | ns | (4) |
| TWLSH | Chip Select Write Pulse Setup Time | 180 |  | 120 | ns | (4) |
| TWLEH | Chip Enable Write Pulse Setup Time | 180 |  | 120 | ns | (4) |
| TSLWH | Chip Select Write Pulse Hold Time | 180 |  | 120 | ns | (4) |
| TELWH | Chip Enable Write Pulse Hold Time | 180 |  | 120 | ns | (4) |
| TWLWH | Write Enable Pulse Width | 180 |  | 120 | ns | (4) |
| TWLSL | Early Output High Z Time | 0 |  | -10 | ns | (4) |
| TSHWH | Late Output High Z Time | 0 |  | -10 | ns | (4) |
| TELEL | Read or Write Cycle Time | 400 |  | 210 | ns | (4) |

A.C.

NOTES: 1 All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=1.5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=20$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.

## ABSOLUTE MAXIMUM RATINGS

Supply Voltage - (VCC - GND)
-0.3 V to +8.0 V
Applied Input or Output Voltage
(GND -0.3V) to (VCC +0.3 V )

Storage Temperature

## OPERATING RANGE

Operating Supply Voltage -VCC
Commercial
4.5 V to 5.5 V

Operating Temperature
Commercial
00 C to $+70{ }^{\circ} \mathrm{C}$

## ELECTRICAL CHARACTERISTICS




TRUTH TABLE

| TIME | INPUTS |  |  |  | OUTPUT |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REFERENCE | E |  | $\overline{\text { w }}$ | A | DO. | FUNCTION |
| -1 | H | H | $\times$ | $\times$ | z | MEMORY DISABLED |
| 0 | 2 | $\times$ | H | V | z | CYCLE BEGINS, ADDRESSES ARE LATCHED |
| 1 | L |  | H | $\times$ | $\times$ | OUTPUTENABLED |
| 2 | L | L | H | x | $v$ | OUTPUT VALID |
| 3 | - |  | H | $\times$ | V | OUTPUT LATCHED |
| 4 | H | H | X | X | z | DEVICE DISABLED, PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 5 | 2 | $\times$ | H | V | z | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS 0) |

NOTES: 1) Device selected only if both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ are low, and deselected if either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S} 2}$ are high.

The HM-6561 Read Cycle is initiated on the falling edge of $\bar{E}$. This signal latches the input address word into on chip registers. Minimum address setup and hold times must be met. After the required hold time, the address lines may change state without affecting device operation. In order to read the output data $\overline{\mathrm{E}}, \overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ must be low and $\bar{W}$ must be high. The output data will be valid at access time (TELQV).

The HM-6561 has output data latches that are controlled by $\overline{\mathrm{E}}$. On the rising edge of $\overline{\mathrm{E}}$ the present data is latched and remains latched until E falls. Either or both S1 or S2 may be used to force the output buffers into a high impedance state.


TRUTH TABLE


NOTES: 1) Device selected only if both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ are low, and deselected if either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S} 2}$ are high.

The write cycle begins with the $\bar{E}$ falling edge latching the address. The write portion of the cycle is defined by $\bar{E}, \overline{S 1}$, $\overline{\mathrm{S} 2}$ and $\overline{\mathrm{W}}$ all being low simultaneously. The write portion of the cycle is terminated by the first rising edge of any control line, $\overline{\mathrm{E}}, \overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2}$ or $\overline{\mathrm{W}}$. The data setup and data hold times (TDVWH and TWHDX) must be referenced to the terminating signal. For example, if $\overline{\mathrm{S} 2}$ rises first, data setup and hold times become TDVS2H and TS2HDX; and are numerically equal to TDVWH and TWHDX.

Data input/output multiplexing is controlled by $\bar{W}$. Care must be taken to avoid data bus conflicts, where the RAM outputs become enabled when another device is driving the data inputs. The following two examples illustrate the timing required to avoid bus conflicts.

Case 1: Both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ fall before $\bar{W}$ falls.
If both selects fall before $\bar{W}$ falls, the RAM outputs will become enabled. $\bar{W}$ is used to disable the outputs, so a disable time (TWLQZ = TWLDV) must pass before any other device can begin to drive the data inputs. This method of operation requires a wider write pulse, because TWLDV + TDVWH is greater than TWLWH. In this case TWLSL and TSHWH are meaningless and can be ignored.

Case 2: $\bar{W}$ falls before both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ fall.
If one or both selects are high until $\bar{W}$ falls the outputs are
guaranteed not to enable at the beginning of the cycle. This eliminates the concern for data bus conflicts and simplifies data input timing. Data input may be applied as early as convenient, and TWLDV is ignored. Since $\bar{W}$ is not used to disable the outputs it can be shorter than in case 1; TWLWH is the minimum write pulse. At the end of the write period, if $\bar{W}$ rises before either select the outputs will enable, reading the data just written. They will not disable until either select goes high (TSHOZ).

|  | IF | OBSERVE | IGNORE |
| :---: | :---: | :---: | :---: |
| Case 1 | Both, $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}=$ low before $\bar{W}=$ low | TWLQZ <br> TWLDV <br> TDVWH | TWLWH <br> TWLSL <br> TSHWH |
| Case 2 | $\bar{W}=$ low before both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}=$ low | TWLWH TDVWH TWLSL TSHWH | TWLQZ TWLDV |

If a series of consecutive write cycles are to be performed, $\bar{W}$ may remain low until all desired locations are written. This is an extension of Case 2.

Read-Modify-Write cycles and Read-Write-Read cycles can be performed (extension of Case 1). In fact, data may be modified as many times as desired with $\overline{\mathrm{E}}$ remaining low.

## Features

- LOW POWER STANDBY
- LOW POWER OPERATION
- EXTREMELY LOW SPEED-POWER PRODUCT
- DATA RETENTION
- TTL COMPATIBLE INPUT/OUTPUT
- THREE-STATE OUTPUT
- STANDARD JEDEC PINOUT
- FAST ACCESS TIME
- MILITARY TEMPERATURE RANGE
- INDUSTRIAL TEMPERATURE RANGE
- 18 PIN PACKAGE FOR HIGH DENSITY
- ON CHIP ADDRESS REGISTER
- GATED INPUTS-NO PULL UP OR PULL DOWN RESISTORS REQUIRED


## Description

The HM-6504 is a $4096 \times 1$ static CMOS RAM fabricated using selfaligned silicon gate technology. The device utilizes synchronous circuitry to achieve high performance and low power operation.

On chip latches are provided for addresses, data input and data output allowing efficient interfacing with microprocessor systems. The data output can be forced to a high impedance for use in expanded memory arrays. Gated inputs allow lower operating current and also eliminates the need for pull-up or pull-down resistors. The HM-6504 is a fully static RAM and may be maintained in any state for an indefinite period of time.

Data retention supply voltage and supply current are guaranteed over temperature.

## Pinouts

TOP VIEW


A - Address input
$\bar{E}$-Chip Enable
$\bar{W}$ - Write Enable
D - Data Input
Q - Data Output

## Functional Diagram



CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

| ABSOLUTE MAXIMUM RATINGS * |  |
| :--- | ---: |
| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

$\begin{aligned} & \text { Operating Supply Voltage } \\ & \text { Military }(-2)\end{aligned}$
$\begin{gathered}\text { Operating Temperature } \\ \text { Military }(-2)\end{gathered}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS PRELIMINARY

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC $=$ OPERATING RANGE |  | $\begin{aligned} \text { TEMP } & =250 \mathrm{C} \\ V C C & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 50 | 5.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & \vec{E}=V C C-0.3 V \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0, V C C=2.0 \mathrm{~V} \\ & E=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq$ VI $\leq V C C$ |
| 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq V O \leq V C C$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | V |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | 2.2 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | $v$ | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | V | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & V I=V C C \text { or } G N D \end{aligned}$ |
| co | Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VO}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| telov | Chip Enable Access Time |  | 120 |  | ns | (4) |
| TAVQV | Address Access Time |  | 120 |  | ns | (4) |
| telox | Chip Enable Output Enable Time | 10 |  |  | ns | (4) |
| TEHOZ | Chip Enable Output Disable Time |  | 50 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 120 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 50 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 0 |  |  | ns | (4) |
| TELAX | Address Hold Time | 40 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 20 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 70 |  |  | ns | (4) |
| TWLEL | Early Write Pulse Setup Time | 0 |  |  | ns | (4) |
| TWHEL | Write Enable Read Mode Setup Time | 0 |  |  | ns | (4) |
| TELWH | Early Write Pulse Hold Time | 40 |  |  | ns | (4) |
| TDVWL | Data Setup Time | 0 |  |  | ns | (4) |
| TDVEL | Early Write Data Setup Time | 0 |  |  | ns | (4) |
| TWLDX | Data Hold Time | 25 |  |  | ns | (4) |
| TELDX | Early Write Data Hold Time | 25 |  |  | ns | (4) |
| TQVWL | Data Valid to Write Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 170 |  |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP =5mA/MHz.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=5$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC -GND) | -0.3 V to +8.0V | Operating Supply Voltage |  |
| Input or Output Voltage Applied | $\begin{array}{r} \text { (GND -0.3V) } \\ \text { to (VCC }+0.3 \mathrm{~V}) \end{array}$ | Industrial (-9) | 4.5 V to 5.5 V |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150{ }^{\circ} \mathrm{C}$ | Operating Temperature Industrial (-9) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS PRELIMINARY

D.C.
A.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \mathrm{TEMP} & =250 \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & \bar{E}=V C C-0.3 V \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & \overline{\mathrm{E}}=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}_{1}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 15 | 2.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 \mathrm{~V}, 10=0 \\ & E=V C C \end{aligned}$ |
| vCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | v |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq$ VI $\leq \mathrm{VCC}$ |
| 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VO} \leq \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | v |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | 2.2 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | $v$ | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | V | $10=-1.0 \mathrm{~mA}$ |
| CI | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VO}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 120 |  | ns | (4) |
| tavov | Address Access Time |  | 120 |  | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 10 |  |  | ns | (4) |
| TEHQZ | Chip Enable Output Disable Time |  | 50 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 120 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 50 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 0 |  |  | ns | (4) |
| TELAX | Address Hold Time | 40 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 20 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 70 |  |  | ns | (4) |
| TWLEL | Early Write Pulse Setup Time | 0 |  |  | ns | (4) |
| TWHEL | Write Enable Read Mode Setup Time | 0 |  |  | ns | (4) |
| TELWH | Early Write Pulse Hold Time | 40 |  |  | ns | (4) |
| TDVWL | Data Setup Time | 0 |  |  | ns | (4) |
| TDVEL | Early Write Data Setup Time | 0 |  |  | ns | (4) |
| TWLDX | Data Hold Time | 25 |  |  | ns | (4) |
| TELDX | Early Write Data Hold Time | 25 |  |  | ns | (4) |
| TQVWL | Data Valid to Write Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 170 |  |  | ns | (4) |

NOTES: All devices tested at worst case limits. Room temp., 5 volt data provided for information,- not guaranteed
 Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP=5mA/MHz.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=5$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

| ABSOLUTE MAXIMUM RATINGS * |  |
| :--- | ---: |
| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage Military (-2)
4.5 V to 5.5 V

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

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \mathrm{TEMP} & =250 \mathrm{C}(1 \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 50 | 5.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & E=V C C-0.3 V \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & \overline{\mathrm{E}}=1 \mathrm{MHz}, \mathrm{IO}=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 \mathrm{~V}, 10=0 \\ & \bar{E}=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
| 10Z | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq V O \leq V C C$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | V |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | 2.2 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | V | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | V | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VI}=\mathrm{VCC} \text { or GND } \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VO}=\mathrm{VCC} \text { or GND } \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 200 |  | ns | (4) |
| TAVQV | Address Access Time |  | 220 |  | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
| TEHQZ | Chip Enable Output Disable Time |  | 80 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 200 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 90 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 20 |  |  | ns | (4) |
| TELAX | Address Hold Time | 50 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 60 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 150 |  |  | ns | (4) |
| TWLEL | Early Write Pulse Setup Time | 0 |  |  | ns | (4) |
| TWHEL | Write Enable Read Mode Setup Time | 0 |  |  | ns | (4) |
| TELWH | Early Write Pulse Hold Time | 60 |  |  | ns | (4) |
| TDVWL | Data Setup Time | 0 |  |  | ns | (4) |
| TDVEL | Early Write Data Setup Time | 0 |  |  | ns | (4) |
| TWLDX | Data Hold Time | 60 |  |  | ns | (4) |
| TELDX | Early Write Data Hold Time | 60 |  |  | ns | (4) |
| TQVWL | Data Valid to Write Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 290 |  |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information.- not guaranteed
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=10 \mathrm{~ns}$; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

## ABSOLUTE MAXIMUM RATINGS *

Supply Voltage - (VCC -GND) Input or Output Voltage Applied

Storage Temperature
-0.3 V to +8.0 V
(GND -0.3V)
to (VCC +0.3 V )
$-65^{\circ} \mathrm{C}$ to $+150{ }^{\circ} \mathrm{C}$

## OPERATING RANGE

Operating Supply Voltage Industrial (-9)
4.5 V to 5.5 V

Operating Temperature
Industrial (-9)
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

> * CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \mathrm{TEMP} & =25{ }^{\circ} \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & E=V C C-0.3 V \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & E=1 \mathrm{MHz}, 10=0 \\ & V I=G N D \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 15 | 2.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 V, 10=0 \\ & E=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq V O \leq V C C$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | V |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | 2.2 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | V | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | $\checkmark$ | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & V I=V C C \text { or GND } \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & V O=V C C \text { or GND } \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 200 |  | ns | (4) |
| TAVQV | Address Access Time |  | 220 |  | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
| TEHQZ | Chip Enable Output Disable Time |  | 80 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 200 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 90 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 20 |  |  | ns | (4) |
| TELAX | Address Hold Time | 50 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 60 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 150 |  |  | ns | (4) |
| TWLEL | Early Write Pulse Setup Time | 0 |  |  | ns | (4) |
| TWHEL | Write Enable Read Mode Setup Time | 0 |  |  | ns | (4) |
| TELWH | Early Write Pulse Hold Time | 60 |  |  | ns | (4) |
| TDVWL | Data Setup Time | 0 |  |  | ns | (4) |
| TDVEL | Early Write Data Setup Time | 0 |  |  | ns | (4) |
| TWLDX | Data Hold Time | 60 |  |  | ns | (4) |
| TELDX | Early Write Data Hold Time | 60 |  |  | ns | (4) |
| TQVWL | Data Valid to Write Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 290 |  |  | ns | (4) |

## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Operating Supply Voltage <br> Military $(-2)$ | 4.5 V to 5.5 V |
| :--- | ---: |
| Operating Temperature |  |
| Military $(-2)$ |  |$\quad-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \mathrm{TEMP} & =250 \mathrm{C}(1 \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 50 | 5.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & \bar{E}=V C C-0.3 V \end{aligned}$ |
| ICCOP | Operating Supply Current(2) |  | 7 | 5 | mA | $\begin{aligned} & \overline{\mathrm{E}}=1 \mathrm{MHz}, \mathrm{IO}=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 \mathrm{~V}, 10=0 \\ & E=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | v |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VO} \leq \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | V |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -20 \end{aligned}$ | $\begin{aligned} & \text { VCc } \end{aligned}$ | 2.2 | v |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | v | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | v | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance(3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VO}=\mathrm{VCC} \text { or } G N D \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 300 |  | ns | (4) |
| tavov | Address Access Time |  | 320 |  | ns | (4) |
| telox | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
| tehaz | Chip Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 120 |  |  | ns | (4) |
| tavel | Address Setup Time | 20 |  |  | ns | (4) |
| TELAX | Address Hold Time | 50 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 80 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 200 |  |  | ns | (4) |
| TWLEL | Early Write Pulse Setup Time | 0 |  |  | ns | (4) |
| TWHEL | Write Enable Read Mode Setup Time | 0 |  |  | ns | (4) |
| TELWH | Early Write Pulse Hold Time | 80 |  |  | ns | (4) |
| TDVWL | Data Setup Time | 0 |  |  | ns | (4) |
| TDVEL | Early Write Data Setup Time | 0 |  |  | ns | (4) |
| TWLDX | Data Hold Time | 80 |  |  | ns | (4) |
| TELDX | Early Write Data Hold Time | 80 |  |  | ns | (4) |
| TQvwL | Data Valid to Write Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 420 |  |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information.- not guaranteed
(2.) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical $I C C O P=5 \mathrm{~mA} / \mathrm{MHz}$.
(3. Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=10$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

## Operating Supply Voltage

 Industrial (-9)4.5 V to 5.5 V

Operating Temperature Industrial (-9)
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \mathrm{TEMP} & =250 \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $10=0, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & \overline{\mathrm{E}}=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 15 | 2.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 V, 10=0 \\ & \bar{E}=V C C \end{aligned}$ |
| vCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | $v$ |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
| 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VO} \leq \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | $v$ |  |
| VIH | Input High Voltage | $\begin{gathered} \text { VCC } \\ -2.0 \end{gathered}$ | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | 2.2 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | $v$ | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | v | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{~V} 1=\mathrm{VCC} \text { or } G N D \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VO}=\mathrm{VCC} \text { or } G N D \end{aligned}$ |


| TELOV | Chip Enable Access Time |  | 300 |  | ns | (4) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tavov | Address Access Time |  | 320 |  | ns | (4) |
| telox | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
| TEHOZ | Chip Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 120 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 20 |  |  | ns | (4) |
| TELAX | Address Hold Time | 50 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 80 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 200 |  |  | ns | (4) |
| TWLEL | Early Write Pulse Setup Time | 0 |  |  | ns | (4) |
| TWHEL | Write Enable Read Mode Setup Time | 0 |  |  | ns | (4) |
| TELWH | Early Write Pulse Hold Time | 80 |  |  | ns | (4) |
| TDVWL | Data Setup Time | 0 |  |  | ns | (4) |
| TDVEL | Early Write Data Setup Time | 0 |  |  | ns | (4) |
| TWLDX | Data Hold Time | 80 |  |  | ns | (4) |
| TELDX | Early Write Data Hold Time | 80 |  |  | ns | (4) |
| TOVWL | Data Valid to Write Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 420 |  |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information.- not guaranteed
(2. Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$.

Capacitance sampled and guaranteed - not $100 \%$ tested.
(4.) AC Test Conditions: Inputs - TRISE $=$ TFALL $=10$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V <br> Input or Output Voltage Applied <br> (GND $-0.3 \mathrm{~V})$ <br> to (VCC $+0.3 \mathrm{~V})$ |
| :--- | ---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Operating Supply Voltage <br> Industrial ( -9 ) |
| :--- |
| Operating Temperature <br> Industrial $(-9)$ |
| O |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} T E M P & =250 \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 100 | 20 | $\mu \mathrm{A}$ | $10=0 \overline{\mathrm{E}}=\mathrm{Vcc}-0.3 \mathrm{~V}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 50 | 12 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 V, 1 O=0 \\ & \bar{E}=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq$ VI $\leq \mathrm{VCC}$ |
| 102 | Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq$ VO $\leq \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | $\checkmark$ |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | VCC $+0.3$ | 2.2 | $\checkmark$ |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | V | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | $\checkmark$ | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance(3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & V O=V C C \text { or } G N D \end{aligned}$ |
| telov | Chip Enable Access Time |  | 300 |  | ns | (4) |
| tavov | Address Access Time |  | 320 |  | ns | (4) |
| telox | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
| TEHQZ | Chip Enable Output Disable Time |  | 100 |  | ns | (4)(5) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 120 |  |  | ns | (4) |
| tavel | Address Setup Time | 20 |  |  | ns | (4) |
| telax | Address Hold Time | 50 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 80 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 200 |  |  | ns | (4) |
| TWLEL | Early Write Pulse Setup Time | 0 |  |  | ns | (4) |
| TWHEL | Write Enable Read Mode Setup Time | 0 |  |  | ns | (4) |
| TELWH | Early Write Pulse Hold Time | 80 |  |  | ns | (4) |
| TDVWL | Data Setup Time | 0 |  |  | ns | (4) |
| TDVEL | Early Write Data Setup Time | 0 |  |  | ns | (4) |
| TWLDX | Data Hold Time | 80 |  |  | ns | (4) |
| TELDX | Early Write Data Hold Time | 80 |  |  | ns | (4) |
| TOVWL | Data Valid to Write Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 420 |  |  | ns | (4) |

NOTES:
All devices tested at worst case limits. Room temp., 5 volt data provided for information. - not guaranteed
Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP =5mA/MHz.
(3. Capacitance sampled and guaranteed - not $100 \%$ tested.
(4.) AC Test Conditions: Inputs - TRISE $=$ TFALL $=10$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

## Operating Supply Voltage Commercial

4.5 V to 5.5 V

Operating Temperature Commercial
$0^{\circ} \mathrm{C}$ to $+70{ }^{\circ} \mathrm{C}$
*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{aligned} \mathrm{TEMP} & =250 \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V} \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 350 | 50 | $\mu \mathrm{A}$ | $10=0, \overline{\mathrm{E}}=\mathrm{Vcc}-0.3 \mathrm{~V}$ |
| ICCOP | Operating Supply Current(2) |  | 7 | 5 | mA | $\begin{aligned} & \overline{\mathrm{E}}=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 200 | 30 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 V, 10=0 \\ & \widetilde{E}=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V |  |
| 11 | Input Leakage Current | -10.0 | +10.0 | $\pm 0.5$ | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
| IOZ | Output Leakage Current | -10.0 | +10.0 | $\pm 0.5$ | $\mu \mathrm{A}$ | GND $\leq \mathrm{VO} \leq \mathrm{VCC}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | V |  |
| VIH | Input High Voltage | $\begin{array}{ll} \mathrm{VCC} \\ -20 \end{array}$ | $\begin{aligned} & \mathrm{VCL} \\ & +0.3 \end{aligned}$ | 2.2 | $v$ |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | $v$ | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | $\checkmark$ | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| CO | Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & f=1 \mathrm{MHz} \\ & \mathrm{VO}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| TELQV | Chip Enable Access Time |  | 350 |  | ns | (4) |
| tavov | Address Access Time |  | 370 |  | ns | (4) |
| telox | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
| TEHOZ | Chip Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 350 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 150 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 20 |  |  | ns | (4) |
| telax | Address Hold Time | 50 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 100 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 250 |  |  | ns | (4) |
| TWLEL | Early Write Pulse Setup Time | 0 |  |  | ns | (4) |
| TWHEL | Write Enable Read Mode Setup Time | 0 |  |  | ns | (4) |
| TELWH | Early Write Pulse Hold Time | 100 |  |  | ns | (4) |
| TDVWL | Data Setup Time | 30 |  |  | ns | (4) |
| TDVEL | Early Write Data Setup Time | 30 |  |  | ns | (4) |
| TWLDX | Data Hold Time | 100 |  |  | ns | (4) |
| TELDX | Early Write Data Hold Time | 100 |  |  | ns | (4) |
| TOVWL | Data Valid to Write Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 500 |  |  | ns | (4) |

(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4.) AC Test Conditions: Inputs - TRISE $=$ TFALL $=10$ nsec; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.


TRUTH TABLE

| TIME REFERENCE | $\bar{E}$ |  | A | $\begin{gathered} \text { OUTPUT } \\ 0 \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| -1 | H | $x$ | x | $z$ | MEMORY DISABLED |
| 0 | 2 | H | $v$ | $z$ | CYCLE BEGINS, ADDRESSES ARE LATCHED. |
| 1 | L | H | x | x | OUTPUT ENABLED |
| 2 | L | H | x | $v$ | OUTPUT VALID |
| 3 | $r$ | H | x | $v$ | READ ACCOMPLISHED |
| 4 | H | X | x | $z$ | PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 5 | 2 | H | v | z | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS O) |

The address information is latched in the on chip registers on the falling edge of $\bar{E}(T=0)$. Minimum address set up and hold time requirements must be met. After the required hold time, the addresses may change state without affecting device operation. During time $(T=1)$ the output
becomes enabled but data is not valid until during time $(T=2)$. $\bar{W}$ must remain high until after time $(T=2)$. After the output data has been read, $\bar{E}$ may return high ( $T=3$ ). This will disable the output buffer and all inputs and ready the RAM for the next memory cycle ( $T=4$ ).

Early Write Cycle


TRUTH TABLE

| TIME REFERENCE | E |  | A | D | $\begin{gathered} \text { OUTPUT } \\ \text { a } \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| -1 | H | x | x | x | $z$ | MEMORY DISABLED |
| 0 | 2 | L | $v$ | $v$ | $z$ | CYCLE BEGINS, ADDRESSES ARE LATCHED |
| 1 | L | x | x | $x$ | $z$ | WRITE IN PROGRESS INTERNALLY |
| 2 | $\sim$ | x | x | $x$ | z | WRITE COMPLETED |
| 3 | H | X | x | x | $z$ | PREPARE FOR NEXT CYCLE (SAME AS - 11 |
| 4 | 2 | L | $v$ | $v$ | $z$ | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS 0) |

The early write cycle is the only cycle where the output is guaranteed not to become active. On the falling edge of $\overrightarrow{\mathrm{E}}(\mathrm{T}=0)$, the addresses, the write signal, and the data input are latched in on chip registers. The logic value of $\bar{W}$ at the time $\bar{E}$ falls determines the state of the output buffer for that cycle. Since $\bar{W}$ is low when $\bar{E}$ falls, the output buffer is latched into the high impedance state and
will remain in that state until $\bar{E}$ returns high $(T=2)$. For this cycle, the data input is latched by $\bar{E}$ going low; therefore data set up and hold times should be referenced to $\bar{E}$. When $\bar{E}(T=2)$ returns to the high state the output buffer and all inputs are disabled and all signals are unlatched. The device is now ready for the next cycle.

Read Modify Write Cycle


TRUTH TABLE

| time reference | E | $\stackrel{\text { in }}{\text { W }}$ |  | D | $\begin{gathered} \text { OUTPUT } \\ 0 \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | H | $x$ | $\times$ | $x$ | 2 | MEMORY DISABLED |
| 0 | 2 | H | $\checkmark$ | x | $z$ | CYCLE BEGINS. ADDRESS ARE LATCHED |
| 1 | L | H | $\times$ | $x$ | $\times$ | OUTPUT ENABLED |
| 2 | L | H | $\times$ | $x$ | $v$ | OUTPUT VALID, READ AND MODIFY TIME |
| 3 | L | 2 | $x$ | v | $v$ | WRITE BEGINS. DATA IS LATCHED |
| 4 | L | $x$ | $\times$ | x | v | WRITE IN PROGRESS INTERNALLY |
| 5 | $\checkmark$ | x | $x$ | x | $v$ | WRITE COMPLETED |
| 6 | H | x | $\times$ | $x$ | $z$ | Prepare for next cycle isame as -1) |
| 7 | 2 | H | $\checkmark$ | $\times$ | 2 | CYCLE ENDS. NEXT CYCLE BEGINS (SAME AS 0) |

The read modify write cycle begins as all other cycles on the falling edge of $\bar{E}(T=0)$. The $\bar{W}$ line should be high at ( $T=0$ ) in order to latch the output buffers in the active state. During ( $\mathrm{T}=1$ ) the output will be active but not valid until ( $T=2$ ). On the falling edge of the $\bar{W}(T=3)$ the data present at the output and input are latched. The
$\bar{W}$ signal also latches itself on its low going edge. All input signals excluding $\bar{E}$ have been latched and have no further effect on the RAM. The rising edge of $\bar{E}(T=5)$ completes the write portion of the cycle and unlatches and disables all inputs and output. The output goes to a high impedance and the RAM is ready for the next cycle.


The late write cycle is a cross between the early write cycle and the read-modify-write cycle.

Recall that in the early write the output is guaranteed to remain high impedance, and in the read-modify-write the output is guaranteed valid at access time. The late
write is between these two cases. With this cycle the output may become active, and may become valid data, or may remain active but undefined. Valid data is written into the RAM if data setup, data hold, write setup and write pulse widths are observed.

## Features

- LOW POWER STANDBY
- LOW POWER OPERATION
- data retention
- TTL COMPATIBLE INPUT/OUTPUT
- COMMON DATA IN/OUT
- THREE-STATE OUTPUTS
- STANDARD JEDEC PINOUT
- FAST ACCESS TIME
$125 \mu$ W MAX. $35 \mathrm{~mW} / \mathrm{MHz}$ MAX. @ 2.0V MIN.
- MILITARY TEMPERATURE RANGE
- INDUSTRIAL TEMPERATURE RANGE
- 18 PIN PACKAGE FOR HIGH DENSITY
- ON-CHIP ADDRESS REGISTER
- GATED INPUTS-NO PULL UP OR PULL DOWN RESISTORS REQUIRED


## D.escription

The HM-6514 is a $1024 \times 4$ static CMOS RAM fabricated using self aligned silicon gate technology. The device utilizes synchronous circuitry to achieve high performance and low power operation.

On-chip latches are provided for the addresses allowing efficient interfacing with microprocessor systems. The data output can be forced to a high impedance state for use in expanded memory systems. Gated inputs allow low operating current and also eliminates the need for pullup or pulldown resistors.

The HM-6514 is a fully static RAM and may be maintained in any state for an indefinite period of time. Data retention supply voltage and supply current are guaranteed over temperature.

Pinouts
TOP VIEW

| $\mathrm{A}_{6}{ }^{1}$ | 18 |
| :---: | :---: |
| $\mathrm{A}_{5} \mathrm{C}_{2}$ | 17 |
| ${ }^{4} \square^{3}$ | 16 |
| $\mathrm{A}^{-1} 4$ | 15 |
| AO 5 | 14 |
| A1-6 | 13 |
| $\mathrm{A}_{2} \square_{7}$ | 12 |
| E $\square_{8}$ | 11 |
| GND 9 | 10 |



## Functional Diagram



ALL LINES ACTIVE HIGH - POSITIVE LOGIC
THREE STATE BUFFERS:
A HIGH $\rightarrow$ OUTPUT ACTIVE
ADDRESS LATCHES: LATCH ON FALLING EDGE OF $\bar{E}$
gated decoders:
GATE ON RISING EDGE OF G

CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

| ABSOLUTE MAXIMUM RATINGS * |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC - GND) | -0.3 V to +8.0V | Operating Supply Voltage |  |
| Input or Output Voltage Applied | (GND -0.3V) | Military (-2) | 4.5 V to 5.5 V |
|  | to (VCC +0.3V) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Military (-2) | $-55^{\circ} \mathrm{C}$ to $+125{ }^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

PRELIMINARY
D.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{gathered} \text { TEMP }=250 \mathrm{C}(1) \\ V C C=5.0 \mathrm{~V} \end{gathered}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 50 | 5.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & \bar{E}=V C C-0.3 V \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 \mathrm{~V}, 10=0 \\ & E=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
| 1102 | Input/Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq V C C$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | V |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \text { vcc } \\ & +0.3 \end{aligned}$ | 2.2 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | V | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | V | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 M H z \end{aligned}$ |
| ClO | Input/Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & V I O=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |


| TELQV | Chip Enable Access Time |  | 120 |  | ns | (4) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TAVQV | Address Access Time |  | 120 |  | ns | (4) |
| telax | Chip Enable Output Enable Time | 10 |  |  | ns | (4) |
| TWLQZ | Write Enable Output Disable Time |  | 50 |  | ns | (4) (5) |
| TEHQZ | Chip Enable Output Disable Time |  | 50 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 120 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 50 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 0 |  |  | ns | (4) |
| TELAX | Address Hold Time | 40 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 120 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 120 |  |  | ns | (4) |
| TELWH | Write Enable Pulse Hold Time | 120 |  |  | ns | (4) |
| TDVWH | Data Setup Time | 50 |  |  | ns | (4) |
| TWHDX | Data Hold Time | 0 |  |  | ns | (4) |
| TWLDV | Write Data Delay Time | 70 |  |  | ns | (4) |
| TWLEL | Early Output High-Z Time | 0 |  |  | ns | (4) |
| TEHWH | Late Output High-Z Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 170 |  |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room Temp., 5 V data provided for information - not guaranteed Operating Supply Current (ICCOP) is proportional to Operating Frequency. Ex: Typical ICCOP = 5mA/MHz. Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions: Inputs - TRISE $=$ TFALL $=5 \mathrm{~ns}$; Output - CLOAD $=50 \mathrm{pF}$. All timing measured at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

## Specifications HM-6514S-9



* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent
damage to the device. This is a stress only rating and functional operation of the device at these or at any
other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

PRELIMINARY


NOTES:
All devices tested at worst case limits. Room Temp., 5 V data provided for information - not guaranteed Operating Supply Current (ICCOP) is proportional to Operating Frequency. Ex: Typical ICCOP = 5mA/MHz. Capacitance sampled and guaranteed - not 100\% tested. AC test conditions: Inputs - TRISE $=$ TFALL $=5 \mathrm{~ns} ;$ Output - CLOAD $=50 \mathrm{pF}$. All timing measured at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

| ABSOLUTE MAXIMUM RATINGS * |  |
| :--- | ---: |
| Supply Voltage $-(V C C-G N D)$ | -0.3 V to +8.0 V |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage Military (-2)
4.5 V to 5.5 V

Operating Temperature Military (-2)
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS



All devices tested at worst case limits. Room Temp., 5V data provided for information - not guaranteed Operating Supply Current (ICCOP) is proportional to Operating Frequency. Ex: Typical ICCOP = $5 \mathrm{~mA} / \mathrm{MHz}$. Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions: Inputs - TRISE $=$ TFALL $=10 \mathrm{~ns}$; Output - CLOAD $=50 \mathrm{pF}$. All timing measured at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

| ABSOLUTE MAXIMUM RATINGS * |  |
| :--- | ---: |
| Supply Voltage - (VCC -GND) | -0.3 V to +8.0 V |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage
industrial (-9)
4.5V to 5.5 V

Operating Temperature
Industrial (-9) $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



NOTES: (1) All devices tested at worst case limits. Room Temp., 5 V data provided for information - not guaranteed
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Ex: Typical ICCOP = 5mA/MHz.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) $A C$ test conditions: Inputs - TRISE $=T F A L L=10 \mathrm{~ns}$; Output $-C L O A D=50 \mathrm{pF}$. All timing measured at 1.5 V reference level.
(5) This parameter is guaranteed and not tested. 2-44

## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage - (VCC - GND) | -0.3 V to +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied |  |
|  | (GND -0.3 V ) |
| to (VCC +0.3 V ) |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage
Military (-2)
4.5V to 5.5 V

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

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanant damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

D.C.
A.C.

| SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\begin{gathered} \text { TEMP }=250 \mathrm{C}(1 \\ V C C=5.0 \mathrm{~V} \end{gathered}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 50 | 5.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & E=V C C-0.3 V \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, \quad 10=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 V, 1 O=0 \\ & \mathbf{E}=\operatorname{VCC} \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
| 1102 | Input/Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq$ VCC |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | V |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | 2.2 | V |  |
| VOL | Output Low Voltage |  | 0.45 | 0.25 | V | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | V | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & V I=V C C \text { or GND } \\ & f=1 M H z \end{aligned}$ |
| ClO | Input/Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & \text { VIO }=\text { VCC or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |


| TELQV | Chip Enable Access Time |  | 300 |  | ns | (4) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TAVQV | Address Access Time |  | 320 |  | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
| TWLQZ | Write Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
| TEHQZ | Chip Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 120 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 20 |  |  | ns | (4) |
| TELAX | Address Hold Time | 50 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 300 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 300 |  |  | ns | (4) |
| TELWH | Write Enable Pulse Hold Time | 300 |  |  | ns | (4) |
| TDVWH | Data Setup Time | 200 |  |  | ns | (4) |
| TWHDZ | Data Hold Time | 0 |  |  | ns | (4) |
| TWLDV | Write Data Delay Time | 100 |  |  | ns | (4) |
| TWLEL | Early Output High-Z Time | 0 |  |  | ns | (4) |
| TEHWH | Late Output High-Z Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 420 |  |  | ns | (4) |

(1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=10 \mathrm{nsec}$; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This value is guaranteed and tested at $25^{\circ} \mathrm{C}$.

| ABSOLUTE MAXIMUM RATINGS* |  |  |  |
| :--- | ---: | ---: | :--- |
| Supply Voitage - (VCC -GND) <br> Input or Output Voltage Applied | -0.3 V to +8.0 V <br> (GND $-0.3 \mathrm{~V})$ <br> to (VCC $+0.3 \mathrm{~V})$ | OPERATING RANGE <br> Operating Supply Voltage <br> Industrial ( -9 ) | 4.5 V to 5.5 V |
| Storage Temperature | $-655^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |  |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

| D.C. | SYMBOL | PARAMETER | TEMP. \& VCC $=$ OPERATING RANGE |  | $\begin{gathered} \mathrm{TEMP}=250 \mathrm{C}(1 \\ V C \mathrm{C}=5.0 \mathrm{~V} \end{gathered}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | TYPICAL |  |  |
|  | ICCSB | Standby Supply Current |  | 25 | 3.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & E=V C C-0.3 V \end{aligned}$ |
|  | ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & \mathbf{E}=1 \mathrm{MHz}, 10=0 \\ & \mathrm{VI}=\mathrm{GND} \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 15 | 2.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 \mathrm{~V}, 10=0 \\ & E=V C C \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | V |  |
|  | 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
|  | IIOZ | Input/Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq \mathrm{VCC}$ |
|  | VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | $v$ |  |
|  | VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \text { vcc } \\ & +0.3 \end{aligned}$ | 2.2 | v |  |
|  | VOL | Output Low Voltage |  | 0.45 | 0.25 | v | $10=2.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | 4.0 | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 M H z \end{aligned}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10.0 | 6.0 | pF | $\begin{aligned} & V I O=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| A.C. | TELQV | Chip Enable Access Time |  | 300 |  | ns | (4) |
|  | tavov | Address Access Time |  | 320 |  | ns | (4) |
|  | telox | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
|  | TWLQZ | Write Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
|  | TEHQZ | Chip Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
|  | TELEH | Chip Enable Pulse Negative Width | 300 |  |  | ns | (4) |
|  | TEHEL | Chip Enable Pulse Positive Width | 120 |  |  | ns | (4) |
|  | TAVEL | Address Setup Time | 20 |  |  | ns | (4) |
|  | TELAX | Address Hold Time | 50 |  |  | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 300 |  |  | ns | (4) |
|  | TWLEH | Write Enable Pulse Setup Time | 300 |  |  | ns | (4) |
|  | TELWH | Write Enable Pulse Hold Time | 300 |  |  | ns | (4) |
|  | TDVWH | Data Setup Time | 200 |  |  | ns | (4) |
|  | TWHDX | Data Hold Time | $0$ |  |  | ns | (4) |
|  | TWLDV | Write Data Delay Time | $100$ |  |  | ns | (4) |
|  | TWLEL | Early Output High-Z Time | 0 |  |  | ns | (4) |
|  | TEHWH | Late Output High-Z Time | 0 |  |  | ns | (4) |
|  | TELEL | Read or Write Cycle Time | 420 |  |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE $=$ TFALL $=10 \mathrm{nsec}$; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

| ABSOLUTE MAXIMUM RATINGS * |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC -GND) | $-0.3 \mathrm{~V} \text { to }+8.0 \mathrm{~V}$ | Operating Supply Voltage Industrial (-9) | 4.5 V to 5.5 V |
| Input or Output Voltage Applied | $\begin{array}{r} \text { (GND -0.3V) } \\ \text { to (VCC }+0.3 \mathrm{~V}) \end{array}$ |  | 4.5V to 5.5 V |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150{ }^{\circ} \mathrm{C}$ | Operating Temperature Industrial (-9) | $-40^{\circ} \mathrm{C}$ to +850 C |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

| SYMBOL | PARAMETER | TEMP. \& VCC $=$ OPERATING RANGE |  | $\begin{gathered} \mathrm{TEMP}=250 \mathrm{C}(1 \\ \mathrm{VCC}=5.0 \mathrm{~V} \end{gathered}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 100 | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & E=V C C-0.3 V \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 7 | 5 | mA | $\begin{aligned} & E=1 \mathrm{MHz}, 10=0 \\ & V I=G N D \end{aligned}$ |
| ICCDR | Data Retention Supply Current |  | 50 | 12 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=2.0 \mathrm{~V}, 10=0 \\ & E=V C C \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 |  | 1.4 | $v$ |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
| 1102 | Input/Output Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq V I O \leq V C C$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 1.2 | V |  |
| VIH | Input High Voltage | $\begin{aligned} & \text { VCC } \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \text { vcc } \\ & +0.3 \end{aligned}$ | 2.2 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.25 | V | $10=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.0 | V | $10=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 8.0 | 5.0 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 M H z \end{aligned}$ |
| ClO | Input/Output Capacitance (3) |  | 10.0 | 6.0 | pF | VIO = VCC or GND $f=1 \mathrm{MHz}$ |


| TELQV | Chip Enable Access Time |  | 300 |  | ns | (4) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tavov | Address Access Time |  | 320 |  | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 20 |  |  | ns | (4) |
| TWLQZ | Write Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
| TEHQZ | Chip Enable Output Disable Time |  | 100 |  | ns | (4) (5) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 120 |  |  | ns | (4) |
| TAVEL | Address Setup Time | 20 |  |  | ns | (4) |
| TELAX | Address Hold Time | 50 |  |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 300 |  |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 300 |  |  | ns | (4) |
| TELWH | Write Enable Pulse Hold Time | 300 |  |  | ns | (4) |
| TDVWH | Data Setup Time | 200 |  |  | ns | (4) |
| TWHDX | Data Hold Time | 0 |  |  | ns | (4) |
| TWLDV | Write Data Delay Time | 100 |  |  | ns | (4) |
| TWLEL | Early Output High-Z Time | 0 |  |  | ns | (4) |
| TEHWH | Late Output High-Z Time | 0 |  |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 420 |  |  | ns | (4) |

NOTES: (1. All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed
(2.) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical $I C C O P=5 \mathrm{~mA} / \mathrm{MHz}$
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4.) AC Test Conditions: Inputs - TRISE $=$ TFALL $=10$ nsec; Outputs $-C L O A D=50 p F$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

| ABSOLUTE MAXIMUM RATINGS * |  | OPERATING RANGE <br> Operating Supply Voltage Commercial | 4.5 V to 5.5 V00 C to +700 C |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC - GND) Input or Output Voltage Applied | $\begin{array}{r} -0.3 \mathrm{~V} \text { to }+8.0 \mathrm{~V} \\ \text { (GND }-0.3 \mathrm{~V} \text { ) } \end{array}$ |  |  |
|  | to (VCC +0.3 V ) | perating Temperature |  |
| Storage Temperature | $-65{ }^{\circ} \mathrm{C}$ to $+150{ }^{\circ} \mathrm{C}$ | Commercial |  |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



NOTES: (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC Test Conditions: Inputs - TRISE = TFALL $=10 \mathrm{nsec}$; Outputs - CLOAD $=50 \mathrm{pF}$. All timing measurements at 1.5 V reference level.
(5) This parameter is guaranteed and not tested.

Read Cycle


TRUTH TABLE

| TIME REFERENCE | $-\frac{\mid N P U}{W}$ | A | $\left\lvert\, \begin{gathered} \text { DATA I/O } \\ \text { DO } \end{gathered}\right.$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 | H X | $\times$ | 2 | memory disabled |
| 0 | 2 H | $v$ | $z$ | CYCLE BEGINS, ADDRESSES ARE LATCHED |
| 1 | L H | $\times$ | x | OUTPUT ENABLED |
| 2 | L H | $\times$ | $v$ | OUTPUT VALIO |
| 3 | $\bigcirc$ | $\times$ | $v$ | READ ACCOMPLISHED |
| 4 | $\mathrm{H} \times$ | x | 2 | PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 5 | $\checkmark \mathrm{H}$ | $v$ | $z$ | cycle ends, next cycle begins (SAME AS O) |

The address information is latched in the on chip registers on the falling edge of $\bar{E}(T=0)$. Minimum address setup and hold time requirements must be met. After the required hold time the addresses may change state without affecting device operation. During time ( $T=1$ ) the outputs become
enabled but data is not valid until time ( $T=2$ ). $\bar{W}$ must remain high throughout the read cycle. After the data has been read $\bar{E}$ may return high $(T=3)$. This will force the output buffers and all inputs to a disabled state at time ( $T=4$ ). The memory is now ready for the next cycle.

Write Cycle


The write cycle is initiated by the falling edge of $\bar{E}(T=0)$, which latches the address information in the on-chip registers. There are two basic types of write cycles, which differ in the control of the common data-in/data-out bus.

$$
\text { Case 1: } \overline{\mathrm{E}} \text { falls before } \bar{W} \text { falls }
$$

The output buffers may become enabled (reading) if $\bar{E}$ falls before $\bar{W}$ falls. $\bar{W}$ is used to disable (three-state) the outputs so input data can be applied. TWLDV must be met to allow the $\bar{W}$ signal time to disable the outputs before applying input data. Also, at the end of the cycle the outputs may become active if $\bar{W}$ rises before $\bar{E}$. The RAM outputs and all inputs will-state) after $\overline{\mathrm{E}}$ rises (TEHOZ). In this type of write cycle TWLEL and TEHWH may be ignored.

> Case 2: $\bar{E}$ falls equal to or after $\bar{W}$ falls, and $\bar{E}$ rises before or equal to $\bar{W}$ rising

This $\overline{\mathrm{E}}$ and $\overline{\mathrm{W}}$ control timing will guarantee that the data outputs will stay disabled throughout the cycle, thus simplyifying the data input timing. TWLEL and TEHWH must be met but TWLDV becomes meaningless and can be ignored. In this cycle TDVWH and TWHDX become TDVEH and TEHDX. In other words, reference data setup and hold times to the $\bar{E}$ rising edge.

|  | IF | OBSERVE | IGNORE |
| :---: | :---: | :---: | :---: |
| Case 1 | $\bar{E}$ falls before $\bar{W}$ | TWLDV | TWLEL |
| Case 2 | $\bar{E}$ falls after $\bar{W} \&$ | TWLEL | TWLDV |
|  | $\bar{E}$ rises before $\bar{W}$ | TEHWH | TWHDX |

If a series of consecutive write cycles are to be performed, $\bar{W}$ may be held low until all desired locations have been written (an extension of Case 2).

Read Modify Write Cycle


| TIME reference | _ inputs |  | $\begin{array}{c\|} \hline \text { DATAI/O } \\ \text { DQ } \end{array}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| $\rightarrow$ | $\mathrm{H} \times$ | x | $z$ | memory disabled |
| 0 | 2 H | $v$ | z | CYCLE BEGINS, ADORESSES ARE LATCHED |
| 1 | L H | x | $\times$ | READ MODE, OUTPUT ENABLED |
| 2 | L H | x | $v$ | READ MODE, OUTPUT VALID |
| 3 |  | $x$ | z | WRITE MODE, OUTPUT HIGH Z |
| 4 | L | x | $v$ | WRITE MODE, DATA IS WRITTEN |
| 5 | $\bigcirc \mathrm{H}$ | $\times$ | $z$ | WRITE COMPLETED |
| 6 | $\mathrm{H} \times$ | x | 2 | PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 7 | 2 H | v | z | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS 0) |

If the pulse width of $\bar{W}$ is relatively short in relation to that of $\overline{\mathrm{E}}$ a combination read-write cycle may be performed. If $\bar{W}$ remains high for the first part of the cycle, the outputs will become active during time ( $T=1$ ). Data out will be valid during time ( $T=2$ ). After the data is read, $\bar{W}$ can go low. After minimum TWLWH, $\bar{W}$ may return high. The
information just written may now be read or $\overline{\mathrm{E}}$ may return high, disabling the output buffers and all inputs and preparing the device for the next cycle. Any number or sequence of read-write operation may be performed while $\bar{E}$ is low providing all timing requirements are met.

NOTES: In the above descriptions the numbers in parenthesis ( $T=n$ ) refer to the respective timing diagrams. The numbers are located on the time reference line below each diagram. The timing diagrams shown are only examples and are not the only valid method of operation.

## 2114 Compatibility



## 2K x 8 CMOS RAM

## Features

- LOW POWER STANDBY
- LOW POWER OPERATION
- FAST ACCESS
- INDUSTRY STANDARD PINOUT
- SINGLE SUPPLY
- TTL COMPATIBLE
- STATIC MEMORY CELLS
- HIGH OUTPUT DRIVE
- ON CHIP ADDRESS LATCHES
- EASY MICROPROCESSOR INTERFACING
- WIDE TEMPERATURE RANGE
$275 \mu \mathbf{W}$ MAX
55mW/MHz MAX
120/200 ns MAX

5 VOLT VCC

## Description

The HM-6516 is a CMOS $2048 \times 8$ Static Random Access Memory. Extremely low power operation is achieved by the use of complementary MOS design techniques. This low power is further enhanced by the use of synchronous circuit techniques that keep the active (operating) power low, and also give fast access times. The pinout of the HM-6516 is the popular 24 pin, 8 bit wide JEDEC standard which allows easy memory board layouts, flexible enough to accomodate a variety of PROMs, RAMs, EPROMs, and ROMs.

The HM-6516 is ideally suited for use in microprocessor based systems. The byte wide organization simplifies the memory array design, and keeps operating power down to a minimum because only one device is enabled at a time. The address latches allow very simple interfacing to recent generation microprocessors which employ a multiplexed address/data bus. The convenient output enable control also simplifies multiplexed bus interfacing by allowing the data outputs to be controlled independent of the chip enable.

## Pinouts

| TOP VIEW |  |  |  |
| :---: | :---: | :---: | :---: |
| A7 1 | ${ }^{24}$ ] vcc |  |  |
| $\mathrm{AC}^{2}$ | ${ }^{23}$ A A8 |  | PIN NAMES |
| A5 3 | $22 \mathrm{fa9}$ |  | PIN NAMES |
| ${ }^{4} 4{ }^{4}$ | 21. | A | Address Input |
| ${ }^{\text {a }}$ - 5 | $200^{\bar{G}}$ | DQ | Data Input/Output |
| ${ }^{\text {A2 }} 6$ | ${ }^{19}$ D A10 | E | Chip Enable |
| A1. 7 | $18 \mathrm{E} \overline{\mathrm{E}}$ | G | Output Enable |
| ${ }^{\text {AO }} 8$ | ${ }^{17}{ }^{16} \mathbf{0} 07$ | W | Write Enable |
| D00 ${ }_{\text {001 }} 0$ | ${ }^{16}{ }^{16}$ D06 | NC | No Connect |
| DO2 11 | ${ }_{14}{ }^{\text {DOA }}$ |  |  |
| GND 12 | ${ }_{13}{ }^{\text {D03 }}$ |  |  |

## Functional Diagram



[^0]| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE <br> Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0 V | Operating Supply Voltage Military ( $\mathrm{B}-2$ ) | 4.5 V to 5.5 V |
| Input or Output Voltage Applied | (GND -0.3V) | Industrial (B-9) | 4.5 V to 5.5 V |
|  | to (VCC +0.3V) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Military ( $\mathrm{B}-2$ ) Industrial (B-9) | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+1250^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+850 \mathrm{C} \end{aligned}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



NOTES:
(1) All devices tested at worst case limits.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency.
(3) Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$. This parameter is sampled and guaranteed - Not $100 \%$ tested.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions: Inputs - TRISE $=$ TFALL $=5 \mathrm{~ns}$; Output - CLOAD $=50 \mathrm{pF}$. All timing measured at 1.5 V reference level. Input pulse levels: 0 V to 3 V .

## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage (VCC - GND) | -0.3 to 8.0V |
| :---: | :---: |
| Input or Output Voltage Applied | (GND -0.3V) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

Operating Supply Voltage Military ( -2 ) Industrial (-9)
Operating Temperature Military (-2) Industrial (-9)
4.5 V to 5.5 V
4.5 V to 5.5 V
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP: OPER RANG | $\begin{aligned} & \text { VCC = } \\ & \text { TING } \\ & \text { (1) } \end{aligned}$ |  | TE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | UNITS | CONDITIONS |
| D.C. |  | Standby Supply Current <br> Operating Supply Current |  | 100 10 | $\mu A$ $m A$ | $\begin{aligned} & I O=0 \\ & V I=V C C \text { or } G N D \\ & f=1 M H z, 10=0, \bar{G}=V C C \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & I O=0, V C C=2.0, \\ & V I=V C C \text { or } G N D, \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | V | $\overline{\mathrm{E}}=\mathrm{VCC}$ |
|  | 11 | Input Leakage Current | $-1.0$ | +1.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
|  | IIOZ | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VIO} \leq \mathrm{VCC}$ |
|  | VIL | Input Low Voltage | -0.3 | 0.8 | $v$ |  |
|  | VIH | Input High Voltage | 2.4 | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | V |  |
|  | VOL | Output Low Voltage |  | 0.4 | v | $10=3.2 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8.0 | pF | $\begin{aligned} & V I=V C C \text { or GND, } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10.0 | pF | $\begin{aligned} & \text { VIO }=\text { VCC or GND, } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| A.C. | TELQV | Chip Enable Access Time |  | 200 | ns | (4) |
|  | TAVQV | Address Access Time |  | 200 | ns | (4) |
|  | TELQX | Chip Enable Output Enable Time | 10 |  | ns | (4) |
|  | TWLQZ | Write Enable Output Disable Time |  | 80 | ns | (4) |
|  | TEHQZ | Chip Enable Output Disable Time |  | 80 | ns | (4) |
|  | TGLQV | Output Enable Output Valid Time |  | 80 | ns | (4) |
|  | TGLQX | Output Enable Output Enable Time | 10 |  | ns | (4) |
|  | TGHQZ | Output Enable Output Disable Time |  | 80 | ns | (4) |
|  | TELEH | Chip Enable Pulse Negative Width | 200 |  | ns | (4) |
|  | TEHEL | Chip Enable Pulse Positive Width | 80 |  | ns | (4) |
|  | TAVEL | Address Setup Time | 0 |  | ns | (4) |
|  | TELAX | Address Hold Time | 50 |  | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 200 |  | ns | (4) |
|  | TWLEH | Write Enable Pulse Setup Time | 200 |  | ns | (4) |
|  | TELWH | Write Enable Pulse Hold Time | 200 |  | ns | (4) |
|  | TDVWH | Data Setup Time | 80 |  | ns | (4) |
|  | TWHDX | Data Hold Time | 10 |  | ns | (4) |
|  | TWLDV | Write Data Delay Time | 80 |  | ns | (4) |
|  | TELEL | Read or Write Cycle Time | 280 |  | ns | (4) |

## (1) All devices tested at worst case limits.

(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency.

Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$. This parameter is sampled and guaranteed - Not $100 \%$ tested.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions: Inputs - TRISE $=$ TFALL $=10 \mathrm{~ns}$; Output - CLOAD $=100 \mathrm{pF}$ All timing measured at 1.5 V reference level. Input pulse levels: 0 V to 3 V .

| ABSOLUTE MAXIMUM RATINGS* |  |  |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) <br> Input or Output Voltage Applied | -0.3 to 8.0 V <br> (GND $-0.3 \mathrm{~V})$ <br> to (VCC $+0.3 \mathrm{~V})$ | OPERATING RANGE <br> Operating Supply Voltage <br> Commercial ( -5 ) | Operating Temperature <br> Commercial ( -5 ) |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP \& VCC = OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB | Standby Supply Current |  | 500 | $\mu \mathrm{A}$ | $10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 10 | mA | $\begin{aligned} & V 1=V C C \text { or } G N D \\ & f=1 M H z, I O=0, \bar{G}=V C C \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 250 | $\mu \mathrm{A}$ | $10=0, V C C=2.0$, |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | V | $\begin{aligned} & \mathrm{VI}=\mathrm{VCC} \text { or } G N D, \\ & \mathrm{E}=\mathrm{VCC} \end{aligned}$ |
|  | 11 | Input Leakage Current | $-5.0$ | +5.0 | $\mu \mathrm{A}$ | GND $\leq$ VI $\leq$ VCC |
|  | IIOZ | Input/Output Leakage Current | -5.0 | +5.0 | $\mu A$ | $\mathrm{GND} \leq \mathrm{VIO} \leq \mathrm{VCC}$ |
|  | VIL | Input Low Voltage | -0.3 | 0.8 | V |  |
|  | VIH | Input High Voltage | 2.4 | VCC | V |  |
|  |  |  |  | +0.3 |  |  |
|  | VOL | Output Low Voltage |  | 0.4 | V | $10=3.2 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8.0 | pF | $\begin{aligned} & V I=V C C \text { or } G N D, \\ & f=1 M H z \end{aligned}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10.0 | pF | $\begin{aligned} & \text { VIO = VCC or GND, } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| A.C. |  |  |  |  |  | (4) |
|  | TELQV | Chip Enable Access Time |  | 200 | ns | ( |
|  | TAVQV | Address Access Time |  | 200 | ns | (4) |
|  | TELQX | Chip Enable Output Enable Time | 10 |  | ns | (4) |
|  | TWLQZ | Write Enable Output Disable Time |  | 80 | ns | (4) |
|  | TEHQZ | Chip Enable Output Disable Time |  | 80 | ns | (4) |
|  | TGLQV | Output Enable Output Valid Time |  | 80 | ns | (4) |
|  | TGLQX | Output Enable Output Enable Time | 10 |  | ns | (4) |
|  | TGHQZ | Output Enable Output Disable Time |  | 80 | ns | (4) |
|  | TELEH | Chip Enable Pulse Negative Width | 200 |  | ns | (4) |
|  | TEHEL | Chip Enable Pulse Positive Width | 80 |  | ns | (4) |
|  | TAVEL | Address Setup Time | 0 |  | ns | (4) |
|  | TELAX | Address Hold Time | 50 |  | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 200 |  | ns | (4) |
|  | TWLEH | Write Enable Pulse Setup Time | 200 |  | ns | (4) |
|  | TELWH | Write Enable Pulse Hold Time | 200 |  | ns | (4) |
|  | TDVWH | Data Setup Time | 80 |  | ns | (4) |
|  | TWHDX | Data Hold Time | 10 |  | ns | (4) |
|  | TWLDV | Write Data Delay Time | 80 |  | ns | (4) |
|  | TELEL | Read or Write Cycle Time | 280 |  | ns | (4) |

NOTES:

## (1) All devices tested at worst case limits.

2) Operating Supply Current (ICCOP) is proportional to Operating Frequency.

Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$. This parameter is sampled and guaranteed - Not $100 \%$ tested.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions: Inputs - TRISE = TFALL = 10ns; Output - CLOAD $=100 \mathrm{pF}$. All timing measured at 1.5 V reference level. Input pulse levels: 0 V to 3 V .


The address information is latched in the on chip registers on the falling edge of $\bar{E}(T=0)$, minimum address setup and hold time requirements must be met. After the required hold time, the addresses may change state without affecting device operation. During time ( $T=1$ ), the outputs become enabled but data is not valid until time ( $T=2$ ), $\bar{W}$ must remain high throughout the read
cycle. After the data has been read, $\overline{\mathrm{E}}$ may return high ( $T=3$ ). This will force the output buffers into a high impedance mode at time ( $T=4$ ). $\bar{G}$ is used to disable the output buffers when in a logical " 1 " state ( $T=-1,0$, $3,4,5)$. After ( $T=4$ ) time, the memory is ready for the next cycle.

Write Cycle


The write cycle is initiated on the falling edge of $\bar{E}(T=0)$, which latches the address information in the on chip registers. If a write cycle is to be performed where the output is not to become active, $\overline{\mathrm{G}}$ can be held high (inactive). TDVWH and TWHDX must be met for proper device operation regardless of $\overline{\mathcal{G}}$. If $\overline{\mathrm{E}}$ and $\overline{\mathrm{G}}$ fall before $\bar{W}$ falls (read mode), a possible bus conflict may exist. If $\bar{E}$ rises before $\bar{W}$ rises, reference data setup and hold times
to the $\overline{\mathrm{E}}$ rising edge. The write operation is terminated by the first rising edge of $\bar{W}(T=2)$ or $\bar{E}(T=3)$. After the minimum $\bar{E}$ high time (TEHEL), the next cycle may begin. If a series of consecutive write cycles are to be performed, the $\bar{W}$ line may be held low unitl all desired locations have been written. In this case, data setup and hold times must be referenced to the rising edge of $\bar{E}$.
Read Modify Write Cycle

TRUTH TABLE

| time reference | $E$ |  |  | A | $\begin{array}{\|c} \text { DATA I/O } \\ \text { DQ } \end{array}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| -1 | H | x | H | $\times$ | $z$ | MEMORY DISABLED |
| 0 | $\lambda$ | H | H | $v$ | 2 | CYCLE BEGINS, ADDRESSES ARE LATCHED |
| 1 | L | H | L | x | $\times$ | READ MODE, OUTPUT ENABLED ( $\overline{\mathbf{W}}=\mathrm{HIGH}, \overline{\mathrm{G}}=$ LOW) |
| 2 | L | H | L | $\times$ | $v$ | READ MODE, OUTPUT VALID |
| 3 |  | L | H | x | z | WRITE MODE, OUTPUT HIGH $Z$ |
| 4 | L | $\checkmark$ | H | x | $v$ | WRITE MODE, DATA IS WRITTEN |
| 5 | $\checkmark$ | H | H | $\times$ | $z$ | WRITE COMPLETED |
| 6 | H | $\times$ | H | $\times$ | $z$ | PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 7 | $\lambda$ | H | H | $v$ | $z$ | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS O) |

If the pulse width of $\bar{W}$ is relatively short in relation to that of $\bar{E}$, a combination read write cycle may be performed. If $\bar{W}$ remains high for the first part of the cycle, the output will become active during time ( $\mathrm{T}=1$ ) provided $\overline{\mathrm{G}}$ is low. Data out will be valid during time ( $T=2$ ). After the data is read, $\bar{W}$ can go low. After minimum

TWLWH, $\bar{W}$ may return high. The information just written may now be read or $\bar{E}$ may return high, disabling the output buffer and preparing the device for the next cycle. Any number or sequence of read-write operations may be performed while $\bar{E}$ is low providing all timing requirements are met.

NOTES:
In the above descriptions, the numbers in parentheses $(T=n)$, refer to the respective timing diagrams. The numbers are located on the time reference line below each diagram. The timing diagrams shown are only examples and are not the only valid method of operation.

## $2048 \times 8$ Asynchronous

Advance Information

## Features

- FAST ACCESS TIME
- LOW STANDBY CURRENT
- LOW OPERATING CURRENT
- DATA RETENTION @ 2.0 VOLTS
- TTL COMPATIBLE INPUTS AND OUTPUTS
- JEDEC APPROVED PINOUT (2716, 6116 TYPE)
- NO CLOCKS OR STROBES REQUIRED
- WIDE TEMPERATURE RaNge
- EQUAL CYCLE AND ACCESS TIME
- SINGLE 5 VOLT SUPPLY


## Description

The HM-65162 is a CMOS $2048 \times 8$ Static Random Access Memory manufactured using the HARRIS advanced SAJI V process. The device utilizes asynchronous circuit design for fast cycle time and ease of use. The pinout is the JEDEC 24 pin, 8 bit wide standard which allows easy memory board layouts flexible to accommodate a variety of industry standard PROMs, RAMs, ROMs and EPROMs. The HM-65162 is ideally suited for use in microprocessor based systems with its 8 bit word length organization. The convenient output enable also simplifies the bus interface by allowing the data outputs to be controlled independent of the chip enable. Gated inputs lower operating current and also eliminate the need for pull-up or pull-down resistors.

- GATED INPUTS - NO PULL-UP OR PULL-DOWN
RESISTORS ARE REQUIRED
- GATED INPUTS - NO PULL-UP OR PULL-DOWN
RESISTORS ARE REQUIRED -


## Pinouts

55/70/90/120 ns MAX
$50 \mu \mathrm{~A}$ MAX
70 mA MAX
$20 \mu A$ MAX
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

## Functional Diagram



CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE <br> Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Military (-2) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Military (-2) | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



NOTES:

[^1]| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE <br> Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND-0.3V) | Military ( -2 ) | 4.5 V to 5.5 V |
|  | to (VCC +0.3V) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Military (-2) | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS


NOTES:
$(1)$
(2)
(4)

All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; $\mathrm{VI}=\mathrm{VCC}$ or GND.

Capacitance sampled and guaranteed - not 100\% tested.
Input pulse levels: 0 V to $3.0 \mathrm{~V} \quad$ Input and Output timing reference levels: 1.5 V
Input rise and fall times: $5 \mathrm{~ns} \quad$ Output load: 1TTL Gate and $\mathrm{CL}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Military (-2) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Military (-2) | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS


| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0 V |  |  |
| Input or Output Voltage Applied | (GND-0.3V) | Industrial (-9) | 4.5 V to 5.5 V |
|  | to (VCC +0.3V) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Industrial (-9) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS


Specifications HM-65162B-9

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE <br> Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Industrial (-9) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Industrial (-9) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Industrial (-9) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Industrial (-9) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS



Specifications HM-65162C-9

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND-0.3V) | Industrial (-9) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Industrial ( -9 ) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE <br> Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND-0.3V) | Commercial ( -5 ) | 4.5 V to 5.5 V |
|  | to (VCC +0.3V) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Commercial ( -5 ) | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | $\begin{gathered} \text { TEMP. \& VCC }= \\ \text { OPERATING } \\ \text { RANGE (1) } \\ \hline \end{gathered}$ |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB1 | Standby Supply Current |  | 100 | $\mu \mathrm{A}$ | $10=0, \bar{E}=\mathrm{VCC}-0.3 \mathrm{~V}$ |
|  | ICCSB | Standby Supply Current |  | 8 | mA | $\bar{E}=\mathrm{VIH}, 10=0$ |
|  | ICC | Enabled Supply Current |  | 70 | mA | $\overline{\mathrm{E}}=\mathrm{VIL}, 10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 70 | mA | $\begin{gathered} E=\text { VIL, } 10=0 \\ f=1 \mathrm{MHz} \end{gathered}$ |
|  | ICCDR | Data Retention Supply Current |  | 40 | $\mu \mathrm{A}$ | $\begin{gathered} 10=0, V C C=2.0 \\ \bar{E}=V C C-0.3 V \end{gathered}$ |
|  | VCCDR | Data Retention Supply Voitage | 2.0 |  | V |  |
|  | 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
|  | 1102 | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $G N D \leqslant V 10 \leqslant V C C$ |
|  | VIL | Input Low Voltage | -0.3 | 0.8 | V |  |
|  | VIH | Input High Voltage | 2.4 | $\begin{gathered} \text { VCC } \\ +0.3 \mathrm{~V} \end{gathered}$ | V |  |
|  | VOL | Output Low Voitage |  | 0.4 | V | $10=4.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8 | pF | $\begin{gathered} V I=V C C \text { or } G N D, \\ f=1 \mathrm{MHz} \end{gathered}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10 | pF | $\begin{gathered} V I O=V C C \text { or GND }, \\ f=1 M H z \end{gathered}$ |
| READ CYCLE | TAVAV | Read Cycle Time | 55 |  | ns | (4) |
|  | TAVQV | Address Access Time |  | 55 | ns | (4) |
|  | TELQV | Chip Enable Access Time |  | 55 | ns | (4) |
|  | TELQX | Chip Enable Output Enable Time | 5 |  | ns | (4) |
|  | TGLQV | Output Enable Output Enable Time |  | 35 | ns | (4) |
|  | TGLQX | Output Enable Output Enable Time | 5 |  | ns | (4) |
|  | TEHQZ | Chip Enable Output Disable Time |  | 30 | ns | (4) |
|  | TGHQZ | Output Enable Output Disable Time |  | 25 | ns | (4) |
|  | TAVQX | Output Hold from Address Change | 5 |  | ns | (4) |
| A.C.WRITECYCLE | TAVAV | Write Cycle Time | 55 |  | ns | (4) |
|  | TELWH | Chip Selection to End of Write | 45 |  | ns | (4) |
|  | TAVWL | Address Setup Time | 5 |  | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 35 |  | ns | (4) |
|  | TWHAV | Write Enable Read Setup Time | 10 |  | ns | (4) |
|  | TGHQZ | Output Enable Output Disable Time |  | 25 | ns | (4) |
|  | TWLQZ | Write Enable Output Disable Time |  | 25 | ns | (4) |
|  | TDVWH | Data Setup Time | 25 |  | ns | (4) |
|  | TWHDX | Data Hold Time | 10 |  | ns | (4) |
|  | TWHQX | Write Enable Output Enable Time | 0 |  | ns | (4) |
|  | TWLEH | Write Enable Pulse Setup Time | 50 |  | ns | (4) |
|  | TDVEH | Chip Enable Data Setup Time | 25 |  | ns | (4) |
|  | TAVWH | Address Valid to End of Write | 50 |  | ns | (4) |

notes:

| (1) | All devices tested at worst case limits. |
| :---: | :---: |
| (2) | Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in $\mathrm{ICCOP} ; \mathrm{VI}=\mathrm{VCC}$ or GND. |
| ) | Capacitance sampled and guaranteed - not 100\% tested. |
| (4) |  |

## Specifications HM-65162B-5

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0 V |  |  |
|  |  | Commercial ( -5 ) | 5 V to 5.5 V |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Commercial ( -5 ) | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE <br> Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Commercial ( -5 ) | 4.5 V to 5.5 V |
|  | to (VCC + 0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Commercial ( -5 ) | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.
ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. \& VCC $=$ OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB1 | Standby Supply Current |  | 100 | $\mu \mathrm{A}$ | $10=0, \bar{E}=\mathrm{VCC}-0.3 \mathrm{~V}$ |
|  | ICCSB | Standby Supply Current |  | 8 | mA | $\overline{\mathrm{E}}=\mathrm{VIH}, 10=0$ |
|  | ICC | Enabled Supply Current |  | 70 | mA | $\bar{E}=$ VIL, $10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 70 | mA | $\begin{gathered} \bar{E}=V I L, 10=0 \\ f=1 \mathrm{MHz} \end{gathered}$ |
|  | ICCDR | Data Retention Supply Current |  | 40 | $\mu \mathrm{A}$ | $\begin{gathered} 10=0, V C C=2.0 \\ \bar{E}=V C C-0.3 V \end{gathered}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | V |  |
|  | II | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leqslant \mathrm{VI} \leqslant \mathrm{VCC}$ |
|  | 1102 | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leqslant \mathrm{VIO} \leqslant \mathrm{VCC}$ |
|  | VIL | Input Low Voltage | -0.3 | 0.8 | V |  |
|  | VIH | Input High Voltage | 2.2 | $\begin{gathered} \text { VCC } \\ +0.3 \mathrm{~V} \end{gathered}$ | V |  |
|  | VOL | Output Low Voltage |  | 0.4 | V | $10=4.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8 | pF | $\begin{gathered} V I=V C C \text { or } G N D, \\ f=1 M H z \end{gathered}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10 | pF | $\begin{gathered} V I O=V C C \text { or GND }, \\ f=1 \mathrm{MHz} \end{gathered}$ |
| READ CYCLE | TAVAV | Read Cycle Time | 90 |  | ns | (4) |
|  | TAVQV | Address Access Time |  | 90 | ns | (4) |
|  | TELQV | Chip Enable Access Time |  | 90 | ns | (4) |
|  | TELQX | Chip Enable Output Enable Time | 5 |  | ns | (4) |
|  | TGLQV | Output Enable Output Enable Time |  | 65 | ns | (4) |
|  | TGLQX | Output Enable Output Enable Time | 5 |  | ns | (4) |
|  | TEHQZ | Chip Enable Output Disable Time |  | 50 | - ns | (4) |
|  | TGHQZ | Output Enable Output Disable Time |  | 40 | ns | (4) |
|  | TAVQX | Output Hold from Address Change | 5 |  | ns | (4) |
| A.C.WRITECYCLE | TAVAV | Write Cycle Time | 90 |  | ns | (4) |
|  | TELWH | Chip Selection to End of Write | 55 |  | ns | (4) |
|  | TAVWL | Address Setup Time | 10 |  | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 55 |  | ns | (4) |
|  | TWHAV | Write Enable Read Setup Time | 10 |  | ns | (4) |
|  | TGHQZ | Output Enable Output Disable Time |  | 40 | ns | (4) |
|  | TWLQZ | Write Enable Output Disable Time |  | 50 | ns | (4) |
|  | TDVWH | Data Setup Time | 30 |  | ns | (4) |
|  | TWHDX | Data Hold Time | 15 |  | ns | (4) |
|  | TWHQX | Write Enable Output Enable Time | 0 |  | ns | (4) |
|  | TWLEH | Write Enable Pulse Setup Time | 55 |  | ns | (4) |
|  | TDVEH | Chip Enable Data Setup Time | 30 |  | ns | (4) |
|  | TAVWH | Address Valid to End of Write | 80 |  | ns | (4) |

NOTES:

| (1) | All devices tested at worst case limits. |
| :--- | :--- |
| (2) | Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in $\mathrm{ICCOP} ; \mathrm{VI}=\mathrm{VCC}$ or GND . |
| (3) | Capacitance sampled and guaranteed - not $100 \%$ tested. |
| (4) | Input pulse levels: 0 V to 3.0 V |
| Input rise and fall times: 5 ns | Input and Output timing reference levels: 1.5 V |
|  | Output load: 1 TTL Gate and $\mathrm{CL}=100 \mathrm{pF}$ (including scope and jig) |

## Read Cycle



NOTE: $\bar{W}$ IS HIGH FOR A READ CYCLE

Addresses must remain stable for the duration of the read cycle. To read, $\bar{G}$ and $\bar{E}$ must be $\leqslant \mathrm{VIL}$ and $\overline{\mathrm{W}} \geqslant \mathrm{VIH}$. The output buffers can be controlled independently by $\bar{G}$ while $\bar{E}$ is low. To execute consecutive
read cycles, Emay be tied low continuously until all desired locations are accessed. When Eis low, addresses must be driven by stable logic levels and must not be in the high impedance state.

Write Cycle I


## NOTE: $\bar{G}$ IS LOW THROUGHOUT WRITE CYCLE

To write, addresses must be stable, $\bar{E}$ low and $\bar{W}$ falling low for a period no shorter than TWLWH. Data in is referenced with the rising edge of $\bar{W}$. (TDVWH and TWHDX). While addresses are changing, $\bar{W}$ must be high. When $\bar{W}$ falls low, the I/O pins are still in the output state for a period of TWLQZ and input data of the opposite phase to
the outputs must not be applied. (Bus contention). If Etransitions low simultaneously with the $\bar{W}$ line transitioning low or after the $\bar{W}$ transition, the output will remain in a high impedance state. $\bar{G}$ is held continuously low.


In this write cycle $\bar{G}$ has control of the output after a period, TGHQZ. $\bar{G}$ switching the output to a high impedance state allows data in to be applied without bus contention after TGHQZ. When $\bar{W}$ transitions high, the data in can change after TWHDX to complete the write cycle.

## $2048 \times 8$ Asynchronous <br> CMOS Static RAM

Advance Information

## Features

- FAST ACCESS TIME
- LOW STANDBY CURRENT

LOW OPERATING CURRENT

- DATA RETENTION © 2.0 VOLTS
- TTL COMPATIBLE INPUTS AND OUTPUTS
- TOSHIBA 5516/HITACHI 6117 PINOUT - TWO CHIP ENABLE INPUTS

NO CLOCKS OR STROBES REQUIRED

- WIDE TEMPERATURE RANGE
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- EQUAL CYCLE AND ACCESS TIME
- SINGLE 5 VOLT SUPPLY
- GATED INPUTS - NO PULL-UP OR PULL-DOWN

RESISTORS ARE REQUIRED

## Description

The HM-65172 is a CMOS $2048 \times 8$ Static Random Access Memory manufactured using the HARRIS advanced SAJI V process. The device utilizes asynchronous circuit design for fast cycle time and ease of use. The pinout is a 24 -pin, industry standard which allows easy memory board layouts flexible to accommodate a variety of industry standard PROMs, RAMs, ROMs and EPROMs. The HM-65172 is ideally suited for use in microprocessor based systems with its 8 bit word length organization. Gated inputs lower operating current and also eliminate the need for pull-up or pull-down resistors. The HM-65172 features two chip enables; $\bar{E}_{1}$ for fast memory access and $\bar{E}_{2}$ for low power applications where battery operation or battery back-up for nonvolatility are required.

## Pinouts

TOP VIEW

| A7 1 | 24 VCC |
| :---: | :---: |
| A6 2 | 235 A8 |
| A5 3 | 22.4 Ag |
| A4 4 | 21. |
| A3 5 | 20 - $\bar{E}_{1}$ |
| A2 6 | 19 A10 |
| A1. 7 | 18 - $\bar{E}_{2}$ |
| AO 8 | $17 \square$ DO7 |
| DOO 9 | 16 DQ6 |
| DO1 10 | 15 D05 |
| DQ2 11 | 14 DQ4 |
| GND 12 | 13 DQ3 |

PIN NAMES
Address Input Data Input/Output Chip Enable Write Enable No Connect


## Functional Diagram



# Specifications HM-65172B-2 

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3t0 8.0V | Operating Supply Voltage |  |
| Input or Output Voltage Applied | (GND -0.3V) | Mililary ( -2 ) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Military (-2) | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS


NOTES: (1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; $\mathrm{VI}=\mathrm{VCC}$ or GND.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: OV to 3.0 V Input and Output timing reference levels: 1.5 V Input rise and fall times: 5 ns Output load: 1TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3t08.0V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Military ( -2 ) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Military ( -2 ) | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS


NOTES: (1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; $\mathrm{VI}=\mathrm{VCC}$ or GND.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: OV to 3.0 V Input and Output timing reference levels: 1.5 V Input rise and fall times: 5 ns Output load: 1TTL Gate and $C_{L}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Military (-2) | 4.5 V to 5.5V |
|  | to (VCC + 0.3V) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Military (-2) | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB1 | Standby Supply Current |  | 1000 | $\mu \mathrm{A}$ | $\overline{E_{2}}=V C C-0.2 V$ <br> OTHER INPUTS = $0.2 \mathrm{~V} \text { or VCC }-0.2 \mathrm{~V}$ |
|  | ICC | Enabled Supply Current |  | 70 | mA | $\overline{E_{1}}, \overline{E_{2}}=$ VIL. $10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 70 | mA | $\begin{aligned} \overline{E_{1}}, \overline{E_{2}} & =\text { VIL, } 10=0 \\ f & =1 \mathrm{MHz} \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 400 | $\mu \mathrm{A}$ | $\begin{gathered} 10=0, V C C=2.0 \\ \overline{E_{1}}, \overline{E_{2}}=V C C-0.3 V \end{gathered}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | V |  |
|  | II | Input Leakage Current | -5.0 | +5.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
|  | 1102 | Input/Output Leakage Current | -5.0 | +5.0 | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq$ VCC |
|  | VIL | Input Low Voltage | -0.3 | +0.8 | $V$ |  |
|  | VIH | Input High Voltage | 2.2 | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | $\begin{aligned} & V \\ & V \end{aligned}$ |  |
|  | VOL | Output Low Voltage |  | 0.4 | V | $10=4.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8 | pF | $\begin{gathered} V I=V C C \text { or } G N D \\ f=1 \mathrm{MHz} \end{gathered}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10 | pF | $\begin{gathered} V I O=V C C \text { or GND, } \\ f=1 \mathrm{MHz} \end{gathered}$ |
| READ CYCLE | TAVAV | Read Cycle Time | 120 |  | ns | (4) |
|  | TAVQV | Address Access Time |  | 120 | ns | (4) |
|  | TEILQV | $\overline{E_{1}}$ to Output Valid |  | 100 | ns | (4) |
|  | TE2LQV | $\bar{E}_{2}$ to Output Valid |  | 120 | ns | (4) |
|  | TE1LQX | $\bar{E}_{1}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE2LQX | $\overline{E_{2}}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE1HQZ | E Disable to Output in High Z |  | $45$ | ns | (4) |
|  | TE2HQZ | E $\bar{E}_{2}$ Disable to Output in High Z |  | 50 | ns | (4) |
|  | TAVQX | Output Hold from Address Change | 5 |  | ns | (4) |
| A.C. <br> WRITE CYCLE | TAVAV | Write Cycle Time | 120 |  | ns | (4) |
|  | TE1LWH | $\overline{E_{1}}$ to End of Write | 65 |  | ns | (4) |
|  | TE2LWH | $\bar{E}_{2}$ to End of Write | 70 |  | ns | (4) |
|  | TAVWL | Address Setup Time | 10 |  | ns | (4) |
|  | TAVWH | Address Valid to End of Write | 105 |  | ns | (4) |
|  | TWLWH | Write Pulse Width | 70 |  | ns | (4) |
|  | TWHAV | Write Recovery Time | 10 |  | ns | (4) |
|  | TWLQZ | Write to Output in High Z |  | 50 | ns | (4) |
|  | TDVWH | Data to Write Time Overlap | 35 |  | ns | (4) |
|  | TWHDX | Data Hold from Write Time | 15 |  | ns | (4) |
|  | TWHQX | Output Active from End of Write | 0 |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; VI $=$ VCC or GND.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: 0 V to 3.0 V Input and Output timing reference levels: 1.5 V Input rise and fall times: 5 ns Output load: 1TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3t0 8.0 V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Industrial (-9) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Industrial (-9) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS


NOTES: (1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; VI $=$ VCC or GND.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: 0 V to 3.0 V Input and Output timing reference levels: 1.5 V Input rise and fall times: 5 ns Output load: 1TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE <br> Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3 to 8.0V |  |  |
| Input or Output Voltage Applied | (GND-0.3V) | Industrial (-9) | 4.5V to 5.5V |
|  | to (VCC +0.3V) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Industrial (-9) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB1 | Standby Supply Current |  | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \bar{E}_{2}=\text { VCC }-0.2 \mathrm{~V} \\ & \text { OTHER INPUTS }= \\ & 0.2 \mathrm{~V} \text { or VCC }-0.2 \mathrm{~V} \end{aligned}$ |
|  | ICC | Enabled Supply Current |  | 70 | mA | $\bar{E}_{1}, \bar{E}_{2}=$ VIL. $10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 70 | mA | $\begin{aligned} \bar{E}_{1}, \bar{E}_{2} & =\text { VIL, } 10=0 \\ f & =1 \mathrm{MHz} \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & \frac{10}{}=0, V C C=2.0 \\ & E_{1}, E_{2}=V C C-0.3 V \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | $v$ |  |
|  | II | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
|  | 1102 | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq$ VCC |
|  | VIL | Input Low Voltage | -0.3 | +0.8 | V |  |
|  | VIH | Input High Voltage | 2.2 | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ |  |
|  | VOL | Output Low Voltage |  | 0.4 | v | $10=4.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | v | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8 | pF | $\begin{gathered} V I=V C C \text { or } G N D, \\ f=1 M H z \end{gathered}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10 | pF | $\begin{gathered} V I O=V C C \text { or GND }, \\ f=1 M H z \end{gathered}$ |
| $\begin{aligned} & \text { READ } \\ & \text { CYCLE } \end{aligned}$ | tavav | Read Cycle Time | 70 |  | ns | (4) |
|  | TAVQV | Address Access Time |  | 70 | ns | (4) |
|  | TE1LQV | $\bar{E}_{1}$ to Output Valid |  | 40 | ns | (4) |
|  | TE2LQV | $\bar{E}_{2}$ to Output Valid |  | 70 | ns | (4) |
|  | TE1LQX | $\bar{E}_{1}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE2LQX | $\bar{E}_{2}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE1H0Z | E $\bar{E}_{1}$ Disable to Output in High Z |  | 35 | ns | (4) |
|  | TE2HQZ | $\mathrm{E}_{2}$ Disable to Output in High Z |  | 40 | ns | (4) |
|  | TAVQX | Output Hold from Address Change | 5 |  | ns | (4) |
| A.C.WRITECYCLE | TAVAV | Write Cycle Time | 70 |  | ns | (4) |
|  | TE1LWH | $\bar{E}_{1}$ to End of Write | 45 |  | ns | (4) |
|  | TE2LWH | $\bar{E}_{2}$ to End of Write | 50 |  | ns | (4) |
|  | TAVWL | Address Setup Time | 10 |  | ns | (4) |
|  | TAVWH | Address Valid to End of Write | 65 |  | ns | (4) |
|  | TWLWH | Write Pulse Width | 40 |  | ns | (4) |
|  | twhav | Write Recovery Time | 10 |  | ns | (4) |
|  | TWLQZ | Write to Output in High Z |  | 40 | ns | (4) |
|  | TDVWH | Data to Write Time Overlap | 30 |  | ns | (4) |
|  | TWHDX | Data Hold from Write Time | 15 |  | ns | (4) |
|  | TWHQX | Output Active from End of Write | 0 |  | ns | (4) |

NOTES:
(1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; VI $=\mathrm{VCC}$ or GND.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: 0 V to 3.0 V Input and Output timing reference levels: 1.5 V Input rise and fall times: 5 ns Output load: 1TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3t08.0V | Operating Supply Voltage |  |
| Input or Output Voltage Applied | (GND -0.3V) | Industrial (-9) | 4.5V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Industrial (-9) | $-40^{\circ} \mathrm{Cto}+85^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB1 | Standby Supply Current |  | 100 | $\mu \mathrm{A}$ | $\overline{\bar{E}_{2}}=V C C-0.2 V$ <br> OTHER INPUTS = $0.2 \mathrm{~V} \text { or VCC }-0.2 \mathrm{~V}$ |
|  | ICC | Enabled Supply Current |  | 70 | mA | $\overline{E_{1}}, \overline{E_{2}}=$ VIL. $10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 70 | mA | $\begin{aligned} \overline{E_{1}}, \bar{E}_{2} & =\text { VIL, } 10=0 \\ f & =1 \mathrm{MHz} \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 40 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0, V C C=2.0 \\ & \overline{E_{1}}, \overline{E_{2}}=V C C-0.3 V \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | V |  |
|  | II | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
|  | 1102 | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq$ VCC |
|  | VIL | Input Low Voltage | -0.3 | +0.8 | V |  |
|  | VIH | Input High Voltage | 2.2 | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
|  | VOL | Output Low Voltage |  | 0.4 | V | $10=4.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance |  | 8 | pF | $\begin{gathered} V I=V C C \text { or } G N D, \\ f=1 M H z \end{gathered}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10 | pF | $\begin{gathered} V I O=V C C \text { or GND, } \\ f=1 M H z \end{gathered}$ |
| $\begin{aligned} & \text { READ } \\ & \text { CYCLE } \end{aligned}$ | TAVAV | Read Cycle Time | 90 |  | ns | (4) |
|  | TAVQV | Address Access Time |  | 90 | ns | (4) |
|  | TE1LQV | $\bar{E}_{1}$ to Output Valid |  | 70 | ns | (4) |
|  | TE2LQV | $\bar{E}_{2}$ to Output Valid |  | 90 | ns | (4) |
|  | TE1LQX | $\overline{E_{1}}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE2LQX | $\overline{E_{2}}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE1HQZ | $\bar{E}_{1}$ Disable to Output in High Z |  | 45 | ns | (4) |
|  | TE2HQZ | $\bar{E}_{2}$ Disable to Output in High Z |  | 50 | ns | (4) |
|  | TAVQX | Output Hold from Address Change | 5 |  | ns | (4) |
| A.C.WRITECYCLE | TAVAV |  | 90 |  | ns | (4) |
|  | TE1LWH | $\overline{E_{1}}$ to End of Write | 55 |  | ns | (4) |
|  | TE2LWH | $\bar{E}_{2}$ to End of Write | 60 |  | ns | (4) |
|  | TAVWL | Address Setup Time | 10 |  | ns | (4) |
|  | TAVWH | Address Valid to End of Write | 80 |  | ns | (4) |
|  | TWLWH | Write Pulse Width | 55 |  | ns | (4) |
|  | TWHAV | Write Recovery Time | 10 |  | ns | (4) |
|  | TWLQZ | Write to Output in High Z |  | 50 | ns | (4) |
|  | TDVWH | Data to Write Time Overlap | 30 |  | ns | (4) |
|  | TWHDX | Data Hold from Write Time | 15 |  | ns | (4) |
|  | TWHQX | Output Active from End of Write | 0 |  | ns | (4) |

NOTES:
(1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; VI $=\mathrm{VCC}$ or GND.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: 0 V to 3.0 V Input and Output timing reference levels: 1.5 V

Input rise and fall times: 5 ns Output load: 1TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) Input or Output Voltage Applied | $\begin{array}{r} -0.3 \text { to } 8.0 \mathrm{~V} \\ (\mathrm{GND}-0.3 \mathrm{~V}) \end{array}$ |  |  |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Industrial (-9) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. <br> OPE RA | $\begin{aligned} & \text { VCC }= \\ & \text { TING } \\ & \text { E } 9 \text { (1) } \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB1 | Standby Supply Current |  | 1000 | $\mu \mathrm{A}$ | $\begin{aligned} & \hline \bar{E}_{2}=\text { VCC }-0.2 \mathrm{~V} \\ & \text { OTHER INPUTS }= \\ & 0.2 \mathrm{~V} \text { or VCC }-0.2 \mathrm{~V} \end{aligned}$ |
|  | ICC | Enabled Supply Current |  | 70 | mA | $\overline{E_{1}}, \overline{E_{2}}=$ VIL. $10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 70 | mA | $\begin{aligned} \overline{E_{1}}, \overline{E_{2}} & =V I L, 10=0 \\ f & =1 M H z \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 400 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0, V C C=2.0 \\ & \overline{E_{1}}, \overline{E_{2}}=V C C-0.3 V \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | V |  |
|  | 11 | Input Leakage Current | -5.0 | +5.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
|  | 1102 | Input/Output Leakage Current | -5.0 | +5.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VIO} \leq \mathrm{VCC}$ |
|  | VIL | Input Low Voltage | -0.3 | +0.8 | V |  |
|  | VIH | Input High Voltage | 2.2 | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
|  | VOL | Output Low Voltage |  | 0.4 | V | $10=4.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8 | pF | $\begin{gathered} V I=V C C \text { or } G N D \\ f=1 M H z \end{gathered}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10 | pF | $\begin{gathered} \text { VIO }=V C C \text { or GND } \\ f=1 \mathrm{MHz} \end{gathered}$ |
| READ CYCLE | TAVAV | Read Cycle Time | 90 |  | ns | (4) |
|  | TAVQV | Address Access Time |  | 90 | ns | (4) |
|  | TE1LQV | $\bar{E}_{1}$ to Output Valid |  | 70 | ns | (4) |
|  | TE2LQV | $\mathrm{E}_{2}$ to Output Valid |  | 90 | ns | (4) |
|  | TE1LQX | $\overline{E_{1}}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE2LQX | $\overline{\bar{E}_{2}}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE1HQZ | $\bar{E}_{1}$ Disable to Output in High Z |  | 45 | ns | (4) |
|  | TE2HQZ | $\bar{E}_{2}$ Disable to Output in High Z |  | 50 | ns | (4) |
|  | TAVQX | Output Hold from Address Change | 5 |  | ns | (4) |
| A.C.WRITECYCLE | TAVAV | Write Cycle Time | 90 |  | ns | (4) |
|  | TE1LWH | $\bar{E}_{1}$ to End of Write | 55 |  | ns | (4) |
|  | TE2LWH | $\bar{E}_{2}$ to End of Write | 60 |  | ns | (4) |
|  | TAVWL | Address Setup Time | 10 |  | ns | (4) |
|  | TAVWH | Address Valid to End of Write | 80 |  | ns | (4) |
|  | TWLWH | Write Pulse Width | 55 |  | ns | (4) |
|  | TWHAV | Write Recovery Time | 10 |  | ns | (4) |
|  | TWLQZ | Write to Output in High Z |  | 50 | ns | (4) |
|  | TDVWH | Data to Write Time Overlap | 30 |  | ns | (4) |
|  | TWHDX | Data Hold from Write Time | 15 |  | ns | (4) |
|  | TWHQX | Output Active from End of Write | 0 |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; $\mathrm{VI}=\mathrm{VCC}$ or GND.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: 0 V to 3.0 V Input and Output timing reference levels: 1.5 V

Input rise and fall times: 5 ns Output load: 1TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

## Specifications HM-65172S-5

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3t0 8.0 V | Operating Supply Voltage |  |
| Input or Output Voltage Applied | (GND -0.3V) | Commercial ( -5 ) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Commercial (-5) | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS



NOTES: (1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; $\mathrm{VI}=\mathrm{VCC}$ or GND.
(3) Capacitance sampled and guaranteed - not 100\% tested.
(4) Input pulse levels: OV to 3.0 V Input and Output timing reference levels: 1.5 V Input rise and fall times: 5 ns Output load: 1TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3t08.0V | Operating Supply Voltage |  |
| Input or Output Voltage Applied | (GND -0.3V) | Commercial ( -5 ) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Commercial (-5) | $0^{\circ} \mathrm{Cto}+70^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB1 | Standby Supply Current |  | 50 | $\mu \mathrm{A}$ | $\overline{E_{2}}=V C C-0.2 V$ <br> OTHER INPUTS = $0.2 \mathrm{~V} \text { or VCC }-0.2 \mathrm{~V}$ |
|  | ICC | Enabled Supply Current |  | 70 | mA | $\overline{E_{1}}, \overline{E_{2}}=$ VIL. $10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 70 | mA | $\begin{aligned} \overline{E_{1}}, \overline{E_{2}} & =\text { VIL, } 10=0 \\ f & =1 \mathrm{MHz} \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0, V C C=2.0 \\ & \overline{E_{1}}, \bar{E}_{2}=V C C-0.3 V \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | $V$ |  |
|  | 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
|  | 1102 | Input/Output Leakage Current | -1.0 | $+1.0$ | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq$ VCC |
|  | VIL | Input Low Voltage | -0.3 | +0.8 | V |  |
|  | VIH | Input High Voltage | 2.2 | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
|  | VOL | Output Low Voltage |  | 0.4 | V | $10=4.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | $V$ | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8 | $\mathrm{pF}$ | $\begin{gathered} V I=V C C \text { or } G N D \\ f=1 M H z \end{gathered}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10 | pF | $\begin{gathered} \text { VIO }=\text { VCC or GND, } \\ f=1 \mathrm{MHz} \end{gathered}$ |
| $\begin{aligned} & \text { READ } \\ & \text { CYCLE } \end{aligned}$ | TAVAV | Read Cycle Time | 70 |  | ns | (4) |
|  | TAVQV | Address Access Time |  | 70 | ns | (4) |
|  | TE1LQV | $\overline{E_{1}}$ to Output Valid |  | 40 | ns | (4) |
|  | TE2LQV | $\bar{E}_{2}$ to Output Valid |  | 70 | ns | (4) |
|  | TE1LQX | $\bar{E}_{1}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE2LQX | $\bar{E}_{2}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE1HQZ | $\bar{E}_{1}$ Disable to Output in High Z |  | 35 | ns | (4) |
|  | TE2HQZ | $\mathrm{E}_{2}$ Disable to Output in High Z |  | 40 | ns | (4) |
|  | TAVQX | Output Hold from Address Change | 5 |  | ns | (4) |
| A.C.WRITECYCLE |  |  | 70 |  | ns | (4) |
|  | TE1LWH | $\overline{E_{1}}$ to End of Write | 45 |  | ns | (4) |
|  | TE2LWH | $\bar{E}_{2}$ to End of Write | 50 |  | ns | (4) |
|  | TAVWL | Address Setup Time | 10 |  | ns | (4) |
|  | TAVWH | Address Valid to End of Write | 65 |  | ns | (4) |
|  | TWLWH | Write Pulse Width | 40 |  | ns | (4) |
|  | TWHAV | Write Recovery Time | 10 |  | ns | (4) |
|  | TWLQZ | Write to Output in High Z |  | 40 | ns | (4) |
|  | TDVWH | Data to Write Time Overlap | 30 |  | ns | (4) |
|  | TWHDX | Data Hold from Write Time | 15 |  | ns | (4) |
|  | TWHQX | Output Active from End of Write | 0 |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in $I C C O P ; \mathrm{VI}=\mathrm{VCC}$ or GND .
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: 0 V to 3.0 V Input and Output timing reference levels: 1.5 V

Input rise and fall times: 5 ns Output load: 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (including scope and jig)

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC - GND) | -0.3t08.0V | Operating Supply Voltage |  |
| Input or Output Voltage Applied | (GND -0.3V) | Commercial ( -5 ) | 4.5 V to 5.5 V |
|  | to (VCC +0.3 V ) $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Operating Temperature |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ | Commercial ( -5 ) | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings'" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |  |
| D.C. | ICCSB1 | Standby Supply Current |  | 100 | $\mu \mathrm{A}$ | $\overline{E_{2}}=V C C-0.2 V$ <br> OTHER INPUTS = $0.2 \mathrm{~V} \text { or VCC }-0.2 \mathrm{~V}$ |
|  | ICC | Enabled Supply Current |  | 70 | mA | $\overline{E_{1}}, \overline{E_{2}}=$ VIL. $10=0$ |
|  | ICCOP | Operating Supply Current (2) |  | 70 | mA | $\begin{aligned} \overline{E_{1}}, \overline{E_{2}} & =\text { VIL, } 10=0 \\ f & =1 \mathrm{MHz} \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 40 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0, V C C=2.0 \\ & \overline{E_{1}}, \overline{E_{2}}=V C C-0.3 V \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  | V |  |
|  | II | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
|  | 1102 | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq$ VCC |
|  | VIL | Input Low Voltage | -0.3 | $+0.8$ | V |  |
|  | VIH | Input High Voltage | 2.2 | $\begin{aligned} & \text { VCC } \\ & +0.3 \end{aligned}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
|  | VOL | Output Low Voltage |  | 0.4 | V | $10=4.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | Cl | Input Capacitance (3) |  | 8 | pF | $\begin{gathered} V I=V C C \text { or } G N D, \\ f=1 \mathrm{MHz} \end{gathered}$ |
|  | ClO | Input/Output Capacitance (3) |  | 10 | pF | $\begin{gathered} V I O=V C C \text { or GND }, \\ f=1 \mathrm{MHz} \end{gathered}$ |
| $\begin{aligned} & \text { READ } \\ & \text { CYCLE } \end{aligned}$ | TAVAV | Read Cycle Time | 90 |  | ns | (4) |
|  | TAVQV | Address Access Time |  | 90 | ns | (4) |
|  | TE1LQV | $\overline{E_{1}}$ to Output Valid |  | 70 | ns | (4) |
|  | TE2LQV | $\overline{E_{2}}$ to Output Valid |  | 90 | ns | (4) |
|  | TE1LQX | $\overline{E_{1}}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE2LQX | $\overline{E_{2}}$ to Output in Low Z | 0 |  | ns | (4) |
|  | TE1HQZ | $\bar{E}_{1}$ Disable to Output in High Z |  | $45$ | ns | (4) |
|  | TE2HQZ | $\overline{E_{2}}$ Disable to Output in High Z |  | 50 | ns | (4) |
|  | TAVQX | Output Hold from Address Change | 5 |  | ns | (4) |
| A.C.WRITECYCLE | TAVAV | Write Cycle Time | 90 |  | ns | (4) |
|  | TE1LWH | $\bar{E}_{1}$ to End of Write | 55 |  | ns | (4) |
|  | TE2LWH | $\bar{E}_{2}$ to End of Write | 60 |  | ns | (4) |
|  | TAVWL | Address Setup Time | 10 |  | ns | (4) |
|  | TAVWH | Address Valid to End of Write | 80 |  | ns | (4) |
|  | TWLWH | Write Pulse Width | 55 |  | ns | (4) |
|  | TWHAV | Write Recovery Time | 10 |  | ns | (4) |
|  | TWLQZ | Write to Output in High Z |  | 50 | ns | (4) |
|  | TDVWH | Data to Write Time Overlap | 30 |  | ns | (4) |
|  | TWHDX | Data Hold from Write Time | 15 |  | ns | (4) |
|  | TWHQX | Output Active from End of Write | 0 |  | ns | (4) |

NOTES: (1) All devices tested at worst case limits.
(2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; $\mathrm{VI}=\mathrm{VCC}$ or GND.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) Input pulse levels: 0 V to 3.0 V Input and Output timing reference levels: 1.5 V
input rise and fall times: 5 ns Output load: 1TTL Gate and $C_{L}=100 \mathrm{pF}$ (including scope and jig)

Read Cycle



Writing data into the memory requires an overlap of $\overline{\mathrm{E}_{1}}, \overline{\mathrm{E}_{2}}$ and $\overline{\mathrm{W}}$. When $\bar{E}_{1}$ or $\overline{\mathrm{E}_{2}}$ transition low simultaneously with the $\overline{\mathrm{W}}$ low transition, or after $\bar{W}$ transitions low, the outputs will remain in a high impedance state. After $\bar{W}$ transitions high and if $\bar{E}_{1}$ and $\bar{E}_{2}$ are low, the $D Q$ pins are in the output
state. Care must be taken when applying data input at this time. Data of opposite phase must not be applied when the DQ lines are in the output state. Also, during TWLQZ, the DQ pins are in the output state and data of opposite phase must not be applied.

## Truth Table

| $\overline{E_{2}}$ | $\overline{E_{1}}$ | $\bar{W}$ | $\mathbf{D}$ | $\mathbf{Q}$ | ICC | MODE |
| :--- | :---: | :---: | :---: | :---: | :--- | :--- |
| $H$ | $X$ | $X$ | $Z$ | $Z$ | ISB | $\overline{E_{2}}=$ VIH; Deselect |
| $H$ | $X$ | $X$ | $Z$ | $Z$ | ISB1 | $\overline{E_{2}} \geq$ VCC $=0.3 ;$ <br> Deselect |
| L | L | $H$ | $Z$ | VALID | ICC | Read |
| L | L | L | VALID | $Z$ | ICC | Write |
| $X$ | $H$ | $X$ | $Z$ | $Z$ | ICC | Deselect |

## Low Voltage Data Retention

Harris CMOS RAMs are designed with battery backup in mind. Data retention voltage and supply current are guaranteed over temperature. The following rules insure data retention:

1. Chip Enable ( $\overline{\mathrm{E}_{2}}$ ) must be held high during data retention; within VCC to VCC +0.3 V .
2. On RAMs which have two chip enables, one of the enables should be held in the deselected state to keep the RAM outputs high impedance, minimizing power dissipation.
3. Inputs which are to be held high, must be kept between VCC +0.3 V and $70 \%$ of VCC during the power up and power down transitions.
4. The RAM can begin operation $>55 \mathrm{~ns}$ after VCC reaches the minimum operating voltage ( 4.5 volts).

## DATA RETENTION TIMING



## Features

- LOW STANDBY CURRENT
- Low operating current
- fast address access time

45/55/70 ns

- LOW VOLTAGE DATA RETENTION @ 2.0V
- cmos/ttl Compatible inputs and outputs
- Jedec approved pinout
- EQUAL CYCLE AND ACCESS TIMES
- no clocks or strobes required
- SINGLE 5 VOLT SUPPLY
- GATED INPUTS-NO PULL-UP OR PULL-DOWN

RESISTORS REQUIRED

- WIDE temperature range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- EASY MICROPROCESSOR INTERFACING


## Description

The HM-65262 is a CMOS $16384 \times 1$ Static Random Access Memory manufactured using Harris' advanced SAJI-VI process. The device utilizes asynchronous circuit design for fast cycle time and ease of use. The pinout is the JEDEC 20 -pin, 0.300 -inch wide standard, providing high board-level packing density. Gated inputs lower operating current and also eliminate the need for pull-up or pull-down resistors.

## Pinouts

TOP VIEW


## Functional Diagram



[^2]НМ-6564

## 8K x 8, 16K x 4 CMOS RAM

## Features

- LOW POWER STANDBY
- LOW POWER OPERATION
- data retention
- tTL COMPATIBLE IN/OUT
- three state outputs
- FAST ACCESS TIME
- FULL MILITARY TEMPERATURE AVAILABLE
- INDUSTRIAL TEMPERATURE STANDARD
- COMMERCIAL temperature available
- ON CHIP ADDRESS REGISTERS
- ORGANIZABLE $8 \mathrm{~K} \times 8$ or $16 \mathrm{~K} \times 4$
- 40 PIN DIP PINOUT $-2.000^{\prime \prime} \times \mathbf{0 . 9 0 0 ^ { \prime \prime }}$


## Description

The HM-6564 is a 64 K bit CMOS RAM. It consists of $16 \mathrm{HM} 4-65044 \mathrm{~K} \times 1$ CMOS RAMs, in leadless carriers, mounted on a ceramic substrate. The HM6564 is configured as an extra wide, standard length 40 pin DIP. The memory appears to the system as an array of $164 \mathrm{~K} \times 1$ static RAMs. The array is organized as two 8 K by 4 blocks of RAM sharing only the address bus. The data inputs, data outputs, chip enables and write enables are separate for each block of RAM. This allows the user to organize the HM-6564 RAM as either an 8 K by 8 or a 16 K by 4 array. The HM-6564 also contains decoupling capacitors to reduce noise and to minimize the need for additional external decoupling.
This 64 K memory provides a unique blend of low power CMOS semiconductor technology and advanced packaging techniques. The HM-6564 is intended for use in any application where a large amount of RAM is needed, and where power consumption and board space are prime concerns. The guaranteed low voltage data retention characteristics allow easy implementation of nonvolatile read/write memory by using very small batteries mounted directly on the memory circuit board. Example applications include digital avionic instrumentation, remote data acquisition, and portable or hand held digital communications devices.

4mW MAX
$280 \mathrm{~mW} / \mathrm{MHz}$ MAX 2.0V MIN

350ns MAX
$-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
$0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$

Pinout

## Functional Diagram



## Organization Guide

## To Organize 8K x 8:

| Connect: | $\bar{E} 1$ with $\bar{E} 3$ | (Pins $9+32$ ) |
| :--- | :--- | :--- |
|  | $\bar{E} 2$ with $\bar{E} 4$ | (Pins $12+29$ ) |
|  | $\bar{W} 1$ with $\bar{W} 2$ | (Pins $11+31$ ) |

## To Organize $16 \mathrm{~K} \times 4$ :

| Connect: | Q0 with 04 | (Pins $2+39$ ) |
| :---: | :---: | :---: |
|  | D0 with D4 | (Pins $3+38$ ) |
|  | Q1 with 05 | (Pins $4+37$ ) |
|  | D1 with D5 | (Pins $5+36$ ) |
|  | D2 with D6 | (Pins $16+25$ ) |
|  | Q2 with Q6 | (Pins $17+24$ ) |
|  | D3 with D7 | (Pins $18+23$ ) |
|  | Q3 with Q7 | (Pins $19+22$ ) |
| Optional | $\overline{\mathrm{W}} 1$ may be common with $\bar{W} 2$ | (Pins $11+31$ ) |

## Concerns for Proper Operation of Chip Enables:

The transition between blocks of RAM requires a change in the chip enable being used. When operating in the $8 \mathrm{~K} \times 8$ mode, use the chip enables as if there were only two, $\overline{\mathrm{E}} 1$ and $\overline{\mathrm{E}} 2$. In the $16 \mathrm{~K} \times 4$ mode, all chip enables must be treated separately. Transitions between chip enables must be treated with the same timing constraints that apply to any one chip enable. All chip enables must be high at least one chip enable high time (TEHEL) before any chip enable can fall. More than one chip enable low simultaneously, for devices whose outputs are tied common either internally or externally, is an illegal input condition and must be avoided.

## Printed Circuit Board Mounting:

The leadless chip carrier packages used in the HM-6564 have conductive lids. These lids are electrically floating, not connected to VCC or GND. The designer should be aware of the possibility that the carriers on the bottom side could short conductors below if pressed completely down against the surface of the circuit board. The pins on the package are designed with a standoff feature to help prevent the leadless carriers from touching the circuit board surface.

Printed circuit board real estate is a costly commodity. Actual board costs depend on layout tolerances, density, complexity, number of layers, choice of board material, and other factors.

The following table compares board space for 16 standard DIP 4K RAMs to the HM-6564 RAM array. Both fine line, close tolerance layout and standard "easy" layout board sizes are shown in the comparison.

64K ARRAY OF 16 4K RAMs ON A PC BOARD
vs. THE HM-6564

| PACKAGE | CIRCUIT SUBSTRATE | SIZE |
| :---: | :---: | :---: |
| 18 Pin DIP | Standard <br> Two Sided PCB | 12 to $15 \mathrm{sq} . \mathrm{in}$. |
| 18 Pin DIP | Fine Line or <br> Multilayer PCB | 9 to $11 \mathrm{sq} . \mathrm{in}$. |
| Leadless Carrier | Multilayer <br> Alumina Substrate | 3 to $5 \mathrm{sq} . \mathrm{in}$. |
| HM5-6564 | Two Sided Mounting <br> Multilayer <br> Alumina Substrate | $2 \mathrm{sq}. \mathrm{in}$. |

The cost of semiconductor circuits decline with time. If actual costs were included, they would be out of date in a very short time. We urge you to contact your local Harris office or sales representative for accurate pricing allowing cost tradeoff analysis. In your cost analysis, also consider
the advantages of a lighter, smaller overall package for your system. Consider how much more valuable your system will be when the memory array size is decreased to about $1 / 6$ of normal size.


HM-6564 - 64K BIT CMOS RAM

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC - GND) | -0.3 V to +8.0V | Operating Supply Voltage |  |
| Input or Output Voltage Applied | $\begin{aligned} & \text { (GND -0.3V) } \\ & \text { to (VCC }+0.3 \mathrm{~V}) \end{aligned}$ | Military (-2)/Industrial (-9) Operating Temperature | +4.5 V to +5.5 V |
| Storage Temperature | $-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Military (-2) | -550 C to +1250 C |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



NOTES:
(1) This value is guaranteed and tested at $25^{\circ} \mathrm{C}$.
(2) Operating supply current is proportional to operating frequency. ICCOP is specified at an operating frequency of 1 MHz , indicating repetitive accessing at a $1 \mu \mathrm{~s}$ rate. Operation at slower rates will decrease ICCOP proportionally.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.

| ABSOLUTE MAXIMUM RATINGS* |  | OPERATING RANGE Operating Supply Voltage |  |
| :---: | :---: | :---: | :---: |
| Supply Voltage - (VCC - GND) | -0.3V to +8.0V |  |  |
| Input or Output Voltage Applied | (GND -0.3V) | Industrial (-9) | +4.5 to +5.5V |
|  | to (VCC +0.3 V ) | Operating Temperature |  |
| Storage Temperature | -650 C to $+150{ }^{\circ} \mathrm{C}$ | Industrial (-9) | -400 C to $+85^{\circ} \mathrm{C}$ |

[^3]
## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. \& VCC = OPERATING RANGE |  | $\left.\begin{gathered} \\ \text { TEMP. }=25{ }^{\circ}{ }^{(1)} \\ \text { VCC }=5.0 \mathrm{~V} \end{gathered} \right\rvert\,$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MAX |  |  |
|  | ICCSB | Standby Supply Current |  | 800 | 48 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & V I=V C C \text { or GND } \end{aligned}$ |
|  | ICCOP1 | Operating Supply <br> Current ( $8 \mathrm{~K} \times 8$ ) |  | 56 |  | mA | $\begin{aligned} & E=1 \mathrm{MHz}, I O=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | ICCOP2 | Operating Supply <br> Current (16K x 4) |  | 28 |  | mA | $\begin{aligned} & E=1 \mathrm{MHz}, I O=0 \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | ICCDR | Data Retention Supply Current |  | 400 | 32 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0, V C C=2.0, \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | VCCDR | Data Retention Supply Voltage | 2.0 |  |  | V |  |
|  | IIA | Address Input Leakage | -20 | +20 |  | $\mu A$ | GND |
|  | IID1 | Data Input Leakage $(8 \mathrm{~K} \times 8)$ | -3 | +3 |  | $\mu A$ | GND |
|  | IID2 | Data Input Leakage (16K x 4) | -5 | +5 |  | $\mu \mathrm{A}$ | GND $\leqslant$ VI |
|  | IIE1 | Enable Input Leakage ( $8 \mathrm{~K} \times 8$ ) | -10 | +10 |  | $\mu \mathrm{A}$ | GND |
|  | IIE2 | Enable Input Leakage (16K $\times 4$ ) | -5 | +5 |  | $\mu \mathrm{A}$ | GND |
| D.C. | IIW | Write Enable Input Leakage (Each) | -10 | +10 |  | $\mu \mathrm{A}$ | GND |
|  | 1021 | Output Leakage ( $8 \mathrm{~K} \times 8$ ) | -5 | +5 |  | $\mu \mathrm{A}$ | GND |
|  | IOZ2 | Output Leakage ( $16 \mathrm{~K} \times 4$ ) | -10 | +10 |  | $\mu A$ | GND |
|  | VIL | Input Low Voltage | -0.3 | 0.8 |  | V |  |
|  | VIH | Input High Voltage | VCC-2.0 | VCC +0.3 |  | V |  |
|  | VOL | Output Low Voltage |  | 0.4 |  | V | $10=2.0 \mathrm{~mA}$ |
|  | VOH | Output High Voltage | 2.4 |  |  | V | $10=-1.0 \mathrm{~mA}$ |
|  | CIA | Address Input Capacitance |  | 200 |  | pF | $\begin{aligned} & f=1 \mathrm{MHz}, \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | CID1 | Data Input Capacitance ( $8 \mathrm{~K} \times 8$ ) (3) |  | 50 |  | pF | $\begin{aligned} & f=1 \mathrm{MHz}, \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | CID2 | Data Input <br> Capacitance (16K $\times 4$ ) |  | 100 |  | pF | $\begin{aligned} & f=1 \mathrm{MHz}, \\ & V I=V C C \text { or GND } \end{aligned}$ |
|  | CIE1 | Enable Input Capacitance ( $8 \mathrm{~K} \times 8$ ) |  | 160 |  | pF | $\begin{aligned} & f=1 \mathrm{MHz}, \\ & V I=V C C \text { or GND } \end{aligned}$ |
|  | CIE2 | Enable Input <br> Capacitance (16K $\times 4$ ) |  | 80 |  | pF | $\begin{aligned} & f=1 \mathrm{MHz}, \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | CIW | Write Enable Input Capacitance (Each) |  | 100 |  | pF | $\begin{aligned} & f=1 \mathrm{MHz}, \\ & V I=V C C \text { or } G N D \end{aligned}$ |
|  | CO1 | Output Capacitance $(8 \mathrm{~K} \times 8)(3)$ |  | 50 |  | pF | $\begin{aligned} & f=1 \mathrm{MHz}, \\ & \text { VO }=\text { VCC or GND } \end{aligned}$ |
|  | $\mathrm{CO2}$ | Output Capacitance (16K x 4) (3) |  | 100 |  | pF | $\begin{aligned} & f=1 \mathrm{MHz}, \\ & \mathrm{VO}=\mathrm{VCC} \text { or GND } \end{aligned}$ |
|  | CVCC | Decoupling Capacitance | . 25 |  |  | $\mu \mathrm{F}$ | $f=1 \mathrm{MHz}$ |

NOTES:
(1) This value is guaranteed and tested at $25^{\circ} \mathrm{C}$.
(2) Operating supply current is proportional to operating frequency. ICCOP is specified at an operating frequency of 1 MHz , indicating repetitive accessing at a $1 \mu \mathrm{~s}$ rate. Operation at slower rates will decrease ICCOP proportionally.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.

## ELECTRICAL CHARACTERISTICS

|  |  |  | TEMP OPE R | $\begin{aligned} & \text { ICC= } \\ & \text { ING } \\ & \text { iE } \end{aligned}$ |  | ES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SYMBOL | PARAMETER | MIN | MAX | UNITS | CONDITIONS |
|  | telov | Chip Enable Access |  | 350 | ns | (4) |
|  | TAVQV | Address Access <br> ( $T A V Q V=T E L Q V+T A V E L$ ) |  | 400 | ns | (4) |
|  | telox | Output Enable | 20 | 120 | ns | (4) |
|  | TEHOZ | Output Disable |  | 120 | ns | (4) |
|  | TELEL | Read or Write Cycle | 480 |  | ns | (4) |
|  | TELEH | Chip Enable Low | 350 |  | ns | (4) |
|  | TEHEL | Chip Enable High | 130 |  | ns | (4) |
|  | tavel | Address Setup | 50 |  | ns | (4) |
| A.C. | telax | Address Hold | 50 |  | ns | (4) |
|  | TWLWH | Write Enable Low | 150 |  | ns | (4) |
|  | TWLEH | Write Enable Setup | 250 |  | ns | (4) |
|  | TWLEL | Early Write Setup (Write Mode) | 10 |  | ns | (4) |
|  | TWHEL | Write Enable Read Setup | 10 |  | ns | (4) |
|  | TELWH | Early Write Hold (Write Mode) | 100 |  | ns | (4) |
|  | tDVWL | Data Setup | 10 |  | ns | (4) |
|  | TDVEL | Early Write Data Setup | 10 |  | ns | (4) |
|  | twLDX | Data Hold | 100 |  | ns | (4) |
|  | TELDX | Early Write Data Hold | 100 |  | ns | (4) |
|  | TOVWL | Data Valid to Write (Read-Modify-Write) | 0 |  | ns | (4) |

NOTES:
(4) AC Test Conditions:

Inputs - Trise $=$ Tfall $\leqq 20 \mathrm{~ns}$.
Outputs - CLOAD $=100 \mathrm{pF}$
Timing measured at 1.5 V reference level.

| ABSOLUTE MAXIMUM RATINGS* | OPERATING RANGE |  |
| :---: | ---: | :--- |
| Supply Voltage - (VCC - GND) | -0.3 V to +8.0 V |  |
| Input or Output Voltage Applied | (GND $-0.3 \mathrm{~V})$ <br> Operating Supply Voltage <br> Commercial ( -5 (VCC $+0.3 \mathrm{~V})$ | Operating Temperature <br> Commercial ( -5 ) |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | +4.5 to +5.5 V |

> * CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS



NOTES:
(1) This value is guaranteed and tested at $25^{\circ} \mathrm{C}$.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(2) Operating supply current is proportional to operating frequency. ICCOP is specified at an operating frequency of 1 MHz , indicating repetitive accessing at a $1 \mu \mathrm{~s}$ rate. Operation at slower rates will decrease ICCOP proportionally.

## Specifications HM-6564-5

## ELECTRICAL CHARACTERISTICS

A.C.

| SYMBOL | PARAMETER | TEMP, \& VCC = OPERATING RANGE |  | UNITS | TEST CONDTIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| TELQV | Chip Enable Access |  | 450 | ns | (4) |
| TAVQV | Address Access (TAVQV=TELQV+TAVEL) |  | 500 | ns | (4) |
| TELQX | Output Enable | 20 | 150 | ns | (4) |
| TEHQZ | Output Disable |  | 150 | ns | (4) |
| TELEL | Read or Write Cycle | 600 |  | ns | (4) |
| TELEH | Chip Enable Low | 450 |  | ns | (4) |
| tehel | Chip Enable High | 150 |  | ns | (4) |
| TAVEL | Address Setup | 50 |  | ns | (4) |
| telax | Address Hold | 50 |  | ns | (4) |
| TWLWH | Write Enable Low | 150 |  | ns. | (4) |
| TWLEH | Write Enable Setup | 250 |  | ns | (4) |
| TWLEL | Early Write Setup (Write Mode) | 10 |  | ns | (4) |
| TWHEL | Write Enable Read Setup | 10 |  | ns | (4) |
| TELWH | Early Write Hold (Write Mode) | 100 |  | ns | (4) |
| TDVWL | Data Setup | 10 |  | ns | (4) |
| TDVEL | Early Write Data Setup | 10 |  | ns | (4) |
| TWLDX | Data Hold | 100 |  | ns | (4) |
| TELDX | Early Write Data Hold | 100 |  | ns | (4) |
| TQVWL | Data Valid to Write (Ready-Modify-Write) | 0 |  | ns | (4) |

NOTES:
(4) AC Test Conditions:

Inputs - Trise $=$ Tfall $\leq 20 n s$.
Outputs - CLOAD $=100 \mathrm{pF}$.
Timing measured at 1.5 V reference level.

## Read Cycle



TRUTH TABLE

| TIME REFERENCE | E |  | A | $\begin{gathered} \text { OUTPUT } \\ 0 \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| -1 | H | X | x | z | MEMORY DISABLED |
| 0 | 2 | H | $v$ | z | CYCLE BEGINS, ADDRESSES ARE LATCHED |
| 1 | L | H | x | $\times$ | OUTPUT ENABLED |
| 2 | L | H | x | v | OUTPUT VALID |
| 3 | $\checkmark$ | H | x | $v$ | READ ACCOMPLISHED |
| 4 | H | x | x | z | PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 5 | 2 | H | $\checkmark$ | z | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS 0) |

The address information is latched in the on chip registers on the falling edge of $\bar{E}(T=0)$. Minimum address set up and hold time requirements must be met. After the required hold time, the addresses may change state without affecting device operation. During time $(T=1)$ the output
becomes enabled but data is not valid until during time ( $T=2$ ). $\bar{W}$ must remain high until after time ( $T=2$ ). After the output data has been read, $\overline{\mathrm{E}}$ may return high ( $T=3$ ). This will disable the output buffer and ready the RAM for the next memory cycle ( $T=4$ ).

Early Write Cycle


The early write cycle is the only cycle where the output is guaranteed not to become active. On the falling edge of $\overline{\mathrm{E}}(\mathrm{T}=0)$, the addresses, the write signal, and the data input are latched in on chip registers. The logic value of $\bar{W}$ at the time $\bar{E}$ falls determines the state of the output buffer for that cycle. Since $\bar{W}$ is low when $\bar{E}$ falls, the output buffer is latched into the high impedance state and
will remain in that state until $\bar{E}$ returns high ( $T=2$ ). For this cycle, the data input is latched by $\bar{E}$ going low; therefore data set up and hold times should be referenced to $\overline{\mathrm{E}}$. When $\bar{E}(T=2)$ returns to the high state the output buffer disables and all signals are unlatched. The device is now ready for the next cycle.


The read modify write cycle begins as all other cycles on the falling edge of $\bar{E}(T=0)$. The $\bar{W}$ line should be high at ( $T=0$ ) in order to latch the output buffers in the active state. During $(T=1)$ the output will be active but not valid until $(T=2)$. On the falling edge of the $\bar{W}(T=3)$ the data present at the output and input are latched. The

W signal also latches itself on its low going edge. All input signals excluding $\bar{E}$ have been latched and have no further effect on the RAM. The rising edge of $\bar{E}(T=5)$ completes the write portion of the cycle and unlatches all inputs and the output. The output goes to a high impedance and the RAM is ready for the next cycle.

## Late Write Cycle



TRUTH TABLE

| TIME REFERENCE |  | $E \quad \frac{\text { iNPUTS }}{W}$ |  | D | $\begin{gathered} \text { OUTPUT } \\ \text { OTS } \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| -1 | H | $\times$ | $\times$ | $\times$ | z | MEmORY DISABLED |
| 0 | 2 | H | $v$ | $\times$ | z | CYCLE BEGINS, ADDresses are latched |
| 1 | L | 2 | $\times$ | $v$ | $\times$ | WRITE BEGINS, DATA IS LATCHED |
| 2 | L | H | $\times$ | $\times$ | $\times$ | WRITE IN PROGRESS INTERNALLY |
| 3 | $\checkmark$ | H | $\times$ | $x$ | $\times$ | WRITE COMPLETED |
| 4 | H | $\times$ | $\times$ | x | z | Prepare for next cycle (SAme as -1) |
| 5 | 2 | н | v | $\times$ | $z$ | cycle ends, next cycle begins (same as o) |

The late write cycle is a cross between the early write cycle and the read-modify-write cycle.
Recall that in the early write the output is guaranteed to remain high impedance, and in the read-modify-write the output is auaranteed valid at access time. The late
write is between these two cases. With this cycle the output may become active, and may become valid data, or may remain active but undefined. Valid data is written into the RAM if data set up, data hold, write setup and write pulse widths are observed.

NOTES: In the above descriptions the numbers in parenthesis ( $T=n$ ) refer to the respective timing diagrams.
The numbers are located on the time reference line below each diagram. The timing diagrams shown are only examples and are not the only valid method of operation.

HM-6504 (One of Sixteen)


## Features

- LOW STANDBY CURRENT
- FAST ADDRESS ACCESS TIME
- DATA RETENTION
- three state outputs
- ORGANIZABLE AS $32 \mathrm{~K} \times 8$ or 16K $\times 16$ ARRAY
- ON CHIP ADDRESS REGISTERS
- 48 PIN DIP PINOUT - $2.53^{\prime \prime} \times 1.30^{\prime \prime} \times 0.29^{\prime \prime}$
- SYNCHRONOUS OPERATION YIELDS
- Low operating power
- WIDE TEMPERATURE RANGE


## Description

The HM-92560 is a high density 256K bit CMOS RAM module. Sixteen synchronous HM-6516 $2 \mathrm{~K} \times 8$ CMOS RAMs in leadless chip carriers are mounted on a multilayer ceramic substrate. The HM-92560 RAM module is organized as two 16 K by 8 CMOS RAM arrays sharing a common address bus. Separate data input/output buses and chip enables allow the user to format the $\mathrm{HM}-92560$ as either a $16 \mathrm{~K} \times 16$ or $32 \mathrm{~K} \times 8$ array. Ceramic capacitors are included on the substrate to reduce noise and to minimize the need for additional external decoupling.
The synchronous design of the HM-92560 provides low operating power along with address latches for ease of interface to multiplexed address/data bus microprocessors.

The HM-92560 is physically constructed as an extra wide 48 pin dual-in-line package with standard $0.1^{\prime \prime}$ centers between pins. This packaging technique combines the high packing density of CMOS and leadless chip carriers with the ease of use of DIP packaging.

Pinout


## Functional Diagram



## Organizational Guide

## FOR 32K x 8 CONFIGURATION

$$
\begin{array}{ll}
\text { CONNECT: } & \text { PIN } 16 \text { (DQ0) to PIN } 33 \text { (DQ8) } \\
& \text { PIN } 17 \text { (DQ1) to PIN } 32 \text { (DQ9) } \\
& \text { PIN } 18 \text { (DQ2) to PIN } 31 \text { (DQ10) } \\
& \text { PIN } 19 \text { (DQ3) to PIN } 30 \text { (DQ11) } \\
& \text { PIN } 20 \text { (DQ4) to PIN } 29 \text { (DQ12) } \\
& \text { PIN } 21 \text { (DQ5) to PIN } 28 \text { (DQ13) } \\
& \text { PIN } 22 \text { (DQ6) to PIN } 27 \text { (DQ14) } \\
& \text { PIN } 23 \text { (DQ7) to PIN } 26 \text { (DQ15) }
\end{array}
$$

## FOR 16K x 16 CONFIGURATION

$$
\begin{array}{ll}
\text { CONNECT: } & \text { PIN } 6 \text { (E1) to PIN } 15 \text { (E9) } \\
& \text { PIN } 7 \text { (E2) to PIN } 24 \text { (E10) } \\
& \text { PIN } 8 \text { (E3) to PIN } 25 \text { (E11) } \\
& \text { PIN } 9 \text { (E4) to PIN } 34 \text { (E12) } \\
& \text { PIN } 10 \text { (E5) to PIN } 35 \text { (E13) } \\
& \text { PIN } 11 \text { (E6) to PIN } 38 \text { (E14) } \\
& \text { PIN } 12 \text { (E7) to PIN } 39 \text { (E15) } \\
& \text { PIN } 14 \text { (E8) to PIN } 40 \text { (E16) } \\
& \text { PIN } 13 \text { (GA) to PIN } 36 \text { (GB) }
\end{array}
$$

## Concerns for Proper Operation of Chip Enables:

The transition between blocks of RAM requires a change in the chip enable being used. When operating in the 16K $\times 16$ mode use the chip enables as if there were only eight, E1 thru E8. In the $32 \mathrm{~K} \times 8$ mode, all chip enables must be treated separately. Transitions between chip enables must be treated with the same timing constraints that apply to any one chip enable. All chip enables must be high at least one
chip enable high time (TEHEL) before any chip enable can fall. As the HM-92560 is a synchrounous memory every address transition must be accompanied by a chip enable transition (see timing diagrams). More than one chip enable low simultaneously, for devices whose outputs are tied common either internally or externally, is an illegal input condition and must be avoided.

## Printed Circuit Board Mounting:

The leadless chip carrier packages used in the HM92560 have conductive lids. These lids are electrically connected to GND. The designer should be aware of the possibility that the carriers on the bottom side could short conductors below if pressed
completely down against the surface of the circuit board. The pins on the package are designed with a standoff feature to help prevent the leadless carriers. from touching the circuit board surface.

## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage (VCC - GND) | -0.3 to 8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-650^{\circ}$ to $150{ }^{\circ} \mathrm{C}$ |

OPERATING RANGE
Operating Supply Voltage
Military (-2, -8)
Industrial (-9)
Operating Temperature
Military (-2, -8)
Industrial (-9)
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

| SYMBOL | PARAMETER | TEMP. \& VCC * OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSB | Standby Supply Current |  | 500 | $\mu \mathrm{A}$ | $10=0$ |
|  |  |  |  |  | $\mathrm{VI}=\mathrm{VCC}$ or GND |
| ICCOP | Operating Supply Current (2) $16 K \times 16$ <br> Operating Supply Current (2) $32 \mathrm{~K} \times 8$ <br> Data Retention Supply Current |  | 30 | mA | $\bar{E}=1 \mathrm{MHz}, 10=0$ |
|  |  |  |  |  | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\overline{\mathrm{G}}=\mathrm{VCC}$ |
| ICCOP |  |  | 15 | mA | $\overline{\mathrm{E}}=1 \mathrm{MHz}, 10=0$ |
|  |  |  |  |  | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\overline{\mathrm{G}}=\mathrm{VCC}$ |
| ICCDR |  |  | 350 | $\mu \mathrm{A}$ | $10=0, V C C=2.0$, |
|  |  |  |  |  | $V I=V C \mathcal{C}$ or GND, $\bar{E}=V C C$ |
| VCCDR <br> II | Data Retention Supply Voltage Input Leakage Current | 2.0 |  | V |  |
|  |  | -5 | +5 | $\mu \mathrm{A}$ | $\mathrm{GND} \leq \mathrm{VI} \leq \mathrm{VCC}$ |
| IIOZ | Input/Output Leakage Current | -5 | +5 | $\mu \mathrm{A}$ | GND $\leq$ VIO $\leq V C C$ |
| VIL | Input Low Voltage | -0.3 | . 8 | V |  |
| VIH | Input High Voltage | VCC | VCC | V |  |
|  |  | -2.0 | +0.3 |  |  |
| VOL | Output Low Voltage |  | 0.4 | V | $10=3.2 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | V | $10=-1.0 \mathrm{~mA}$ |
| CIA | Address Input (3) |  | 200 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND |
|  | Capacitance |  |  |  | $f=1 \mathrm{MHz}$ |
| CIE1 | Enable Input (3) |  | 100 | pF | $\mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}$ |
|  | Capacitance (16K $\times 16$ ) |  |  |  | $f=1 \mathrm{MHz}$ |
| CIE2 | Enable Input (3) |  | 50 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND |
|  | Capacitance ( $32 \mathrm{~K} \times 8$ ) |  |  |  | $f=1 \mathrm{MHz}$ |
| CIG 1 | Output Enable Input (3) Capacitance ( $16 \mathrm{~K} \times 16$ ) |  | 150 | pF | $\begin{aligned} & V I=V C C \text { or GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| CIG 2 | Output Enable Input (3) |  | 100 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND |
|  | Capacitance ( $32 \mathrm{~K} \times 8$ ) |  |  |  | $\mathrm{f}=1 \mathrm{MHz}$ |
| $\mathrm{ClO1}$ | Input/Output (3) |  | 150 | pF | VI/O = VCC or GND |
|  | Capacitance ( $16 \mathrm{~K} \times 16$ ) |  |  |  | $f=1 \mathrm{MHz}$ |
| ClO 2 | Input/Output (3) |  | 250 | pF | VIIO $=$ VCC or GND |
|  | Capacitance ( $32 \times 8$ ) |  |  |  | $f=1 \mathrm{MHz}$ |
| CIW | Write Input (3) |  | 200 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND |
|  | Capacitance |  |  |  | $f=1 \mathrm{MHz}$ |
| CVec | Decoupling |  | . 5 | $\mu \mathrm{f}$ | $f=1 \mathrm{MHz}$ |
|  | Capacitance |  |  |  |  |

## ABSOLUTE MAXIMUM RATINGS*

Supply Voltage (VCC - GND)
Input or Output Voltage Applied
Storage Temperature

## OPERATING RANGE

| Operating Supply Voltage |  |
| :--- | ---: |
| Military $(-2,-8)$ | 4.5 V to 5.5 V |
| Industrial $(-9)$ | 4.5 V to 5.5 V |
| Operating Temperature | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Military $(-2,-8)$ | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" mav cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP <br> OPE <br> RAN | VCC * <br> TING <br> (1) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | UNITS | CONDITIONS |
| A.C. | TELQV | Chip Enable Access Time |  | 150 | ns | (4) |
|  | TAVQV | Address Access Time |  | 170 | ns | (4) |
|  | TELQX | Chip Enable Output Enable Time | 10 |  | ns | (4) |
|  | TWLQZ | Write Enable Output Disable Time |  | 70 | ns | (4) |
|  | TEHQZ | Chip Enable Output Disable Time |  | 70 | ns | (4) |
|  | TGLQX | Output Enable Output Enable Time | 10 |  | ns | (4) |
|  | TGLQV | Output Enable Output Valid Time |  | 70 | ns | (4) |
|  | TGHQZ | Output Enable Output Disable Time |  | 70 | ns | (4) |
|  | TELEH | Chip Enable Pulse Negative Width | 150 |  | ns | (4) |
|  | TEHEL | Chip Enable Pulse Positive Width | 80 |  | ns | (4) |
|  | TAVEL | Address Setup Time | 20 |  | ns | (4) |
|  | TELAX | Address Hold Time | 50 |  | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 150 |  | ns | (4) |
|  | TWLEH | Write Enable Pulse Setup Time | 150 |  | ns | (4) |
|  | TELWH | Write Enable Pulse Hold Time | 150 |  | ns | (4) |
|  | TDVWH | Data Setup Time | 80 |  | ns | (4) |
|  | TWHDX | Data Hold Time | 20 |  | ns | (4) |
|  | TWLDV | Write Data Delay Time | 70 |  | ns | (4) |
|  | TELEL | Read or Write Cycle Time | 230 |  | ns | (4) |

## NOTES:

(1) All devices tested at worst case limits.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions:

Input Pulse Levels: 0 V to 3.0 V Input Rise Time: 10ns

Input to Output timing Reference Levels: 1.5 V Output load: 50pf

## ABSOLUTE MAXIMUM RATINGS*

Supply Voltage (VCC - GND) Input or Output Voltage Applied

Storage Temperature $\qquad$
-0.3 to 8.0 V
(GND -0.3V)
to (VCC +0.3 V )
$-65{ }^{\circ} \mathrm{C}$ to $150{ }^{\circ} \mathrm{C}$

OPERATING RANGE
Operating Supply Voltage
Commercial (-5)
4.5 V to 5.5 V

Operating Temperature
Commercial (-5)
00 C to +700 C

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage (VCC - GND) | -0.3 to 8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | (GND -0.3 V ) |
|  | to (VCC +0.3 V ) |
| Storage Temperature | $-650^{\circ}$ to $150^{\circ} \mathrm{C}$ |

OPERATING RANGE
Operating Supply Voltage
Commercial (-5)
4.5 V to 5.5 V

Operating Temperature
Commercial (-5)
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

| SYMBOL | PARAMETER | TEMP. \& VCC * OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| TELQV | Chip Enable Access Time |  | 250 | ns | (4) |
| TAVQV | Address Access Time |  | 270 | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 10 |  | ns | (4) |
| TWLQZ | Write Enable Output Disable Time |  | 80 | ns | (4) |
| TEHQZ | Chip Enable Output Disable Time |  | 80 | ns | (4) |
| TGLQX | Output Enable Output Enable Time | 10 |  | ns | (4) |
| TGLQV | Output Enable Output Valid Time |  | 70 | ns | (4) |
| TGHQZ | Output Enable Output Disable Time |  | 80 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 250 |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 100 |  | ns | (4) |
| TAVEL | Address Setup Time | 20 |  | ns | (4) |
| TELAX | Address Hold Time | 50 |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 250 |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 250 |  | ns | (4) |
| TELWH | Write Enable Pulse Hold Time | 250 |  | ns | (4) |
| TDVWH | Data Setup Time | 100 |  | ns | (4) |
| TWHDX | Data Hold Time | 20 |  | ns | (4) |
| TWLDV | Write Data Delay Time | 150 |  | ns | (4) |
| TELEL | Read or Write Cycle Time | 350 |  | ns | (4) |

A.C.

TELEH
TEHEL
TAVEL
TWLWH
TWLEH
TELWH
Enable Pulse Hold Time

TWHDX
TWLDV Write Data Delay Time Read or Write Cycle Time

All devices tested at worst case limits.
1
$(2)$
$(3)$
4 Operating Supply Current (ICCOP) is proportional to Operating Frequency.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions:

Input Pulse Levels: 0 V to 3.0 V Input to Output timing Reference Levels: 1.5 V
Input Rise Time: 10ns Output load: 50pf

Read Cycle


The address information is latched in the on chip registers on the falling edge of $\bar{E}(T=0)$, minimum address setup and hold time requirements must be met. After the required hold time, the addresses may change state without affecting device operation. During time ( $T=1$ ), the outputs become enabled but data is not valid until time ( $T=2$ ), $\bar{W}$ must remain high throughout the read
cycle. After the data has been read, $\bar{E}$ may return high ( $T=3$ ). This will force the output buffers into a high impedance mode at time $(T=4)$. $\overline{\mathrm{G}}$ is used to disable the output buffers when in a logical " 1 " state ( $T=-1,0$, $3,4,5)$. After $(T=4)$ time, the memory is ready for the next cycle.

Write Cycle


The write cycle is initiated on the falling edge of $\bar{E}(T=0)$, which latches the address information in the on chip registers. If a write cycle is to be performed where the output is not to become active, $\overline{\mathrm{G}}$ can be held high (inactive). TDVWH and TWHDX must be met for proper device operation regardless of $\bar{G}$. If $\bar{E}$ and $\bar{G}$ fall before $\bar{W}$ falls (read mode), a possible bus conflict may exist. If $\bar{E}$ rises before $\bar{W}$ rises, reference data setup and hold times
to the $\overline{\mathrm{E}}$ rising edge. The write operation is terminated by the first rising edge of $\bar{W}(T=2)$ or $\bar{E}(T=3)$. After the minimum $\bar{E}$ high time (TEHEL), the next cycle may begin. If a series of consecutive write cycles are to be performed, the $\bar{W}$ line may be held low unitl all desired locations have been written. In this case, data setup and hold times must be referenced to the rising edge of $\overline{\mathrm{E}}$.

Read Modify Write Cycle


| TIME REFERENCE | $E$ |  |  | A | $\begin{gathered} \text { DATA } / / O \\ \text { DQ } \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| -1 | H | $\times$ | H | $\times$ | $z$ | MEMORY DISABLED |
| 0 | $\gamma$ | H | H | $v$ | $z$ | CYCLE BEGINS, ADDRESSES ARE LATCHED |
| 1 | L | H | L | $x$ | $\times$ | READ MODE, OUTPUT ENABLED ( $\overline{\mathbf{W}}=$ HIGH, $\overline{\mathrm{G}}$ - LOW) |
| 2 | L | H | L | $x$ | $v$ | READ MODE, OUTPUT VALID |
| 3 | L | L | H | x | z | WRITE MODE, OUTPUT HIGH Z |
| 4 | L | a | H | x | $v$ | WRITE MODE, DATA IS WRITTEN |
| 5 | f | H | H | $x$ | $z$ | WRITE COMPLETED |
| 6 | H | $\times$ | H | $\times$ | 2 | PREPARE FOR NEXT CYCLE (SAME AS -1) |
| 7 | $x$ | H | H | $v$ | $z$ | CYCLE ENDS, NEXT CYCLE BEGINS (SAME AS O) |

If the pulse width of $\bar{W}$ is relatively short in relation to that of $\bar{E}$, a combination read write cycle may be performed. If $\bar{W}$ remains high for the first part of the cycle, the output will become active during time ( $T=1$ ) provided $\bar{G}$ is low. Data out will be valid during time ( $T=2$ ). After the data is read, $\bar{W}$ can go low. After minimum

TWLWH, $\bar{W}$ may return high. The information just written may now be read or $\overline{\mathrm{E}}$ may return high, disabling the output buffer and preparing the device for the next cycle. Any number or sequence of read-write operations may be performed while $\bar{E}$ is low providing all timing requirements are met.

## NOTES:

In the above descriptions, the numbers in parentheses $(T=n)$, refer to the respective timing diagrams. The numbers are located on the time reference line below each diagram. The timing diagrams shown are only examples and are not the only valid method of operation.

НМ-92570

## 256K BUFFERED SYNCHRONOUS <br> Advanced Information

## Features

- LOW STANDBY CURRENT
- FAST ACCESS TIME
- DATA RETENTION
$600 \mu \mathrm{~A} / 3.5 \mathrm{~mA}$
- three state outputs
- ORGANIZABLE AS 32K $\times 8$ or $16 \mathrm{~K} \times 16$ ARRAY
- BUFFERED ADDRESS AND CONTROL LINES
- ON CHIP ADDRESS REGISTERS
- 48 PIN DIP PINOUT $-2.66^{\prime \prime} \times 1.30^{\prime \prime} \times 0.29^{\prime \prime}$
- WIDE temperature range
$5^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The HM-92570 is a fully buffered 256K bit CMOS RAM module consisting of sixteen HM-6516 2K x 8 CMOS RAMs, two HD-6495 CMOS hex buffers, and two HD-6440 CMOS 3:8 line decoders in leadless chip carriers mounted on a multilayer ceramic substrate. The HM-92570 RAM module is organized as two 16K by 8 CMOS RAM arrays sharing a common address bus. Separate data input/output buses allow the user to format the HM-92570 as either a $16 \mathrm{~K} \times 16$ or $32 \mathrm{~K} \times 8$ array.

On-board CMOS buffers and decoders reduce external package count requirements. Write enable and chip enable control signals are buffered along with address inputs. Ceramic capacitors are included on the substrate to reduce noise and to minimize the need for additional external decoupling.

The synchronous design of the HM-92570 provides low operating power along with address latches for ease of interface to multiplexed address/data bus microprocessor.
The HM-92570 is physically constructed as an extra wide 48 pin dual-in-line package with standard $0.1^{\prime \prime}$ centers between pins. This packaging technique combines the high packing density of CMOS and leadless chip carriers with the ease of use of DIP packaging.

## Pinout

| GND 1 | 48 | $\square \mathrm{Vcc}$ |
| :---: | :---: | :---: |
| A7 - 2 | 47 | $\square \mathrm{AO}$ |
| A8 3 | 46 | - A1 |
| A9 4 | 45 | $\square \mathrm{A} 2$ |
| A10-5 | 44 | D A3 |
| A11 6 | 43 | ص A4 |
| A12 ${ }^{\text {¢ }}$ | 42 | A5 |
| A13 ${ }^{8}$ | 41 | - ${ }^{\text {a } 6}$ |
| E1A 9 | 40 | ] E1B |
| E2A 10 | 39 | E2B |
| E3A 11 | 38 | E3B |
| NC 12 | 37 | ] $\bar{W}$ |
| GA 13 | 36 | $\square \overline{\mathrm{GB}}$ |
| NC 14 | 35 | $\square \mathrm{NC}$ |
| NC 15 | 34 | $\square \mathrm{NC}$ |
| DO0 16 | 33 | D D08 |
| D01 17 | 32 | $\square$ D09 |
| DO2 ${ }^{18}$ | 31 | P Da10 |
| DQ3 19 | 30 | P DQ11 |
| D04 20 | 29 | $\square$ Da12 |
| DQ5 $5^{21}$ | 28 | P DQ13 |
| DQ6 522 | 27 | ص D014 |
| DQ7 23 | 26 | P DQ15 |
| VCC 24 | 25 | ] GND |


| $A$ | - Address Input |
| ---: | :--- |
| $\overline{\mathrm{DQ}}$ | - Data Input/Output |
| $\overline{\mathrm{GX}}$ | - Output Enable |
| $\overline{\mathrm{EXX}}$ | - Chip Enable |
| $\bar{W}$ | - Write Enable |
| NC | - No Connection |

## Functional Diagram



## Organizational Guide

## FOR 32K x 8 CONFIGURATION

| CONNECT: | PIN 16 (DQO) to PIN 33 (DQ8) |
| :--- | :--- |
|  | PIN 17 (DQ1) to PIN 32 (DQ9) |
| PIN 18 (DQ2) to PIN 31 (DQ10) |  |
| PIN 19 (DQ3) to PIN 30 (DQ11) |  |
|  | PIN 20 (DQ4) to PIN 29 (DQ12) |
| PIN 21 (DQ5) to PIN 28 (DQ13) |  |
|  | PIN 22 (DQ6) to PIN 27 (DQ14) |
|  | PIN 23 (DQ7) to PIN 26 (DQ15) |

FOR $16 \mathrm{~K} \times 16$ CONFIGURATION

$$
\begin{array}{ll}
\text { CONNECT: } & \text { PIN } 9(\overline{E 1 A}) \text { to PIN } 40(\overline{E 1 B}) \\
& \text { PIN } 10(\overline{E 2 A}) \text { to PIN } 39(\overline{E 2 B}) \\
& \text { PIN } 11(E 3 A) \text { to PIN } 38(E 3 B) \\
& \text { PIN } 13(G A) \text { to PIN } 36(G B)
\end{array}
$$

## Concerns for Proper Operation of Chip Enables:

The transition between blocks of RAM requires a change in the chip enable being used. When operating in the $16 \mathrm{~K} \times 16$ mode use the chip enables as if there were only three, E1 thru E3. In the $32 \mathrm{~K} \times 8$ mode all chip enables must be treated separately. Transitions between chip enables must be treated with the same timing constraints that apply to any one chip enable. All chip enables must be high at least one chip enable high time (TEHEL) before any chip enable can fall.

## Printed Circuit Board Mounting:

The leadless chip carrier packages used in the HM92570 have conductive lids. These lids are electrically connected to GND. The designer should be aware of the possibility that the carriers on the bottom side could short conductors below if pressed

As the HM-92570 is a synchrounous memory, every address transition must be accompanied by a chip enable transition (see timing diagrams). More than one chip enable low simultaneously, for devices whose outputs are tied common either internally or externally, is an illegal input condition and must be avoided. To properly decode the chip enables, addresses A11, A12, and A13 must be valid for the duration of TAVAV.

ABSOLUTE MAXIMUM RATINGS*
Supply Voltage (VCC - GND)
Input or Output Voltage Applied

Storage Temperature
-0.3 to 8.0 V
(GND -0.3V)
to (VCC +0.3 V )
$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

OPERATING RANGE
Operating Supply Voltage
Military (-2, -8)
4.5 V to 5.5 V

Industrial (-9)
Operating Temperature
Military ( $-2,-8$ )
Industrial (-9)
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS



## ABSOLUTE MAXIMUM RATINGS*

Supply Voltage (VCC - GND)
Input or Output Voltage Applied
Storage Temperature
Stor

## OPERATING RANGE

Operating Supply Voltage
Military ( $-2,-8$ )
4.5 V to 5.5 V

Industrial (-9)
4.5 V to 5.5 V

Operating Temperature
Military ( $-2,-8$ )
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Industrial (-9)
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | TEMP. <br> OPER <br> RAN | VCC * <br> TING <br> (1) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | UNITS | CONDITIONS |
| A.C. | TELQV | Chip Enable Access Time |  | 250 | ns | (4) |
|  | TAVQV | Address Access Time |  | 270 | ns | (4) |
|  | TELQX | Chip Enable Output Enable Time | 10 |  | ns | (4) |
|  | TWLQZ | Write Enable Output Disable Time |  | 120 | ns | (4) |
|  | TEHQZ | Chip Enable Output Disable Time |  | 150 | ns | (4) (6) |
|  | TGLQX | Output Enable Output Enable Time | 10 |  | ns | (4) |
|  | TGLQV | Output Enable Output Valid Time |  | 70 | ns | (4) |
|  | TGHQZ | Output Enable Output Disable Time |  | 100 | ns | (4) (6) |
|  | TELEH | Chip Enable Pulse Negative Width | 250 |  | ns | (4) |
|  | TEHEL | Chip Enable Pulse Positive Width | 100 |  | ns | (4) |
|  | TAVEL | Address Setup Time | 20 |  | ns | (4) (5) |
|  | TELAX | Address Hold Time | 120 |  | ns | (4) |
|  | TWLWH | Write Enable Pulse Width | 140 |  | ns | (4) |
|  | TWLEH | Write Enable Pulse Setup Time | 140 |  | ns | (4) |
|  | TELWH | Write Enable Pulse Hold Time | 250 |  | ns | (4) |
|  | TDVWH | Data Setup Time | 20 |  | ns | (4) |
|  | TWHDX | Data Hold Time | 70 |  | ns | (4) |
|  | TWLDV | Write Data Delay Time | 120 |  | ns | (4) |
|  | TELEL TAVAV | Read or Write Cycle Time <br> Enable Decoder Address Valid Time | 350 270 |  | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ | Applies Only to A11, A12, A13 |

## NOTES:



All devices tested at worst case limits.
Operating Supply Current (ICCOP) is proportional to Operating Frequency.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions:

Input Pulse Levels: 0 V to 3.5 V Input to Output timing Reference Levels: 1.5 V
Input Rise Time: 10ns Output load: 50pf
(5) Includes A11, A12, A13
(6) Output Disable Time is faster when using $\overline{G A}$ or $\overline{G B}$ to Disable the Outputs. See Note 1 in Read Cycle Timing Diagram.

## ABSOLUTE MAXIMUM RATINGS*

Supply Voltage (VCC - GND)
Input or Output Voltage Applied
Storage Temperature
-0.3 to 8.0 V
(GND -0.3V)
to (VCC +0.3 V )
$-65^{\circ} \mathrm{C}$ to $150{ }^{\circ} \mathrm{C}$

OPERATING RANGE
Operating Supply Voltage Commercial (-5)
4.5 V to 5.5 V

Operating Temperature
Commercial (-5)
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS


## ABSOLUTE MAXIMUM RATINGS*

Supply Voltage (VCC - GND)
Input or Output Voltage Applied
Storage Temperature

## OPERATING RANGE

Operating Supply Voltage
Commercial (-5)
4.5 V to 5.5 V

Operating Temperature
Commercial (-5)
$0^{\circ} \mathrm{C}$ to $+70{ }^{\circ} \mathrm{C}$

* CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

A.C.

| SYMBOL | PARAMETER | TEMP. \& VCC * OPERATING RANGE (1) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| TELQV | Chip Enable Access Time |  | 300 | ns | (4) |
| TAVQV | Address Access Time |  | 320 | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 10 |  | ns | (4) |
| TWLQZ | Write Enable Output Disable Time |  | 120 | ns | (4) |
| TEHQZ | Chip Enable Output Disable Time |  | 200 | ns | (4) (6) |
| TGLQX | Output Enable Output Enable Time | 10 |  | ns | (4) |
| TGLQV | Output Enable Output Valid Time |  | 80 | ns | (4) |
| TGHOZ | Output Enable Output Disable Time |  | 120 | ns | (4) (6) |
| TELEH | Chip Enable Pulse Negative Width | 300 |  | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 150 |  | ns | (4) |
| TAVEL | Address Setup Time | 20 |  | ns | (4) (5) |
| TELAX | Address Hold Time | 130 |  | ns | (4) |
| TWLWH | Write Enable Pulse Width | 150 |  | ns | (4) |
| TWLEH | Write Enable Pulse Setup Time | 150 |  | ns | (4) |
| TELWH | Write Enable Pulse Hold Time | 300 |  | ns | (4) |
| TDVWH | Data Setup Time | 30 |  | ns | (4) |
| TWHDX | Data Hold Time | 80 |  | ns | (4) |
| TWLDV | Write Data Delay Time | 120 |  | ns | (4) |
| TELEL TAVAV | Read or Write Cycle Time <br> Enable Decoder Address Valid Time | $\begin{aligned} & 450 \\ & 320 \end{aligned}$ |  | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ | Applies Only to A11, A12, A13 |

NOTES:
(1) All devices tested at worst case limits.
(2) Operating Supply Current (ICCOP) is proportional to Operating Frequency.
(3) Capacitance sampled and guaranteed - not $100 \%$ tested.
(4) AC test conditions:
Input Pulse Levels: OV to 3.5 V
Input Rise Time: 10ns
(5) Includes A11, A12, A13
(6) Output Disable Time is faster when using $\overline{\mathrm{GA}}$ or $\overline{\mathrm{GB}}$ to Disable the Outputs.
See Note 1 in Read Cycle Timing Diagram.


The address information is latched in the on chip registers on the falling edge of $\bar{E}(T=0)$, minimum address setup and hold time requirements must be met. After the required hold time, the addresses may change state without affecting device operation. During time ( $T=1$ ), the outputs become enabled but data is not valid until time ( $T=2$ ), $\bar{W}$ must remain high throughout the read
cycle. After the data has been read, E may return high ( $T=3$ ). This will force the output buffers into a high impedance mode at time ( $T=4$ ). $\overline{\mathrm{G}}$ is used to disable the output buffers when in a logical " 1 " state ( $T=-1,0$, $3,4,5)$. After $T=4$ ) time, the memory is ready for the next cycle. *E3A and E3B are opposite polarity of EIA.


The write cycle is initiated on the falling edge of $\mathrm{E}(\mathrm{T}=0)$, which latches the address information in the on chip registers. If a write cycle is to be performed where the output is not to become active, $\overline{\mathrm{G}}$ can be held high (inactive). TDVWH and TWHDX must be met for proper device operation regardless of $\bar{G}$. If $\bar{E}$ and $\bar{G}$ fall before $\bar{W}$ falls (read mode), a possible bus conflict may exist. If $\bar{E}$ rises before $\bar{W}$ rises, reference data setup and hold times
to the $\overline{\mathrm{E}}$ rising edge. The write operation is terminated by the first rising edge of $\bar{W}(T=2)$ or $\bar{E}(T=3)$. After the minimum $\bar{E}$ high time (TEHEL), the next cycle may begin. If a series of consecutive write cycles are to be performed, the $\bar{W}$ line may be held low until all desired locations have been written. In this case, data setup and hold times must be referenced to the rising edge of $\bar{E}$. *E3A and E3B are opposite polarity of EIA.

## Read Modify Write Cycle



If the pulse width of $\bar{W}$ is relatively short in relation to that of $\overline{\mathrm{E}}$, a combination read write cycle may be performed. If $\bar{W}$ remains high for the first part of the cycle, the output will become active during time ( $\mathrm{T}=1$ ) provided $\bar{G}$ is low. Data out will be valid during time ( $T=2$ ). After the data is read, $\bar{W}$ can go low. After minimum TWLWH, $\bar{W}$ may return high. The information just
written may now be read or $\bar{E}$ may return high, disabling the output buffer and preparing the device for the next cycle. Any number or sequence of read-write operations may be performed while $\bar{E}$ is low providing all timing requirement are met. *E3A and E3B are opposite polarity of EIA.

NOTES:
In the above descriptions, the numbers in parentheses $(T=1)$, refer to the respective timing diagrams. The numbers are located on the time reference line below each diagram. The timing diagrams shown are only examples and are not the only valid method of operation.

## Faatures

- LOW POWER STANDBY
- LOW POWER OPERATION
- FAST ACCESS TIME
- FIELD PROGRAMMABLE
- POLYSILICON FUSE LINKS
- tTL COMPATIBLE IN/OUT
- POPULAR PINOUT LIKE BIPOLAR 7641
- thRE STATE OUTPUTS
- ADDRESS LATCHES INCLUDED ON CHIP
- EASY MICROPROCESSOR INTERFACING
- WIDE TEMPERATURE RANGES


## Description

The HM-6641 is a $512 \times 8$ CMOS polysilicon fusible link Programmable Read Only Memory in the popular 24 pin, byte wide pinout. Synchronous circuit design techniques combine with CMOS processing to give this device high speed performance with very low power dissipation.

On chip address latches are provided, allowing easy interfacing with recent generation microprocessors that use multiplexed address/data bus structures, such as the 8085. The output enable controls, both active low and active high, further simplify microprocessor system interfacing by allowing output data bus control independert of the chip enable control. The data output latches allow the use of the HM-6641 in high speed pipelined architecture systems, and also in synchronous logic replacement functions.

Applications for the HM-6641 CMOS PROM include low power handheld microprocessor based instrumentation and communications systems, remote data acquisition and processing systems, processor control store, and synchronous logic replacement.

Functional Diagram


ALL LINES POSITIVE LOGIC ACTIVE HIGH
THREE STATE BUFFERS: A HIGH $\rightarrow$ OUTPUT ACTIVE
DATA LATCHES:
L. $\mathrm{HIGH}-\mathrm{O}=\mathrm{D}$

Q LATCHES ON RISING EDGE OF E
ADDRESS LATCHES AND GATED DECODERS:

LATCH ON FALLING EDGE OF E
GATE ON FALLING EDGE OF E

CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

ABSOLUTE MAXIMUM RATINGS*
Supply Voltage -VCC
Input or Output Voltage Applied
GND -0.3Vto
VCC $+0.3 V$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

## OPERATING RANGE

Operating Supply
Military ( $-2 /-8$ )
4.5 V to 5.5 V

Industrial (-9)
4.5 V to 5.5 V

Operating Temperature

| Military $(-2 /-8)$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| :--- | :--- |
| Industrial $(-9)$ | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

* CAUTION: Stresses above those listed under "Absolute Maximum Rating"" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.


## ELECTRICAL CHARACTERISTICS

| SYMBOL | PARAMETER | TEMP \& VCC = OPERATING RANGE |  | $\begin{aligned} & \mathrm{TEMP}=25^{\circ} \mathrm{C} \\ & \mathrm{VCC}=5.0 \text { (1) } \end{aligned}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | TYPICAL |  |  |
| ICCSB | Standby Supply Current |  | 100 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \\ & V I=G N D \text { OR VCC } \end{aligned}$ |
| ICCOP | Operating Supply Current (2) |  | 10 | 5 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, \mathrm{IO}=0 \\ & \mathrm{VI}=\mathrm{VCC} \text { or GND } \end{aligned}$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | 0.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | $\pm 0.5$ | $\mu \mathrm{A}$ | GND $\leq V O \leq V C C$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | 2.0 | V |  |
| VIH | Input High Voltage | VCC -2.0 | VCC +0.3 | 2.0 | V |  |
| VOL | Output Low Voltage |  | 0.4 | 0.1 | V | $1 \mathrm{OL}=3.2 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | 4.25 | V | $1 \mathrm{OH}=-1.0 \mathrm{~mA}$ |
| Cl | Input Capacitance (3) |  | 10.0 | 5.0 | pF | $\begin{aligned} & V I=V C C \text { or } G N D \\ & f=1 M H z \end{aligned}$ |
| CO | Output Capacitance (3) |  | 12.0 | 8.0 | pF | $\begin{aligned} & V O=V C C \text { OR GND } \\ & f=1 \mathrm{MHz} \end{aligned}$ |


| TELQV | Chip Enable Access Time |  | 250 | 150 | ns | (4) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TAVQV | (TAVQV = TELQV + TAVEL) |  |  |  |  |  |
|  | Address Access Time |  | 270 | 150 | ns | (4) |
| TELQX | Chip Enable Output Enable Time | 20 | 150 | 70 | ns | (4) |
| TGVQX | Output Enable Output Enable Time | 20 | 150 | 70 | ns | (4) |
| TGXQZ | Output Enable Output Disable Time | 20 | 150 | 70 | ns | (4) |
| TELEH | Chip Enable Pulse Negative Width | 250 |  | 150 | ns | (4) |
| TELEL | Read Cycle Time | 400 |  | 230 | ns | (4) |
| TEHEL | Chip Enable Pulse Positive Width | 150 |  | 80 | ns | (4) |
| TAVEL | Address Set-up Time | 20 |  | 0 | ns | (4) |
| TELAX | Address Hold Time | 60 |  | 40 | ns | (4) |

NOTES:

[^4]

In the HM-6641 read cycle, the address information is latched into the on chip registers on the falling edge of $\overline{\mathrm{E}}(\mathrm{T}=0)$. Minimum address setup and hold time requirements must be met. After the required hold time,the addresses may change state without affecting device operation. To read data $\overline{\mathrm{G} 1}$ and $\overline{\mathrm{G} 2}$ must be low, and G3 must be high. After access time, $\bar{E}$ may be taken high to latch
the data outputs and begin TEHEL. Taking either or both $\overline{\mathrm{G} 1}$ or $\overline{\mathrm{G} 2}$ high or G 3 low will force the output buffers to a high impedance state. The output data may be reenabled at any time taking $\overline{\mathrm{G} 1}$ and $\overline{\mathrm{G} 2}$ low and G3 high. On the falling edge of $\overline{\mathrm{E}}$ the data will be unlatched. P should be grounded except when in the programming mode.

## Programming

## INTRODUCTION

The HM-6641 is a 512 word, by 8 bit field programmable read only memory utilizing polycrystalline silicon fusible links as programmable memory elements. Selected memory locations are permanently changed from their manufactured state, of all low (VOL) to a logical high (VOH), by the controlled application of programming potentials and pulses. Careful adherence to the following programming specifications will result in high programming yield. Both high VCC ( 6.0 volts) and low VCC ( 4.0 volts) verify cycles are specified to assure the integrity of the programmed fuse. This programming specification, although complete, does not preclude rapid programming. The worst case programming time required is 37.4 seconds, and typical programming time can be approximately 4 seconds per device.

The chip ( $\bar{E}$ ) and output enable ( $\overline{\mathrm{G}}$ ) are used during the programming procedure. On PROM's which have more than one output enable control $\overline{\mathrm{G} 1}$ is to be used. The other output enables must be held in the active, or enabled, state throughout the entire programming sequence. The programmer designer is advised that all pins of the programmer's socket should be at ground potential when
the PROM is inserted into the socket. VCC must be applied to the PROM before any input or output pin is allowed to rise*.

## OVERALL PROGRAMMING PROCEDURE

1. The address of the first bit to be programmed is presented, and latched by the chip enable ( $\bar{E}$ ) falling edge. The output is disabled by taking the output enable ( $\overline{\mathrm{G}})$ high.
2. VCC is raised to the programming voltage level, 12.5 V .
3. The data output pin corresponding to the bit to be programmed is pulled low. All other bits in the word are pulled up to VCC (at the programming level).
4. A $500 \mu \mathrm{~s}$ pulse is applied to the programming control pin (P).
5. The data output pin is returned to VCC, and the VCC pin is returned to 6.0 volts.
6. The address of the bit is again presented, and latched by a second chip enable falling edge.
7. The data outputs are enabled, and read, to verify that the bit was successfully programmed.
a). If verified, two post programming pulses are applied (the bit is programmed twice more). Then the next bit to be programmed is addressed and programmed.
b). If not verified, the program/verify sequence is repeated up to 8 times total, at the programming voltage level, 12.5 volts.
c). If data is not verified, the programming voltage is increased to +14.0 volts. The program/verify sequence is then repeated up to 8 additional times.
8. After all bits to be programmed have been verified at 6.0 volts, the VCC is lowered to 4.0 volts and all bits are verified.
a). If all bits verify, the device is properly programmed.
b). If any bit fails to verify, the device is rejected.

## PROGRAMMING SYSTEM REQUIREMENTS

1. The power supply for the device to be programmed must be able to be set to four voltages; $4.0 \mathrm{~V}, 6.0 \mathrm{~V}$, $12.5 \mathrm{~V}, 14.0 \mathrm{~V}$. This supply must be able to supply 500 mA average, and 1A dynamic, currents to the PROM during programming. The power supply rise fall times when switching between voltages must be no quicker than $1 \mu \mathrm{~s}$.
2. The address drivers must be able to maintain input voltage levels $\geq 70 \%$ VCC for VIH, and $\leq 20 \%$ VCC for VIL. The programming system designer has a choice between buffers that will track VCC up and down (e.g. open collector buffers with pull up resistors) or buffers used for VIH only at 4.0 V and 6.0 V and returned to VIL when the system is at programing voltages.*
3. The control input buffers have the same $\mathbf{7 0 \%}$ and $\mathbf{2 0 \%}$ VCC requirements as the address buffers. Notice that chip enable (E) does not require a pull up to programming voltage levels, but that the output enable (G) must have a pull up to track VCC up and down. The program control (P) must switch from ground to programming VCC level.*
4. The data input buffers must be able to sink up to 3 mA from the PROM's output pins without rising more than 0.7 volts above ground, be able to hold the other outputs high with a current source capability of 0.5 mA to 2.0 mA , and not interfere with the reading and verifying of the data output of the PROM. Notice that a bit to be programmed is changed from a low state (VOL) to high (VOH) by pulling low on the output pin. A suggested implementation is open collector TTL buffers (or inverters) with $4.7 \mathrm{~K} \Omega$ pull up resistors to VCC. *
*Note: Never allow any input or output pin to rise more than 0.3 volts above VCC, or fall more than 0.3 volts below ground.

PROGRAMMING SYSTEM CHARACTERISTICS

| PARAMETER | NAME | MIN | TARGET | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VCCN | Normal VCC | 5.75 | 6.0 | 6.25 | volts |
| VCC PGM | Programming Voltage | 12.0 | 12.5 | 14.0 | voits |
| VCC LV | Low Voltage Verify VCC | 3.75 | 4.0 | 4.25 | volts |
| ICC | System ICC Capability | 500 |  |  | mA |
| ICC Peak | Transient ICC Capability For PROM Input Pins: | 1.0 |  |  | A |
| VOL | Output Low Voltage (to PROM) | -0.3 | GND | 20\% VCC | volts |
| VOH | Output High Voltage (to PROM) | 70\% VCC | VCC | VCC +0.3 | volts |
| IOL | Output Sink Current (at VOL) | . 01 |  |  | mA |
| IOH | Output Source Current (At VOH) <br> For PROM Data Output Pins: | . 01 |  | , | mA |
| VOL | Output Low Voltage (to PROM) | -0.3 | GND | 0.7 | volts |
| VOH | Output High Voltage (to PROM) | 70\% VCC | VCC | VCC +0.3 | volts |
| IOL | Output Sink Current (at VOL) | 3.0 |  |  | mA |
| IOH | Output Source Current (at VOH ) | 0.5 | 1.0 | 2.0 | mA |

PROGRAMMING SYSTEM TIMING

| SYMBOLS | PARAMETER | MIN | MAX | UNITS |
| :--- | :--- | :--- | :--- | :--- |
| TAVEL | Address Set-up Time | 500 |  | ns |
| TELAX | Address Hold Time | 500 |  | ns |
| TEHEL | Chip Enable High Time | 500 |  | ns |
| TELVP | Chip Enable Low to VCC Rising Delay | 500 |  | ns |
| TGHVP | Output Enable High to VCC Rising Delay | 500 |  | ns |
| TGHQZ | Output Disable Time |  | 150 | ns |
| TRISE | VCC Rise Time (to PGM Voltage) | 1.0 |  | $\mu \mathrm{~s}$ |
| TVPQL | VCC High (PGM) to Output Low Delay | 500 |  | ns |
| TQLPH | Programming Data Setup Time | 500 |  | ns |
| TPHPL | Programming Pulse Width | 450 | 550 | $\mu \mathrm{~s}$ |
| TPLQH | Programming Data Hold Time | 500 |  | ns |
| TQHVN | Output High to VCC Normal Delay | 500 |  | ns |
| TFALL | VCC Fall Time (to Normal VCC) | 1.0 |  | $\mu \mathrm{~s}$ |
| TVNEH | VCC Normal to Chip Enable High Delay | 500 |  | ns |
| TVNGL | VCC Normal to Output Enable Low Delay | 500 |  | ns |
| TELQV | Chip Enable Access Time |  | 500 | ns |
| TGLQV | Qutput Enable Access Time | 500 | ns |  |
| TGLQX | Output Enable Time |  | ns |  |

## LOW VOLTAGE VERIFY CYCLE



PROGRAM AND VERIFY CYCLE


## Features

- LOW STANDBY AND OPERATING POWER
- ICCSB - $50 \mu \mathrm{~A} / 100 \mu \mathrm{~A}$
- ICCOP - $13 \mathrm{~mA} / \mathrm{MHz}$
- FAST ACCESS TIME
- INDUSTRY STANDARD PINOUT
- SINGLE 5.0 VOLT SUPPLY
- TTL COMPATIBLE INPUTS
- high OUTPUT DRIVE
- synchronous operation
- ON-CHIP ADDRESS LATCHES
- SEPARATE OUTPut enable
- full industrial and military temperature ranges


## Description

The HM-6616 is a 16,384 bit fuse link CMOS PROM in a 2 K word by 8 bit/word format with "Three State"' outputs. This PROM is available in the standard 0.600 inch wide 24-Pin DIP, the 0.300 inch wide slimline DIP, and the JEDEC standard 32-Pin LCC.
The HM-6616 utilizes a synchronous design technique. This includes on-chip address latches and a separate output enable control which makes this device ideal for applications utilizing recent generation microprocessors. This design technique, combined with the Harris advanced self-aligned silicon gate CMOS process technology offers ultra-low standby current. Low ICCSB is ideal for battery applications or other systems with low power requirements.
The Harris polysilicon fuse link technology is utilized on this and all other Harris CMOS PROMS. This gives the user a PROM with permanent, stable storage characteristics over the full industrial and military temperature and voltage ranges. Polysilicon fuse technology combined with the low power characteristics of CMOS provides an excellent alternative to standard Bipolar PROMS or NMOS EPROMS.
All bits are manufactured storing a logical " 0 ' ' and can be selectively programmed for a logical " 1 " at any bit location.

Pinout
TOP VIEW


PIN NAMES

| A Address inpút | G Output Enable |
| :---: | :---: |
| a Data Output | P Program Enable |
| E Chip Enable | $\begin{aligned} & \text { ( } \overline{\mathrm{F}}=\text { VCC except during } \\ & \text { Programming) } \end{aligned}$ |

TOP VIEW - LCC


## Functional Diagram



ALL LINES POSItive LOGIC: ACTIVE HIGH
three state buffers: A HIGH OUTPUT ACTIVE ADDRESS LATCHES AND GATED DECODERS: LATCH ON FALLING EDGE OFE GATE ON FALLING EDGE OF $\bar{G}$
$\overline{\mathrm{P}}=$ VCC EXCEPT DURING PROGRAMMING

CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

## Specifications HM-6616-9/-2/-8

## ABSOLUTE MAXIMUM RATINGS*

Supply Voltage
Input/Output Voltage Applied
Storage Temperature Range Operating Temperature Range

Military - HM-6616-2/-8
Industrial - HM-6616-9
Operating Voltage Range
+7.0 Volts
GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
+4 V to +7 V

* CAUTION: Stresses above those listed under the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damaqe to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. ELECTRICAL CHARACTERISTICS VCC $=5.0 \mathrm{~V} \pm 10 \%$; $T_{A}=$ Industrial $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(H M-6616-9)$

$$
=\text { Military }-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{HM}-6616-2 /-8)
$$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | $\begin{aligned} & \text { TEST } \\ & \text { CONDITIONS } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | 2.4 |  | V |  |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| VOH | Logical One Output Voltage | 2.4 |  | V | $10 \mathrm{H}=-2.0 \mathrm{~mA}$ |
| VOL | Logical Zero Output Voltage |  | 0.4 | V | $10 \mathrm{~L}=+4.8 \mathrm{~mA}$ |
| 11 | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VIN} \leq V C C$ |
| 102 | Output Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\begin{gathered} O V \leq V O \leq V C C \\ G=H I G H \end{gathered}$ |
| ICCSB | Standby Power Supply Current |  | 100 | $\mu \mathrm{A}$ | $\begin{gathered} \mathrm{VIN}=\mathrm{VCC} \text { or GND } \\ \mathrm{VCC}=5.5 \mathrm{~V} \\ 10=0 \end{gathered}$ |
| ICCOP | Operating Power Supply Current |  | 15 | mA | $\begin{gathered} f=1 \mathrm{MHz} \\ \mathrm{VCC}=5.5 \mathrm{~V} \\ 10=0 \\ \mathrm{VIN}=\mathrm{VCC} \text { or } \mathrm{GND} \end{gathered}$ |
| CIN | Input Capacitance* |  | 10 | pF | $\begin{gathered} f=1 \mathrm{MHz} \\ \mathrm{VIN}=\mathrm{VCC} \text { or GND } \end{gathered}$ |
| COUT | Output Capactiance* |  | 12 | pF | $\begin{gathered} f=1 \mathrm{MHz} \\ \mathrm{VIN}=\mathrm{VCC} \text { or } G N D \end{gathered}$ |

*Guaranteed and sampled, but not $100 \%$ tested.

## Specifications HM-6616-9/-2/-8

$$
\text { A.C. ELECTRICAL CHARACTERISTICS VCC =5.0V } \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=\begin{aligned}
& \text { Industrial }-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(\mathrm{HM}-6616-9) \\
& \\
& \\
& \\
& =\text { Military }-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{HM}-6616-2 /-8)
\end{aligned}
$$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST <br> CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TAVQV | Address Access Time |  | 140 | ns | see notes 1,2 |
| TELQV | Chip Enable Access Time |  | 120 | ns |  |
| TELQX | Chip Enable Time | 5 |  | ns |  |
| TAVEL | Address Setup Time | 20 |  | ns |  |
| TELAX | Address Hold Time | 25 |  | ns |  |
| TELEH | Chip Enable Low Width | 120 |  | ns |  |
| TEHEL | Chip Enable High Width | 40 |  | ns |  |
| TELEL | Cycle Time | 160 |  | ns |  |
| TGLQV | Output Access Time |  | 50 | ns |  |
| TGLQX | Output Enable Time | 5 |  | ns |  |
| TGHQZ | Output Disable Time |  | 50 | ns |  |
| TEHQZ | Chip Enable Disable Time |  | 50 | ns |  |

NOTE 1: All A C. parameters tested at worst case limits and per test circuits and definitions in Figures 1 and 2. NOTE 2: Input test signais must switch between 0 V and 3.0 V . Input rise and fall times must be $<5 \mathrm{nsec}$.

Switching Waveforms


Figure 1 Read Cycle


Figure 2 Output Test Circuit

## Specifications HM-6616B-9/-2/-8

## ABSOLUTE MAXIMUM RATINGS*

Supply Voltage
Input/Output Voltage Applied Storage Temperature Range Operating Temperature Range Military - HM-6616-2/-8 Industrial - HM-6616-9
Operating Voltage Range
+7.0 Volts
GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
+4 V to +7 V

* CAUTION: Stresses above those listed under the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. ELECTRICAL CHARACTERISTICS VCC $=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=$ Industrial $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HM}-6616 \mathrm{~B}-9)$ $=$ Military $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{HM}-6616 \mathrm{~B}-2 /-8)$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | 2.4 |  | $V$ |  |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| VOH | Logical One Output Voltage | 2.4 |  | V | $10 \mathrm{H}=-2.0 \mathrm{~mA}$ |
| VOL | Logical Zero Output Voltage |  | 0.4 | V | $10 \mathrm{~L}=+4.8 \mathrm{~mA}$ |
| 11 | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VIN} \leq \mathrm{VCC}$ |
| 102 | Output Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\begin{gathered} O V \leq V O \leq V C C \\ \bar{G}=H I G H \end{gathered}$ |
| ICCSB | Standby Power Supply Current |  | 50 | $\mu \mathrm{A}$ | $\begin{gathered} V I N=V C C \text { or } G N D \\ V C C=5.5 \mathrm{~V} \\ I O=0 \end{gathered}$ |
| ICCOP | Operating Power Supply Current |  | 15 | mA | $\begin{gathered} f=1 \mathrm{MHz} \\ V C C=5.5 \mathrm{~V} \\ 10=0 \\ \mathrm{VIN}=\mathrm{VCC} \text { or GND } \end{gathered}$ |
| CIN | Input Capacitance* |  | 10 | pF | $\begin{gathered} f=1 \mathrm{MHz} \\ \mathrm{VIN}=\mathrm{VCC} \text { or } \mathrm{GND} \end{gathered}$ |
| COUT | Output Capactiance* |  | 12 | pF | $\begin{gathered} f=1 \mathrm{MHz} \\ \mathrm{VIN}=\mathrm{VCC} \text { or } \mathrm{GND} \end{gathered}$ |

*Guaranteed and sampled, but not $100 \%$ tested.

## Specifications HM-6616B-9/-2/-8

A.C. ELECTRICAL CHARACTERISTICS VCC $=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=$ Industrial $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HM}-6616 \mathrm{~B}-9)$

$$
=\text { Military }-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{HM}-6616 \mathrm{~B}-2 /-8)
$$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST <br> CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TAVQV | Address Access Time |  | 105 | ns | see notes 1,2 |
| TELQV | Chip Enable Access Time |  | 90 | ns |  |
| TELQX | Chip Enable Time | 5 |  | ns |  |
| TAVEL | Address Setup Time | 15 |  | ns |  |
| TELAX | Address Hold Time | 20 |  | ns |  |
| TELEH | Chip Enable Low Width | 90 |  | ns |  |
| TEHEL | Chip Enable High Width | 30 |  | ns |  |
| TELEL | Cycle Time | 120 |  | ns |  |
| TGLQV | Output Access Time |  | 40 | ns |  |
| TGLQX | Output Enable Time | 5 |  | ns |  |
| TGHQZ | Output Disable Time |  | 40 | ns |  |
| TEHQZ | Chip Enable Disable Time |  | 45 | ns |  |

NOTE 1: All A.C. parameters tested at worst case limits and per test circuits and definitions in Figures 1 and 2
NOTE 2: Input test signais must switch between OV and 3.0 V . Input rise and fall times must be $<5 \mathrm{nsec}$


Figure 1 Read Cycle


Figure 2 Output Test Circuit

## HM-6616 CMOS PROM Programming Algorithm

The HM-6616 PROM is manufactured with all bits storing a logical " 0 "' (output low). Any desired bit can be selectively programmed to a logical " 1 " (output high) by following the procedure shown below. One may build their own programmer to satisfy the specifications shown, or use any of the approved commercially available programmers.

## program sequence of events

1) Apply $V_{C C}($ pin 24) $=$ VCC1 to the PROM.
2) Read all fuse locations to verify (blank check) a $100 \% V_{0 L}$ (unprogrammed) condition.
3) Place the $P R O M$ in the initial state for programming. $\bar{E}=V I H$, $\overline{\mathrm{P}}=\mathrm{VIH}, \overline{\mathrm{G}}=\mathrm{VIL}$.
4) Apply the current binary address for the word to be programmed. An open circuit should not be used to address the PROM.
5) Apply $\overline{\mathrm{E}}=$ VIL after a delay of td to access the addressed word.
6) Address may be held throughout cycle, but must be held at least time td (address hold time), after $\bar{E}=$ VIL.
7) After a delay of td tristate the outputs by applying $\bar{G}=$ VIH.
8) After a delay of td apply $\bar{P}=$ VIL.
9) After a delay of td raise VCC(pin 24) to VCCPROG with rise time $=\operatorname{tr}$. All signals at VIH should track VCC(pin 24) within $\mathrm{VCC}-2 \mathrm{~V}$ to $\mathrm{VCC}+0.3 \mathrm{~V}$ (including outputs - pull-up resistors Rn to VCC would suffice).
10) After a delay of td pull the output to be programmed to VIL. After a duration tpw, allow the output to be pulled to VIH through the pull-up resistor Rn.
11) Repeat step 10 for all other bits to be programmed in the addressed word.
12) Lower $\operatorname{Vcc}($ pin 24) to VCC1 with a fall time tf. Signals at VIH should track VCC (pin 24) in range VCC-2V to VCC +0.3 V .
13) After a delay of td apply $\bar{E}=$ VIH for duration of TEHEL, and the apply $\overline{\mathrm{E}}=$ VIL.
14) After a delay $=$ TELPH1, apply $\bar{P}=$ VIH.
15) After a delay of td apply $\bar{G}=$ VIL. Following a delay of $t d$ examine the outputs for correct data.
16) If any location verifies incorrectly, repeat steps 4 through 15 (attempting to program only those bits in the word which verified incorrectly) up to a maximum of eight attempts for any given word. If a word does not program within eight attempts, it should be considered a programming reject.
17) Repeat steps 4 through 16 for all other words in the PROM.

## POST PROGRAMMING VERIFICATION

18) Place the PROM in the post-programming verify mode. $\overline{\mathrm{E}}=$ $\mathrm{VIH}, \overline{\mathrm{G}}=\mathrm{VIL}, \overline{\mathrm{P}}=\mathrm{VIH} . \operatorname{VCC}($ pin 24 $)=$ VCC1.
19) Apply the correct binary address of the word to be verified.
20) After a delay of td, apply $\bar{E}=$ VIL.
21) After a delay of td apply $\overline{\mathrm{G}}=$ VIH to disable the outputs (outputs are tied to VCC through pull-up resistors Rn).
22) After a delay of td apply $\bar{P}=$ VIL.
23) After a delay of td apply $\bar{E}=$ VIH for duration TEHEL, then apply $\bar{E}=$ VIL.
24) After a delay $=$ TELPH2 apply $\bar{P}=V I H$.
25) After a delay of td apply $\bar{G}=$ VIL to enable the outputs. After a delay of td examine the outputs for correct data.
26) Repeat steps 19 through 25 for all possible address locations.

## POST PROGRAMMING READ

27) Apply $\mathrm{VCC2}=4.0 \mathrm{~V}$ to $\mathrm{VCC}($ pin 24 $)$.
28) After a delay of td, apply $\bar{E}=$ VIH.
29) Apply the correct binary address of the word to be read.
30) After a delay of TAVEL, apply $\bar{E}=$ VIL.
31) After a delay of TELQV, examine the outputs for correct data. If any bit verifies incorrectly, the device is to be considered a programming reject.
32) Repeat steps 28 thru 31 for all other words in the PROM.
33) Repeat steps 27 thru 32 for VCC2 $=6.0 \mathrm{~V}$ applied to $\operatorname{VCC}($ pin 24).

Figure 3 - Programming and Verify Cycle


Figure 4 - Post Programming Verify \& Read Cycle


| SYMBOL | PARAMETER | MIN | TYP. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIL <br> VIH (1) | $\begin{array}{ll} \text { Input } & " 0 \text { "" } \\ \text { Voltage } & " 1 \text { "" } \end{array}$ | $\begin{array}{r} 0.0 \\ \text { VCC-2 } \end{array}$ | $\begin{array}{r} 0.2 \\ \mathrm{VCC} \end{array}$ | $\begin{array}{r} 0.8 \\ \mathrm{VCC}+0.3 \end{array}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |
| VCCPROG(2) VCC1 VCC2 (3) | Programming VCC Operating VCC <br> Special Verify VCC | $\begin{array}{r} 13.5 \\ 4.5 \\ 4.0 \end{array}$ | $\begin{array}{r} 14.0 \\ 5.0 \\ --- \end{array}$ | $\begin{array}{r} 14.0 \\ 5.5 \\ 6.0 \end{array}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ |
| td | Delay Time | 1.0 | 1.0 | ---- | us |
| $\begin{aligned} & \mathrm{tr} \\ & \mathrm{tf} \end{aligned}$ | Programming VCC Rise and Fall Times | $\begin{aligned} & 1.0 \\ & 1.0 \end{aligned}$ | $\begin{aligned} & 10.0 \\ & 10.0 \end{aligned}$ | $\begin{aligned} & 10.0 \\ & 10.0 \end{aligned}$ | us <br> us |
| TEHEL | Chip Enable Pulse Width | 50 | ---- | ---- | ns |
| TAVEL | Address valid to Chip Enable low time | 20 | ---- | ---- | ns |
| TELQV | Chip Enable low to Output Valid time | -..- | ---- | 120 | ns |
| $\begin{aligned} & \text { TELPH1 (4) } \\ & \text { TELPH2 (5) } \end{aligned}$ | $\begin{aligned} & \bar{E} \text { Low to } \\ & \bar{P} \text { High Time } \end{aligned}$ | $\begin{array}{r} 400 \\ 5.0 \end{array}$ | $\begin{array}{r} 500 \\ 5.0 \end{array}$ | $\begin{array}{r} 600 \\ 10.0 \end{array}$ | $\begin{aligned} & \text { us } \\ & \text { us } \end{aligned}$ |
| tpw (6) | Programming Pulse Width | 0.9 | 1.0 | 1.1 | ms |
| IIP | Input Leakage at VCC $=$ VCCPROG | -10 | +1.0 | 10 | uA |
| IOP | Data Output Current at VCC = VCCProg | -- | $-5.0$ | -10 | mA |
| Rn (7) | Output pull-up resistor | 5 | 10 | 15 | kohms |
| Ta | Ambient Temperature | --.- | 25 | ---- | ${ }^{\circ} \mathrm{C}$ |

Notes: 1) All inputs must track VCC(pin 24) within these limits
2) VCCPROG must be capable of supplying 500 mA .
3) See steps 27 thru 33 of the programming algorithm.
4) See steps $13 \& 14$ of the programming algorithm.
5) See steps $23 \& 24$ of the programming algorithm.
6) See step 10 of the programming algorithm.
7) All outputs should be pulled up to VCC thru a resistor of value Rn.

## Preview

## Features

- 175ns MAXIMUM ADDRESS ACCESS TIME
- LOW STANDBY CURRENT - $\mathbf{1 0 0} \mu$ a MAXIMUM OVER THE VOLTAGE AND TEMPERATURE RANGE
- LOW OPERATING CURRENT - $\mathbf{1 0 m a}$ AT $\mathbf{1 M H z}$
- JEDEC STANDARD $28-P I N$ DIP
- PIN COMPATIBLE WITH 2764 UV EPROM
- ASYNCHRONOUS OPERATION
- "THREE STATE" OUTPUT CONTROL WITH $\overline{\mathrm{G}}$, AND $\bar{E}$
- GATED inputs - removing the need for pull-up or PULL-DOWN RESISTORS
- SELF-POWER DOWN in the read mode


## Pinout

TOP VIEW DIP

| VPP 1 | 28 | $\square \mathrm{Vcc}$ |
| :---: | :---: | :---: |
| A12 2 | 27 | 日 ${ }^{\text {P }}$ |
| A7 3 | 26 | $\square \mathrm{NC}$ |
| A6 4 | 25 | $\square \mathrm{AB}$ |
| A5-5 | 24 | A9 |
| A4 6 | 23 | A11 |
| A3 ${ }^{-1}$ | 22 | $\underline{G}$ |
| A2-8 | 21 | A10 |
| A1) 9 | 20 | 日 $\overline{\text { E }}$ |
| AO 10 | 19 | Q7 |
| 00.11 | 18 | -66 |
| Q1512 | 17 | 05 |
| $02 \mathrm{Cl}^{13}$ | 16 | $\square 04$ |
| GND- 14 | 15 | O3 |

## Description

The HM-6664 is a 65,536 bit fuse link CMOS PROM in an 8 K word by 8 bit/word format with "Three State" outputs. This PROM is available in the JEDEC standard 28 pin $0.600^{\prime \prime}$ wide DIP.

The HM-6664 utilizes advanced design techniques coupled with the Harris advanced self-aligned silicon gate CMOS process technology. This provides a high speed PROM with ultra-low standby current. Low ICCSB is ideal for battery applications or other systems with low power requirements.

The Harris polysilicon fuse link technology is utilized on this and all other Harris CMOS PROMS. This gives the user a PROM with permanent, stable storage characteristics over the full industrial and military temperature and voltage ranges. Polysilicon fuse technology combined with the low power characteristics of CMOS provides an excellent alternative to standard Bipolar PROMS or NMOS EPROMS.

This PROM has a chip enable input $\bar{E}$ and an output enable
input $\overline{\mathrm{G}}$. The output enable input is used to "Three State" the output buffers by bringing $\overline{\mathrm{G}}$ high. Bringing the chip enable input $\bar{E}$ high will "Three State" the output buffers, place the device in the standby power mode and gate the input buffers. Gated input buffers allow the user to float the inputs after chip enable $\overline{\mathrm{E}}$ has gone high without exceeding the ICCSB specification due to excessive current drain in the input buffers. This eliminates the need for pull-up or pull-down resistors.

In addition, there is an input edge activated, retriggerable one-shot circuit internal to the HM-6664 which automatically reduces the supply current to the power down standby mode (ICCPD) after an address transition has been made and no further input transitions are made for approximately 1 micro second. The device will stay in the power down mode until another input transition takes place.

All bits are manufactured storing a logical " 0 " and can be selectively programmed for a logical " 1 " at any bit location.

Functional Diagram


# Data Entry Formats for Harris Custom Programming* 

For Harris to custom program to a user data pattern specification, the user must supply the data in one of the following formats:

1. Master PROM of same organization and pinout as device ordered. Two pieces required, three preferred.
2. Paper tape in Binary or ASCII BPNF.

## * BINARY PAPER TAPE FORMAT

- A minimum of six inches of leader.
- A rubout (all eight locations punched).
- Data words beginning with the first word (word " 0 "), proceeding sequentially, ending with the last word (word " $N$ "), with no interruptions or extraneous characters of any kind.
- Specify whether a punched hole is a $\mathrm{VOH}=" 1$ " = logic high or is a $\mathrm{VOL}=" 0^{\prime \prime}=$ logic low.
- A minimum trailer of six inches of tape.


## * ASCII BPNF FORMAT

- A minimum leader of twenty rubouts (all eight locations punched).
- Any characters desired (none necessary) except "B'".
- Data words beginning with the first word (word " 0 "), proceeding sequentially, ending with the last word (word " N ").
- Data words consist of:

1. The character " $B$ " denoting the beginning of a data word.
2. A sequence of characters, only " $P$ " or " $N$ ", one character for each bit in the word.
3. The character "F" denoting the finish of the data word.

- No extraneous characters of any kind may appear within a data word (between any " $B$ " and the next " $F$ ").
- Errors may be deleted by rubouts superimposed over the entire word including the " $B$ ", and beginning the word again with a new " $B$ ".
- Any text of any kind (except the character " $B$ ") is allowed between data words (between any " $F$ " and the next " $B$ "), including carriage return and line feed.
- A minimum trailer of twenty-five rubouts.
- Specify whether a " $P$ " is a " 1 " = VOH = logic high or is a " $O$ " = VOL = logic low.
- The use of even or odd parity is optional.
* Harris can not assume responsibility for PROMs programmed to data tapes or masters which contain errors. The user must insure the accuracy of the data provided to Harris. Harris guarantees that the programmed PROMs will contain the information provided if either of the following formats are followed.


Punched Hole $=" 0$ ' $=$ VOL $=$ Logic Low

| Word |  |  |  | PROM Output Data (1) |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AX $\cdots$ A2 | A1 | A0 |  | Channel Output | $\begin{gathered} 8 \\ 0_{8} \end{gathered}$ | $\begin{gathered} 7 \\ 07 \end{gathered}$ | $\begin{gathered} 6 \\ \mathrm{O}_{6} \end{gathered}$ | $\begin{gathered} 5 \\ \mathrm{O}_{5} \end{gathered}$ | $\begin{gathered} 4 \\ \mathrm{O}_{4} \end{gathered}$ | $\begin{gathered} 3 \\ \mathrm{O}_{3} \end{gathered}$ | $\begin{gathered} 2 \\ \mathrm{O}_{2} \end{gathered}$ | 1 0 0 |
| $0 \cdots 0$ | 0 | 0 | First |  | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |
| $0 \cdots 0$ | 0 | 1 | Second |  | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 |
| $0 \cdots 0$ | 1 | 0 | Third |  | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 |
| $0 \cdots 0$ | 1 | 1 | Fourth |  | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |
| $0 \cdots 1$ | 0 | 0 | Fifth |  | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
| $1 \cdots{ }^{1}$ | 1 | 1 | Last |  | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 |

NOTES:
(1) PROMs with 4 bit wide data outputs require punching only first 4 channels on tape (Channels 1 thru 4).
(2) On HARRIS PROMS $O_{X}$ (Example: $O_{1}$ ) designates a respective output pin on the device. $\mathrm{O}_{1}$ (Output 1 ) is always LSB.

## DEVICE OUTPUT PACKAGE PINS

EXAMPLE:

$$
\text { V } 678 \circ 911121314
$$


Output 8 (08)
Output $1\left(0_{1}\right)$

| Package | Device Type |
| :---: | :---: |
| 16 Pin CMOS | $\mathrm{HM}-6611$ |



## Preview CMOS HPL ${ }^{\text {TM }}$ Harris Programmable Logic

## Features

- PIN \& FUNCTION COMPATIBLE WITH THE BIPOLAR 16L8 PALTM
- SCALED SAJI IV CMOS PROCESS
- FAST ACCESS (INPUT TO OUTPUT)
- LOW STANDBY AND OPERATING POWER

90nsec. MAX.
ICCSB $150 \mu \mathrm{~A}$ ICCOP $10 \mathrm{~mA} / \mathrm{MHz}$

- INDUSTRIAL AND MILITARY TEMPERATURE RANGES
- 20 PIN SLIMLINE DIP
- SECURITY FUSE FOR PATTERN PROTECTION
- TTL/CMOS COMPATIBLE INPUTS/OUTPUTS FOR MIXED SYSTEM COMPATIBILITY
- RELIABLE POLYSILICON FUSE TECHNOLOGY
- LOGIC PATHS TESTED TO INSURE FUNCTIONALITY


## Applications

- RANDOM LOGIC REPLACEMENT
- CODE CONVERTORS
- ADDRESS DECODING
- FAULT DETECTORS
- BOOLEAN FUNCTION GENERATORS
- DIGITAL MULTIPLEXERS
- PARITY GENERATORS
- PATTERN RECOGNITION
- ROM PATCHING


## Pinout



## Description

The HPL-16LC8 is a programmable CMOS logic device which is designed to provide a high performance, low power alternative to the industry standard bipolar 16L8 programmable logic device.

The Harris polysilicon fuse link technology provides a permanent fuse with stable storage characteristics over the full industrial/military temperature and voltage ranges. Like all Harris

Programmable Logic (HPL), this device contains unique test circuitry developed by Harris which allows full AC, DC and functional testing before programming.

On-chip automatic power-down circuitry places internal circuitry into an ultra-low ICCSB power mode after output data becomes valid.

[^5]

## Preview <br> CMOS HPL ${ }^{\text {M }}$ Harris Programmable Logic

## Features

- PIN \& FUNCTION COMPATIBLE WITH THE BIPOLAR 16R4, 16R6, 16R8 PALs ${ }^{\text {TM }}$
- SCALED SAJI IV CMOS PROCESS
- FAST ACCESS (INPUT TO OUTPUT)
- LOW STANDBY AND OPERATING POWER

90nsec. MAX,
ICCSB $150 \mu \mathrm{~A}$ ICCOP $10 \mathrm{~mA} / \mathrm{MHz}$

- 20 PIN SLIMLINE DIP
- SECURITY FUSE FOR PATTERN PROTECTION
- TTL/CMOS COMPATIBLE INPUTS/OUTPUTS FOR MIXED SYSTEM COMPATIBILITY
- RELIABLE POLYSILICON FUSE TECHNOLOGY
- LOGIC PATHS TESTED TO INSURE FUNCTIONALITY
- INDUSTRIAL AND MILITARY TEMPERATURE RANGES


## Applications

- RANDOM LOGIC REPLACEMENT
- CODE CONVERTORS
- ADDRESS DECODING
- CUSTOM SHIFT REGISTERS
- bOOLEAN FUNCTION GENERATORS
- DIGITAL MULTIPLEXERS
- PARITY GENERATORS
- PATTERN RECOGNITION
- STATE MACHINE DESIGN


HPL-16RC6



80C86 Family
Product Index ..... 3-2
CMOS 80C86 Family
Harris/Intel Cross-Reference ..... 3-3
Product Information ..... 3-4
$\qquad$

## CMOS 80C86 Family Product Index

HARRIS $80 C 86$ FAMILY DATA SHEETS ..... PAGE
$80 C 86$ 16 Bit Microprocessor ..... 3-4
82C52 Full Duplex UART ..... 3-27
82C54 Programmable Interval Timer ..... 3-28
82C55A Programmable Peripheral Interface ..... 3-43
82C59A Priority Interrupt Controller ..... 3-62
HD-6406 Programmable Asynchronous Communications ..... 3-76Interface
82C82 Octal Latch ..... 3-77
82C84A Clock Generator/Driver ..... 3-82
82C88 Bus Controller ..... 3-89
PREVIEW OF FUTURE HARRIS $80 C 86$ FAMILY PRODUCTS
80C88 8 Bit Microprocessor ..... 3-96
82C37A High Performance Programmable DMA ..... 3-97
82C83 Octal Latching Inverting Bus Driver ..... 3-98
82C84B Clock Generator/Driver ..... 3-99
82C86 Octal Bus Transceiver ..... 3-100
82C87 Octal Bus Transceiver ..... 3-101
82C89 Bus Arbiter ..... 3-102

## HARRIS CMOS 80C86 Family Cross-Reference

| INTEL | DESCRIPTION | HARRIS EQUIVALENT |
| :---: | :---: | :---: |
| $80 \mathrm{C86}$ CMOS 16 Bit Microprocessor |  |  |
| $\begin{aligned} & \text { D8086 } \\ & \text { ID8086 } \\ & \text { MD8086/B } \end{aligned}$ | Commercial temp, ceramic or plastic pkg Industrial temp, ceramic or plastic pkg Military temp range, ceramic pkg with DASH 8 processing without DASH 8 processing | CD80C86 or CP80C86 ID80C86 or IP80C86 <br> MD80C86/B MD80C86 |
| 82C54 CMOS Programmable Timer |  |  |
| $\begin{aligned} & \text { P8254 } \\ & \text { D8254 } \\ & \text { MD8254/B } \end{aligned}$ | Commercial temp, plastic pkg Commercial temp, ceramic pkg Military temp, ceramic pkg with DASH 8 processing without DASH 8 processing | CP82C54 CD82C54 <br> MD82C54/B <br> MD82C54 |
| 82C55A CMOS Programmable Peripheral Interface (PPI) |  |  |
| $\begin{aligned} & \text { P8255A } \\ & \text { D825AA } \\ & \text { P8255A-5 } \\ & \text { D825A-5 } \\ & \text { D8255A } \\ & \text { MD8255A/B } \end{aligned}$ | Commercial temp, plastic pkg, 2 MHz Commercial temp, ceramic pkg, 2 MHz Commercial temp, plastic pkg, 3 MHz Commercial temp, ceramic pkg, 3 MHz Industrial temp, ceramic pkg, 2 MHz Military temp range, ceramic pkg with DASH 8 processing without DASH 8 processing | CP82C55A <br> CD82C55A <br> CP82C55A <br> CD82C55A <br> IP82C55A or ID82C55A <br> MD82C55A/B <br> MD82C55A |
| 82C59A CMOS Interrupt Controller |  |  |
| D8259A P8259A D8259A-2 <br> P8259A-2 <br> D8259A-8 <br> P8259A-8 <br> ID8259A <br> MD8259A | Commercial temp range, ceramic pkg, 5 MHz Commercial temp range, plastic pkg, 5 MHz Commercial temp range, ceramic pkg, 8 MHz Commercial temp range, plastic pkg, 8 MHz Commercial temp range, ceramic pkg, 2 MHz Commercial temp range, plastic pkg, 2 MHz Industrial temp range, ceramic or plastic pkg Military temp, ceramic pkg with DASH 8 processing without DASH 8 processing | CD82C59A <br> CP82C59A <br> CD82C59A <br> CP82C59A <br> CD82C59A <br> CP82C59A <br> IP82C59A or ID82C59A <br> MD82C59A/B <br> MD82C59A |
| $82 \mathrm{C82}$ CMOS Octal Non-inverting Latching Bus Driver |  |  |
| $\begin{aligned} & \text { D8282 } \\ & \text { P8282 } \\ & 108282 \\ & \text { MD8282/B } \end{aligned}$ | Commercial temp range, ceramic pkg Commercial temp range, plastic pkg Industrial temp range, ceramic pkg Military temp range, ceramic pkg with DASH 8 processing without DASH 8 processing | $\begin{aligned} & \text { CD82C82 } \\ & \text { CP82C82 } \\ & \text { 1P82C82 or ID82C82 } \\ & \text { MD82C82/B } \\ & \text { MD82C82 } \end{aligned}$ |
| 82C84A CMOS Clock Generator Driver |  |  |
| $\begin{aligned} & \text { P8284A } \\ & \text { D8284A } \\ & \text { ID8284A } \\ & \text { MD8284A/B } \end{aligned}$ | Commercial temp, plastic pkg Commercial temp, ceramic pkg Industrial temp, ceramic pkg Military temp, ceramic pkg with DASH 8 processing without DASH 8 processing | CP82C84A <br> CD82C84A <br> IP82C84A or ID82C84A <br> MD82C84A/B <br> MD82C84A |
| $82 \mathrm{C88}$ CMOS Bus Controller |  |  |
| $\begin{aligned} & \text { D8288 } \\ & \text { 1D8288 } \\ & \text { MD8288/B } \end{aligned}$ | Commercial temp, ceramic or plastic pkg Industrial temp, ceramic pkg Military temp, ceramic pkg with DASH 8 processing without DASH 8 processing | $\begin{aligned} & \text { DP82C88 or CD82C88 } \\ & \text { IP82C88 or ID82C88 } \\ & \text { MD82C88/B } \\ & \text { MD82C88 } \end{aligned}$ |

$80 C 86$
CMOS
Advance Information

## Features

- COMPATIBLE WITH NMOS 8086
- COMPLETELY STATIC DESIGN - OPERATION FROM DC TO 5MHz
- LOW POWER OPERATION
- ICCSB $=500 \mu$ A MAXIMUM
- ICCOP $=10 \mathrm{~mA} / \mathrm{MHz}$ TYPICAL
- 1 MBYTE OF DIRECT MEMORY ADDRESSING CAPABILITY
- 24 OPERAND ADDRESSING MODES
- BIT, BYTE, WORD, AND BLOCK MOVE OPERATIONS
- 8 and 16 BIT SIGNED/UNSIGNED ARITHMETIC
- BINARY or DECIMAL

MULTIPLY and DIVIDE

- BUS-HOLD CIRCUITRY ELIMINATES PULL-UP RESISTORS
- SCALED SAJI IV CMOS PROCESS
- SINGLE 5V POWER SUPPLY
- COMMERCIAL, INDUSTRIAL and MILITARY TEMPERATURE RANGES


## Description

The Harris 80 C 86 high performance 16 bit CMOS CPU is manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV).Two modes of operation, MINimum for small systems and MAXimum for larger applications such as multi-processing, allow user configuration to achieve the highest performance level. Full TTL compatibility and industry standard operation allow use of existing NMOS 8086 hardware and software designs.

## Pinout

MAX (MIN)

| GND 1 | 40 | $\square V_{C C}$ |
| :---: | :---: | :---: |
| AD14 2 | 39 | $\square$ AD15 |
| AD13 3 | 38 | A $16 / 53$ |
| AD12 4 | 37 | A17/S4 |
| AD11 | 36 | A18/S5 |
| AD10 6 | 35 | A19/S6 |
| AD9 7 | 34 | $\square \overline{\mathrm{BHE} / \mathrm{S7}}$ |
| AD8 8 | 33 | $\square M N / \overline{M X}$ |
| $A D 7$ | 32 | $\square \overline{\mathrm{RD}}$ |
| AD6 10 | 8008631 | $\square \overline{R Q} / \overline{\mathrm{GTO}}$ (HOLD) |
| $A D 511$ | 30 | ] $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ (HLDA) |
| AD4 12 | 29 | $\overline{\text { LOCK ( }}$ ( $\overline{\mathrm{FR}}$ ) |
| $A D 3$ | 28 | $\overline{\mathrm{S} 2} \quad(\mathrm{M} / \overline{\mathrm{I}})$ |
| $A D 2$ | 27 | $\square \overline{\mathrm{S} 1}$ (DT/ $\overline{\mathrm{R}})$ |
| AD1 15 | 26 | $\square \overline{\text { SO }}$ (DEN) |
| ADO 16 | 25 | ] OSO (ALE) |
| NMI 17 | 24 | $\square$ OS1 ( $\overline{\mathrm{NTTA}})$ |
| INTR 18 | 23 | TEST |
| CLK 19 | 22 | IREADY |
| GND 20 | 21 | $\square \mathrm{RESET}$ |

## Functional Diagram



CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

## $80 C 86$

## Pin Description

The following pin function descriptions are for 80 C 86 systems in either minimum or maximum mode. The "Local Bus" in these descriptions is the direct multiplexed bus
interface connection to the 80C86 (without regard to additional bus buffers).

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $A D_{15}-A D_{0}$ | 2-16, 39 | 1/0 | ADDRESS DATA BUS: These lines constitute the time multiplexed memory/10 address ( $\mathrm{T}_{1}$ ) and data $\left(T_{2}, T_{3}, T_{W}, T_{4}\right)$ bus. $A_{0}$ is analogous to $\overline{B H E}$ for the lower byte of the data bus, pins $D_{7}-D_{0}$. It is LOW during $\mathrm{T}_{1}$ when a byte is to be transferred on the lower portion of the bus in memory or 1/O operations. Eight-bit oriented devices tied to the lower half would normally use $A_{0}$ to condition chip select functions (See $\overline{\mathrm{BHE}}$ ). These lines are active HIGH and float to 3 -state OFF during interrupt acknowledge and local bus "hold acknowledge." |
| $\mathrm{A}_{19} / \mathrm{S}_{6}$ <br> $\mathrm{A}_{18} / \mathrm{S}_{5}$ <br> $\mathrm{A}_{17} / \mathrm{S}_{4}$ <br> $\mathrm{A}_{16} / \mathrm{S}_{3}$ | 35-38 | 0 | ADDRESS/STATUS: During $T_{1}$, these are the four most significant address lines for memory operations. During I/O operations these lines are LOW. During memory and I/O operations, status information is available on these lines during $T_{2}, T_{3}, T_{W}$, and $T_{4}$. The status of the interrupt enable FLAG bit $\left(S_{5}\right)$ is updated at the beginning of each CLK cycle. $A_{17} / S_{4}$ and $A_{16} / S_{3}$ are encoded as shown in (Table 1). <br> This information indicates which relocation register is presently being used for data accessing. <br> These lines float to 3-state OFF during local bus "hold acknowledge." |
| $\overline{\mathrm{BHE}} / \mathrm{S}_{7}$ | 34 | 0 | BUS HIGH ENABLE/STATUS: During $T_{1}$ the bus high enable signal (BHE) should be used to enable data onto the most significant half of the data bus, pins $\mathrm{D}_{15}-\mathrm{D}_{8}$. Eight bit oriented devices tied to the upper half of the bus would normally use $\overline{\mathrm{BHE}}$ to condition chip select functions. BHE is LOW during $\mathrm{T}_{1}$ for read, write, and interrupt acknowledge cycles when a byte is to be transferred on the high portion of the bus. The $\mathrm{S}_{7}$ status information is available during $\mathrm{T}_{2}, \mathrm{~T}_{3}$, and $\mathrm{T}_{4}$. The signal is active LOW, and floats to 3-state OFF in "hold". It is LOW during T1for the first interrupt acknowledge cycle. (See Table 2) |
| $\overline{R D}$ | 32 | 0 | READ: Read strobe indicates that the processor is performing a memory of 1/O read cycle, depending on the state of the $\overline{S_{2}}$ pin. This signal is used to read devices which reside on the 80 C 86 local bus. $\overline{\mathrm{RD}}$ is active LOW during $T_{2}, T_{3}$, and $T_{W}$ of any read cycle, and is guaranteed to remain HIGH in $T_{2}$ until the 80 C 86 local bus has floated. <br> This signal floats to 3-state OFF in "hold acknowledge." |
| READY | 22 | 1 | READY: is the acknowledgement from the addressed memory or $I / O$ device that will complete the data transfer. The RDY signal from memory/10 is synchronized by the 82C84A Clock Generator to form READY. This signal is active HIGH. The 80C86 READY input is not synchronized. Correct operation is not guaranteed if the setup and hold times are not met. |
| INTR | 18 | 1 | INTERRUPT REQUEST: a level triggered input which is sampled during the last clock cycle of each instruction to determine if the processor should enter into an interrupt acknowledge operation. A subroutine is vectored to via an interrupt vector lookup table located in system memory. It can be internally masked by software resetting the interrupt enable bit. INTR is internally synchronized. This signal is active HIGH. |
| TEST | 23 | 1 | TEST: input is examined by the "Wait" instruction. If the TEST input is LOW execution continues, otherwise the processor waits in an "Idle" state. This input is synchronized internally during each clock cycle on the leading edge of CLK. |
| NMI | 17 | 1 | NON-MASKABLE INTERRUPT: an edge triggered input which causes a type 2 interrupt. A subroutine is vectored to via an interrupt vector lookup table located in system memory. NMI is not maskable internally by software. A transition from a LOW to HIGH initiates the interrupt at the end of the current instruction. This input is internally synchronized. |
| RESET | 21 | 1 | RESET: causes the processor to immediately terminate its present activity. The signal must be active HIGH for at least four clock cycles. It restarts execution, as described in the Instruction Set description, when RESET returns LOW. RESET is internally synchronized. |
| CLK | 19 | 1 | CLOCK: provides the basic timing for the processor and bus controller. It is asymmetric with a $33 \%$ duty cycle to provide optimized internal timing. |
| VCC | 40 |  | VCC: +5 V power supply pin. |
| GND | 1,20 |  | GND: Ground Note: both must be connected. |
| $\mathrm{MN} / \overline{\mathrm{MX}}$ | 33 | 1 | MINIMUM/MAXIMUM: Indicates what mode the processor is to operate in. The two modes are discussed in the following sections. |

## Pin Description

The following pin function descriptions are for the 80C86/ 82 C 88 system in maximum mode (i.e., $M N / \overline{M X}=G N D$ ). Only the pin functions which are unique to maximum
mode are described; all other pin functions are as described above.

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $\overline{s_{0}}, \overline{s_{1}}, \overline{s_{2}}$ | 26-28 | 0 | STATUS: active during $T_{4}, T_{1}$, and $T_{2}$ and is returned to the passive state $(1,1,1)$ during $T_{3}$ or during TW when READY is HIGH. This status is used by the $82 \mathrm{C88}$ Bus Controller to generate all memory and I/O access control signals. Any change by $\overline{S_{2}}, \overline{S_{1}}$, or $\overline{S_{0}}$ during $T_{4}$ is used to indicate the beginning of a bus cycle, and the return to the passive state in $\mathrm{T}_{3}$ or $\mathrm{TW}_{W}$ is used to Indicate the end of a bus cycle. These signals float to 3 -state OFF in "hold acknowledge. These status lines are encoded as shown in Table 3. |
| $\begin{aligned} & \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{0} \\ & \overline{\mathrm{RQ}} / \mathrm{GT}_{1} \end{aligned}$ | 30, 31 | 1/0 | REQUEST/GRANT: pins are used by other local bus masters to force the processor to release the local bus at the end of the processor's current bus cycle. Each pin is bidirectional with $\overline{\mathrm{RO}} / \overline{\mathrm{GT}} 0$ having higher priority than $\overline{R Q} / \overline{G T} 1 . \overline{R Q} / \overline{\mathrm{GT}}$ has an internal pull-up bus hold device so It may be left unconnected. The request/grant sequence is as follows (see Waveform Section): <br> 1. A pulse of 1 CLK wide from another local bus master Indicates a local bus request ("hold") to the $80 C 86$ (pulse 1). <br> 2. During a $T_{4}$ or $T_{\text {}}$ clock cycle, a pulse 1 CLK wide from the $80 C 86$ to the requesting master (pulse 2), Indlcates that the $80 C 86$ has allowed the local bus to float and that It will enter the "hold acknowledge" state at the next CLK. The CPU's bus interface unit is disconnected logically from the local bus during "hold acknowledge." <br> 3. A pulse 1 CLK wide from the requesting master Indicates to the $80 \mathrm{C86}$ (pulse 3) that the "hold" request is about to end and that the $80 \mathrm{C86}$ can reclalm the local bus at the next CLK. <br> Each master-master exchange of the local bus is a sequence of 3 pulses. There must be one dead CLK cycle after each bus exchange. Pulses are active LOW. <br> If the request is made while the CPU is performing a memory cycle, it will release the local bus during $\mathrm{T}_{4}$ of the cycle when all the following conditions are met: <br> 1. Request occurs on or before $\mathrm{T}_{2}$. <br> 2. Current cycle is not the low byte of a word (on an odd address). <br> 3. Current cycle is not the first acknowledge of an Interrupt acknowledge sequence, <br> 4. A locked Instruction is not currently excuting. <br> If the local bus is ide when the request is made the two possible events will follow: <br> 1. Local bus will be released during the next clock. <br> 2. A memory cycle will start within three clocks. Now the four rules for a currently active memory cycle apply with condition number 1 already satisfied. |
| $\overline{\text { LOCK }}$ | 29 | 0 | LOCK: output indicates that other system bus masters are not to gain control of the system bus while $\overline{\text { LOCK }}$ is active LOW. The LOCK signal is activated by the "LOCK" prefix instruction and remains active until the completion of the next instruction. This signal is active LOW, and floats to 3-state OFF in "hold acknowledge." In MAX mode, LOCK is automatically generated during T2 of the first INTA cycle and removed during $\mathrm{T}_{2}$ of the second INTA cycle, |
| $\mathrm{OS}_{1}, \mathrm{OS}_{0}$ | 24, 25 | 0 | QUEUE STATUS: The queue status is valid during <br> the CLK cycle after which the queue operation QS $_{1}$  OS  <br> is performed. 0 (LOW) 0 No Operation  <br>   0 1 First Byte of Op Code from Queue |


| $\mathbf{A}_{17} / \mathbf{S}_{\mathbf{4}}$ | A $_{\mathbf{1 6}} / \mathbf{S}_{\mathbf{3}}$ | CHARACTERISTICS |
| :---: | :---: | :--- |
| 0 (LOW) | 0 | Alternate Data |
| 0 | 1 | Stack |
| 1 (HIGH) | 0 | Code or None |
| 1 | 1 | Data |
| $\mathrm{S}_{6}$ is 0 (LOW) |  |  |

Table 1.

| BHE | A $_{0}$ | CHARACTERISTICS |
| :---: | :---: | :--- |
| 0 | 0 | Whole word <br> Upper byte from/ $/$ <br> to odd addess <br> Lower byte from/ |
| 1 | 0 | Lo even address <br> to e <br> None |
| 1 | 1 |  |

Table 2.

| $\overline{\mathbf{S}_{\mathbf{2}}}$ | $\overline{\mathbf{s}_{\mathbf{1}}}$ | $\overline{\mathbf{S}_{\mathbf{0}}}$ | CHARACTERISTICS |
| :---: | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt |
| 0 | 0 | 1 | Acknowedge |
| 0 | 0 | 0 | Read $/ 10$ Port |
| 0 | 1 | 0 | Write I/O Port |
| 0 | 1 | 1 | Halt |
| $1(H I G H)$ | 0 | 0 | Code Access |
| 1 | 0 | 1 | Read Memory |
| 1 | 1 | 0 | Write Memory |
| 1 | 1 | 1 | Passive |

Table 3.

## Pin Description

The following pin function descriptions are for the 80C86 in minimum mode (i.e. $M N / \overline{M X}=V_{C C}$ ). Only the pin
functions which are unique to minimum mode are described; all other pin functions are as described above.

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| M/ $\overline{10}$ | 28 | $\bigcirc$ | STATUS LINE: logically equivalent to $\mathbf{S}_{2}$ in the maximum mode. It is used to distinguish a memory access from an I/O access. $\mathrm{M} / \overline{\mathrm{IO}}$ becomes valid in the $T_{4}$ preceding a bus cycle and remains valid until the final $\mathrm{T}_{4}$ of the cycle ( $\mathrm{M}=\mathrm{HIGH}, \mathrm{IO}=\mathrm{LOW}$ ). $\mathrm{M} / \overline{\mathrm{O}}$ floats to 3-state OFF in local bus "hold acknowledge". |
| $\overline{W R}$ | 29 | $\bigcirc$ | WRITE: Indicates that the processor is performing a write memory or write I/O cycle, depending on the state of the $M / \overline{\mathrm{CO}}$ signal. $\overline{\mathrm{WR}}$ is active for $\mathrm{T}_{2}, T_{3}$, and $T_{W}$ of any write cycle. It is active LOW, and floats to 3-state OFF in local bus "hold acknowledge". |
| INTA | 24 | 0 | INTERRUPT ACKNOWLEDGE: is used as a read strobe for interrupt acknowledge cycles. It is active LOW during $T_{2}, T_{3}$, and $T_{W}$ of each interrupt acknowledge cycle. Note that INTA is never floated. |
| ALE | 25 | 0 | ADDRESS LATCH ENABLE: provided by the processor to latch the address into the 82C82 address latch. It is a HIGH pulse active during $\mathrm{T}_{1}$ of any bus cycle. Note that ALE is never floated. |
| DT/R | 27 | $\bigcirc$ | DATA TRANSMIT/RECEIVE: needed in minimum system that desires to use a data bus transceiver. It is used to control the direction of data flow through the transceiver. Logically, DT/ $\overline{\mathrm{R}}$ is equivalent to $\overline{\mathbf{S}_{1}}$ in maximum mode, and its timing is the same as for $\mathrm{M} / \overline{\mathrm{IO}}(\mathrm{T}=\mathrm{HIGH}, \mathrm{R}=$ LOW). DT/ $\overline{\mathrm{R}}$ floats to 3-state OFF in local bus "hold acknowledge." |
| $\overline{\text { DEN }}$ | 26 | 0 | DATA ENABLE: provided as an output enable for a bus transceiver in a minimum system which uses the transceiver. DEN is active LOW during each memory and I/O access and for INTA cycles. For a read or INTA cycle it is active from the middle of $T_{2}$ until the middie of $T_{4}$, while for a write cycle it is active from the beginning of $T_{2}$ until the middle of $T_{4}$. DEN floats to 3 -state OFF in local bus "hold acknowledge." |
| $\begin{aligned} & \text { HOLD } \\ & \text { HLDA } \end{aligned}$ | $\begin{aligned} & 31, \\ & 30 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | HOLD: indicates that another master is requesting a local bus "hold". To be a acknowledged, HOLD must be active HIGH. The processor receiving the "hold" will issue a "hold acknowledge" (HLDA) in the middle of a $T_{4}$ or $T_{1}$ clock cycle. Simultaneous with the issuance of HLDA, the processor will float the local bus and control lines. After HOLD is detected as being LOW, the processor will LOWer HLDA, and when the processor needs to run another cycle, it will again drive the local bus and control lines. <br> The same rules as for $\overline{R Q} / \overline{G T}$ apply regarding when the local bus will be released. HOLD is not an asynchronous input. External synchronization should be provided if the system cannot otherwise guarantee the setup time. |

## Functional Description

## Static Operation

All 80C86 circuitry is of static design. Internal registers, counters and latches are static and require no refresh as with dynamic circuit design. This eliminates the minimum operating frequency restriction placed on other microprocessors. The CMOS $80 C 86$ can operate from DC to the appropriate upper frequency limit. The processor clock may be stopped in either state (high/low) and held there indefinitely. This type of operation is especially useful for system debug or power critical applications.

The 80C86 can be single stepped using only the CPU clock. This state can be maintained as long as is necessary during debug. Single step clock operation allows simple interface
circuitry to provide critical information for bringing up your system.

Static design also allows very low frequency operation (down to DC). In a power critical situation, this can provide extremely low power operation since 80 C 86 power dissipation is directly related to operating frequency. As the system frequency is reduced, so is the operating power until, ultimately, at a DC input frequency, the $80 C 86$ power requirement is the standby current. ( $500 \mu \mathrm{~A}$ maximum)

## Internal Architecture

The internal functions of the 80C86 processor are partitioned logically into two processing units. The first is the

Bus Interface Unit (BIU) and the second is the Execution Unit (EU) as shown in the CPU functional diagram.

These units can interact directly but for the most part perform as separate asynchonous operational processors. The bus interface unit provides the functions related to instruction fetching and queuing, operand fetch and store, and address relocation. This unit also provides the basic bus control. The overlap of instruction pre-fetching provided by this unit serves to increase processor performance through improved bus bandwidth utilization. Up to 6 bytes of the instruction stream can be queued while waiting for decoding and execution.

The instruction stream queuing mechanism allows the BIU to keep the memory utilized very efficiently. Whenever there is space for at least 2 bytes in the queue, the BIU will attempt a word fetch memory cycle. This greatly reduces "dead time" on the memory bus. The queue acts as a First-In-First-Out (FIFO) buffer, from which the EU extracts instruction bytes as required. If the queue is empty (following a branch instruction, for example), the first byte into the queue immediately becomes available to the EU.

The execution unit receives pre-fetched instructions from the BIU queue and provides un-relocated operand addresses to the BIU. Memory operands are passed through the BIU for processing by the EU, which passes results to the BIU for storage.

## Memory Organization

The processor provides a 20-bit address to memory, which locates the byte being referenced. The memory is organized as a linear array of up to 1 million bytes, addressed as $00000(\mathrm{H})$ to $\operatorname{FFFFF}(\mathrm{H})$. The memory is logically divided into code, data, extra data, and stack segments of up to 64 K bytes each, with each segment falling on 16 -byte boundaries. (See Figure 1).


Figure 1. 80C86 Memory Organization
All memory references are made relative to base addresses contained in high speed segment registers. The segment types were chosen based on the addressing needs of programs. The segment register to be selected is automatically chosen according to specific rules of operation. All information in one segment type share the same logical attributes (e.g. code or data). By structuring memory into relocatable areas of similar characteristics and by automatically selecting segment registers, programs are shorter, faster, and more structured. (See Table 4).

Word (16-bit) operands can be located on even or odd address boundaries and are thus not constrained to even boundaries as is the case in many 16 -bit computers. For address and data operands, the least significant byte of the

| TYPE OF MEMORY REFERENCE | DEFAULT <br> SEGMENT <br> BASE | ALTERNATE <br> SEGMENT <br> BASE | OFFSET |
| :--- | :---: | :---: | :--- |
| Instruction Fetch | CS | NONE | IP |
| Stack Operation | SS | NONE | SP |
| Variable (except following) | DS | CS, ES, SS | Effective Address |
| String Source | DS | CS, ES, SS | SI |
| String Destination | ES | NONE | DI |
| BP Used As Base Register | SS | CS, DS, ES | Effective Address |

Table 4.
word is stored in the lower valued address location and the most significant byte in the next higher address location. The BIU automatically performs the proper number of memory accesses, one if the word operand is on an even byte boundary and two is it is on an odd byte boundary. Except for the performance penalty, this double access is transparent to the software. The performance penalty does not occur for instruction fetches; only word operands.

Physically, the memory is organized as a high bank (D15D8) and a low bank (D7-DO) of 512 K 8 -bit bytes addressed in parallel by the processor's address lines.

Byte data with even addresses is transferred on the D7-DO bus lines while odd addressed byte data (AO HIGH) is transferred on the D15-D8 bus lines. The processor provides two enable signals. $\overline{\mathrm{BHE}}$ and AO to selectively allow reading from or writing into either an odd byte location, even byte location, or both. The instruction stream is fetched from memory as words and is addressed internally by the processor at the byte level as necessary.

In referencing word data, the BIU requires one or two memory cycles depending on whether the starting byte of the word is on an even or odd address, respectively. Consequently, in referencing word operands performance can be optimized by locating data on even address boundaries. This is an especially useful technique for using the stack, since odd address references to the stack may adversely affect the context switching time for interrupt processing or task multiplexing.

Certain locations in memory are reserved for specific CPU operations (See Figure 2). Locations from address FFFFOH


Figure 2. Reserved Memory Locations
through FFFFFH are reserved for operations including a jump to the initial program loading routine. Following RESET, the CPU will always begin execution at location FFFFOH where the jump must be. Locations 00000 H through 003FFH are reserved for interrupt operations. Each of the 256 possible interrupt types has its service routine pointed to be a 4-byte pointer element consisting of a 16 -bit segment address and a 16 -bit offset address. The pointer elements are assumed to have been stored at the respective places in reserved memory prior to occurrence of interrupts.

## Minimum and Maximum Operation Modes

The requirements for supporting minumum and maximum 80 C 86 systems are sufficiently different that they cannot be met efficiently using 40 uniquely defined pins. Consequently, the $80 C 86$ is equipped with a strap pin ( $\mathrm{MN} / \overline{\mathrm{MX} \text { ) }}$ which defines the system configuration. The definition of a certain subset of the pins changes dependent on the condition of the strap pin. When the $M N / \overline{M X}$ pin is strapped to GND, the 80C86 treats pins 24 through 31 in maximum mode. An 82 C 88 bus controller interprets status information coded into $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{~S}_{2}}$ to generate bus timing and control signals compatible with the MULTIBUS © architecture. When the $M N / \overline{M X}$ pin is strapped to VCC, the $80 C 86$ generates bus control signals itself on pins 24 through 31.

## Bus Operation

The 80C86 has a combined address and data bus commonly referred to as a time multiplexed bus. This technique provides the most efficient use of pins on the processor while permitting the use of a standard 40 -lead package. This "local bus" can be buffered directly and used throughout the system with address latching provided on memory and I/O modules. In addition, the bus can also be demultiplexed at the processor with a single set of 82 C 82 address latches if a standard non-multiplexed bus is desired for the system.

Each processor bus cycle consists of at least four CLK cycles. These are referred to as $T_{1}, T_{2}, T_{3}$ and $T_{4}$ (see Figure 3). The address is emitted from the processor during $T_{1}$ and data transfer occurs on the bus during $T_{3}$ and $T_{4}$. $T_{2}$ is used primarily for changing the direction of the bus during read operations. In the event that a "NOT READY" indication is given by the addressed device, "Wait" states (TW) are inserted between $\mathrm{T}_{3}$ and $\mathrm{T}_{4}$. Each inserted "Wait" state is of the same duration as a CLK cycle. Periods between 80 C 86 bus cycles are referred to as "idle" states ( $T_{1}$ ) or inactive CLK cycles. The processor uses these cycles for internal housekeeping and processing.

During $T_{1}$ of any bus cycle, the ALE (Address Latch Enable) signal is emitted (by either the processor or the
(10) MULTIBUS is an Intel Trademark


Figure 3. Basic System Timing

82 C 88 bus controller, depending on the $\mathrm{MN} / \overline{\mathrm{MX}}$ strap). At the trailing edge of this pulse, a valid address and certain status information for the cycle may be latched.

Status bits $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}_{1}}$, and $\overline{\mathrm{S}_{2}}$ are used, in maximum mode, by the bus controller to identify the type of bus transaction according to the following table:

| $\overline{\mathbf{S}_{\mathbf{2}}}$ | $\overline{\mathbf{S}_{1}}$ | $\overline{\mathbf{S}_{0}}$ | CHARACTERISTICS |
| :--- | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt Acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Instruction Fetch |
| 1 | 0 | 1 | Read Data from Memory |
| 1 | 1 | 0 | Write Data to Memory |
| 1 | 1 | 1 | Passive (no bus cycle) |

Table 5.

Status bits $\mathrm{S}_{3}$ through $\mathrm{S}_{7}$ are time multiplexed with high order address bits and the $\overline{\mathrm{BHE}}$ signal, and are therefore valid during $T_{2}$ through $T_{4} . S_{3}$ and $S_{4}$ indicate which segment register (see Instruction Set description) was used for this bus cycle in forming the address, according to the following table:

| $\mathbf{S}_{\mathbf{4}}$ | $\mathbf{S}_{\mathbf{3}}$ | CHARACTERISTICS |
| :--- | :--- | :--- |
| 0 (LOW) | 0 | Alternate Data (extra segment) |
| 0 | 1 | Stack |
| 1 (HIGH) | 0 | Code or None |
| 1 | 1 | Data |

Table 6.
$\mathrm{S}_{5}$ is a reflection of the PSW interrupt enable bit. $\mathrm{S}_{6}$ is undefined and $\mathrm{S}_{7}$ is a spare status bit.

## I/O Addressing

In the 80C86, I/O operations can address up to a maximum of $64 \mathrm{~K} 1 / \mathrm{O}$ byte registers on $32 \mathrm{~K} 1 / \mathrm{O}$ word registers. The I/O address appears in the same format as the memory address on bus lines A15-A0. The address lines A19-A16 are zero in I/O operations. The variable I/O instructions which use register DX as a pointer have full address capability while the direct I/O instructions directly address one or two of the $256 \mathrm{I} / \mathrm{O}$ byte locations in page 0 of the I/O address space.

I/O ports are addressed in the same manner as memory locations. Even addressed bytes are transferred on the D7-D0 bus lines and odd addressed bytes on D15-D8. Care must be taken to ensure that each register within an 8 -bit peripheral located on the lower portion of the bus be addressed as even.

## External Interface

## Processor Reset and Initialization

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The 80C86 RESET is required to be HIGH for greater than 4 CLK cycles. The 80C86 will terminate operations on the high-going edge of RESET and will remain dormant as long as RESET is HIGH. The low-going transition of RESET triggers an internal reset sequence. After this interval, the 80 C 86 operates normally beginning with the instruction in absolute location FFFFOH. The RESET input is internally synchronized to the processor clock. At initialization, the HIGH-to-LOW transition of RESET must occur no sooner than $50 \mu \mathrm{~s}$ (or 4 CLK cycles, whichever is greater) after power-up, to allow complete initialization of the 80 C 86 .


Figure 4. Interrupt Acknowledge Sequence

NMI may not be asserted prior to the second CLK cycle following the end of RESET.

## Bus Hold Circuitry

To avoid high current conditions caused by floating inputs to CMOS devices, "bus-hold" circuitry has been used on the 80C86 pins 2-16, 26-32, and 34-39. These circuits will maintain the last valid logic state if no driving source is present (i.e. àn unconnected pin or a driving source which goes to a high impedance state). To overdrive the "bus hold" circuits, an external driver must be capable of supplying approximately $400 \mu \mathrm{~A}$ minimum sink or source current at valid input voltage levels. Since this "bus hold" circuitry is active and not a "resistive" type element, the associated power supply current is negligible and power dissipation is significantly reduced when compared to the use of passive pull-up resistors.

## Interrupt Operations

Interrupt operations fall into two classes; software or hardware initiated. The software initiated interrupts and software aspects of hardware interrupts are specified in the Instruction Set description in the 80C86 data sheet. Hardware interrupts can be classified as non-maskable or maskable.

Interrupts result in a transfer of control to a new program location. A 256 -element table containing address pointers to the interrupt service program locations resides in absolute locations 0 through 3FFH, which are reserved for this purpose. Each element in the table is 4 bytes in size and corresponds to an interrupt "type". An interrupting device supplies an 8-bit type number during the interrupt acknowledge sequence, which is used to "vector" through the appropriate element to the new interrupt service program location. All flags and both the Code Segment and Instruction Pointer registers and saved as part of the INTA sequence. These are restored upon execution of an Interrupt Return (IRET) instruction.

## Non-Maskable Interrupt (NMI)

The processor provides a single non-maskable interrupt pin (NMI) which has higher priority than the maskable interrupt request pin (INTR). A typical use would be to activate a power failure routine. The NMI is edge-triggered on a LOW-to-HIGH transition.

NMI is required to have a duration in the HIGH state of greater than two CLK cycles, but is not required to be synchronized to the clock. Any positive transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves of a blocktype instruction. Worst case response to NMI would be for
multiply, divide, and variable shift instructions. There is no specification on the occurrence of the low-going edge; it may occur before, during, or after the servicing of NMI. Another positive edge triggers another response if it occurs after the start of the NMI procedure. The signal must be free of logical spikes in general and be free of bounces on the low-going edge to avoid triggering extraneous responses.

## Maskable Interrupt (INTR)

The 80C86 provides a single interrupt request input (INTR) which can be masked internally by software with the resetting of the interrupt enable FLAG status bit. The interrupt request signal is level triggered. It is internally synchronized during each clock cycle on the high-going edge of CLK. To be responded to, INTR must be present (HIGH) during the clock period preceding the end of the current instruction or the end of a whole move for a blocktype instruction. During the interrupt response sequence further interrupts are disabled. The enable bit is reset as part of the response to any interrupt (INTR, NMI, software interrupt or single-step), although the FLAGS register which is automatically pushed onto the stack reflects the state of the processor prior to the interrupt. Until the old FLAGS register is restored the enable bit will be zero unless specifically set by an instruction.

During the response sequence (Figure 4) the processor executes two successive (back-to-back) interrupt acknowledge cycles. The $80 C 86$ emits the LOCK signal from $T_{2}$ of the first bus cycle until $T_{2}$ of the second. A local bus "hold" request will not be honored until the end of the second bus cycle. In the second bus cycle, a byte is supplied to the 80 C 86 by the 82C59A Interrupt Controller, which identifies the source (type) of the interrupt. This byte is multiplied by four and used as a pointer into the interrupt vector look-up table. An INTR signal left HIGH will be continually responded to within the limitations of the enable bit and sample period. The INTERRUPT RETURN instruction includes a FLAGS pop which returns the status of the original interrupt enable bit when it restores the FLAGS.

## Halt

When a software "HALT" instruction is executed the processor indicates that it is entering the "HALT" state in one of two ways depending upon which mode is strapped. In minimum mode, the processor issues one ALE with no qualifying bus control signals. In maximum mode, the processor issues appropriate HALT status on $\overline{\mathrm{S}_{2}}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{~S}_{0}}$ and the 82 C 88 bus controller issues one ALE. The 80 C 86 will not leave the "HALT" state when a local bus "hold" is entered while in "HALT". In this case, the processor reissues the HALT indicator. An NMI or interrupt request (when interrupts enabled) at the end of the bus hold period or RESET will force the 80 C 86 out of the "HALT" state.

## Read/Modify/Write (Semaphore)

## Operations Via Lock

The $\overline{\text { LOCK }}$ status information is provided by the processor when directly consecutive bus cycles are required during the execution of an instruction. This gives the processor the capability of performing read/modify/write operations on memory (via the Exchange Register With Memory instruction, for example) without the possibility of another system bus master receiving intervening memory cycles. This is useful in multiprocessor system configurations to accomplish "test and set lock" operations. The LOCK signal is activated (forced LOW) in the clock cycle following the one in which the software "LOCK" prefix instruction is decoded by the EU. It is deactivated at the end of the last bus cycle of the instruction following the "LOCK" prefix instruction. While $\overline{\text { LOCK }}$ is active a request on a $\overline{\mathrm{RO}} / \overline{\mathrm{GT}}$ pin will be recorded and then honored at the end of the $\overline{\text { LOCK. }}$

## External Synchronization Via TEST

As an alternative to the interrupts and general $1 / O$ capabilities, the 80C86 provides a single software testable input known as the TEST signal. At any time the program may execute a WAIT instruction. If at that time the TEST signal is inactive (HIGH), program execution becomes suspended while the processor waits for TEST to become active. It must remain active for at least five CLK cycles. The WAIT instruction is re-executed repeatedly until that time. This activity does not consume bus cycles. The processor remains in idle state while waiting. All 80 C 86 drivers go to 3 -state OFF if bus "Hold" is entered. If interrupts are enabled, they may occur while the processor is waiting. When this occurs the processor fetches the WAIT instruction on extra time, processes the interupt, and then refetches and re-executes the WAIT instruction upon returning from the interrupt.

## Basic System Timing

Typical system configurations for the processor operating in minimum mode and in maximum mode are shown in Figures $5 a$ and $5 b$, respectively. In minimum mode, the $M N / \overline{M X}$ pin is strapped to VCC and the processor emits bus control signals (e.g. $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, etc.) directly. In maximum mode, the $M N / \overline{M X}$ pin is strapped to GND and the processor emits coded status information which the 82 C 88 bus controller used to generate MULTIBUS © ${ }^{\text {comp- }}$ atible bus control signals. Figure 3 shows the signal timing relationships.


Table 7. 80C86 Register Model

## System Timing - Minimum System

The read cycle begins in $\mathrm{T}_{1}$ with the assertion of the Address Latch Enable (ALE) signal. The trailing (low-going) edge of this signal is used to latch the address information, which is valid on the local bus at this time, into the 82C82 latch. The $\overline{\mathrm{BHE}}$ and $\mathrm{A}_{0}$ signals address the low, high, or both bytes. From $\mathrm{T}_{1}$ to $\mathrm{T}_{4}$ the $\mathrm{M} / \overline{\mathrm{IO}}$ signal indicates a memory or $\mathrm{I} / \mathrm{O}$ operation. At $\mathrm{T}_{2}$, the address is removed from the local bus and the bus goes to a high impedance state. The read control signal is also asserted at $T_{2}$. The read ( $\overline{\mathrm{RD}}$ ) signal causes the addressed device to enable its data bus drivers to the local bus. Some time later, valid data will be available on the bus and the addressed device will drive the READY line HIGH. When the processor returns the read signal to a HIGH level, the addressed device will again 3-state its bus drivers. If a transceiver is required to buffer the 80 C 86 local bus, signals $D T / \bar{R}$ and $\overline{\mathrm{DEN}}$ are provided by the 80 C 86 .

A write cycle also begins with the assertion of ALE and the emission of the address. The $M / \overline{\mathrm{O}}$ signal is again asserted to indicate a memory or I/O write operation. In $\mathrm{T}_{2}$, immediately following the address emission, the processor emits the data to be written into the addressed location. This data remains valid until the middle of $\mathrm{T}_{4}$. During $\mathrm{T}_{2}$, $T_{3}$ and $T_{W}$, the processor asserts the write control signal. The write ( $\overline{\mathrm{WR}}$ ) signal becomes active a the beginning of $T_{2}$ as opposed to the read which is delayed somewhat into $\mathrm{T}_{2}$ to provide time for the bus to float.


Figure 5a. Minimum Mode 80 C 86 Typical Configuration


Figure 5b. Maximum Mode $80 \mathrm{C86}$ Typical Configuration

The $\overline{B H E}$ and $A_{0}$ signals are used to select the proper byte(s) of the memory/IO word to be read or written according to the following table:

| BHE | AO | CHARACTERISTICS |
| :---: | :---: | :---: |
| 0 | 0 | Whole word <br> 0 |
| 1 | 0 | Upper byte from/ <br> to odd address <br> Lower byte from/ <br> to even address <br> None |
| 1 | 1 |  |

Table 8,

I/O ports are addressed in the same manner as memory location. Even addressed bytes are transferred on the D7DO bus lines and odd addressed bytes on D15-D8.

The basic difference between the interrupt acknowledge cycle and a read cycle is that the interrupt acknowledge signal (INTA) is asserted in place of the read ( $\overline{\mathrm{RD}}$ ) signal and the address bus is floated. (See Figure 4). In the second of two successive INTA cycles, a byte of information is read from bus lines D7-DO as supplied by the interrupt system logic (i.e., 82C59A Priority Interrupt Controller). This byte identifies the source (type) of the interrupt. It is multiplied by four and used as a pointer into an interrupt vector lookup table, as described earlier.

## Bus Timing - Medium Size Systems

For medium size systems the $M N / \overline{M X}$ pin is connected to GND and the 82C88 Bus Controller is added to the system as well as an $82 C 82$ latch for latching the system address, and a transceiver to allow for bus loading greater than the $80 C 86$ is capable of handling. ALE, $\overline{D E N}$, and DT/ $\overline{\mathrm{R}}$ are generated by the $82 C 88$ instead of the processor in this configuration, although their timing remains relatively the same. The 80 C 86 status outputs ( $\overline{\mathrm{S}_{2}}, \overline{\mathrm{~S}_{1}}$, and $\overline{\mathrm{S}_{0}}$ ) provide type-of-cycle information and become $82 \mathrm{C88}$ inputs. This bus cycle information specifies read (code, data, or I/O), write (data or I/O), interrupt acknowledge, or software halt. The 82 C 88 thus issues control signals specifying memory read or write, I/O read or write, interrupt acknowledge, or halt. The 82C88 provides two types of write strobes, normal and advanced, to be applied as required. The normal write strobes have data valid at the leading edge of write. The advanced write strobes have the same timing of write. The transceiver receives the usual $T$ and $\overline{O E}$ inputs from the $82 C 88 D T / \bar{R}$ and $\overline{D E N}$ signals.

The pointer into the interrupt vector table, which is passed during the second INTA cycle, can be derived from an 82C59A located on either the local bus or the system bus. If the master 82C59A Priority Interrupt Controller is positioned on the local bus, a TTL gate is required to disable the transceiver when reading from the master 82C59A during the interrupt acknowledge sequence and software "poll".

## Specifications

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 Volts |
| :--- | ---: |
| Operating Voltage Range | +4 V to +7 V |
| Input Voltage Applied | GND -2.0 V to 6.5 V |
| Output Voltage Applied | GND -0.5 V to $\mathrm{VCC}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | -650 C to $+150^{\circ} \mathrm{C}$ |


| Operating Temperature Range |  |
| :--- | ---: |
| Commercial | 00 C to $+70{ }^{\circ} \mathrm{C}$ |
| Industrial | $-40 \mathrm{C}^{\circ}$ to +850 C |
| Military | $-55 \mathrm{C}^{\circ} \mathrm{C}$ to +1250 C |
| Maximum Power Dissipation | 1 Watt |

CAUTION: Stresses above those listed in the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Specifications (continued)

D.C. ELECTRICAL CHARACTERISTICS
$\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C80C86); $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 180 C 86 ); $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C86)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ |  | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & \text { C80C86, } 180 \text { C86 } \\ & \text { M80C86 } \end{aligned}$ |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| VIHC | CLK Logical One Input Voltage | VCC -0.8V |  | V |  |
| VILC | CLK Logical Zero Input Voltage |  | 0.8 | V |  |
| VOH | Output High Voltage | $\begin{gathered} 3.0 \\ \text { VCC }-0.4 \end{gathered}$ |  | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & 1 O H=-2.5 \mathrm{~mA} \\ & 1 \mathrm{OH}=-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | Output Low Voltage |  | 0.4 | V | $1 \mathrm{OL}=+2.5 \mathrm{~mA}$ |
| IIL | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VIN} \leq \mathrm{VCC}$ |
| IBHH | Input Leakage Current-Bus Hold High | -40 | -400 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN = 3.0V } \\ & \text { (see Note 1) } \end{aligned}$ |
| IBHL | Input Leakage Current-Bus Hold Low | 40 | 400 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN }=0.8 \mathrm{~V} \\ & \text { (see Note 2) } \end{aligned}$ |
| 10 | Output Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VO} \leq \mathrm{VCC}$ |
| ICCSB | Standby Power Supply Current |  | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V} \\ & \text { VIN }=\text { VCC or GND } \\ & \text { Outputs unloaded } \end{aligned}$ |
| ICCOP | Operating Power Supply Current |  | 10 | $\mathrm{mA} / \mathrm{MHz}$ | $\begin{aligned} & \mathrm{TA}=25^{\circ} \mathrm{C} \\ & \mathrm{VCC}=5 \mathrm{~V}, \mathrm{TYPICAL} \end{aligned}$ |

## CAPACITANCE

$T A=25^{\circ} \mathrm{C} ; \mathrm{VCC}=\mathrm{GND}=\mathrm{OV} ; \mathrm{VIN}=+5 \mathrm{~V}$ or GND

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :---: |
| CIN* | Input Capacitance |  | 5 | pf | FREQ $=1 \mathrm{MHz}$ <br> Unmeasured pins <br> returned to GND |
| COUT* | Output Capacitance |  |  |  |  |
| CI/O* | I/O Capacitance |  | 15 | pf |  |

[^6]Note 1: IBHH should be measured after raising VIN to VCC and then lowering to 3.0 V on the following pins: 2-16, 26-32, 34-39.

Note 2: IBHL should be measured after lowering VIN to GND and then raising to 0.8 V on the following pins: 2-16, 26-32, 34-39.

## A.C. CHARAC TERISTICS

$$
\begin{aligned}
\mathrm{VCC}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V} & : \mathrm{TA}=0^{\circ} \mathrm{C} \text { to }+700^{\circ} \mathrm{C}(\mathrm{CBOC86}) \\
& : \mathrm{TA}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(\mathrm{I} 80 \mathrm{CB6}) \\
& : \mathrm{TA}=-55{ }^{\circ} \mathrm{C} \text { to }+125{ }^{\circ} \mathrm{C}(\mathrm{M} 80 \mathrm{C} 86)
\end{aligned}
$$

MINIMUM COMPLEXITY SYSTEM

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL <br> TCLCH <br> TCHCL <br> TCH1CH2 <br> TCL2CL1 <br> TDVCL <br> TCLDX <br> TR1VCL | CLK Cycle Period CLK Low Time CLK High Time CLK Rise Time CLK Fall Time Data in Setup Time Data in Hold Time RDY Setup Time into 82C84A (see Note 1,2) | $\begin{gathered} 200 \\ 118 \\ 69 \end{gathered}$ | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns |  |
|  |  |  |  |  | From 1.0V to 3.5V |
|  |  |  |  |  | From 3.5V to 1.0 V |
|  |  | 30 |  |  | - |
|  |  | 10 |  |  |  |
|  |  | 35 |  |  |  |
| TCLR1X | RDY Hold Time into 82C84A (see Note 1,2) | 0 |  |  |  |
| TRYHCH | READY Setup Time into 80C86 | 118 |  | ns | $C L=20-100 \mathrm{pF}$ |
| TCHRYX | READY Hold Time into $80 \mathrm{C86}$ | 30 |  | ns | $C L=20-100 p$ |
| TRYLCL | READY Inactive to CLK (see Note 3) | -8 |  | ns |  |
| THVCH <br> TINVCH | HOLD Setup Time INTR, NMI, TEST | $\begin{aligned} & 35 \\ & 30 \end{aligned}$ |  | ns |  |
|  | Setup Time <br> (See Note 2) |  |  |  |  |
| TILIH | Input Rise Time |  | 15 | ns | From 0.8 V to 2.0 V |
| TIHIL | Input Fall Time (Except CLK) |  | 15 | ns | From 2.0 V to 0.8 V |
| TIMING RESPONSES |  |  |  |  |  |
| TCLAV TCLAX TCLAZ TLHLL TCLLH TCHLL TLLAX | Address Valid Delay Address Hold Time Address Float Delay ALE Width ALE Active Delay ALE Inactive Delay Address Hold Time to ALE Inactive | $\begin{gathered} 10 \\ 10 \\ \text { TCLAX } \\ \text { TCLCH-20 } \end{gathered}$ | 110 | ns | $C L=20-100 \mathrm{pF}$ |
|  |  |  |  | ns |  |
|  |  |  | 80 | ns |  |
|  |  |  |  | ns |  |
|  |  |  | 80 | ns |  |
|  |  |  | 85 | ns |  |
|  |  | TCHCL-10 |  | ns |  |
| $\begin{aligned} & \text { TCLDV } \\ & \text { TCHDX } \\ & \text { TWHDX } \end{aligned}$ | Data Valid Delay Data Hold Time | 10 | 110 | ns |  |
|  |  | ${ }_{10}^{10}$ |  | ns |  |
|  | Data Hold Time <br> Data Hold Time <br> After WR | TCLCH-30 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 110 | ns |  |
| TCVCTX | Control Inactive Delay | 10 | 110 | ns |  |
| TAZRL | Address Float to READ Active | 0 |  | ns |  |
| TCLRL TCLRH TRHAV | RD Active Delay RD Inactive Delay RD Inactive to Next Address Active | 10 | 165 | ns |  |
|  |  | 10 | 150 | ns |  |
|  |  | TCLCL-45 |  | ns |  |
| $\begin{aligned} & \text { TCLHAV } \\ & \text { TRLRH } \\ & \text { TWLWH } \\ & \text { TAVAL } \end{aligned}$ | Address Active HLDA Valid Delay RD Width |  | 160 | ns |  |
|  |  | 2TCLCL-75 |  | ns |  |
|  | WR Width | 2TCLCL-60 |  | ns |  |
|  | Address Valid to | TCLCH-60 |  | ns | 1 |
| $\begin{aligned} & \text { TOLOH } \\ & \text { TOHOL } \end{aligned}$ | Output Rise Time Output Fall Time |  | 15 | ns | From 0.8 V to 2.0 V |
|  |  |  | 15 | ns | From 2.0 V to 0.8 V |

NOTES: 1. Signal at 82C84A shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to T2 state (8 ns into T3).

## Waveforms



## Waveforms (continued)

MINIMUM MODE (Continued)


## NOTES:

1. All signals switch between $V_{O H}$ and $V_{O L}$ unless otherwise specified.
2. RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
3. Two INTA cycles run back-to-back. The 80 C86 LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control signals shown for second INTA cycle.
4. Signals at 82C84A are shown for reference only.
5. All timing measurements are made at 1.5 V unless otherwise noted.

$$
\begin{aligned}
\text { A.C. CHARAC TERISTICS } \quad V C C= \pm 5 \mathrm{~V} \pm 10 \%, G N D=0 \mathrm{~V} & : T A=0{ }^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \text { (C80C86) } \\
& : T A=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \text { (I80C86) } \\
\text { MAX MODE SYSTEM (USING 82C88 BUS CONTROLLER) } & : T A=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \text { (M80C86) }
\end{aligned}
$$



| TIMING RESPONSES (Continued) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| TCLRL | RD Active Delay RD Inactive Delay RD Inactive to Next Address Active Direction Control Active Delay (see Note 1) Direction Control Inactive Delay (see Note 1) GT Active Delay GT Inactive Delay RD Width Output Rise Time Output Fall Time | $\begin{gathered} 10 \\ 10 \\ \text { TCLCL-45 } \end{gathered}$ | 165150 | nsnsns |  |
| TCLRH |  |  |  |  | $\mathrm{CL}=20-100 \mathrm{pF}$ |
| TRHAV |  |  |  |  |  |
| TCHDTL |  |  | 50 | ns |  |
|  |  |  |  |  |  |
| TCHDTH |  |  | 30 | ns |  |
|  |  |  |  |  |  |
| TCLGL |  | 0 | 85 | ns |  |
| TCLGH |  | 0 | 85 | ns |  |
| TRLRH |  | 2TCLCL-75 |  | ns |  |
| TOLOH |  |  | 15 | ns | From 0.8V to 2.0V |
| TOHOL |  |  | 15 | ns | From 2.0 V to 0.8 V |

NOTES: 1. Signal at 82C84A or 82C88 shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to $T 3$ and wait states.
4. Applies only to T 2 state ( 8 ns into T 3 ).

## A.C. Test Circuits


*Includes stray and jig capacitance

## A.C. Testing Input, Output Waveform


A. C. Testing: All input signals (other than CLK) must switch between VILmax -0.4 V and $\mathrm{VIH}_{\text {min }}+0.4 \mathrm{~V}$. CLK must switch between 0.4 V and 3.9 V . $T_{R}$ and $T_{F}$ must be less than or equal to 15 ns . CLK $T_{R}$ and $T_{F}$ must be less than or equal to 10 ns .

## Waveforms



## Waveforms (continued)



## NOTES:

1. All signals switch between $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ unless otherwise specified.
2. RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
3. Cascade address is valid between first and second INTA cycle.
4. Two INTA cycles run back-to-back. The $80 C 86$ LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control for pointer address is shown for second INTA cycle.
5. Signals at 82C84A or 82C88 are shown for reference only.
6. The issuance of the 82 C 88 command and control signals ( $\overline{M R D C}, \overline{M W T C}, \overline{A M W C}, \overline{I O R C}, \overline{O W C}, \overline{A D W C}, \overline{I N T A}$ and DEN) lags the active high 82C88 CEN.
7. All timing measurements are made at 1.5 V unless otherwise noted.
8. Status inactive in state just prior to $\mathrm{T}_{4}$.

## Waveforms (continued)

## ASYNCHRONOUS SIGNAL RECOGNITION



NOTE: 1. SETUP REQUIREMENTS FOR ASYNCHRONOUS SIGNALS ONLY TO GUARANTEE RECOGNITION AT NEXT CLK

BUS LOCK SIGNAL TIMING (MAXIMUM MODE ONLY)


RESET TIMING


REQUEST/GRANT SEQUENCE TIMING (MAXIMUM MODE ONLY)

notes.
the coprocessor may not drive the buses outside the region SHE COP WITHOUT RISKING CONTENTION.

HOLD/HOLD ACKNOWLEDGE TIMING (MINIMUM MODE ONLY)


## Instruction Set Summary



## ABITMME TIC

ADO = ANO:
Reg. /mamory with register to either

| 0000000 w | mod 'eg $\mathrm{r} / \mathrm{m}$ |
| :--- | :--- | :--- |
| $10000 \mathrm{~m}^{2}$ | mad |

Immediate to registet/memory Immediate to accumulator

| 0000010 w | data | data $1 \mathrm{~m} / 1$ |
| :--- | :---: | :---: |

ABC = ACA with earry:
Aeg. /mumory with register to either

| $0001000 \%$ | mod reg $\mathrm{t} / \mathrm{m}$ |  |  |
| :---: | :---: | :---: | :---: |
| 100000 sw | mod $010 \mathrm{t} / \mathrm{m}$ | data | datait sw 01 |
| 0001010 w | data | data If ${ }^{\text {d }}$ |  |


| IWC = Meromme: |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Register/memory | 1111111w | $\bmod 000 \mathrm{c} / \mathrm{m}$ |  |  |
| Aegister | 01000 reg |  |  |  |
| MM-ASCll adjust for add | 00110111 |  |  |  |
| ama-oveimal adjust tor add | 00100111 |  |  |  |
| SUE = 8wtruct: |  |  |  |  |
| Rev./memory and regutier to either | 0010100 m | mod reg $1 / \mathrm{m}$ |  |  |
| Immediate from register/memory | 100000 sw | mod $101 \mathrm{l} / \mathrm{m}$ | data | dala it s w 001 |
| immediate from accumulator | 0010110 w | gata | data 11 \| |  |
| 8EA - Ewitruan with merrw |  |  |  |  |
| Reg./memory and register to either | 0001100 m | mod reg $1 / \mathrm{m}$ |  |  |
| Immediate from register/memory | 1000003w | mod $011 \mathrm{l} / \mathrm{m}$ | data | data if 5 w. 01 |
| Immediate from accumulator | 0001110 w | data | data ifw |  |




TEST And function to liage. na result
Register imemory and register
mestate dala anc accumulato

OR Or
Reg /memory and register to ether
immediate to register /memory
immediate to accumulator

| 0000100 m | $\bmod$ reg $\mathrm{c/m}$ |  |  |
| :---: | :---: | :---: | :---: |
| 1000000 m | $\bmod 001 \mathrm{r} / \mathrm{m}$ | data | data itw m |
| 0000110 w | dala | data if wl |  |

xOR Exelusive or:
Reo /memory and register to erthet
immediate to register / memory
immediate to accumulator

| 0011000 w | mod reg $1 / \mathrm{m}$ |  |  |
| :---: | :---: | :---: | :---: |
| 1000000 w | mod 110 lm | data | dataitw 1 |
| 0011010 w | data | dala \|l w 1 |  |

## staing manipulation

| REP $\quad$ Repeat | 11110012 |
| :---: | :---: |
| Movs=Move byte/word | 1010010 w |
| CMPS = Compare byte/word | 1010011 |
| SCAS=SCan byte/word | 1010111 w |
| LOOS*Load byte/wd to AL/AX | 1010110 w |
| STOSEStor byte/wd trom AL/A | 101010 |

3

1000010 w mod res $1 / \mathrm{m}$

| 1111011 m | $\bmod 000 \mathrm{IIm}$ | data | data it w 1 |
| :---: | :---: | :---: | :---: |
| 1010100 w | data | data 1 w 1 |  | 1010101 w

Mnemonics ©Intel, 1978

## CONTROL TRAMSFER

CALL = Call:
Direct within segment
Indirect within segment
Direct intersegment

Indirect intersegment

| 76543210 | 76543210 | 76543210 |
| :---: | :---: | :---: |
| 11101000 | disp-How | disp-high |
| 11111111 | mod $010 \mathrm{r} / \mathrm{m}$ |  |
| 10011010 | offset-tow | offset-high |
|  | seg.low | seg-high |
| 11111111 | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |

JMP = Unconditional Jump:
Direct within segment Direct within segment-short Indirect within segment Direct intersegment

Indirect intersegment

| 1:101001 | disp.10w | disp-high |
| :---: | :---: | :---: |
| 11101011 | disp |  |
| 11111111 | mod $100 \mathrm{f} / \mathrm{m}$ |  |
| 11101010 | offset-10w | oftset-high |
|  | seg.low | seg-high |
| 11111111 | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |

RET : Return from CALL:

## Within segment

Within seg adding immed to SP intersegment
Intersegment. adding immediate to SP

$$
J E / J Z=\text { Jump on equal/zero }
$$

JL/JMGE = Jump on less/not greater JLE/JM or equal
JLE/JMG $=$ Jump on less or equal/not
JB/JMAE Jump on below/not above
JBE/JMA $=$ Jump on below or equal/
not abov
Jo=Jump on overflow
JS-Jump on sign
JME/JWZ = Jump on not equal/not zero JML/JGE = Jump on not less/greater $J W L E / J 6=\begin{gathered}\text { = Jump } \\ \text { greater }\end{gathered}$

| 11000011 |  |  |
| :---: | :---: | :---: |
| 11000010 | data-10w | data.high |
| 11001011 |  |  |
| 11001010 | data $\cdot 10 \mathrm{w}$ | data-high |
| 01110100 | disp |  |
| 01111100 | disp |  |
| 01.111110 | disp |  |
| 01110010 | disp |  |
| 01110110 | disp |  |
| 01111010 | disp |  |
| 01110000 | disp |  |
| 01111000 | disp |  |
| 010110101 | disp |  |
| 01111101 | disp |  |
| 0111111111 | disp |  |

## Footnotes:

$A L=8$-bit accumulator
$A X=16$-bit accumulator
CX = Count register
DS = Data segment
ES = Extra segment
Above/below refers to unsigned value.
Greater = more positive:
Less = less positive (more negative) signed values
if $d=1$ then "to" reg; if $d=0$ then "from" reg
if $w=1$ then word instruction; if $w=0$ then byte instruction
if $\bmod =11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
if $\bmod =00$ then DISP $=0^{*}$. disp-low and disp-high are absent
if mod $=01$ then DISP $=$ disp-low sign-extended to 16 -bits, disp-high is absent
if $\bmod =10$ then DISP $=$ disp-high: disp-low
if $\mathrm{r} / \mathrm{m}=000$ then $E A=(B X)+(S I)+D I S P$
if $r / m=001$ then $E A=(B X)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=010$ then $E A=(B P)+(S I)+D I S P$
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+$ DISP
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then $E A=(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+$ DISP*
if $\mathrm{r} / \mathrm{m}=111$ then $E A=(B X)+$ DISP
DISP follows 2 nd byte of instruction (before data if required)
"except if $\bmod =00$ and $r / m=110$ then $E A=$ disp-high: disp-low.
if $\mathrm{s}: \mathrm{w}=01$ then 16 bits of immediate data form the operand. if $\mathrm{s}: \mathrm{w}=11$ then an immediate data byte is sign extended to form the 16 -bit operand.
if $v=0$ then "count" $=1$; if $v=1$ then "count" in (CL)
$x=$ don't care
$z$ is used for string primitives for comparison with Z.F FLAG.
SEGMENT OVERRIDE PREFIX
001 reg 110

REG is assigned according to the following table:

| 16-8it $(\mathrm{w}=11)$ | 8-Bit ( $\mathbf{w}=0$ ) | Segment |
| :---: | :---: | :---: |
| 000 AX | 000 AL | 00 ES |
| 001 CX | 001 CL | 01 CS |
| $010{ }^{-}$DX | 010 DL | 10 SS |
| 011 BX | 011 BL | 11 DS |
| 100 SP | 100 AH |  |
| 101 BP | 101 CH |  |
| 110 SI | 110 DH |  |
| 111 DI | 111 BH |  |

Instructions which reference the flag register file as a 16 -bit object use the symbol FLAGS to represent the file:
$F L A G S=X: X: X: X:(O F):(D F):(I F):(T F):(S F):(Z F): X:(A F): X:(P F): X:(C F)$

82C52
CMOS Serial
Preview

## Features

- SINGLE CHIP UART/BRG
- DC TO 16MHz OPERATION
- CRYSTAL OR EXTERNAL CLOCK INPUT
- ON CHIP BAUD RATE GENERATOR
... 72 SELECTABLE BAUD RATES
- INTERRUPT MODE WITH MASK CAPABILITY
- MICROPROCESSOR bUS ORIENTED INTERFACE
- $80 C 86$ COMPATIBLE
- SCALED SAJI IV CMOS PROCESS
- SINGLE 5V POWER SUPPLY
- LOW POWER - $\mathbf{1 m A} / \mathrm{MHz}$ TYPICAL
- modem interface
- LINE BREAK GENERATION AND DETECTION
- LOOPBACK AND ECHO MODES


## Description

## Pinout

Top View

| $\overline{R D} \square_{1}$ | 28 | $\overline{\mathrm{CSO}}$ |
| :---: | :---: | :---: |
| WR ${ }^{2}$ | 27 | $\square \mathrm{Vcc}$ |
| DO $\square^{3}$ | 26 | $\square \mathrm{DR}$ |
| D1 | 25 | $\square$ SDI |
| D2 5 | 24 | ] INTR |
| D3 [ 6 | 23 | $\square \mathrm{RST}$ |
| D4 | 22 | $\square \mathrm{TBRE}$ |
| D5 [8 | 21 | $\square \mathrm{CO}$ |
| D6 | 20 | $\square \overline{\text { RTS }}$ |
| D7 10 | 19 | ] DTR |
| AO 11 | 18 | $\square \overline{\mathrm{DSR}}$ |
| A1 12 | 17 | $\square \mathrm{CTS}$ |
| $1 \times 13$ | 16 | $\square \mathrm{GND}$ |
| 0x 단 | 15 | SDO |

The 82C52 is a high performance programmable Universal Asynchronous Receiver/Transmitter (UART) and Baud Rate Generator (BRG) on a single chip. Utilizing the Harris advanced Scaled SAJI IV CMOS process, the 82C52 will support data rates from D.C. to 1M baud asynchronously with a 16X clock ( $0-16 \mathrm{MHz}$ clock frequency).

The on-chip Baud Rate Generator can be programmed for any one of 72 different baud rates using a single industry standard crystal or external frequency source. A unique pre-scale divide circuit has been designed to provide standard RS-232-C baud rates when using any one of three industry standard baud rate crystals ( $1.8432 \mathrm{MHz}, 2.4576 \mathrm{MHz}$, or 3.072 MHz ).

A programmable buffered clock output (CO) is available and can be programmed to provide either a buffered oscillator or 16X baud rate clock for general purpose system usage.

Inputs and outputs have been designed with full TTL/CMOS compatibility in order to facilitate mixed TTL/NMOS/CMOS system design.


CAUTION: These devices are sensitive to electrostatic discharge. Users should follow standard IC Handling Procedures.

## Features

- COMPATIBLE WITH NMOS 8254
-ENHANCED VERSION OF NMOS 8253
- THREE INDEPENDENT 16 BIT COUNTERS
- SIX PROGRAMMABLE COUNTER MODES
- STATUS READ-BACK COMMAND
- BINARY OR 8CD COUNTING
- FULLY TTL COMPATIBLE
- SCALED SAJIIV CMOS PROCESS
- LOW POWER
- ICCSB $=10 \mu \mathrm{~A}$
$-I C C O P=10 \mathrm{~mA} @ 8 \mathrm{MHz}$ COUNT FREQUENCY
- SINGLE 5V POWER SUPPLY
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES


## Description

The Harris 82C54 is a high performance CMOS Programmable Interval Timer manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV). The 82C54 has three independently programmable and functional 16 bit counters, each capable of handling clock input frequencies of up to 8 MHz . The high speed and industry standard configuration of the 82C54 make it compatible with many industry standard microprocessors.

Six programmable timer modes allow the 82C54 to be used as an event counter, elapsed time indicator, programmable one-shot along with many other applications.

Static CMOS circuit design insures low operation power Harris advanced SAJI process results in a significant reduction in power with performance equal to or greater than existing equivalent products.

## Pinout



## Functional Diagram



CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

## Pin Description

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | 1-8 | 1/0 | Data: Bi-directional three state data bus lines, connected to system data bus. |
| CLKO | 9 | 1 | Clock 0: Clock input of Counter 0. |
| OUT 0 | 10 | 0 | Output 0: Output of Counter 0. |
| GATE 0 | 11 | 1 | Gate 0: Gate input of Counter 0 . |
| GND | 12 |  | Ground: Power supply connection. |
| OUT 1 | 13 | 0 | Out 1: Output of Counter 1. |
| GATE 1 | 14 | 1 | Gate 1: Gate input of Counter 1. |
| CLK 1 | 15 | 1 | Clock 1: Clock input of Counter 1. |
| GATE 2 | 16 | 1 | Gate 2: Gate input of Counter 2. |
| OUT 2 | 17 | 0 | Out 2: Output of Counter 2. |
| CLK 2 | 18 | 1 | Clock 2: Clock input of Counter 2. |
| A0, A1 | 19-20 | 1 | Address: Select inputs for one of the three counters or Control Word Register for read/write operations. Normally connected to the system address bus. |
| $\overline{\mathrm{CS}}$ | 21 | 1 | Chip Select: A low on this input enables the 82C54 to respond to $\overline{\mathrm{RD}}$ and $\overline{W R}$ signals. $\overline{\mathrm{RD}}$ and $\overline{W R}$ are ignored otherwise. |
| $\overline{R D}$ | 22 | 1 | Read: This input is low during CPU read operations. |
| $\overline{W R}$ | 23 | 1 | Write: This input is low during CPU write operations. |
| VCC | 24 |  | Power: +5 V power supply connection. |

## Functional Description

## General

The 82C54 is a programmable interval timer/counter designed for use with microcomputer systems. It is a general purpose, multi-timing element that can be treated as an array of I/O ports in the system software.

The 82C54 solves one of the most common problems in any microcomputer system, the generation of accurate time delays under software control. Instead of setting up timing loops in software, the programmer configures the 82C54 to match his requirements and programs one of the counters for the desired delay. After the desired delay, the 82C54 will interrupt the CPU. Software overhead is minimal and variable length delays can easily be accommodated.

Some of the other computer/timer functions common to
microcomputers which can be implemented with the 82C54 are:

- Real time clock
- Event counter
- Digital one-shot
- Programmable rate generator
- Square wave generator
- Binary rate multiplier
- Complex waveform generator
- Complex motor controller


## Data Bus Buffer

This 3-state, bi-directional, 8-bit buffer is used to interface the 82 C 54 to the system bus (see Fiqure 1).


Figure 1. Data Bus Buffer and Read/Write Logic Function

## Read/Write Logic

The Read/Write Logic accepts inputs from the system bus and generates control signals for the other functional blocks of the 82C54. A1 and A0 select one of the three counters or the Control Word Register to be read from/ written into. A "low" on the $\overline{R D}$ input tells the 82C54 that the CPU is reading one of the counters. A "low" on the $\overline{W R}$ input tells the 82C54 that the CPU is writing either a Control Word or an initial count. Both $\overline{R D}$ and $\overline{W R}$ are qualified by $\overline{\mathrm{CS}} ; \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are ignored unless the 82C54 has been selected by holding $\overline{\mathrm{CS}}$ low.

## Control Word Register

The Control Word Register (Figure 2) is selected by the Read/Write Logic when $A 1, A 0=11$. If the $C P U$ then does a write operation to the 82 C 54 , the data is stored in the Control Word Register and is interpreted as a Control Word used to define the Counter operation.

The Control Word Register can only be written to; status information is available with the Read-Back Command.

## Counter 0, Counter 1, Counter 2

These three functional blocks are identical in operation, so only a single Counter will be described. The internal block diagram of a single counter is shown in Figure 3.


Figure 2. Control Word Register and Counter Functions

The Counters are fully independent. Each Counter may operate in a different Mode.

The Control Word Register is shown in the figure; it is not part of the Counter itself, but its contents determine how the Counter operates.


Figure 3. Counter Internal Block Diagram

The status register, shown in the Figure, when latched, contains the current contents of the Control Word Register and status of the output and null count flag. (See detailed explanation of the Read-Back command.)

The actual counter is labeled CE (for "Counting Element). It is a 16-bit presettable synchronous down counter.

OLM and OLL are two 8-bit latches. OL stands for "Output Latch"; the subscripts M and L for "Most significant byte" and "Least significant byte" respectively. Both are normally referred to as one unit and called just OL. These latches normally "follow" the CE, but if a suitable Counter Latch Command is sent to the 82C54, the latches "latch" the present count until read by the CPU and then return to "following" the CE. One latch at a time is enabled by the counter's Control Logic to drive the internal bus. This is how the 16 -bit Counter communicated over the 8 -bit internal bus. Note that the CE itself cannot be read; whenever you read the count, it is the OL that is being read.

Similarly, there are two 8-bit registers called $C R_{M}$ and $C R_{L}$ (for "Count Register"). Both are normally referred to as one unit and called just CR. When a new count is written to the Counter, the count is stored in the CR and later transferred to the CE. The Control Logic allows one register at a time to be loaded from the internal bus. Both bytes are transferred to the CE simultaneously. $C R_{M}$ and $C R_{L}$ and cleared when the Counter is programmed for one byte counts (either most significant byte only or least significant byte only) the other byte will be zero. Note that the CE cannot be written into; whenever a count is written, it is written into the CR.

The Control Logic is also shown in the diagram. CLK $n$, GATE $n$, and OUT $n$ are all connected to the outside world through the Control Logic.

## 82C54 System Interface

The 82C54 is treated by the system software as an array of peripheral I/O ports; three are counters and the fourth is a control register for MODE programming.

Basically, the select inputs A0, A1 connect to the AO, A1 address bus signals of the CPU. The CS can be derived directly from the address bus using a linear select method or it can be connected to the output of a decoder, such as a Harris HD-6440 for larger systems.


Figure 4. 82C54 System Interface

## General

After power-up, the state of the 82C54 is undefined. The Mode, count value, and output of all Counters are undefined.

How each Counter operates is determined when it is programmed. Each Counter must be programmed before it can be used. Unused counters need not be programmed.

## Programming The 82C54

Counters are programmed by writing a Control Word and then an initial count.

All Control Words are written into the Control Word Register, which is selected when $\mathrm{A} 1, \mathrm{AO}=11$. The Control Word specifies which Counter is being programmed.

By contrast, initial counts are written into the Counters, not the Control Word Register. The A1, A0 inputs are used to select the Counter to be written. The format of the initial count is determined by the Control Word used.

Control Word Format

$$
A 1, A 0=11 ; \overline{C S}=0 ; \overline{R D}=1 ; \overline{W R}=0
$$

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC1 | SCO | RW1 | RWO | M2 | M1 | M0 | BCD |


| SC - Select Counter: |
| :--- |
| SC1 |
| SCO |
| 0 |

> RW - Read/Write:
M M MODE:

M2 $\mathbf{\text { M1 }}$ M0 $\quad$| 0 | 0 | 0 | Mode 0 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | Mode 1 |
| $X$ | 1 | 0 | Mode 2 |
| $X$ | 1 | 1 | Mode 3 |
| 1 | 0 | 0 | Mode 4 |
| 1 | 0 | 1 | Mode 5 |

RW1 RW0

| 0 | 0 | Counter Latch Command (see Read <br> Operations) |
| :---: | :---: | :--- |
| 0 | 1 | Read/Write least significant byte only. |
| 1 | 0 | Read/Write most significant byte only. |
| 1 | 1 | Read/Write least significant byte first, <br> then most significant byte. |

## BCD:

| 0 | Binary Counter 16-bits |
| :--- | :--- |
| 1 | Binary Coded Decimal (BCD) Counter <br> (4 Decades) |

NOTE: DON'T CARE BITS (X) SHOULD BE 0 TO INSURE COMPATIBILITY WITH FUTURE PRODUCTS.

Figure 5. Control Word Format

## Write Operations

The programming procedure for the 82C54 is very flexible. Only two conventions need to be remembered:

1. For each Counter, the Control Word must be written before the initial count is written.
2. The initial count must follow the count format specified in the Control Word (least significant byte only, most significant byte only, or least significant byte and then most significant byte).

Since the Control Word Register and the three Counters have separate addresses (selected by the A1, AO inputs), and each Control Word specifies the Counter it applies to (SCO, SC1 bits), no special instruction sequence is required. Any programming sequence that follows the conventions above is acceptable.

A new initial count may be written to a Counter at any time without affecting the Counter's programmed Mode in any way. Counting will be affected as described in the Mode definitions. The new count must follow the programmed count format.

If a Counter is programmed to read/write two-byte counts, the following precaution applies: A program must not transfer control between writing the first and second byte to another routine which also writes into that same Counter. Otherwise, the Counter will be loaded with an incorrect count.

## Read Operations

It is often desirable to read the value of a Counter without disturbing the count in progress. This is easily done in the 82C54.

There are three possible methods for reading the Counters. The first is through the Read-Back command, which is explained later. The second is a simple read operation of the Counter, which is selected with the A1, AO inputs. The only requirement is that the CLK input of the selected Counter must be inhibited by using either the GATE input or external logic. Otherwise, the count may be in process of changing when it is read, giving an undefined result.

| , | $A_{1}$ | $A_{0}$ |  | $A_{1}$ | $A_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Control Word - Counter 0 | 1 | 1 | Control Word - Counter 2 | 1 | 1 |
| LSB of count - Counter 0 | 0 | 0 | Control Word - Counter 1 | 1 | 1 |
| MSB of count - Counter 0 | 0 | 0 | Control Word - Counter 0 | 1 | 1 |
| Control Word - Counter 1 | 1 | 1 | LSB of count - Counter 2 | 1 | 0 |
| LSB of count - Counter 1 | 0 | 1 | MSB of count - Counter 2 | 1 | 0 |
| MSB of count - Counter 1 | 0 | 1 | LSB of count - Counter 1 | 0 | 1 |
| Control Word - Counter 2 | 1 | 1 | MSB of count - Counter 1 | 0 | 1 |
| LSB of count - Counter 2 | 1 | 0 | LSB of count - Counter 0 | 0 | 0 |
| MSB of count - Counter 2 | 1 | 0 | MSB of count - Counter 0 | 0 | 0 |
|  | $A_{1}$ | $A_{0}$ |  | $A_{1}$ | $A_{0}$ |
| Control Word - Counter 0 | 1 | 1 | Control Word - Counter 1 | 1 | 1 |
| Control Word - Counter 1 | 1 | 1 | Control Word - Counter 0 | 1 | 1 |
| Control Word - Counter 2 | 1 | 1 | LSB of count - Counter 1 | 0 | 1 |
| LSB of count - Counter 2 | 1 | 0 | Control Word - Counter 2 | 1 | 1 |
| LSB of count - Counter 1 | 0 | 1 | LSB of count - Counter 0 | 0 | 0 |
| LSB of count - Counter 0 | 0 | 0 | MSB of count - Counter 1 | 0 | 1 |
| MSB of count - Counter 0 | 0 | 0 | LSB of count - Counter 2 | 1 | 0 |
| MSB of count - Counter 1 |  | 1 | MSB of count - Counter 0 | 0 | 0 |
| MSB of count - Counter 2 | 1 | 0 | MSB of count - Counter 2 | 1 | 0 |
| NOTE: IN ALL FOUR EXAMPLES, ALL COUNTERS ARE PROGRAMMED TO READNRITE TWO.bYtE COUNTS. these are only four of many possible programming sequences. |  |  |  |  |  |

Figure 6. A Few Possible Programming Sequences

## Counter Latch Command

The other method involves a special software command called the "Counter Latch Command". Like a Control Word, this command is written to the Control Word Register, which is selected when $A 1, A 0=11$. Also, like a Control Word, the SCO, SC1 bits select one of the three Counters, but two other bits, D5 and D4, distinguish this command from a Control Word.

| $A_{1}, A_{0}=11 ; ~ C S=0 ; ~ R D=1 ; ~ W R=0 ~$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| SC 1 | SC 0 | 0 | 0 | X | X | X | X |

SC1,SC0 - specify counter to be latched

| SC1 | SCO | Counter |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | Read-Back Command |

[^7]Figure 7. Counter Latch Command Format

The selected Counter's output latch (OL) latches the count when the Counter Latch Command is received. This count is held in the latch until it is read by the CPU (or until the Counter is reprogrammed). The count is then unlatched automatically and the OL returns to "following" reading the contents of the Counters "on the fly" without affecting counting in progress. Multiple Counter Latch Commands may be used to latch more than one Counter. Each latched Counter's OL holds its count until read. Counter Latch Commands do not affect the programmed Mode of the Counter in any way.

If a Counter is latched and then, some time later, latched again before the count is read, the second Counter Latch Command is ignored. The count read will be the count at the time the first Counter Latch Command was issued.

With either method, the count must be read according to the programmed format; specifically, if the Counter is programmed for two byte counts, two bytes must be read. The two bytes do not have to be read one right after the other; read or write or programming operations of other Counters may be inserted between them.

Another feature of the 82C54 is that reads and writes of the same Counter may be interleaved; for example, if the Counter is programmed for two byte counts, the following sequence is valid.

1. Read least significant byte.
2. Write new least significant byte.
3. Read most significant byte.
4. Write new most significant byte.

If a Counter is programmed to read or write two-byte counts, the following precaution applies: A program MUST NOT transfer control between reading the first and second byte to another routine which also reads from that same Counter. Otherwise, an incorrect count will be read.

## Read-Back Command

The read-back command allows the user to check the count value, programmed Mode, and current state of the OUT pin and Null Count flag of the selected counter(s).

The command is written into the Control Word Register and has the format shown in Figure 8. The command applies to the counters selected by setting their corresponding bits D3, D2, D1 $=1$.

```
A0.A1=11 }\overline{\textrm{CS}}=0\quad\overline{RD}=1\quad\overline{WR}=
```

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | COUNT | $\overline{\text { STATUS }}$ | CNT 2 | CNT 1 | CNT 0 | 0. |

$\mathrm{D}_{5}: 0=$ LATCH COUNT OF SELECTED COUNTER(S)
$\mathrm{D}_{4}: 0=$ LATCH STATUS OF SELECTED COUNTER(S)
$\mathrm{D}_{3}: 1=$ SELECT COUNTER 2
$\mathrm{D}_{2}: 1=$ SELECT COUNTER 1
$\mathrm{D}_{1}: 1=$ SELECT COUNTER 0
$D_{0}$ : RESERVED FOR FUTURE EXPANSION; MUST EE 0

Figure 8. Read-Back Command Format

The read-back command may be used to latch multiple counter output latches (OL) by setting the COUNT bit D5 $=0$ and selecting the desired counter(s). This single command is functionally equivalent to several counter latch commands, one for each counter latches. Each counter's latched count is held until it is read (or the counter is reprogrammed). That counter is automatically unlatched when read, but other counters remain latched until they are read. If multiple count read-back commands are issued to the same counter without reading the count, all but the first are ignored; i.e., the count which will be read is the count at the time the first read-back command was issued.

The read-back command may also be used to latch status information of selected counter(s) by setting STATUS bit $D 4=0$. Status must be latched to be read; status of a counter is accessed by a read from that counter.

The counter status format is shown in Figure 9. Bits D5 through DO contain the counter's programmed Mode exactly as written in the last Mode Control Word. OUTPUT bit D7 contains the current state of the OUT pin. This allows the user to monitor the counter's output via software, possibly eliminating some, hardware from a system.


Figure 9. Status Byte

NULL COUNT bit D6 indicates when the last count written to the counter register (CR) has been loaded into the counting element (CE). The exact time this happens depends on the Mode of the counter and is described in the Mode Definitions, but until the count is loaded into the counting element (CE), it can't be read from the counter. If the count is latched or read before this time, the count value will not reflect the new count just written. The operation of Null Count is shown in Figure 10.

THIS ACTION:
A. WRITE TO THE CONTROL WORD REGISTER: ${ }^{[1]}$
B. WRITE TO THE COUNT REGISTER (CR); ${ }^{[2]}$
C. NEW COUNT IS LOADED INTO CE (CR $\rightarrow$ CE);
causes:
NULL COUNT=1 NULL COUNT=1 NULL COUNT $=0$
[1] ONLY THE COUNTER SPECIFIED BY THE CONTROL WORD WILL HAVE ITS NULL COUNT SET TO 1. NULL COUNT BITS OF OTHER COUNTERS ARE UNAFFECTED.
[2] IF THE COUNTER IS PROGRAMMED FOR TWO-BYTE COUNTS (LEAST SIGNIFIIANT BYTE THEN MOST SIGNIFICANT BYTE) NULL COUNT
GOES TO 1 WHEN THE SECOND BYTE IS WRITTEN.

Figure 10. Null Count Operation

If multiple status latch operations of the counter(s) are performed without reading the status, all but the first are ignored; i.e., the status that will be read is the status of the counter at the time the first status read-back command was issued.

Both count and status of the selected counter(s) may be latched simultaneously by setting both COUNT and status bits $\mathrm{D} 5, \mathrm{D} 4=0$. This is functionally the same as issuing two separate read-back commands at once, and the above discussions apply here also. Specifically, if multiple count and/or status read-back commands are issued to the same counter(s) without any intervening reads, all but the first are ignored. This is illustrated in Figure 11.

If both count and status of a counter are latched, the first read operation of that counter will return latched status, regardless of which was latched first. The next one or two reads (depending on whether the counter is programmed for one or two type counts) return latched count. Subsequent reads return unlatched count.

| $\overline{\mathbf{C S}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\mathbf{A}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{0}}$ |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | 0 | 0 | Write into Counter 0 |
| 0 | 1 | 0 | 0 | 1 | Write into Counter 1 |
| 0 | 1 | 0 | 1 | 0 | Write into Counter 2 |
| 0 | 1 | 0 | 1 | 1 | Write Control Word |
| 0 | 0 | 1 | 0 | 0 | Read from Counter 0 |
| 0 | 0 | 1 | 0 | 1 | Read from Counter 1 |
| 0 | 0 | 1 | 1 | 0 | Read from Counter 2 |
| 0 | 0 | 1 | 1 | 1 | No-Operation (3-State) |
| 1 | X | X | X | X | No-Operation (3-State) |
| 0 | 1 | 1 | X | X | No-Operation (3-State) |

Figure 12. Read/Write Operations Summary

## Mode Definitions

The following are defined for use in describing the operation of the 82C54.

CLK PULSE: a rising edge, then a falling edge, in that order, of a Counter's CLK input.

TRIGGER: a rising edge of a Counter's Gate input.

## COUNTER

LOADING: the transfer of a count from the CR to the CE (See "Functional Description")

## Mode 0: Interrupt on Terminal Count

Mode 0 is typically used for event counting. After the

Control Word is written, OUT is initially low, and will remain low until the Counter reaches zero. OUT then goes high and remains high until a new count or a new Mode 0 Control Word is written to the Counter.

GATE $=1$ enables counting; GATE $=0$ disables counting. GATE has no effect on OUT.

After the Control Word and initial count are written to a Counter, the initial count will be loaded on the next CLK pulse. This CLK pulse does not decrement the count, so for an intial count of N, OUT does not go high until $\mathrm{N}+1$ CLK pulses after the initial count is written.

If a new count is written to the Counter it will be loaded on the next CLK pulse and counting will continue from the new count. If a two-byte count is written, the following happens:

1 - Writing the first byte disables counting. Out is set low immediately (no clock pulse required).

2 - Writing the second byte allows the new count to be loaded on next CLK pulse.

This allows the counting sequence to be synchronized by software. Again OUT does not go high until $\mathrm{N}+1$ CLK pulses after the new count of $N$ is written.

If an initial count is written while GATE $=0$, it will still be loaded on the next CLK pulse. When GATE goes high, OUT will go high N CLK pulses later; no CLK pulse is needed to load the Counter as this has already been done.

## Mode 1: Hardware Retriggerable One-Shot

OUT will be initially high. OUT will go low on the CLK pulse following a trigger to begin the one-shot pulse, and will remain low until the Counter reaches zero. OUT will then go high and remain high until the CLK pulse after the next trigger.

After writing the Control Word and initial count, the Counter is armed. A trigger results in loading the Counter and setting OUT low on the next CLK pulse, thus starting the one-shot pulse N CLK cycles in duration. The oneshot is retriggerable, hence OUT will remain low for N CLK

pulses after any trigger. The one-shot pulse can be repeated without rewriting the same count into the counter. GATE has no effect on OUT.

If a new count is written to the Counter during a one-shot pulse, the current one-shot is not affected unless the Counter is retriggered. In that case, the Counter is loaded with the new count and the one-shot pulse continues until the new count expires.

## Mode 2: Rate Generator

This Mode functions like a divide-by-N counter. It is typically used to generate a Real Time Clock interrupt. OUT will initially be high. When the initial count has decremented to 1 , OUT goes low for one CLK pulse. OUT then goes high again, the Counter reloads the initial count and the process is repeated. Mode 2 is periodic; the same sequence is repeated indefinitely. For an initial count of $N$, the sequence repeats every N CLK cycles.


Figure 13. Mode 0

Figure 14. Mode 1

GATE $=1$ enables counting; GATE $=0$ disables counting. If GATE goes low during an output pulse, OUT is set high immediately. A trigger reloads the Counter with the initial count on the next CLK pulse; OUT goes low $N$ CLK pulses after the trigger. Thus the GATE input can be used to synchronize the Counter.

After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. OUT goes low $N$ CLK pulses after the initial count is written. This allows the Counter to be synchronized by software also.

Writing a new count while counting does not affect the current counting sequence. If a trigger is received after writing a new count but before the end of the current period, the Counter will be loaded with the new count on the next CLK pulse and counting will continue form the new count. Otherwise, the new count will be loaded at the end of the current counting cycle.


Figure 15. Mode 2

## Mode 3: Square Wave Mode

Mode 3 is typically used for Baud rate generation. Mode 3 is similar to Mode 2 except for the duty cycle of OUT. OUT will initially be high. When half the initial count has expired, OUT goes low for the remainder fo the count. Mode 3 is periodic; the sequence above is repeated indefinitely. An initial count of N results in a square wave with a period of N CLK cycles.

GATE $=1$ enables counting; GATE $=0$ disables counting. If GATE goes low while OUT is low, OUT is set high immediately; no CLK pulse is required. A trigger reloads the Counter with the initial count on the next CLK pulse. Thus the GATE input can be used to synchronize the Counter.

After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. OUT goes low N CLK pulses after the initial count is written. This allows the Counter to be synchronized by software.

Writing a new count while counting does not affect the


Figure 16. Mode 3
current counting sequence. If a trigger is received after writing a new count but before the end of the current half-cycle of the square wave, the Counter will be loaded with the new count on the next CLK pulse and counting will continue from the new count. Otherwise, the new count will be loaded at the end of the current half-cycle.

Mode 3 is implemented as follows:
EVEN COUNTS: OUT is initially high. The initial count is loaded on one CLK pulse and then is decremented by two on succeeding CLK pulses. When the count expires OUT changes value and the Counter is reloaded with the initial count. The above process is repeated indefinitely.

ODD COUNTS: OUT is initially high. The initial count minus one (an even number) is loaded on one CLK pulse and then is decremented by two on succeeding CLK pulses. One CLK pulse after the count expires, OUT goes low and the Counter is reloaded with the initial count minus one. Succeeding CLK pulses decrement the count by two. When the count expires, OUT goes high again and the Counter is reloaded with the initial count minus one. The above process is repeated indefinitely. So for odd counts, OUT will be high for ( $\mathrm{N}+1$ )/2 counts and low for ( $\mathrm{N}-1$ )/2 counts.

## Mode 4: Software Triggered Mode

OUT will be initially high. When the initial count expires, OUT will go low for one CLK pulse and then go high again. The counting sequence is "Triggered" by writing the initial count.

GATE $=1$ enables counting; GATE $=0$ disables counting. GATE going low freezes OUT in current logic state.

After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. This CLK pulse does not decrement the count, so for an initial count of N , OUT does not strobe low until $\mathrm{N}+1$ CLK pulses after the initial count is written.

If a new count is written during counting, it will be loaded on the next CLK pulse and counting will continue from the new count. If a two-byte count is written, the following happens:

1. Writing the first byte has no effect on counting.
2. Writing the second byte allows the new count to be loaded on the next CLK pulse.

This allows the sequence to be "retriggered" by software. OUT strobes low $N+1$ CLK pulses after the new count of $N$ is written.


Figure 17. Mode 4

## Mode 5: Hardware Triggered Strobe (Retriggerable)

OUT will initially be high. Counting is triggered by a rising edge of GATE. When the initial count has expired, OUT will go low for one CLK pulse and then go high again.

After writing the Control Word and initial count, the counter will not be loaded until the CLK pulse after a trigger. This CLK pulse does not decrement the count, so for an initial count of N, OUT does not strobe low until $\mathrm{N}+1$ CLK pulses after trigger.

A trigger results in the Counter being loaded with the initial count on the next CLK pulse. The counting sequence is triggerable. OUT will not strobe low for $\mathrm{N}+1$ CLK pulses after any trigger. GATE has no effect on OUT.

If a new count is written during counting, the current counting sequence will not be affected. If a trigger occurs after the new count is written but before the current count
expires, the Counter will be loaded with the new count on the next CLK pulse and counting will continue from there.

## Operation Common to all Modes

## Programming

When a Control Word is written to a Counter, all Control Logic is immediately reset and OUT goes to a known initial state; no CLK pulses are required for this.

## Gate

The GATE input is always sampled on the rising edge of CLK. In Modes $0,2,3$, and 4 the Gate input is level sensitive, and the logic level is sampled on the rising edge of CLK. In Modes 1, 2, 3, and 5 the GATE input is risingedge sensitive. In these Modes, a rising edge of Gate (trigger) sets an edge-sensitive flip-flop in the Counter. This flip-fiop in the Counter. This flip-flop is reset imme-


Figure 18. Mode 5
diately after it is sampled. In this way, a trigger will be detected no matter when it occurs - a high logic level does not have to be maintained until the next rising edge of CLK. Note that in Modes 2 and 3, the GATE input is both edge- and level-sensitive.

## Counter

New counts are loaded and Counters are decremented on the falling edge of CLK.

The largest possible initial count is 0 ; this is equivalent to 216 for binary counting and 104 for BCD counting.

The Counter does not stop when it reaches zero. In Modes $0,1,4$, and 5 the Counter "wraps around" to the highest count, either FFFF hex for binary counting or 9999 for BCD counting, and continues counting. MOdes 2 and 3 are periodic; the Counter reloads itself with the initial count and continues counting from there.

| Signal Status Modes | Low Or Going Low | Riaing | High |
| :---: | :---: | :---: | :---: |
| 0 | Disables counting | -- | Enables counting |
| 1 | -- | 1) Initiates counting <br> 2) Resets output after next clock | - |
| 2 | 1) Disables counting <br> 2) Sets output immediately high | Initiates counting | Enables counting |
| 3 | 1) Disables counting <br> 2) Sets output Immediately high | Initiates counting | Enables counting |
| 4 | Disables counting | -- | Enables counting |
| 5 | -- | Initiates counting | -- |

Figure 19. Gate Pin Operations Summary

|  |
| :--- |
| $\qquad$Mode Min <br> Count Max <br> Count <br> 0 1 0 <br> 1 1 0 <br> 2 2 0 <br> 3 3 0 <br> 4 1 0 <br> 5 1 0 |
| NOTE: O IS EQUIVALENT TO 2 ${ }^{16}$ FOR BINARY COUNTING AND 10 ${ }^{4}$ FOR |
| BCD COUNTING. |

Figure 20. Minimum and Maximum Initial Counts

## Specifications

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 Volts | Operating Temperature Range |  |
| :--- | ---: | :---: | ---: |
| Operating Voltage Range | +4 V to +7 V | Commercial | 00 C TO $+700^{\circ} \mathrm{C}$ |
| Input Voltage Applied | GND -2.0 V to +6.5 V | Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Output Voltage Applied | GND -0.5 V to VCC +0.5 V | Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $-650^{\circ} \mathrm{C}$ to $+1500^{\circ} \mathrm{C}$ | Maximum Power Dissipation | 1 Watt |

CAUTION: Stresses above those listed in the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## D.C. ELECTRICAL CHARACTERISTICS

$\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 54) ; \mathrm{TA}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}(182 \mathrm{C} 54) ; \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C54)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One | 2.0 |  | v | C82C54, 182C54 |
|  | Input Voltage | 2.2 |  | v | M82C54 |
| VIL | Logical Zero |  | 0.8 | v |  |
|  | Input Voltage |  |  |  |  |
| VOH | Output High Voltage | 3.0 |  | $v$ | $1 \mathrm{OH}=-2.5 \mathrm{~mA}$ |
|  |  | VCC -0.4 |  | v | $10 \mathrm{H}=-100 \mu \mathrm{~A}$ |
| $\begin{aligned} & \text { VOL } \\ & \text { IIL } \end{aligned}$ | Output Low Voltage |  | 0.4 | $v$ | $10 \mathrm{~L}=+2.5 \mathrm{~mA}$ |
|  | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | OV $\leq$ VIN $\leq V C C$ |
| 10 | Output Leakage Current | -10.0 | +10.0 | $\mu \mathrm{A}$ | $\mathrm{ov} \leq \mathrm{vo} \leq \mathrm{vCc}$ |
| ICCSB | Standby Power Supply Current |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
|  |  |  |  |  | $\mathrm{VIN}=\mathrm{VCC}$ or GND |
|  |  |  |  |  | OUTPUTS OPEN |
| ICCOP | Operating Power Supply Current |  | 10 | mA | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
|  |  |  |  |  | CLK $\mathrm{FREQ}=8 \mathrm{MHz}$ |
|  |  |  |  |  | OUTPUTS OPEN |

## CAPACITANCE

$\mathrm{TA}=25^{\circ} \mathrm{C} ; \mathrm{VCC}=\mathrm{GND}=\mathrm{OV} ; \mathrm{VIN}=+5 \mathrm{~V}$ or GND

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{I N^{*}}$ | Input Capacitance |  | 5 | pf | FREQ $=1 \mathrm{MHz}$ <br> Unmeasured pins <br> returned to GND |
| COUT* $^{*}$ | Output Capacitance |  | 15 | pf |  |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}^{*}}$ | I/O Capacitance |  | 20 | pf |  |

*Guaranteed and sampled, but not $100 \%$ tested.

## A.C. CHARACTERISTICS

$V C C=+5 \mathrm{~V} \pm 10 \%: T A=0{ }^{\circ} \mathrm{C}$ to $+70{ }^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 54) ; T A=-40{ }^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(182 \mathrm{C} 54) ; T A=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{M} 22 \mathrm{C} 54)$
Bus Parameters

| READ CYCLE |  |  |  |  |  |  |  |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |  |  |
| TAR | Address Stable Before $\overline{\text { RD }}$ | 45 |  | ns |  |  |  |
| TSR | CS Stable Before $\overline{\text { RD }}$ | 0 |  | ns |  |  |  |
| TRA | Address Hold Time After $\overline{\text { RD }}$ | 0 |  | ns |  |  |  |
| TRR | RD Pulse Width | 150 |  | ns |  |  |  |
| TRD | Data Delay from $\overline{\text { RD }}$ |  |  | 120 | ns |  |  |
| TAD | Data Delay from Address |  | 220 | ns |  |  |  |
| TDF | RD to Data Floating | 5 | 90 | ns |  |  |  |
| TRV | Command Recovery Time | 200 |  | ns |  |  |  |

WRITE CYCLE

| TAW | Address Stable Before $\overline{W R}$ | 0 |  | ns |  |
| :--- | :--- | :---: | :--- | :--- | :--- |
| TSW | CS Stable Before $\overline{W R}$ | 0 |  | ns |  |
| TWA | Address Hold Time $\overline{\mathrm{WR}}$ | 0 |  | ns |  |
| TWW | $\overline{W R}$ Pulse Width | 150 |  | ns |  |
| TDW | Data Setup Time Before $\overline{\mathrm{WR}}$ | 140 |  | ns |  |
| TWD | Data Hold Time After $\overline{W R}$ | 10 |  | ns |  |
| TRV | Command Recovery Time | 200 |  | ns |  |

## CLOCK AND GATE

| TCLK | Clock Period | 125 | DC | ns |
| :---: | :---: | :---: | :---: | :---: |
| TPWH | High Pulse Width | 60 |  | ns |
| TPWL | Low Pulse Width | 60 |  | ns |
| TR | Clock Rise Time |  | 100 | ns |
| TF | Clock Fall Time |  | 100 | ns |
| TGW | Gate Width High | 50 |  | ns |
| TGL | Gate Width Low | 50 |  | ns |
| TGS | Gate Setup Time to CLK | 50 |  | ns |
| TGH | Gate Hold Time After CLK | 50 |  | ns |
| TOD | Output Delay from CLK |  | 150 | ns |
| TODG | Output Delay from Gate |  | 120 | ns |

## A.C. Test Circuits



| TEST <br> CONDITION | V 1 | R1 | R2 | C1 |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1.7 V | 523 | OPEN | 150 pf |
| 2 | 5.0 V | 2 K | 1.7 K | 50 pf |
| 3 | 1.5 V | 750 | OPEN | OPEN |

TEST CONDITION DEFINITION TABLE
*Includes stray and jig capacitance

## A.C. Testing Input, Output Waveform


A. C. Testing: All input signals must switch between VIL -0.4 V and $\mathrm{VIH}+0.4 \mathrm{~V}$ $T_{R}$ and $T_{F}$ must be less than or equal to 15 ns .

## Waveforms

## WRITE



## RECOVERY

$\overline{\mathrm{BD}}, \overline{\mathrm{WR}}$


CLOCK AND GATE


## Features

- PIN COMPATIBLE WITH NMOS 8255A
- 24 PROGRAMMABLE I/O PINS
- FULLY TTL COMPATIBLE
- BUS-HOLD CIRCUITRY ON ALL I/O PORTS ELIMINATES PULL-UP RESISTORS
- HIGH SPEED, NO "WAIT STATE" OPERATION WITH 8MHz 80 C86
- DIRECT BIT SET/RESET CAPABILITY
- ENHANCED CONTROL WORD READ CAPABILITY
- SCALED SAJII IV CMOS PROCESS
- SINGLE 5V POWER SUPPLY
- 2.5 mA DRIVE CAPABILITY ON ALL I/O PORT OUTPUTS
- LOW STANDBY POWER - ICCSB $=10 \mu \mathrm{~A}$
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES


## Description

The Harris 82C55A is a high performance CMOS version of the industry standard 8255A and is manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV). It is a general purpose programmable I/O device which may be used with many different microprocessors. There are 24 I/O pins which may be individually programmed in 2 groups of 12 and used in 3 major modes of operation. The high performance and industry standard configuration of the 82C55A make it compatible with microprocessors such as the 80C86, 8048, 8051, and NSC800.
Static CMOS circuit design insures low operating power. TTL compatibility of VIH = 2.0 volts over the industrial temperature range and bus hold circuitry eliminate the need for pull-up resistors. Harris's advanced SAJI process results in performance equal to or greater than existing equivalent products at a fraction of the power.

Pinout



PIN NAMES

| $\mathrm{D}_{7}-\mathrm{D}_{8}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| RESET | RESET INPUT |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |
| $\overline{\overline{A D}}$ | READ INPUT |
| $\overline{\text { WF }}$ | WRITE INPUT |
| A0, A1 | PORT ADDRESS |
| PA7-PAO | PORT A (BIT) |
| PB7-PBO | PORT B (BIT) |
| PC7-PCO | PORT C (BIT) |
| VCC | +5 VOLTS |
| GND | O VOLTS |

CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

## 82C55A FUNCTIONAL DESCRIPTION

## Data Bus Buffer

This 3-state bidirectional 8-bit buffer is used to interface the 82C55A to the system data bus. Data is transmitted or received by the buffer upon execution of input or output instructions by the CPU. Control words and status information are also transferred through the data bus buffer.

## Read/Write and Control Logic

The function of this block is to manage all of the internal and external transfers of both Data and Control or Status words. It accepts inputs from the CPU Address and Control busses and in turn, issues commands to both of the Control Groups.

## (CS)

Chip Select. A "low" on this input pin enables the communication between the 82C55A and the CPU.

## ( $\overline{\mathrm{RD}})$

Read. A "low" on this input pin enables the 82C55A to send the data or status information to the CPU on the data bus. In essence, it allows the CPU to "read from" the 82C55A.
(WR)
Write. A "low" on this input pin enables the CPU to write data or control words into the 82C55A.

## (Ao and $A_{1}$ )

Port Select 0 and Port Select 1. These input signals, in conjunction with the $\overline{R D}$ and WR inputs, control the selection of one of the three ports or the control word registers. They are normally connected to the least significant bits of the address bus ( $A_{0}$ and $A_{1}$ ).

## 82C55A BASIC OPERATION

| $A_{1}$ | $A_{0}$ | $\overline{R D}$ | $\overline{W R}$ | $\overline{\mathrm{CS}}$ | INPUT OPERATION (READ) |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 1 | 0 | PORT A $\rightarrow$ DATA BUS |
| 0 | 1 | 0 | 1 | 0 | PORT $\rightarrow$ DATA BUS |
| 1 | 0 | 0 | 1 | 0 | PORT $C \rightarrow$ DATA BUS |
| 1 | 1 | 0 | 1 | 0 | CONTROL WORD $\rightarrow$ DATA BUS |
|  |  |  |  |  | OUTPUT OPERATION <br> (WRITE) |
| 0 | 0 | 1 | 0 | 0 | DATA BUS $\rightarrow$ PORT A |
| 0 | 1 | 1 | 0 | 0 | DATA BUS $\rightarrow$ PORT B |
| 1 | 0 | 1 | 0 | 0 | DATA BUS $\rightarrow$ PORT $C$ |
| 1 | 1 | 1 | 0 | 0 | DATA BUS $\rightarrow$ CONTROL |
|  |  |  |  |  | DISABLE FUNCTION |
| X | X | X | X | 1 | DATA BUS $\rightarrow 3-S T A T E$ |
| X | X | 1 | 1 | 0 | DATA BUS $\rightarrow 3-S T A T E$ |



FIgure 1
82C55A Block Diagram
Data Bus Buffer and Read/Write Control Logic Functions

## (RESET)

Reset. A "high" on this input clears the control register and all ports ( $A, B, C$ ) are set to the input mode. "Bus hold" devices internal to the 82C55A will hold the I/O port inputs to a logic "1" state with a maximum hold current of $300 \mu \mathrm{~A}$.

## Group A and Group B Controls

The functional configuration of each port is programmed by the systems software. In essence, the CPU "outputs" a control word to the 82C55A. The control word contains information such as "mode", "bit set", "bit reset", etc., that initializes the functional configuration of the 82C55A.
Each of the Control blocks (Group A and Group B) accepts "commands" from the Read/Write Control Logic, receives "control words" from the internal data bus and issues the proper commands to its associated ports.
Control Group A - Port A and Port C upper (C7-C4)

## Control Group B - Port B and Port C lower (C3-CO)

The control word register can be both written and read as shown in the "Basic Operation" table. Figure 4 shows the control word format for both Read and Write operations. When the control word is read, bit D7 will always be a logic " 1 ", as this implies control word mode information.

## Ports A, B and C

The 82C55A contains three 8-bit ports (A, B, and C). All can be configured to a wide variety of functional characteristics by the system software but each has its own special features or "personality" to further enhance the power and flexibility of the 82C55A.
Port A One 8-bit data output latch/buffer and one 8-bit data input latch. Both "pull-up" and "pull-down" bus-hold devices are present on Port A.

Port B One 8-bit data input/output latch/buffer and one 8-bit data input buffer.

Port C One 8-bit data output latch/buffer and one 8-bit data input buffer (no latch for input). This port can be divided into two 4-bit ports under the mode control. Each 4-bit port contains a 4-bit latch and it can be used for the control signal outputs and status signal inputs in conjunction with ports A and B .


## Mode Selection

There are three basic modes of operation that can be selected by the system software:

Mode 0-Basic Input/Output
Mode 1-Strobed Input/Output
Mode 2-Bi-Directional Bus
When the reset input goes "high", all ports will be set to the input mode with all 24 port lines held at a logic "one" level by internal bus hold devices. After the reset is removed, the 82C55A can remain in the input mode with no additional initialization required. This eliminates the need for pullup or pulldown resistors in all-CMOS designs. During the execution of the system program, any of the other modes may be selected using a single output instruction. This allows a single 82C55A to service a variety of peripheral devices with a simple software maintenance routine.
The modes for Port A and Port B can be separately defined, while Port $C$ is divided into two portions as required by the Port A and Port B definitions. All of the output registers, including the status flip-flops, will be reset whenever the mode is changed. Modes may be combined so that their functional definition can be "tailored" to almost any I/O structure. For instance: Group B can be programmed in Mode 0 to monitor simple switch closings or display computational results, Group A could be programmed in Mode 1 to monitor a keyboard or tape reader on an interrupt-driven basis.


Figure 3 Basic Mode Definitions and Bus Interface


Figure 4
Mode Definition Format

The mode definitions and possible mode combinations may seem confusing at first but after a cursory review of the complete device operation a simple, logical I/O approach will surface. The design of the 82C55A has taken into account things such as efficient PC board layout, control signal definition vs PC layout and complete functional flexibility to

CONTROL WORD


Figure 5
Bit Set/Reset Format
support almost any peripheral device with no external logic. Such design represents the maximum use of the available pins.

## Single Blt Set/Reset Feature

Any of the eight bits of Port $C$ can be Set or Reset using a single OUTput instruction. This feature reduces software requirements in control-based applications.
When Port C is being used as status/control for Port A or B, these bits can be set or reset by using the Bit Set/Reset operation just as if they were data output ports.

## Interrupt Control Functions

When the 82C55A is programmed to operate in mode 1 or mode 2, control signals are provided that can be used as interrupt request inputs to the CPU. The interrupt request signals, generated from port C , can be inhibited or enabled by setting or resetting the assoclated INTE flip-flop, using the bit set/reset function of port C.
This function allows the programmer to enable or disable a CPU interrupt by a specific I/O device without affecting any other device in the interrupt structure.

## INTE filp-flop definition:

(BIT-SET)-INTE is SET - Interrupt enable
(BIT-RESET)-INTE is RESET - Interrupt disable.
Note: All Mask flip-flops are automatically reset during mode selection and device Reset.

## Operating Modes

Mode O (Basic Input/Output). This functional configuration provides simple input and output operations for each of the three ports. No handshaking is required, data is simply written to or read from a specific port.

## Mode O Basic Functional Definitions:

- Two 8-bit ports and two 4-bit ports
- Any port can be input or output
- Outputs are latched
- Inputs are not latched
- 16 different Input/Output configurations possible


MODE 0 (Basic Input)


## MODE 0 Port Dofinition

| A |  | B |  | QROUP A |  |  | OROUP B |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $D_{4}$ | $D_{3}$ | $D_{1}$ | $D_{0}$ | PORT A | PORT C <br> (UPPER) | $\#$ | PORT B | PORT C <br> ILOWER) |
| 0 | 0 | 0 | 0 | OUTPUT | OUTPUT | 0 | OUTPUT | OUTPUT |
| 0 | 0 | 0 | 1 | OUTPUT | OUTPUT | 1 | OUTPUT | INPUT |
| 0 | 0 | 1 | 0 | OUTPUT | OUTPUT | 2 | INPUT | OUTPUT |
| 0 | 0 | 1 | 1 | OUTPUT | OUTPUT | 3 | INPUT | INPUT |
| 0 | 1 | 0 | 0 | OUTPUT | INPUT | 4 | OUTPUT | OUTPUT |
| 0 | 1 | 0 | 1 | OUTPUT | INPUT | 5 | OUTPUT | INPUT |
| 0 | 1 | 1 | 0 | OUTPUT | INPUT | 6 | INPUT | OUTPUT |
| 0 | 1 | 1 | 1 | OUTPUT | INPUT | 7 | INPUT | INPUT |
| 1 | 0 | 0 | 0 | INPUT | OUTPUT | 8 | OUTPUT | OUTPUT |
| 1 | 0 | 0 | 1 | INPUT | OUTPUT | 9 | OUTPUT | INPUT |
| 1 | 0 | 1 | 0 | INPUT | OUTPUT | 10 | INPUT | OUTPUT |
| 1 | 0 | 1 | 1 | INPUT | OUTPUT | 11 | INPUT | INPUT |
| 1 | 1 | 0 | 0 | INPUT | INPUT | 12 | OUTPUT | OUTPUT |
| 1 | 1 | 0 | 1 | INPUT | INPUT | 13 | OUTPUT | INPUT |
| 1 | 1 | 1 | 0 | INPUT | INPUT | 14 | INPUT | OUTPUT |
| 1 | 1 | 1 | 1 | INPUT | INPUT | 15 | INPUT | INPUT |

## MODE 0 Configurations

CONTROL WORD \#O

| $D_{1}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |



CONTROL WORD \#2


CONTROL WORD \#1

| $D_{7}$ | $D_{6}$ | $D_{3}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 |



CONTROL WORD \#3

| $D_{7}$ | $D_{6}$ | $D_{8}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |



CONTROL WORD \#4

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |



CONTROL WORD \#8

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |



CONTROL WORD \#5

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |



CONTROL WORD \#9

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |



CONTROL WORD \#10

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |



CONTROL WORD \#6

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |



CONTROL WORD \#7

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 |



CONTROL WORD \#11



## Operating Modes

Mode 1 (Strobed Input/Output). This functional configuration provides a means for transferring I/O data to or from a specified port in conjunction with strobes or "handshaking" signals. In mode 1, port A and port B use the lines on port $C$ to generate or accept these "handshaking" signals.

Mode 1 Basic Functional Definitions:

- Two Groups (Group A and Group B)
- Each group contains one 8-bit port and one 4-bit control/data port.
- The 8 -bit data port can be either input or output. Both inputs and outputs are latched.
- The 4 -bit port is used for control and status of the 8 -bit port.


## Specifications 82C55A

## Input Control Signal Definition

$\overline{\mathrm{STB}}$ (Strobe Input)
A "low" on this input loads data into the input latch.
IBF (Input Buffer Full F/F)
A "high" on this output indicates that the data has been loaded into the input latch; in essence, an acknowledgement. IBF is set by STB input being low and is reset by the rising edge of the $\overline{R D}$ input.

## INTR (Interrupt Request)

A "high"on this output can be used to interrupt the CPU when an input device is requesting service. INTR is set by the condition; STB is a "one", IBF is a "one" and INTE is a "one". It is reset by the falling edge of RD. This procedure allows an input device to request service from the CPU by simply strobing its data into the port.

## INTE A

Controlled by bit set/reset of $\mathrm{PC}_{4}$.

## INTE B

Controlled by bit set/reset of $\mathrm{PC}_{2}$.


Figure 6 MODE 1 Input


Figure 7
MODE 1 (Strobed Input)

## Specifications 82C55A

## OUTPUT CONTROL SIGNAL DEFINITION

$\overline{\mathrm{OBF}}$ (Output Buffer Full F/F). The OBF output will go "low" to indicate that the CPU has written data out to the specified port. The OBF F/F will be set by the rising edge of the WR input and reset by ACK Input being low.
$\overline{A C K}$ (Acknowledge Input). A "low" on this input informs the 82C55A that the data from port $A$ or port $B$ has been accepted. In essence, a response from the peripheral device indicating that it has received the data output by the CPU.
INTR (Interrupt Request). A "high" on this output can be used to interrupt the CPU when an output device has accepted data transmitted by the CPU. INTR is set when $\overline{A C K}$ is a "one", $\overline{O B F}$ is a "one" and INTE is a "one". It is reset by the falling edge of WR.

## INTE A

Controlled by Bit Set/Reset of $\mathrm{CS}_{2}$.

## INTE B

Controlled by Bit Set/Reset of $\mathrm{PC}_{6}$.


Figure 8 MODE 1 Output


Figure 9
MODE 1 (Strobed Output)

Combinations of MODE 1: Port A and Port B can be individually defined as input or output in Mode 1 to support a wide variety of strobed I/O applications.


Figure 10
Comblnations of MODE 1

## Operating Modes

## MODE 2 (Strobed Bldirectional Bus I/O)

The functional configuration provides a means for communicating with a peripheral device or structure on a single 8 -bit bus for both transmitting and receiving data (bidirectional bus I/O). "Handshaking" signals are provided to maintain proper bus flow discipline similar to MODE 1. Interrupt generation and enable/disable functions are also available.

## MODE 2 Basic Functional Definitions:

- Used in Group A only.
- One 8-bit, bi-directional bus Port (Port A) and a 5-bit control Port (Port C).
- Both inputs and outputs are latched.
- The 5 -bit control port (Port C) is used for control and status for the 8 -bit, bi-directional bus port (Port A).


## Bidirectional Bus I/O Control Signal Definition

INTR (Interrupt Request). A high on this output can be used to interrupt the CPU for both input or output operations.

## Output Operations

$\overline{\mathrm{OBF}}$ (Output Buffer Full). The $\overline{\mathrm{OBF}}$ output will go "low" to indicate that the CPU has written data out to port A.
$\overline{A C K}$ (Acknowledge). A "low" on this input enables the tri-state output buffer of port A to send out the data. Otherwise, the output buffer will be in the high impedance state.
INTE 1 (The INTE Flip-Flop Associated with $\overline{O B F}$ ). Controlled by bit set/reset of $\mathrm{PC}_{6}$.
Input Operations
$\overline{\text { STB }}$ (Strobe Input). A "low" on this input loads data into the input latch.
IBF (Input Buffer Full F/F). A "high" on this output indicates that data has been loaded into the input latch.
INTE 2 (The INTE Flip-Flop Associated with IBF). Controlled by bit set/reset of $\mathrm{PC}_{4}$.


Figure 13. MODE Control Word


Figure 14. MODE 2


Figure 15. MODE 2 (Bidirectional)


FIgure 16
MODE 2 Combinations

## Mode Definition Summary

|  | MODE 0 |  |
| :---: | :---: | :---: |
|  | IN | OUT |
| PAO | IN | OUT |
| $P A_{1}$ | IN | OUT |
| $P A_{2}$ | IN | OUT |
| $\mathrm{PA}_{3}$ | IN | OUT |
| $\mathrm{PA}_{4}$ | IN | OUT |
| $\mathrm{PA}_{5}$ | IN | OUT |
| $\mathrm{PA}_{6}$ | IN | OUT |
| $\mathrm{PA}_{7}$ | IN | OUT |
| $\mathrm{PB}_{0}$ | IN | OUT |
| $\mathrm{PB}_{1}$ | IN | OUT |
| $\mathrm{PB}_{2}$ | IN | OUT |
| $\mathrm{PB}_{3}$ | IN | OUT |
| $\mathrm{PB}_{4}$ | IN | OUT |
| $\mathrm{PB}_{5}$ | IN | OUT |
| $\mathrm{PB}_{6}$ | IN | OUT |
| $\mathrm{PB}_{7}$ | IN | OUT |
| $\mathrm{PCO}_{0}$ | IN | OUT |
| $P \mathrm{PC}_{1}$ | IN | OUT |
| $\mathrm{PC}_{2}$ | IN | OUT |
| $\mathrm{PC}_{3}$ | IN | OUT |
| $\mathrm{PC}_{4}$ | IN | OUT |
| $\mathrm{PC}_{5}$ | IN | OUT |
| $\mathrm{PC}_{6}$ | IN | OUT |
| $\mathrm{PC}_{7}$ | IN | OUT |


| MODE 1 |  |
| :---: | :---: |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| INTR $_{B}$ | INTR $_{8}$ |
| IBFB | $\overline{O B F}_{B}$ |
| $\overline{S T B}_{B}$ | $\overline{A C K}_{B}$ |
| $\mathrm{INTR}_{A}$ | INTR $_{A}$ |
| $\overline{S T B}_{A}$ | 1/O |
| IBFA | 1/0 |
| 1/0 | $\overline{\text { ACK }}^{\text {A }}$ |
| $1 / 0$ | $\overline{O B F}_{A}$ |



## Special Mode Combination Considerations:

There are several combinations of modes possible. For any combination, some or all of Port C lines are used for control or


Figure 15. MODE 1 Status Word Format


Figure 16. MODE 2 Status Word Format
status. The remaining bits are either inputs or outputs as defined by a "Set Mode" command.

During a read of Port C, the state of all the Port C lines, except the $\overline{A C K}$ and $\overline{S T B}$ lines, will be placed on the data bus. In place of the ACK and STB line states, flag status will appear on the data bus in the PC2, PC4, and PC6 bit positions as illustrated by Figure 17.
Through a "Write Port C" command, only the Port C pins programmed as outputs in a Mode 0 group can be written. No other pins can be affected by a "Write Port C" command, nor can the interrupt enable flags be accessed. To write to any Port C output programmed as an output in a Mode 1 group or to change an interrupt enable flag, the "Set/Reset Port C Bit" command must be used.
With a "Set/Reset Port C Bit" command, any Port C line programmed as an output (including INTR, IBF and OBF) can be written, or an interrupt enable flag can be either set or reset. Port C lines programmed as inputs, including ACK and STB lines, associated with Port C are not affected by a "Set/Reset Port C Bit" command. Writing to the corresponding Port C bit positions of the $\overline{A C K}$ and STB lines with the "Set/Reset Port C Bit" command will affect the Group A and Group B interrupt enable flags, as illustrated in Figure 17.

| Interrupt Enable Flag* | Position | Alternate Port C Pin Signal (Mode) |
| :---: | :---: | :--- |
| INTE B | PC2 | $\overline{\text { ACK }}_{\mathrm{B}}$ (Output Mode 1) or STB B (Input Mode 1) |
| INTE A2 | PC4 | $\overline{\operatorname{STB}}_{\mathrm{A}}$ (Input Mode 1 or Mode 2) |
| INTE A1 | PC6 | $\overline{\mathrm{ACK}}_{\mathrm{A}}$ (Output Mode 1 or Mode 2) |

Figure 17
interrupt Enable Flags in Modes 1 and 2

## Current Drive Capability:

Any output on Port A, B or C can sink or source 2.5mA. This feature allows the 82C55A to directly drive Darlington type drivers and high-voltage displays that require such sink or source current.

## Reading Port C Status

In Mode 0, Port C transfers data to or from the peripheral
device. When the 82C55A is programmed to function in Modes 1 or 2, Port C generates or accepts "hand-shaking" signals with the peripheral device. Reading the contents of Port C allows the programmer to test or verify the "status" of each peripheral device and change the program flow accordingly.
There is no special instruction to read the status information from Port C. A normal read operation of Port C is exécuted to perform this function.

## APPLICATIONS OF THE 82C55A

The 82C55A is a very powerful tool for interfacing peripheral equipment to the microcomputer system. It represents the optimum use of available pins and is flexible enough to interface almost any I/O device without the need for additional external logic.
Each peripheral device in a microcomputer system usually has a "service routine" associated with it. The routine manages the software interface between the device and the CPU. The functional definition of the 82C55A is programmed by the I/O service routine and becomes an extension of the system software. By examining the I/O devices interface characteristics for both data transfer and timing, and matching this information to the examples and tables in the detailed operational description, a control word can easily be developed to initialize the 82C55A to exactly "fit" the application. Figures 19 through 25 present a few examples of typical applications of the 82C55A.


Figure 19. Printer Interface


Figure 20. Keyboard and Display Interface


Figure 21. Keyboard and Terminal Address Interface

Figure 24. Basic Floppy Disc Interface


Figure 22. Digital to Analog, Analog to Digital

Figure 25. Machine Tool Controller Interface

ABSOLUTE MAXIMUM RATINGS


## D.C. ELECTRICAL CHARACTERISTICS

$\mathrm{VCC}=-5.0 \mathrm{~V}+/-10 \% ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70{ }^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 55 \mathrm{~A}) ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 55 A );
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C55A)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | LOGICAL ONE INPUT VOLTAGE | $\begin{aligned} & 2.0 \\ & 0.0 \end{aligned}$ |  | v | $\begin{aligned} & \text { I82C55A } \\ & \text { M82C55A } \end{aligned}$ |
| VIL | LOGICAL ZERO INPUT VOLTAGE |  | 0.8 | V |  |
| VOH | LOGICAL ONE OUTPUT VOLTAGE | $\begin{gathered} 3.0 \\ \text { VCC-0.4 } \end{gathered}$ |  | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-2.5 \mathrm{~mA} \\ & \mathrm{IOH}=-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | LOGICAL ZERO OUTPUT VOLTAGE |  | 0.4 | V | $1 \mathrm{OL}=+2.5 \mathrm{~mA}$ |
| IIL | INPUT LEAKAGE CURRENT | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leqslant \mathrm{VIN} \leqslant \mathrm{VCC}$ |
| 10 | I/O PIN LEAKAGE CURRENT | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leqslant \mathrm{VO} \leqslant \mathrm{VCC}$ |
| IBHH | BUS HOLD HIGH CURRENT | -50 | $-300$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VO}=3.0 \mathrm{~V} \\ & \text { PORTS A, B, C } \end{aligned}$ |
| IBHL | BUS HOLD LOW CURRENT | +50 | +300 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VO}=1.0 \mathrm{~V} \\ & \text { PORT A ONLY } \end{aligned}$ |
| IDAR | DARLINGTON DRIVE CURRENT | -2.0 |  | mA | PORTS A, B, C Test Condition 3 |
| ICC | POWER <br> SUPPLY CURRENT |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} \\ & \mathrm{VIN}=\mathrm{VCC} \text { or GND } \\ & \text { OUTPUTS OPEN } \end{aligned}$ |

CAPACITANCE $\quad T_{A}=250 \mathrm{C} ; \mathrm{VCC}=\mathrm{GND}=0 \mathrm{~V} ; \mathrm{VIN}=+5 \mathrm{~V}$ or GND

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :--- |
| CIN* $^{\text {INPUT }}$CAPACITANCE |  | 5 | pf | FREQ $=1$ MHZ <br> Unmeasured pins <br> returned to GND |  |
| CI/O* | I/O PIN <br> CAPACITANCE | 20 | pf |  |  |

* Guaranteed and sampled, but not $100 \%$ tested


NOTE 1: Period of initial Reset pulse after power-on must be at least 50 usec. Subsequent Reset pulses may be 500 ns minimum.
82C55A AC TEST CIRCUITS

FROM OUTPUT UNDER TEST


| TEST CONDITION | $\mathbf{V 1}$ | R1 | R2 | C1 |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1.7 V | $523 \Omega$ | OPEN | 150 pf |
| 2 | 5.0 V | $2 \mathrm{~K} \Omega$ | $1.7 \mathrm{~K} \Omega$ | 50 pf |
| 3 | 1.5 V | $750 \Omega$ | OPEN | OPEN |

[^8]
## WAVEFORMS

MODE 0 (BASIC INPUT)


MODE 0 (BASIC OUTPUT)


MODE 1 (STROBED INPUT)


MODE 1 (STROBED OUTPUT)


WRITE TIMING


READ TIMING


## Advance Information

## Features

- PIN COMPATIBLE WITH NMOS 8259A
- EIOHT LEVEL PRIORITY CONTROLLER
- EXPANDABLE TO 64 LEVELS
- fully Ttl compatible
- high Speed, NO "WAIT STATE" OPERATION WITH 8 MHz 80c88
- PROQRAMMABLE INTERRUPT MODES
- 8080/8085 and 8086/80C88 COMPATIBLE OPERATION
- INDIVIDUAL REQUEST MASK CAPABILITY
- FULLY STATIC DESIGN
- SCALED SAJIIV CMOS PROCESS
- SINQLE SV POWER SUPPLY
- LOW STANDBY POWER - $10 \mu \mathrm{~A}$
- COMMERCIAL, industrial and military temperature ranges่


## Description

The Harris 82C59A is a high performance CMOS Priority Interrupt Controller manufactured using a self-aligned silicon gate CMOS process (Scaled SAJIV). The 82C59A is designed to relieve the system CPU from the task of polling in a multi-level priority interrupt system. The high speed and industry standard configuration of the 82C59A make it compatible with microprocessors such as the 80C86, 8086, 8080/85 and NSC800.

The 82C59A can handle up to eight vectored priority interrupting sources and is cascadable to 64 without additional circuitry. Individual interrupting sources can be masked or prioritized to allow custom system configuration. Two modes of operation make the 82C59A compatible with both $8080 / 85$ and 80C86/86 formats.

Static CMOS circuit design insures low operating power. Harris advanced SAJI process results in performance equal to or greater than existing equivalent products at a fraction of the power.

Pinout



[^9]| SYMBOL | PIN NO. | TYPE |
| :--- | :---: | :---: | :--- |
| VCC | 28 | NAME AND FUNCTION |
| GND |  |  |

## Functional Description

## INTERRUPTS IN MICROCOMPUTER SYSTEMS

Microcomputer system design requires that $I / O$ devices such as keyboards, displays, sensors and other components receive servicing in an efficient manner so that large amounts of the total system tasks can be assumed by the microcomputer with little or no effect on throughput.

The most common method of servicing such devices is the Polled approach. This is where the processor must test each device in sequence and in effect "ask" each one if it needs servicing. It is easy to see that a large portion of the main program is looping through this continuous polling cycle and that such a method would have a serious, detrimental effect on system through-put, thus limiting the tasks that could be assumed by the microcomputer and reducing the cost effectiveness of using such devices.

A more desirable method would be one that would allow the microprocessor to be executing its main program and only stop to service peripheral devices when it is told to do so by the device itself. In effect, the method would provide an external asynchronous input that would inform the processor that it should complete whatever instruction that is currently being executed and fetch a new routine that will service the requesting device. Once this servicing is
complete, however, the processor would resume exactly where it left off.

This is the interrupt-driven method. It is easy to see that system throughput would drastically increase, and thus more tasks could be assumed by the microcomputer to further enhance its cost effectiveness.

The Programmable Interrupt Controller (PIC) functions as an overall manager in an Interrupt-Driven system. It accepts requests from the peripheral equipment, determines which of the incoming requests is of the highest importance (priority), ascertains whether the incoming request has a higher priority value than the level currently being serviced, and issues an interrupt to the CPU based on this determination.

Each peripheral device or structure usually has a special program or "routine" that is associated with its specific functional or operational requirements; this is referred to as a "service routine". The PIC, after issuing an interrupt to the CPU, must somehow input information into the CPU that can "point" the Program Counter to the service routine associated with the requesting device. This "pointer" is an address in a vectoring table and will often be referred to, in this document, as vectoring data.


POLLED METHOD


INTERRUPT METHOD


82C59A INTERRUPT LOGIC


82C59A DATA AND CONTROL LOGIC

## 82C59A FUNCTIONAL DESCRIPTION

The 82C59A is a device specifically designed for use in real time, interrupt driven microcomputer systems. It manages eight levels of requests and has built-in features for expandability to other 82C59As (up to 64 levels). It is programmed by system software as an I/0 peripheral. A selection of priority modes is available to the programmer so that the manner in which the requests are processed by the 82C59A can be configured to match system requirements. The priority modes can be changed or reconfigured dynamically at any time during main program operation. This means that the complete
interrupt structure can be defined as required, based on the total system environment.

## INTERRUPT REQUEST REGISTER (IRR) and IN-SERVICE REGISTER (ISR)

The interrupts at the IR input lines are handled by two registers in cascade, the Interrupt Request Register (IRR) and the In-Service Register (ISR). The IRR is used to store all the interrupt levels which are requesting service, and the ISR is used to store all the interrupt levels which are currently being serviced.


## PRIORITY RESOLVER

This logic block determines the priorities of the bits set in the IRR. The highest priority is selected and strobed into the corresponding bit of the ISR during the INTA sequence.

## INTERRUPT MASK REGISTER (IMR)

The IMR stores the bits which disable the interrupt lines to be masked. The IMR operates on the output of the IRR. Masking of a higher priority input will not affect the interrupt request lines of lower priority.

## INTERRUPT (INT)

This output goes directly to the CPU interrupt input. The VoH level on this line is designed to be fully compatible with the 8080A, 8085A, 8086 and 80 C86 input levels.

## INTERRUPT ACKNOWLEDGE (INTA)

INTA pulses will cause the 82C59A to release vectoring information onto the data bus. The format of this data depends on the system mode ( $\mu \mathrm{PM}$ ) of the 82C59A.

## DATA BUS BUFFER

This 3 -state, bidirectional 8 -bit buffer is used to interface the 82C59A to the system Data Bus. Control words and status information are transferred through the Data Bus Buffer.

## READ/WRITE CONTROL LOGIC

The function of this block is to accept OUTput commands from the CPU. It contains the Initialization Command Word (ICW) registers and Operation Command Word (OCW) registers which store the various control formats for device operation. This function block also allows the status of the 82C59A to be transferred onto the Data Bus.

## CHIP SELECT ( $\overline{\mathrm{CS}}$ )

A LOW on this input enables the 82C59A. No reading or writing of the device will occur unless the device is selected.

## WRITE ( $\overline{\text { WR }}$ )

A LOW on this input enables the CPU to write control words (ICWs and 0 CWs ) to the 82 C 59 A .

READ ( $\overline{\mathrm{RD}}$ )
A LOW on this input enables the 82C59A to send the status of the Interrupt Request Register (IRR), In Service Register (ISR), the Interrupt Mask Register (IMR), or the interrupt level (in the poll mode) onto the Data Bus.

## A0

This input signal is used in conjunction with $\overline{W R}$ and $\overline{R D}$ signals to write commands into the various command registers, as well as reading the various status registers of the chip. This line can be tied directly to one of the address lines.

## THE CASCADE BUFFER/COMPARATOR

This function block stores and compares the IDs of all 82C59A s used in the system. The associated three I/O pins (CASO-2) are outputs when the 82C59A is used as a master and are inputs when the 82C59A is used as a slave. As a master, the 82C59A sends the ID of the interrupting slave device onto the CASO-2 lines. The slave thus selected will send its preprogrammed subroutine address onto the Data Bus during the next one or two consecutive INTA pulses. (See section "Cascading the 82C59A".)

## INTERRUPT SEQUENCE

The powerful features of the 82C59A in a microcomputer system are its programmability and the interrupt routine addressing capability. The latter allows direct or indirect jumping to the specified interrupt routine requested without any polling of the interrupting devices. The normal sequence of events during an interrupt depends on the type of CPU being used.

These events occur in an 8080A/8085 system:

1. One or more of the INTERRUPT REQUEST lines (I0-17) are raised high, setting the corresponding IRR bit(s).
2. The 82C59A evaluates these requests in the priority resolver and sends an interrupt (INT) to the CPU, if appropriate.
3. The CPU acknowledges the INT and responds with an INTA pulse.
4. Upon receiving an INTA from the CPU group, the highest priority ISR bit is set, and the corresponding IRR bit is reset. The 82C59A will also release a CALL instruction code (11001101) onto the 8 -bit data bus through $D_{0}-\mathrm{D}_{7}$
5. This CALL instruction will initiate two additional INTÄ pulses to be sent to the 82C59A from the CPU group.
6. These two INTA pulses allow the 82C59A to release its preprogrammed subroutine address onto the data bus. The lower 8-bit address is released at the first INTA pulse and the higher 8 -bit address is released at the second INTA pulse.
7. This completes the 3 -byte CALL instruction released by the 82C59A. In the AEOI mode, the ISR bit is reset at the end of the third INTA pulse. Otherwise, the ISR bit remains set until an appropriate EOI command is issued at the end of the interrupt sequence.
The events occurring in an $80 C 86$ system are the same until step 4.
8. Upon receiving an $\overline{\mathbb{N T A}}$ from the CPU group, the highest priority ISR bit is set and the corresponding IRR bit is reset. The 82C59A does not drive the data bus during this cycle.
9. The 80 C 86 will initiate a second INTA pulse. During this pulse, the 82C59A releases an 8-bit pointer onto the data bus where it is read by the CPU.
10. This completes the interrupt cycle. In the AEOI mode, the ISR bit is reset at the end of the second INTA pulse. Otherwise, the ISR bit remains set until an appropriate EOI command is issued at the end of the interrupt subroutine.

If no interrupt request is present at step 4 of either sequence (i.e.,the request was too short in duration), the 82C59A will issue an interrupt level 7. If a slave is programmed on IR bit 7, the CAS lines remain inactive and vector addresses are output from the master 82C59A.

## Interrupt Sequence Outputs

8080, 8085
This sequence is timed by three INTA pulses. During the first $\overline{\text { INTA }}$ pulse, the CALL opcode is enabled onto the data bus.

First Interrupt Vector Byte Data: Hex CD

CALL CODE

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 |

During the second INTA pulse, the lower address of the appropriate service routine is enabled onto the data bus. When interval $=4$ bits, $A_{5}-A_{7}$ are programmed, while $A_{0}-A_{4}$ are automatically inserted by the 82C59A. When interval $=8$, only $A_{6}$ and $A_{7}$ are programmed, while $A_{0}-A_{5}$ are automatically inserted.

| Content of Second Interrupt Vector Byte |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IR |  |  | Interval $=4$ |  |  |  |  |  |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| 7 | A7 | A6 | A5 | 1 | 1 | 1 | 0 | 0 |
| 6 | A7 | A6 | A5 | 1 | 1 | 0 | 0 | 0 |
| 5 | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 |
| 4 | A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 |
| 3 | A7 | A6 | A5 | 0 | 1 | 1 | 0 | 0 |
| 2 | A7 | A6 | A5 | 0 | 1 | 0 | 0 | 0 |
| 1 | A7 | A6 | A5 | 0 | 0 | 1 | 0 | 0 |
| 0 | A7 | A6 | A5 | 0 | 0 | 0 | 0 | 0 |
|  |  |  |  |  |  |  |  |  |
| IR |  |  |  |  |  | Interval $=8$ |  |  |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| 7 | A7 | A6 | 1 | 1 | 1 | 0 | 0 | 0 |
| 6 | A7 | A6 | 1 | 1 | 0 | 0 | 0 | 0 |
| 5 | A7 | A6 | 1 | 0 | 1 | 0 | 0 | 0 |
| 4 | A7 | A6 | 1 | 0 | 0 | 0 | 0 | 0 |
| 3 | A7 | A6 | 0 | 1 | 1 | 0 | 0 | 0 |
| 2 | A7 | A6 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1 | A7 | A6 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | A7 | A6 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  |  |  |  |  |  |  |  |

During the third INTA pulse, the higher address of the appropriate service routine, which was programmed as byte 2 of the initialization sequence ( $\mathrm{A}_{8}-\mathrm{A}_{15}$ ), is enabled onto the bus.

Content of Third Interrupt Vector Byte

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |

## 80C86, $80 C 88$ INTERRUPT RESPONSE MODE

80C86 mode is similar to 8080/85 mode except that only two Interrupt Acknowledge cycles are issued by the processor and no CALL opcode is sent to the processor. The first interrupt acknowledge cycle is similar to that of 8080/85 systems in that the 82C59A uses it to internally freeze the state of the interrupts for priority resolution and, as a master, it issues the interrupt code on the cascade lines. On this first cycle, it does not issue any data to the processor and leaves its data bus buffers disabled. On the second interrupt acknowledge cycle in 80C86 mode, the master (or slave if so programmed) will send a byte of data to the processor with the acknowledged interrupt code composed as follows (note the state of the ADI mode control is ignored and $\mathrm{A}_{5}-\mathrm{A}_{11}$ are unused in 80C86 mode.)

Content of Interrupt Vector Byte for 80C86 System Mode

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IR7 | T 7 | T6 | T5 | T4 | T3 | 1 | 1 | 1 |
| IR6 | T 7 | T 6 | T 5 | T 4 | T 3 | 1 | 1 | 0 |
| IR5 | T 7 | T 6 | T 5 | T 4 | T 3 | 1 | 0 | 1 |
| IR4 | T 7 | T 6 | T 5 | T 4 | T 3 | 1 | 0 | 0 |
| IR3 | T 7 | T 6 | T 5 | T 4 | T 3 | 0 | 1 | 1 |
| IR2 | T 7 | T 6 | T 5 | T 4 | T 3 | 0 | 1 | 0 |
| IR1 | T 7 | T 6 | T 5 | T 4 | T 3 | 0 | 0 | 1 |
| IR0 | T 7 | T 6 | T 5 | T 4 | T 3 | 0 | 0 | 0 |

## PROGRAMMING THE 82C59A

The 82C59A accepts two types of command words generated by the CPU;

1. Initialization Command Words (ICWs): Before normal operation can begin, each 82C59A in the system must be brought to a starting point-by a sequence of 2 to 4 bytes timed by WR pulses.
2. Operation Command Words ( OCWs ): These are the command words which command the 82C59A to operate in various interrupt modes. Among these modes are:
a. Fully nested mode
c. Special mask mode
b. Rotating priority mode
d. Polled mode

The OCWs can be written into the 82C59A anytime after initialization.

## Initialization Command Words (ICWS)

## GENERAL

Whenever a command is issued with $\mathrm{A} 0=0$ and $\mathrm{D} 4=1$, this is interpreted as Initialization Command Word 1 (ICW1). ICW1 starts the initialization sequence during which the following automatically occur.
a. The edge sense circuit is reset, which means that following
initialization, an interrupt request (IR) input must make a low-to-high transition to generate an interrupt.
b. The Interrupt Mask Register is cleared.
c. IR7 input is assigned priority 7.
d. Special Mask Mode is cleared and Status Read is set to IRR.
e. If IC4=0, then all functions selected in ICW4 are set to zero. (Non-Buffered mode*, no Auto-EOI, 8080/85 system).
*NOTE: Master/Slave in ICW4 is only used in the buffered mode.

## INITIALIZATION COMMAND WORDS 1 and 2 (ICW1, ICW2)

A $_{5}$-A ${ }_{15}$ : Page starting address of service routines. In an 8080/85 system, the 8 request levels will generate CALLS to 8 locations equally spaced in memory. These can be programmed to be spaced at intervals of 4 or 8 memory locations, thus the 8 routines will occupy a page of 32 or 64 bytes, respectively.

The address format is 2 bytes long ( $A_{0}-A_{15}$ ). When the routine interval is $4, \mathrm{~A}_{0}-\mathrm{A}_{4}$ are automatically inserted by the 82C59A, while $\mathrm{A}_{5}-\mathrm{A}_{15}$ are programmed externally. When the routine interval is $8, A_{0}-A_{s}$ are automatically inserted by the 82C59A while A6-A15 are programmed externally.

The 8 -byte interval will maintain compatibility with current software, while the 4-byte interval is best for a compact jump table.

In an $80 C 86$ system, $A_{15}-A_{11}$ are inserted in the five most significant bits of the vectoring byte and the 82C59A sets the three least significant bits according to the interrupt level. A $A_{10}-A_{5}$ are ignored and ADI (Address interval) has no effect.

LTIM: If LTIM $=1$, then the 82C59A will operate in the level interrupt mode. Edge detect logic on the interrupt inputs will be disabled.
ADI: $\quad$ CALL address interval. $A D I=1$ then interval $=4 ; A D I$ $=0$ then interval $=8$.
SNGL: $\quad$ Single. Means that this is the only 82C59A in the system. If $\operatorname{SNGL}=1$, no ICW3 will be issued.
IC4: If this bit is set-ICW4 has to be issued. If ICW4 is not needed, set IC4 $=0$.


## 82C59A INITIALIZATION SEQUENCE

## INITIALIZATION COMMAND WORD 3 (ICW3)

This word is read only when there is more than one 82C59A in the system and cascading is used, in which case SNGL $=0$. It will load the 8 -bit slave register. The functions of this register are:
a. In the master mode (either when $\mathrm{SP}=1$, or in buffered mode when M/S = 1 in ICW4), a " 1 " is set for each slave in the bit corresponding to the appropriate IR line for the slave. The master then will release byte 1 of the call sequence (for 8080/85 system ) and will enable the corresponding slave to


## 82C59A INITIALIZATION COMMAND WORD FORMAT

release bytes 2 and 3 (for 80c86, only byte 2 ) through the cascade lines.
b. In the slave mode (either when $S P=0$, or if $B U F=1$ and $M / S=0$ in ICW4), bits 2-0 identify the slave. The slave compares its cascade input with these bits and if they are equal, bytes 2 and 3 of the call sequence (or just byte 2 for 80 C 86 ) are released by it on the Data Bus (Note: the slave address must correspond to the IR line it is connected to in the master ID).

## INITIALIZATION COMMAND WORD 4 (ICW4)

SFNM: If $\operatorname{SFNM}=1$, the special fully nested mode is programmed.
BUF: $\quad$ If $B U F=1$, the buffered mode is programmed. In buffered mode, SP/EN becomes an enable output and the master/slave determination is by M/S.
M/S: If buffered mode is selected: $M / S=1$ means the 82C59A is programmed to be a master, $\mathrm{M} / \mathrm{S}=0$ means the 82C59A is programmed to be a slave. If $B U F=0$, M/S has no function.
AEOI: If $\mathrm{AEOI}=1$, the automatic end of interrupt mode is programmed.
$\mu \mathrm{PM}: \quad$ Microprocessor mode: $\mu \mathrm{PM}=0$ sets the 82C59A for $8080 / 85$ system operation, $\mu \mathrm{PM}=1$ sets the 82C59A for 80C86 system operation.

## OPERATION COMMAND WORDS (OCWs)

After the initialization Command Words (ICWs) are programmed into the 82C59A, the device is ready to accept interrupt requests at its input lines. However, during the 82C59A operation, a selection of algorithms can command the 82C59A to operate in various modes through the Operation Command Words (OCWs).

OPERATION CONTROL WORDS (OCWs)

| AO | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OCW1 |  |  |  |  |  |  |  |  |
| 1 | M7 | M6 | M5 | M4 | M3 | M2 | M1 | M0 |
| OCW2 |  |  |  |  |  |  |  |  |
| 0 | R | SL | EOI | 0 | 0 | L2 | L1 | LO |
| OCW3 |  |  |  |  |  |  |  |  |
| 0 | 0 | ESMM | SMM | 0 | 1 | P | RR | RIS |

## OPERATION CONTROL WORD 1 (OCW1)

OCW1 sets and clears the mask bits in the interrupt Mask Register (IMR). $M_{7}-M_{0}$ represent the eight mask bits. $M=1$ indicates the channel is masked (inhibited), $M=0$ indicates the channel is enabled.

## OPERATION CONTROL WORD 2 (OCW2)

R, SL, EOI - These three bits control the Rotate and End of Interrupt modes and combinations of the two. A chart of these combinations can be found on the Operation Command Word Format.
$L_{2}, L_{1}, L_{0}-$ These bits determine the interrupt level acted upon when the SL bit is active.


## OPERATION CONTROL WORD 3 (OCW3)

ESMM - Enable Special Mask Mode. When this bit is set to 1 it enables the SMM bit to set or reset the Special Mask Mode. When ESMM $=0$, the SMM bit becomes a "don't care".

SMM - Special Mask Mode. If ESMM $=1$ and $\operatorname{SMM}=1$, the 82C59A will enter Special Mask Mode. If ESMM $=1$ and SMM $=0$,the 82C59A will revert to normal mask mode. When ESMM $=0$, SMM has no effect.

## FULLY NESTED MODE

This mode is entered after initialization unless another mode is programmed. The interrupt requests are ordered in priority from 0 through 7 ( 0 highest). When an interrupt is acknowledged the highest priority request is determined and its vector placed on the bus. Additionally, a bit of the Interrupt Service register (IS0-7) is set. This bit remains set until the microprocessor issues an End of Interrupt (EOI) command immediately before returning from the service routine, or if AEOI (Automatic End of Interrupt) bit is set, until the trailing edge of the last INTA. While the IS bit is set, all further interrupts of the same or lower priority are inhibited, while higher levels will generate an interrupt (which will be acknowledged only if the microprocessor internal interrupt enable flip-flop has been re-enabled through software).
After the initialization sequence, IRO has the highest priority and IR7 the lowest. Priorities can be changed, as will be explained, in the rotating priority mode or via the set priority command.

## END OF INTERRUPT (EOI)

The In Service (IS) bit can be reset either automatically following the trailing edge of the last in sequence INTA pulse (when AEOI bit in ICW1 is set) or by a command word that must be issued to the82C59A before returning from a service routine (EOI Command). An EOI command must be issued twice if in the Cascade mode, once for the master and once for the corresponding slave.

There are two forms of EOI command: Specific and Non-Specific. When the 82C59A is operated in modes which preserve the fully nested structure, it can determine which IS bit to reset on EOI. When a Non-Specific EOI command is issued the 82C59A will automatically reset the highest IS bit of those that are set, since in the fully nested mode the highest IS level was necessarily the last level acknowledged and serviced. A non-specific EOI can be issued with OCW2 (EOI=1, $S L=0, R=0$ ).

When a mode is used which may disturb the fully nested structure, the 82C59A may no longer be able to determine the last level acknowledged. In this case a Specific End of Interrupt must be issued which includes as part of the command the IS level to be reset. A specific $E O$ I can be issued with $0 C W 2$ ( $E O I=1, S L=1, R=0$, and LO-L2 is the binary level of the IS bit to be reset).
An IRR bit that is masked by an IMR bit will not be cleared by a non-specific EOI if the 82C59A is in the Special Mask Mode.

## AUTOMATIC END OF INTERRUPT (AEOI) MODE

If AEOI $=1$ in ICW4, then the 82C59A will operate in AEOI mode continuously until reprogrammed by ICW4. In this mode the 82C59A will automatically perform a non-specific EOI operation at the trailing edge of the last interrupt acknowledge pulse (third pulse in 8080/85, second in 80C86). Note that from a system standpoint, this mode should be used only when a nested multi-level interrupt structure is not required within a single 82C59A.

## AUTOMATIC ROTATION (Equal Priority Devices)

In some applications there are a number of interrupting devices of equal priority. In this mode a device, after being serviced, receives the lowest priority, so a device requesting an interrupt will have to
wait, in the worst case until each of 7 other devices are serviced at most once. For example, if the priority and "in service" status is:

Before Rotate (IR4 the highest priority requiring service)

|  | IS7 | IS6 | IS5 | IS4 | IS3 | IS2 | IS1 | ISO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "IS" STATUS | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 |
| PRIORITY |  | 6 | 5 | 4 | 3 | 2 | 1 |  |
| STATUS | lowe |  |  |  |  |  |  | igh |

After Rotate (IR4 was serviced, all other priorities rotated correspondingly)


There are two ways to accomplish Automatic Rotation using OCW2, the Rotation on Non-Specific EOI Command ( $\mathrm{R}=1, \mathrm{SL}=0, \mathrm{EOI}=1$ ) and the Rotate in Automatic EOI Mode which is set by ( $R=1, S L=0$, $\mathrm{EOI}=0)$ and cleared by $(\mathrm{R}=0, \mathrm{SL}=0, \mathrm{EOI}=0)$.

## SPECIFIC ROTATION (Specific Priority)

The programmer can change priorities by programming the bottom priority and thus fixing all other priorities; i.e., if IR5 is programmed as the bottom priority device, then IR6 will have the highest one.
The Set Priority command is issued in OCW2 where: $R=1, S L=1$; L0-L2 is the binary priority level code of the bottom priority device.

Observe that in this mode internal status is updated by software control during OCW2. However, it is independent of the End of Interrupt (EOI) command (also executed by OCW2). Priority changes can be executed during an EOI command by using the Rotate on Specific EOI command in OCW2 ( $\mathrm{R}=1, \mathrm{SL}=1, \mathrm{EOI}=1$ and LO$12=$ IR level to receive bottom priority).

## INTERRUPT MASKS

Each Interrupt Request input can be masked individually by the Interrupt Mask Register (IMR) programmed through OCW1. Each bit in the IMR masks one interrupt channel if it is set (1). Bit 0 masks IRO, Bit 1 masks IR1 and so forth. Masking an IR channel does not affect the other channels operation.

## SPECIAL MASK MODE

Some applications may require an interrupt service routine to dynamically alter the system priority structure during its execution under software control. For example, the routine may wish to inhibit lower priority requests for a portion of its execution but enable some of them for another portion.
The difficulty here is that if an Interrupt Request is acknowledged and an End of Interrupt command did not reset its IS bit (i.e., while executing a service routine), the 82C59A would have inhibited all lower priority requests with no easy way for the routine to enable them.

That is where the Special Mask Mode comes in. In the special Mask Mode, when a mask bit is set in OCW1, it inhibits further interrupts at that level and enables interrupts from all other levels (lower as well as higher) that are not masked.
Thus, any interrupts may be selectively enabled by loading the mask register.

The special Mask Mode is set by $0 C W 3$ where: $S S M M=1, S M M=1$, and cleared where $\operatorname{SSMM}=1$, SMM $=0$.

## POLL COMMAND

In this mode, the INT output is not used or the microprocessor internal Interrupt Enable flip-flop is reset, disabling its interrupt input. Service to devices is achieved by software using a Poll command.

The Poll command is issued by setting $P=1$ in 0 CW3. The 82C59A treats the next $\overline{R D}$ pulse to the 82C59A (i.e. $\overline{\mathrm{RD}}=0, \overline{\mathrm{CS}}=0$ ) as an interrupt acknowledge, sets the appropriate IS bit if there is a reguest, and reads the priority level. Interrupt is frozen from WR to $\overline{\mathrm{RD}}$.

The word enabled onto the data bus during $\overline{\mathrm{RD}}$ is:

| $D 7$ | $D 6$ | $D 5$ | $D 4$ | D3 | D2 | D1 | DO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | - | - | - | - | W2 | W1 | W0 |

W0-W2: Binary code of the highest priority level requesting service.
I: Equal to a " 1 " if there is an interrupt.
This mode is useful if there is a routine command common to several levels so that the INTA sequence is not needed (saves ROM space). Another application is to use the poll mode to expand the number of priority levels to more than 64.


PRIORITY CELL - SIMPLIFIED LOGIC DIAGRAM

## READING THE 82C59A STATUS

The input status of several internal registers can be read to update the user information on the system. The following registers can be read via OCW3 (IRR and ISR or OCW1 (IMR)).

In-Service Register (ISR): 8-bit register which contains the priority levels that are being serviced. The ISR is updated when an End of Interrupt Command is issued.

Interrupt Mask Register: 8-bit register which contains the interrupt request lines which are masked.
The IRR can be read when, prior to the $\overline{R D}$ pulse, a Read Register Command is issued with OCW3 ( $\mathrm{RR}=1, \mathrm{RIS}=1$ ).
There is no need to write an OCW3 before every status read operation, as long as the status read corresponds with the previous one; i.e., the 82C59A "remembers" whether the IRR or ISR has been previously selected by the OCW3. This is not true when poll is used. In the poll mode, the 82C59A treats the $\overline{\mathrm{RD}}$ following a "poll write" operation as an INTA. After initialization, the 82C59A is set to IRR.

For reading the IMR, no OCW3 is needed. The output data bus will contain the IMR whenever $\overline{R D}$ is active and $A O=1$ (OCW1). Polling overrides status read when $P=1, R R=1$ in $O C W 3$.

## EDGE AND LEVEL TRIGGERED MODES

This mode is programmed using bit 3 in ICW1.
If LTIM $=$ ' 0 ', an interrupt request will be recognized by a low to high transition on an IR input. The IR input can remain high without generating another interrupt.

If LTIM = ' 1 ', an interrupt request will be recognized by a 'high' level on IR input, and there is no need for an edge detection. The interrupt request must be removed before the EOI command is issued or the CPU interrupt is enabled to prevent a second interrupt from occurring.

The priority cell diagram shows a conceptual circuit of the level sensitive and edge sensitive input circuitry of the 82C59A. Be sure to note that the request latch is a transparent $D$ type latch.

In both the edge and level triggered modes the IR inputs must remain high until after the falling edge of the first INTA. If the IR input goes low before this time a DEFAULT IR7 will occur when the CPU acknowledges the interrupt. This can be a useful safeguard for detecting interrupts caused by spurious noise glitches on the IR inputs. To implement this feature the IR7 routine is used for "clean up" simply executing a return instruction, thus ignoring the interrupt. If IR7 is needed for other purposes a default IR7 can still be
detected by reading the ISR. A normal IR7 interrupt will set the corresponding ISR bit, a default IR7 won't. If a default IR7 routine occurs during a normal IR7 routine, however, the ISR will remain set. In this case it is necessary to keep track of whether or not the IR7 routine was previously entered. If another IR7 occurs it is a default.
In power sensitive applications, it is advisable to place the 82C59A in the edge-triggered mode. This will minimize the current through the pull-up resistors on the IR pins.
ir triggering
TIMING
REQUIREMENTS


## THE SPECIAL FULLY NESTED MODE

This mode wili be used in the case of a big system where cascading is used, and the priority has to be conserved within each slave. In this case the fully nested mode will be programmed to the master (using ICW4). This mode is similar to the normal nested mode with the following exceptions:
a. When an interrupt request from a certain slave is in service, this slave is not locked out from the master's priority logic and further interrupt requests from higher priority IRs within the slave will be recognized by the master and will initiate interrupts to the processor. (In the normal nested mode a slave is masked out when its request is in service and no higher requests from the same slave can be serviced.)
b. When exiting the Interrupt Service routine the software has to check whether the interrupt serviced was the only one from that slave. This is done by sending a non-specific End of Interrupt (EOI) command to the slave and then reading its In-Service register and checking for zero. If it is empty, a non-specified EOI can be sent to the master, too. If not, no EOI should be sent.

## BUFFERED MODE

When the 82C59A is used in a large system where bus driving buffers are required on the data bus and the cascading mode is used, there exists the problem of enabling buffers.

The buffered mode will structure the 82C59A to send an enable signal of SP/EN to enable the buffers. In this mode, whenever the 82C59A's data bus outputs are enabled, the SP/EN output becomes active.

This modification forces the use of software programming to determine whether the 82C59A is a master or a slave. Bit 3 in ICW4 programs the buffered mode, and bit 2 in ICW4 determines whether it is a master or a slave.

## CASCADE MODE

The 82C59A can be easily interconnected in a system of one master with up to eight slaves to handle up to 64 priority levels.


The master controls the slaves through the 3 line cascade bus. The cascade bus acts like chip selects to the slaves during the INTA sequence.

In a cascade configuration, the slave interrupt outputs are connected to the master interrupt request inputs. When a slave request line is activated and afterwards acknowledged, the master will enable the corresponding slave to release the device routine address during bytes 2 and 3 of INTA. (Byte 2 only for 80C86/ 8088).

The cascade bus lines are normally low and will contain the slave address code from the trailing edge of the first INTA pulse to the trailing edge of the third pulse. Each 82C59A in the system must follow a separate initialization sequence and can be programmed to work in a different mode. An EOI command must be issued twice: once for the master and once for the corresponding slave. Chip select decoding is required to activate each 82C59A.

The cascade lines of the Master 82C59A are activated only for slave inputs, non-slave inputs leave the cascade line inactive (low).

ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 VOLTS |
| :--- | :--- |
| Operating Voltage Range | +4 V to +7 V |
| Input Voltage Applied | GND -2.0 V to 6.5 V |
| Output Voltage Applied | $\mathrm{GND}-0.5 \mathrm{~V}$ to $\mathrm{VCC}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Commercial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Industrial | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Military | 1 Watt |

CAUTION: Stresses above those listed in the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## D.C. ELECTRICAL CHARACTERISTICS

$$
\begin{aligned}
\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}} & =0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 59 \mathrm{~A}), \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(182 \mathrm{C} 59 \mathrm{~A}) ; \\
\mathrm{T}_{\mathrm{A}} & =-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\text { M82C59A })
\end{aligned}
$$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | LOGICAL ONE INPUT VOLTAGE | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ |  | $\begin{aligned} & \hline V \\ & V \end{aligned}$ | $\begin{aligned} & \text { 182C59A C82C59A } \\ & \text { M82C59A } \end{aligned}$ |
| VIL | LOGICAL ZERO INPUT VOLTAGE |  | 0.8 | V |  |
| VOH | OUTPUT HIGH VOLTAGE | $\begin{aligned} & 3.0 \\ & \text { VCC }-0.4 \end{aligned}$ |  | V | $\begin{aligned} & 10 \mathrm{H}=-2.5 \mathrm{~mA} \\ & 10 \mathrm{H}=-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | OUTPUT LOW VOLTAGE |  | 0.4 | $v$ | $10 \mathrm{~L}=+2.5 \mathrm{~mA}$ |
| IIL | INPUT LEAKAGE CURRENT | -1.0 | +1.0 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{VIN} \leqslant \mathrm{VCC}$ |
| 10 | OUTPUT LEAKAGE CURRENT | -10.0 | +10.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leqslant \mathrm{V} 0 \leqslant \mathrm{VCC}$ |
| ICCSB | STANDBY POWER SUPPLY CURRENT |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V C C=5.5 \mathrm{~V} \\ & V I N=V C C \text { or GND } \\ & \text { OUTPUTS OPEN } \end{aligned}$ |

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{VCC}=\mathrm{GND}=\mathrm{OV} ; \mathrm{VIN}=+5 \mathrm{~V}$ or GND

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{CiN}^{*}$ | InPUT CAPACITANCE |  | 5 | pf | FREQ $=1 \mathrm{MHz}$ Unmeasured pins returned to GND |
| $\begin{aligned} & \text { Cout*** } \\ & \text { Clio * } \end{aligned}$ | OUTPUT CAPACITANCE 1/0 CAPACITANCE |  | $\begin{aligned} & 15 \\ & 20 \end{aligned}$ | $\begin{aligned} & \mathrm{pf} \\ & \mathrm{pf} \end{aligned}$ |  |

* Guaranteed and sampled, but not 100\% tested


## A.C. CHARACTERISTICS

$\mathrm{VCC}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}: \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C82C59A})$
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 59 A$)$
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 59 \mathrm{~A})$
Timing Requirements

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAHRL | AO// $/ \overline{C S}$ Setup to $\overline{\mathrm{RD}} / \overline{\mathrm{NTTA}}$ | 10 |  | ns |  |
| TRHAX | A0/CS Hold after $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}}$ | 5 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Pulse Width | 160 |  | ns |  |
| TAHWL | A0/CS Setup to $\overline{W R}$ | 0 |  | ns |  |
| TWHAX | A0/ES Hold after WR | 0 |  | ns |  |
| TWLWH | $\overline{\text { Wr Pulse Width }}$ | 190 |  | ns |  |
| TDVWH | Data Setup to WR | 160 |  | ns |  |
| TWHDX | Data Hold after $\overline{\text { WR }}$ | 0 |  | ns |  |
| TJLJH | Interrupt Request Width (LOW) | 100 |  | ns | See Note 1 |
| TCVIAL | Cascade Setup to Second or Third INTA (Slave Only) | 40 |  | ns |  |
| TRHRL | End of $\overline{\mathrm{RD}}$ to next $\overline{\mathrm{RD}}$; <br> End of INTA to next INTA within an $\overline{\operatorname{NTA}}$ sequence only | 160 |  | ns |  |
| TWHWL | End of $\overline{W R}$ to next $\overline{W R}$ | 190 |  | ns |  |
| *TCHCL | End of Command to next Command (Not same command type) <br> End of INTA sequence to next INTA sequence | 400 |  | ns |  |

*Worst case timing for TCHCL in an actual microprocessor system is typically much greater than 400 ns ( $i . e .8085 \mathrm{~A}=1.6 \mu \mathrm{~s}, 8085 \mathrm{~A}-2=1 \mu \mathrm{~s}, 80 \mathrm{C} 86=$ $1 \mu \mathrm{~s})$.
Note: This is the low time required to clear the input latch in the edge triggered mode.
Timing Responses

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TRLDV | Data Valid from $\overline{\mathrm{RD}} / / \overline{\mathrm{NTA}}$ |  | 120 | ns | 1 |
| TRHDZ | Data Float after $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}}$ | 10 | 85 | ns | 2 |
| TJHIH | Interrupt Output Delay |  | 300 | ns | 1 |
| TIALCV | Cascade Valid from First INTA (Master Only) |  | 360 | ns | 1 |
| TRLEL | Enable Active from $\overline{\mathrm{RD}}$ or INTA |  | 100 | ns | 1 |
| TRHEH | Enable inactive from $\overline{\mathrm{RD}}$ or INTA |  | 150 | ns | 1 |
| TAHDV | Data Valid from Stable Address |  | 200 | ns | 1 |
| TCVDV | Cascade Valid to Valid Data |  | 200 | ns | 1 |

## 82C59A AC TEST CIRCUITS



| TEST CONDITION | V1 | R1 | R2 | C1 |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1.7 V | $523 \Omega$ | 0 PEN | 100 pf |
| 2 | 4.5 V | $1.8 \mathrm{~K} \Omega$ | $1.8 \mathrm{~K} \Omega$ | 30 pf |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. Testing: All input signals must switch between VIL -0.4 V and $\mathrm{VIH}+0.4 \mathrm{~V}$. $\mathrm{T}_{\mathrm{r}}$ and $\mathrm{T}_{\mathrm{F}}$ must be less than or equal to 15 ns.
test condition definition table

WRITE


READ/INTA


OTHER TIMING


INTA SEQUENCE


NOTES: Interrupt output must remain HIGH at least until leading edge of first INTA
Cycle 1 in $80 C 86 / 88$ systems, the Data Bus is not active.

Advance Information

## Features

## Pinout

|  | Top View |  |  |
| :---: | :---: | :---: | :---: |
| $\overline{\text { CSO }}$ | 1 | 40 | $\square \vee C c$ |
| $\overline{\mathrm{RD}}$ | 2 | 39 | $\square \mathrm{CS} 1$ |
| $\overline{W R}$ | 3 | 38 | コDR |
| DO | 4 | 37 | PE |
| D1 | 5 | 36 | $\square F E$ |
| D2 | 6 | 35 | $\square O E$ |
| D3 | 7 | 34 | コSDI |
| D4 | 8 | 33 | صINTR |
| D5 | 9 | 32 | $\square \mathrm{SFD}$ |
| D6 | 10 | 31 | $\square \mathrm{SIE}$ |
| D7 | 11 | 30 | $\square R S T$ |
| AO | 12 | 29 | ］tbre |
| A1 | 13 | 28 | $\square \mathrm{CO}$ |
| ALE | 14 | 27 | $\square \mathrm{RTS}$ |
| TXDACK | 15 | 26 | $\square \overline{\text { DTR }}$ |
| $\overline{\text { RXDACK }}$ | 16 | 25 | 兂 |
| $1 \times$ | 17 | 24 | $\square \overline{\mathrm{DSR}}$ |
| OX | 18 | 23 | $\square$ CTS |
| SDO | 19 | 22 | RLSD |
| GND | 20 | 21 | TC |

## Description

The HD－6406（PACI）is a high performance programmable Universal Asynchronous Receiver／Trans－ mitter（UART）and Baud Rate Generator（BRG）on a single chip．Utilizing Harris Semiconductor＇s advanced Scaled SAJI IV CMOS process，the PACI will support data rates from DC to 1Mbaud $(0-16 \mathrm{MHz}$ clock）．In addition to all standard UART functions，the PACI includes a complete Data Communications Equipment（DCE）interface．

Provision is made for DMA control of the PACI so that operation at the higher data rates is not hindered by slow microprocessor response times．An ALE control input permits direct interfacing to multiplexed data／address buses common to many microprocessors．

The interrupt structure of the PACI is user－programmable and can be configured to provide a single interrupt for any status change．A subsequent read of an internal status register will identify the source of the interrupt．If desired，the PACI can also provide separate hardware interrupt outputs for the receiver，transmitter and modem status changes．Separate error condition outputs can be used to pinpoint the exact cause of any detected error condition．

## Block Diagram



CAUTION：These devices are sensitive to electrostatic discharge．Users should follow standard IC Handling Procedures．

## Features

- FULL EIGHT BIT PARALLEL LATCHING BUFFER
- bipolar 8282 Compatible
- three state non-inverting outputs
- PROPAGATION DELAY - 35nsec MAX.
- A.C. CHARACTERISTICS GUARANTEED FOR:
- FULL TEMPERATURE RANGE
- 10\% POWER SUPPLY TOLERANCE
- $C_{L}=300 \mathrm{pF}$
- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT - 10 $\mu$ A MAX. STANDBY
- OUTPUTS GUARANTEED VALID AT VCC $=2.0$ VOLTS
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES
- 20 PIN PACKAGE ON 0.3" CENTERS


## Description

The Harris 82 C 82 is an octal latching buffer manufactured using a selfaligned silicon gate CMOS process. This circuit provides an eight bit parallel latch/buffer in a $\mathbf{2 0}$ pin package. The active high strobe (STB) input allows transparent transfer of data and latches data on the negative transition of this signal. The active low output enable ( $\overline{\mathrm{OE}})$ permits simple interface to state-of-the-art microprocessor systems.

Pinout


## Functional Diagram



PIN NAMES
D10-D17 Data Input Pins $\mathrm{DO}_{0}-\mathrm{DO}_{7}$ Data Output Pins

STB Active High Strobe Input
$\overline{\mathrm{OE}}$ Active Low Output Enable

Truth Table

| STB | $\overline{O E}$ | $D I$ | $D O$ |
| :---: | :---: | :---: | :---: |
| $X$ | $H$ | $X$ | $H i-Z$ |
| $H$ | $L$ | $L$ | $L$ |
| $H$ | $L$ | $H$ | $H$ |
| $\dagger$ | $L$ | $X$ | $*$ |

$H=$ Logic One $\mathrm{Hi}-\mathrm{Z}=$ High Impedance
L = Logic Zero $\quad$ = Negative Transition
$X=$ Don't Care $\quad$ = Latched to value of last data

CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 VOLTS | Storage Temperature Range | -650 C to +1500 C |
| :--- | ---: | :--- | ---: |
| Operating Voltage Range | +4 V to +7 V | Operating Temperature Range |  |
| Input Voltage Applied | GND -2.0 V to +6.5 V | Commercial | 00 C to +700 C |
| Output Voltage Applied | GND -0.5 V to VCC +0.5 V | Industrial <br>  |  |
|  |  | Maximum Power Dissipation | -400 C to +850 C |
|  |  | 1 Watt |  |

CAUTION: Stresses above those Ilsted in the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this spec/fication is not implied.
D.C. ELECTRICAL CHARACTERISTICS

$$
V C C=5.0 \mathrm{~V}+/-10 \% ; T_{A}=00 \mathrm{C} \text { to }+700 \mathrm{C}(\mathrm{C} 82 \mathrm{C} 82) ; \mathrm{T}_{\mathrm{A}}=-400 \mathrm{C} \text { to }+850 \mathrm{C}(182 \mathrm{C} 82)
$$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | 2.0 |  | V | See note 1 |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| VOH | Logical One Output Voltage | 2.9 |  | V | $\frac{1 O H}{\frac{1 O H}{O E}=-8 \mathrm{~mA}}$ |
| VOL | Logical Zero Output Voltage |  | 0.4 | V | $\begin{aligned} & I O L=8 \mathrm{~mA} \\ & O E=L O W \end{aligned}$ |
| IIL | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VIN} \leq \mathrm{VCC}$ |
| 10 | Output Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & O V \leq V O \leq V C C \\ & \overline{O E}=V C C-0.5 V \end{aligned}$ |
| ICC | Power <br> Supply Current |  | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN }=V C C \text { or GND } \\ & \text { VCC }=5.5 \mathrm{~V} \\ & \text { OUTPUTS OPEN } \end{aligned}$ |
| CIN* | Input Capacitance |  | 5 | pf | $\begin{aligned} & \text { FREQ }=1 \mathrm{MHZ} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & \text { VIN }=V C C \text { or GND } \end{aligned}$ |
| couT* | Output Capacitance |  | 15 | pf | $\begin{aligned} & \text { FREQ }=1 \mathrm{MHZ} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & \text { VIN }=\text { VCC or GND } \end{aligned}$ |

*Guaranteed and sampled, but not 100\% tested.

NOTE 1: VIH is measured by applying a pulse of magnitude $=\mathrm{VIH}_{\min }$ to one data input at a time and checking the corresponding device output for a valid logical " $l$ " during valid input high time. Control pins (STB, OE) are tested separately with all device data input pins at $\mathrm{VIH}_{\mathrm{min}}$.

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 VOLTS | Storage Temperature Range | $-655^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: | :--- | ---: |
| Operating Voltage Range | +4 V to +7 V | Operating Temperature Range |  |
| Input Voltage Applied | GND -2.0 V to +6.5 V | Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Output Voltage Applied | GND -0.5 V to VCC +0.5 V | Maximum Power Dissipation | 1 Watt |

CAUTION：Stresses above those listed in the＂ABSOLUTE MAXIMUM RATINGS＂may cause permanent damage to the device．This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied．

D．C．ELECTRICAL CHARACTERISTICS；$V C C=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | 2.2 |  | V | See note 1 |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| VOH | Logical One Output Voltage | 2.9 |  | V | $\begin{aligned} & \frac{1 O H}{}=-8 \mathrm{~mA} \\ & O E=L O W \end{aligned}$ |
| VOL | Logical Zero Output Voltage |  | 0.4 | V | $\begin{aligned} & \mathrm{IOL}=8 \mathrm{~mA} \\ & \mathrm{OE}=\mathrm{LOW} \end{aligned}$ |
| IIL | Input Leakage Current | $-1.0$ | 1.0 | $\mu \mathrm{A}$ | OVSVIN $\leq$ VCC |
| 10 | Output Leakage Current | －10．0 | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{OV} \leq \mathrm{VO} \leq \mathrm{VCC} \\ & \mathrm{OE}=\mathrm{VCC}-0.5 \mathrm{~V} \end{aligned}$ |
| ICC | Power <br> Supply Current |  | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN }=\text { VCC or GND } \\ & \text { VCC }=5.5 \mathrm{~V} \\ & \text { OUTPUTS OPEN } \end{aligned}$ |
| CIN＊ | Input Capacitance |  | 5 | pf | $\begin{aligned} & \text { FREQ }=1 \mathrm{MHZ} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & \text { VIN }=\text { VCC or GND } \end{aligned}$ |
| cout＊ | Output <br> Capacitance |  | 15 | pf | $\begin{aligned} & \text { FREQ }=1 \mathrm{MHZ} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & \text { VIN }=\text { VCC or GND } \end{aligned}$ |

＊Guaranteed and sampled，but not $100 \%$ tested．

NOTE 1：VIH is measured by applying a pulse of magnitude $=$ VIH $H_{\min }$ to one data input at a time and checking the corres－ ponding device output for a valid logical＂ $\mid$＂during valid input high time．Control pins（STB，OE）are tested separately with all device data input pins at VIH $_{\text {min }}$ ．
A.C. ELECTRICAL CHARACTERISTICS; VCC $=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=$ Commercial, Industrial or Military $C_{L}=300 \mathrm{pf}^{*}$, FREQ $=1 \mathrm{MHZ}$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TIVOV | Propagation Delay Input to Output |  | 35 | ns | see notes 1, 2 |
| TSHOV | Propagation Delay STB to Output |  | 55 | ns | see notes 1, 2 |
| TEHOZ | Output Disable Time |  | 35 | ns | see notes 1, 2 |
| TELOV | Output Enable Time |  | 50 | ns | see notes 1, 2 |
| TIVSL | Input to STB <br> Set Up Time | 0 |  | ns | see notes 1, 2 |
| TSLIX | Input to STB Hold Time | 25 |  | ns | see notes 1, 2 |
| TSHSL | STB High Time | 25 |  | ns | see notes 1, 2 |
| TR, TF | Input Rise/Fall Times |  | 20 | ns | see notes 1, 2 |

* Output load capacitance is rated at 300 pf for ceramic and plastic packages.

NOTES: 1. All A.C. parameters tested as per test circuits and definitions in Figures 1-4.
2. Input test signals must switch between $\mathrm{VIL}-0.4 \mathrm{~V}$ and $\mathrm{VIH}+0.4 \mathrm{~V}$. Input rise and fall times must be $\leq 20$ nsec.


All timing measurements are made at 1.5 V unless otherwise noted.

Figure 1
$82 C 82$ TIMING RELATIONSHIPS

## $82 C 82$

## A.C. TEST CIRCUIT SPECIFICATIONS


*includes jig and stray capacitance

## DECOUPLING CAPACITORS

The transient current required to charge and discharge the 300 pf load capacitance specified in the $82 \mathrm{C82}$ data sheet is determined by

$$
I=C_{L}(d v / d t)
$$

Assuming that all outputs change state at the same time and that $\mathrm{dv} / \mathrm{dt}$ is constant;

$$
I=C_{L} \frac{(V C C \times 80 \%)}{t_{R} / t_{F}}
$$

where $\mathrm{t}_{\mathrm{R}}=20 \mathrm{~ns}, \mathrm{VCC}=5.0$ volts, $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pf}$ on each of eight outputs.

$$
\begin{aligned}
\mathrm{I} & =\left(8 \times 300 \times 10^{-12}\right) \times(5.0 \mathrm{v} \times 0.8) /\left(20 \times 10^{-9}\right) \\
& =480 \mathrm{~mA}
\end{aligned}
$$

This current spike may cause a large negative voltage spike on VCC, which could cause improper operation of the device. To filter out this noise, it is recommended that a 0.1 uF ceramic disc decoupling capacitor be placed between VCC and GND at each device, with placement being as near to the device as possible.

## Features

- GENERATES THE SYSTEM CLOCK FOR CMOS OR NMOS MICROPROCESSORS
- UP TO 25 MHZ OPERATION
- USES A PARALLEL MODE CRYSTAL CIRCUIT OR EXTERNAL FREQUENCY SOURCE
- PROVIDES READY SYNCHRONIZATION
- GENERATES SYSTEM RESET OUTPUT FROM SCHMITT TRIGGER INPUT
- CAPABLE OF CLOCK SYNCHRONIZATION WITH OTHER 82C84As
- tTL COMPATIBLE INPUTS/OUTPUTS
- VERY LOW POWER CONSUMPTION
- 18 PIN PACKAGE
- SINGLE +5V POWER SUPPLY
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES AVAILABLE


## Description

The Harris 82C84A is a high performance CMOS clock generator-driver which is designed to service the requirements of both CMOS and NMOS microprocessors such as the $80 \mathrm{C} 86,80 \mathrm{C} 88,8086$ and the 8088 . The chip contains a crystal controlled oscillator, a divide-by-three counter and complete "Ready" synchronization and reset logic.
Static CMOS circuit design permits operation with an external frequency source from DC to 25 MHz . Crystal controlled operation to 25 MHz is guaranteed with the use of a parallel, fundamental mode crystal and two small load capacitors.
All inputs (except $\mathrm{X} 1, \mathrm{X} 2$ and $\overline{\mathrm{RES}}$ ) are TTL compatible with a $\mathrm{V}_{\mathrm{IH}}$ of 2.0 volts over the industrial temperature and voltage ranges.

Power consumption is a fraction of that of the equivalent bipolar circuits. This speed-power characteristic of CMOS permits the designer to custom tailor his system design with respect to power and/or speed requirements.

Pinout


| CONTROL <br> PIN | LOGICAL 1 | LOGICAL 0 |
| :---: | :---: | :---: |
| F/ $\overline{\mathrm{C}}$ | External <br> Clock | Crystal <br> Drive |
| $\overline{\text { RES }}$ | Normal | Reset |
| RDY1 <br> RDY2 | Bus Ready | Bus not <br> ready |
| $\overline{\overline{\text { AEN1 }}}$ | Address <br> Disabled | Address <br> Enabled |
| $\overline{\text { AEN2 }}$ | 2 Stage Ready <br> Synchronization | 1 Stage Ready <br> Synchronization |
| ASYNC |  |  |

## Block Diagram



| Pin | I/O | Definition |
| :---: | :---: | :---: |
| $\overline{\overline{A E N 1}} \overline{\overline{A E N 2}}$ | 1 | ADDRESS ENABLE: $\overline{\mathrm{AEN}}$ is an active LOW signal. $\overline{\mathrm{AEN}}$ serves to qualify its respective Bus Ready Signal (RDY1 or RDY2). $\overline{\text { AEN1 }}$ validates RDY1 while $\overline{\mathrm{AEN2}}$ validates RDY2. Two AEN signal inputs are useful in system configurations which permit the processor to access two Multi-Master System Busses. In non Multi-Master configurations, the $\overline{\mathrm{AEN}}$ signal inputs are tied true (LOW). |
| RDY 1, RDY2 | 1 | BUS READY (Transfer Complete). RDY is an active HIGH signal which is an indication from a device located on the system data bus that data has been received, or is available. RDY1 is qualified by AEN1 while RDY2 is qualified by AEN2. |
| $\overline{\text { ASYNC }}$ | 1 | READY SYNCHRONIZATION SELECT: $\overline{A S Y N C}$ is an input which defines the synchronization mode of the READY logic. When $\overline{A S Y N C}$ is low, two stages of READY synchronization are provided. When $\overline{\text { ASYNC }}$ is left open or HIGH a single stage of READY synchronization is provided. |
| READY | 0 | READY: READY is an active HIGH signal which is the synchronized RDY signal input. READY is cleared after the guaranteed hold time to the processor has been met. |
| X1, X2 | 1 | CRYSTAL IN: X1 and X2 are the pins to which a crystal is attached. The crystal frequency is 3 times the desired processor clock frequency. |
| F/C | 1 | FREQUENCY/CRYSTAL SELECT: F/ $\overline{\mathrm{C}}$ is a strapping option. When strapped LOW, F/C permits the processor's clock to be generated by the crystal. When $\mathrm{F} / \overline{\mathrm{C}}$ is strapped HIGH, CLK is generated from the EFI input. |
| EFI | 1 | EXTERNAL FREQUENCY IN: When $F / \overline{\mathrm{C}}$ is strapped HIGH, CLK is generated from the input frequency appearing on this pin. The input signal is a square wave 3 times the frequency of the desired CLK output. |


| Pin | I/O | Definition |
| :---: | :---: | :--- |
| CLK | O | PROCESSOR CLOCK: CLK is the clock out- <br> put used by the processor and all devices <br> which directly connect to the processor's <br> local bus. CLK has an output frequency <br> which is 1/3 of the crystal or EFI input fre- <br> quency and a 1/3 duty cycle. |
| PCLK | O | PERIPHERAL CLOCK: PCLK is a peripheral <br> clock signal whose output frequency is 1/2 <br> that of CLK and has a 50\% duty cycle. |
| OSC | O | OSCILLATOR OUTPUT: OSC is the output <br> of the internal oscillator circuitry. Its fre- <br> quency is equal to that of the crystal. |
| $\overline{\text { RES }}$ | I | RESET IN: $\overline{R E S}$ is an active LOW signal <br> which is used generate RESET.The 82C84A <br> provides a Schmitt trigger input so that an <br> RC connection can be used to establish the <br> power-up reset of proper duration. |
| RESET | O | RESET: RESET is an active HIGH signal <br> which is used to reset the 80C86 family <br> processors. Its timing characteristics are de- <br> termined by RES. |
| CSYNC | I | CLOCK SYNCHRONIZATION: CSYNC is <br> an active HIGH signal which allows multiple <br> 82C84As to be synchronized to provide <br> clocks that are in phase. When CSYNC is <br> HIGH the internal counters are reset. When <br> CSYNC goes LOW the internal counters <br> are allowed to resume counting. CSYNC <br> needs to be externally synchronized to EFI. <br> When using the internal oscillator CSYNC <br> should be hardwired to ground. |
| VCC | Ground <br> GND |  |

TABLE 1. PIN DEFINITIONS

## FUNCTIONAL DESCRIPTION

## Oscillator

The oscillator circuit of the 82C84A is designed primarily for use with an external parallel resonant, fundamental mode crystal from which the basic operating frequency is derived.

The crystal frequency should be selected at three times the required CPU clock. X1 and X2 are the two crystal input crystal connections. For the most stable operation of the oscillator (OSC) output circuit, two capacitors $(\mathrm{C} 1=\mathrm{C} 2)$ as shown in the waveform figures are recommended. The output of the oscillator is buffered and brought out on OSC so that other system timing signals can be derived from this stable, crystal-controlled source.

Capacitors $\mathrm{C} 1, \mathrm{C} 2$ are chosen such that their combined capacitance:

$$
C T=\frac{C 1 \cdot C 2}{C 1+C 2} \text { (Including stray capacitance) }
$$

matches the load capacitance as specified by the crystal manufacturer. This insures operation within the frequency tolerance specified by the crystal manufacturer.

## Clock Generator

The clock generator consists of a synchronous divide-bythree counter with a special clear input that inhibits the counting. This clear input (CSYNC) allows the output clock to be synchronized with an external event (such as
another 82C84A clock). It is necessary to synchronize the CSYNC input to the EFI clock external to the 82C84A. This is accomplished with two flip-flops. (See Figure 3.) The counter output is a 33\% duty cycle clock at one-third the input frequency.

* The F/C input is a strapping pin that selects either the crystal oscillator or the EFI input as the clock for the $\div 3$ counter. If the EFI input is selected as the clock source, the oscillator section can be used independently for another clock source. Output is taken from OSC.


## Clock Outputs

The CLK output is a $33 \%$ duty cycle clock driver designed to drive the 80C86, 80 C 88 processors directly. PCLK is a peripheral clock signal whose output frequency is $1 / 2$ that of CLK. PCLK has a 50\% duty cycle.

## Reset Logic

The reset logic provides a Schmitt trigger input ( $\overline{\mathrm{RES}}$ ) and a synchronizing flip-flop to generate the reset timing. The reset signal is synchronized to the falling edge of CLK. A simple RC network can be used to provide poweron reset by utilizing this function of the 82C84A. Waveforms for clocks and reset signals are illustrated in Figure 4.

## READY Synchronization

Two READY inputs (RDY1, RDY2) are provided to accommodate two system busses. Each input has a qualifier ( $\overline{\mathrm{AEN}} 1$ and $\overline{\mathrm{AEN} 2}$, respectively). The $\overline{\mathrm{AEN}}$ signals validate their respective RDY signals. If a Multi-Master system is not being used the $\overline{\mathrm{AEN}}$ pin should be tied LOW.

Synchronization is required for all asynchronous activegoing edges of either RDY input to guarantee that the RDY setup and hold times are met. Inactive-going edges of RDY in normally ready systems do not require synchronization but must satisfy RDY setup and hold as a matter of proper system design.
The $\overline{\text { ASYNC }}$ input defines two modes of READY synchronization operation.

When $\overline{\text { ASYNC }}$ is LOW, two stages of synchronization are provided for active READY input signals. Positive-going asynchronous READY inputs will first be synchronized to flip-flop one at the rising edge of CLK (requiring a setup time trivCH) and then synchronized to flip-flop two at the next falling edge of CLK, after which time the READY output will go active (HIGH). Negative-going asynchronous READY inputs will be synchronized directly to flip-flop two at the falling edge of CLK, after which time the READY output will go inactive.This mode of operation is intended for use by asynchronous (normally not ready) devices in the system which cannot be guaranteed by design to meet the required RDY setup timing, tR1VCL, on each bus cycle. (Refer to Figure 5.)

When $\overline{\text { ASYNC }}$ is high or left open, the first READY flipflop is bypassed in the READY synchronization logic. READY inputs are synchronized by flip-flop two on the falling edge of CLK before they are presented to the processor. This mode is available for synchronous devices that can be guaranteed to meet the required RDY setup time. (Refer to Figure 6.)
$\overline{\text { ASYNC }}$ can be changed on every bus cycle to select the appropriate mode of synchronization for each device in the system.


FIGURE 3. CSYNC SYNCHRONIZATION
*Note: If EFI input is used, then crystal input X1 must be tied to VCC or GND and X2 should be left open. If the crystal inputs are used, then EFI should be tied to VCC or GND.

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 Volts | Operating Temperature Range |  |
| :--- | ---: | :--- | ---: |
| Operating Voltage Range | +4 V to +7 V | Commercial | $0{ }^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Input Voltage Applied | GND -2.0 V to 6.5 V | Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Output Voltage Applied | GND -0.5 V to VCC +0.5 V | Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $-65 \circ^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Maximum Power Dissipation | 1 Watt |

CAUTION: Stresses above those listed in the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D. C. ELECTRICAL CHARACTERISTICS

$$
V C C=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=0^{\circ} \mathrm{C} \text { to }+70{ }^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 84 \mathrm{~A}) ; T_{A}=-40^{\circ} \mathrm{C} \text { to }+85{ }^{\circ} \mathrm{C}(182 \mathrm{C} 84 \mathrm{~A}) ;
$$

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C84A)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \text { I82C84A } \\ & \text { M82C84A } \end{aligned}$ |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{T}}{ }^{+}$ | Reset Input High Voltage | 0.6 VCC | VCC -0.8 | V |  |
| $\mathrm{V}_{\mathrm{T}^{+}-\mathrm{V}_{\mathrm{T}}-}$ | Reset Input Hysteresis | 0.2 VCC |  |  |  |
| VOH | Logical One Output Voltage | VCC-0.4 |  | V | $10 \mathrm{H}=-4.0 \mathrm{~mA}$ for CLK output $1 \mathrm{OH}=-2.5 \mathrm{~mA}$ for all others |
| VOL | Logical Zero Output Voltage |  | 0.4 | V | $10 \mathrm{~L}=+4.0 \mathrm{~mA}$ for CLK output $10 \mathrm{~L}=+2.5 \mathrm{~mA}$ for all others |
| IIL | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | OV<VIN $<$ VCC except $\overline{A S Y N C}, \times 1$-see note 1 |
| ICC | Power <br> Supply Current |  | 40 | mA | Crystal <br> Frequency $=25 \mathrm{MHz}$ <br> Outputs Open |

NOTES:

1. ASYNC pin includes an internal $17.5 \mathrm{~K} \Omega$ nominal pull-up resistor. For $\overline{\mathrm{ASYNC}}$ input at $\mathrm{GND}, \overline{\mathrm{ASYNC}}$ input leakage current $=130 \mu \mathrm{~A}$ nominal.
X1 - crystal feedback input.
CAPACITANCE

$$
T_{A}=25^{\circ} \mathrm{C} . \mathrm{VCC}=G N D=0 \mathrm{~V} ; \mathrm{VIN}=+5 \mathrm{~V} \text { or } G N D
$$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1 N^{*}}$ | Input <br> Capacitance |  | 5 | pf | Freq. $=1 \mathrm{MHz}$ |

[^10]$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ Commercial Grade - C82C84A
A. C. CHARACTERISTICS

TIMING REQUIREMENTS
$T_{A}=-400 \mathrm{C}$ to $+850 \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$ Industrial Grade -182C84A
$T_{A}=-550 \mathrm{C}$ to $+1250 \mathrm{C}, \mathrm{VCC}=5 \mathrm{~V} \pm 10 \%$ Military Grade -M 82 C 84 A

| Symbol | Marameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| tEHEL | External Frequency HIGH Time | 13 |  | ns | $90 \%-90 \%$ VIN |
| tELEH | External Frequency LOW Time | 13 |  | ns | $10 \%-10 \% \mathrm{VIN}$ |
| tELEL | EFI Period | 36 |  | ns |  |
|  | XTAL Frequency | 2.4 | 25 | MHz |  |
| tR1VCL | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | ASYNC = HIGH |
| tR1VCH | RDY1, RD2 Active Setup to CLK | 35 |  | ns | ASYNC = LOW |
| tR1VCL | RDY1, RDY2 Inactive Setup to CLK | 35 |  | ns |  |
| tCLR1X | RDY1, RDY2 Hold to CLK | 0 | ns |  |  |
| tAYVCL | ASYNC Setup to CLK | 50 |  | ns |  |
| tCLAYX | ASYNC Hold to CLK | 0 |  | ns |  |
| tA1VR1V | AEN1, AEN2 Setup to RDY1, RDY2 | 15 |  | ns |  |
| tCLA1X | AEN1, AEN2 Hold to CLK | 0 |  | ns |  |
| tYHEH | CSYNC Setup to EFI | 20 |  | ns |  |
| tEHYL | CSYNC Hold to EFI | 20 |  | ns |  |
| tYHYL | CSYNC Width | $2 . t E L E L$ |  | ns |  |
| tI1HCL | RES Setup to CLK | 65 |  | ns | (Note 2) |
| tCLI1H | RES Hold to CLK | 20 |  | ns | (Note 2) |

## A. C. CHARACTERISTICS (cont.) <br> TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| tCLCL | CLK Cycle Period | 125 |  | ns |  |
| tCHCL | CLK HIGH Time | $(1 / 3 \mathrm{tCLCL})+2.0$ |  | ns | Fig. 7 \& Fig. 8 |
| tCLCH | CLK LOW Time | $(2 / 3 \mathrm{tCLCL})-15.0$ |  | ns | Fig. $7 \&$ Fig. 8 |
| tCH1CH2 <br> tCL2CL1 | CLK Rise or Fall Time |  | 10 | ns | 1.0 V to 3.5V |
| tPHPL |  | PCLK HIGH Time | tCLCL-20 |  | ns |
| tPLPH | PCLK LOW Time | tCLCL-20 |  | ns |  |
| tRYLCL | Ready Inactive to CLK (See note 4) | -8 |  | ns | Fig. 8 \& Fig. 10 |
| tRYHCH | Ready Active to CLK (See note 3) | $(2 / 3$ tCLCL) -15.0 |  | ns | Fig. 9 \& Fig. 10 |
| tCLIL | CLK to Reset Delay |  | 40 | ns |  |
| tCLPH | CLK to PCLK HIGH Delay |  | 22 | ns |  |
| tCLPL | CLK to PCLK LOW Delay |  | 22 | ns |  |
| tOLCH | OSC to CLK HIGH Delay | -5 | 22 | ns |  |
| tOLCL | OSC to CLK LOW Delay | 2 | 35 | ns |  |

NOTES:

1. Output signals switch between VOH and VOL unless otherwise specified.
2. Setup and hold necessary only to guarantee recognition at next clock.
3. Applies only to T3 TW states.
4. Applies only to T2 states.
5. All timing delays are measured at 1.5 volts unless otherwise noted.
6. Input signals must switch between VIL max -.4 VOH and VIH min +.4 volts in 15 ns unless otherwise specified.
+Figure 11 illustrates test load measurement condition.

note: all timing measurements are made at 1.5 volts, unless otherwise noted.
FIGURE 4. WAVEFORMS FOR CLOCKS AND RESET SIGNALS


FIGURE 5. WAVEFORMS FOR READY SIGNALS (FOR ASYNCHRONOUS DEVICES)


FIGURE 6. WAVEFORMS FOR READY SIGNALS (FOR SYNCHRONOUS DEVICES)


FIGURE 7. CLOCK HIGH AND LOW TIME (USING X1, X2)

FIGURE 9. READY TO CLOCK (USING X1, X2)



FIGURE 8. CLOCK HIGH AND LOW TIME (USING EFI)


FIGURE 10. READY TO CLOCK (USING EFI)


FIGURE 11. TEST LOAD MEASUREMENT CONDITIONS

NOTES:

1. $C_{L}=100 \mathrm{pF}$
2. $C_{L}=30 \mathrm{pF}$
3. $C_{L}$ INCLUDES PROBE AND JIG CAPACITANCE

| PARAMETER | TYPICAL CRYSTAL SPEC |
| :--- | :--- |
| Frequency | $2.4-25 \mathrm{MHz}$, Fundamental, "AT" cut |
| Type of Operation | Parallel |
| Unwanted Modes | -6 db (Min) |
| Load Capacitance | $18-32 \mathrm{pf}$ |

TABLE 2. CRYSTAL SPECIFICATIONS

See Harris Publication TB-47 for recommended crystal specifications.

## CMOS BUS CONTROLLER

## Features

- PIN COMPATIBLE WITH BIPOLAR 8288
- PROVIDES ADVANCED COMMANDS FOR MULTI-MASTER BUSSES


## 3-STATE COMMAND OUTPUTS

- BIPOLAR DRIVE CAPABILITY
- FULLY TTL COMPATIBLE
- SCALED SAJI IV CMOS PROCESS
- SINGLE 5V POWER SUPPLY
- LOW POWER OPERATION
$\quad$ ICCSB $-10 \mu \mathrm{~A}$
$\mathrm{ICCOP}-1 \mathrm{~mA} / \mathrm{MHz}$
- INDUSTRIAL, MILITARY, AND COMMERCIAL TEMPERATURE RANGES


## Description

The Harris 82 C 88 is a high performance CMOS Bus Controller manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV). The 82C88 provides the control and command timing signals for $80 C 86$ and $8086 / 88$ systems. The high output drive capability of the 82 C 88 eliminates the need for additional bus drivers. High speed and industry standard configuration make the 82 C 88 compatible with microprocessors such as the $80 \mathrm{C} 86,8086$, 8088, 8089, 80186, and 80188.

Static CMOS circuit design insures low operating power. Harris's advanced SAJI process results in performance equal to or greater than existing equivalent products at a significant power savings.

Pinout


## Functional Diagram



82C88

## Pin Description

| SYMBOL | PIN <br> NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $V_{C C}$ | 20 |  | +5 V power supply |
| GND | 10 |  | Ground |
| $\overline{s_{0}}, \overline{S_{1}}$ | $\begin{gathered} 19,3 \\ 18 \end{gathered}$ | 1 | Status Input pins: These pins are the input pins from the $80 C 86,8086 / 88 / 8089$ processors. The 82C88 decodes these inputs to generate command and control signals at the appropriate time. When Status pins are not in use (passive), command outputs are held HIGH (See Table 1.) |
| CLK | 2 | 1 | Clock: This is a CMOS compatible input which receives a clock signal from the 82C84A clock generator and serves to establish when command/control signals are generated. |
| ALE | 5 | 0 | Address Latch Enable: This signal serves to strobe an address into the address latches. This signal is active HIGH and latching occurs on the falling (HIGH to LOW) transition. ALE is intended for use with transparent D type latches, such as the 82 C 82. |
| DEN | 16 | 0 | Data Enable: This signal serves to enable data transceivers onto either the local or system data bus. This signal is active HIGH. |
| $\mathrm{DT} / \overline{\mathrm{R}}$ | 4 | 0 | Data Transmit/Receive: This signal establishes the direction of data flow through the transceivers. A HIGH on this line indicates Transmit (write to I/O or memory) and a LOW indicates Receive (Read). |
| $\overline{\text { AEN }}$ | 6 | 1 | Address Enable: $\overline{\text { AEN }}$ enables command outputs of the 82 C 88 Bus Controller a minimum of 110 ns ( 250 ns maximum) after it becomes active (LOW). $\overline{\text { AEN }}$ going inactive immediately 3 states the command output drivers. $\overline{A E N}$ does not affect the I/O command lines if the 82C88 is in the I/O Bus mode (IOB tied HIGH). |
| CEN | 15 | 1 | Command Enable: When this signal LOW all 82C88 command outputs and the DEN and PDEN control outputs are forced to their Inactive state. When this signal is HIGH, these same outputs are enabled. |
| 108 | 1 | 1 | Input/Output Bus Mode: When the IOB is strapped HIGH the 82 C 88 functions in the I/O Bus mode. When it is strapped LOW, the 82C88 functions in the System Bus mode (See I/O Bus and System Bus sections). |
| $\overline{\text { AIOWC }}$ | 12 | 0 | Advanced I/O Write Command: The $\overline{\mathrm{AIOWC}}$ issues an I/O Write Command earlier in the machine cycle to give I/O devices an early indication of a write instruction. Its timing is the same as a read command signal. $\overline{\text { AlOWC }}$ is active LOW. |
| $\overline{\text { IOWC }}$ | 11 | 0 | I/O Write Command: This command line instructs an I/O device to read the data on the data bus. The signal is active LOW. |
| $\overline{\text { IORC }}$ | 13 | 0 | I/O Read Command: This command line instructs an I/O device to drive its data onto the data bus. This signal is active LOW. |
| $\overline{\text { AMWC }}$ | 8 | 0 | Advanced Memory Write Command: The $\overline{A M W C}$ issues a memory write command earlier in the machine cycle to give memory devices an early indication of a write instruction. Its timing is the same as a read command signal. $\overline{A M W C}$ is active LOW. |
| $\overline{\text { MWTC }}$ | 9 | 0 | Memory Write Command: This command line instructs the memory to record the data present on the data bus. This signal is active LOW. |
| $\overline{\text { MRDC }}$ | 7 | 0 | Memory Read Command: This command line instructs the memory to drive its data onto the data bus. $\overline{M R D C}$ is active LOW. |
| $\overline{\text { INTA }}$ | 14 | 0 | Interrupt Acknowledge: This command line tells an interrupting device that its interrupt has been acknowledged and that it should drive vectoring information onto the data bus. This signal is active LOW. |
| MCE/PDEN | 17 | 0 | This is a dual function pin. MCE (IOB is tied LOW): Master Cascade Enable occurs during an interrupt sequence and serves to read a Cascade Address from a master 82C59A Priority Interrupt Controller onto the data bus. The MCE signal is active HIGH. $\overline{\text { PDEN (IOB is tied HIGH) : }}$ Peripheral Data Enable enables the data bus transceiver for the I/O bus that DEN performs for the system bus. $\overline{\text { PDEN }}$ is active LOW. |

## Functional Description

## Command and Control Logic

The command logic decodes the three 80C86, 8086, 8088 or 8089 status lines ( $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{~S}_{2}}$ ) to determine what command is to be issued (see Table 1).

Table 1. Command Decode Definition

| $\overline{\mathbf{S}_{\mathbf{2}}}$ | $\overline{\mathbf{S}_{\mathbf{1}}}$ | $\overline{\mathbf{S}_{\mathbf{0}}}$ | Processor State | $\mathbf{8 2 C 8 8}$ <br> Command |
| :--- | :---: | :---: | :--- | :--- |
| 0 | 0 | 0 | Interrupt Acknowledge | $\overline{\mathrm{NTA}}$ |
| 0 | 0 | 1 | Read I/O Port | $\overline{\overline{O R C}}$ |
| 0 | $\mathbf{1}$ | 0 | Write I/O Port | $\overline{\mathrm{IOWC}}, \overline{\mathrm{AIOWC}}$ |
| 0 | $\mathbf{1}$ | 1 | Halt | None |
| 1 | $\mathbf{0}$ | 0 | Code Access | $\overline{\text { MRDC }}$ |
| 1 | 0 | $\mathbf{1}$ | Read Memory | $\overline{\text { MRDC }}$ |
| 1 | 1 | 0 | Write Memory | $\overline{\text { MWTC }, \overline{\text { AMWC }}}$ |
| 1 | $\mathbf{1}$ | $\mathbf{1}$ | Passive | None |

## I/O Bus Mode

The 82 C 88 is in the I/O Bus mode if the IOB pin is strapped HIGH. In the I/O Bus mode, all I/O command lines IORC, $\overline{\overline{I O W C},} \overline{\mathrm{AIOWC}}, \overline{\mathrm{INTA}}$ ) are always enabled (i.e., not dependent on $\overline{\mathrm{AEN}})$. When an I/O command is initiated by the processor, the 82C88 immediately activates the command lines using $\overline{P D E N}$ and $D T / \bar{R}$ to control the $I / O$ bus transceiver. The I/O command lines should not be used to control the system bus in this configuration because no arbitration is present. This mode allows one 82C88 Bus Controller to handle two external busses. No waiting is involved when the CPU wants to gain access to the I/O bus. Normal memory access requires a "Bus Ready" signal ( $\overline{\mathrm{AEN}}$ LOW) before it will proceed. It is advantageous to use the IOB mode if I/O or peripherals dedicated to one processor exist in a multi-processor system.

## System Bus Mode

The 82C88 is in the System Bus mode if the IOB pin is strapped LOW. In this mode, no command is issued until a specified time period after the $\overline{\text { AEN }}$ line is activated (LOW). This mode assumes bus arbitration logic will inform the bus controller (on the $\overline{\operatorname{AEN}}$ line) when the bus is free for use. Both memory and I/O commands wait for bus arbitration. This mode is used when only one bus exists. Here, both I/O and memory are shared by more than one processor.

## Command Outputs

The advanced write commands are made available to initiate write procedures early in the machine cycle. This signal can be used to prevent the processor from entering an unnecessary wait state.
The command outputs are:

[^11]AMWC - Advanced Memory Write Command
$\overline{\text { AIOWC }}$ - Advanced I/O Write Command
INTA - Interrupt Acknowledge
INTA (Interrupt Acknowledge) acts as an I/O read during an interrupt cycle. Its purpose is to inform an interrupting device that its interrupt is being acknowledged and that it should place vectoring information onto the data bus.

## Control Outputs

The control outputs of the 82C88 are Data Enable (DEN), Data Transmit/Receive (DT/R) and Master Cascade Enable/ Peripheral Data Enable (MCE/PDEN). The DEN signal determines when the external bus should be enabled onto the local bus and the $\mathrm{DT} / \overline{\mathrm{R}}$ determines the direction of data transfer. These two signals usually go to the chip select and direction pins of a transceiver.

The MCE/ $\overline{P D E N}$ pin changes function with the two modes of the 82 C 88 . When the 82 C 88 is in the IOB mode (IOB HIGH), the PDEN signal serves as a dedicated data enable signal for the I/O or Peripheral System bus.

## Interrupt Acknowledge and MCE

The MCE signal is used during an interrupt acknowledge cycle if the 82C88 is in the System Bus mode (IOB LOW). During any interrupt sequence, there are two interrupt acknowledge cycles that occur back to back. During the first interrupt cycle no data or address transfers take place. Logic should be provided to mask off MCE during this cycle. Just before the second cycle begins the MCE signal gates a master Priority Interrupt Controller's (PIC) cascade address onto the processor's local bus where ALE (Address Latch Enable) strobes it into the address latches. On the leading edge of the second interrupt cycle, the addressed slave PIC gates an interrupt vector onto the system data bus where it is read by the processor.

If the system contains only one PIC, the MCE signal is not used. In this case, the second Interrupt Acknowledge signal gates the interrupt vector onto the processor bus.

## Address Latch Enable and Halt

Address Latch Enable (ALE) occurs during each machine cycle and serves to strobe the current address into the 82C82 address latches. ALE also serves to strobe the status $\left(\overline{\mathbf{S}_{0}}, \overline{\mathbf{S}_{1}}, \overline{\mathbf{S}_{2}}\right)$ into a latch for halt state decoding.

## Command Enable

The Command Enable (CEN) input acts as a command qualifier for the 82 C 88 . If the CEN pin is high, the 82C88 functions normally. If the CEN pin is pulled LOW, all command lines are held in their inactive state (not 3-state). This feature can be used to implement memory partitioning and to eliminate address conflicts between system bus devices and resident bus devices.

## Specifications

## ABSOLUTE MAXIMUM RATINGS


D. C. ELECTRICAL CHARACTERISTICS
$V C C=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 88) ; \mathrm{T}_{A}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}(182 \mathrm{C} 88) ; \mathrm{T}_{A}=-55^{\circ} \mathrm{C}$ to $+1250 \mathrm{C}(\mathrm{M} 82 \mathrm{C} 88)$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ |  | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & \text { 182C88 } \\ & \text { M82C88 } \end{aligned}$ |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| VIHC | CLK Logical One Input Voltage | 0.7 VCC |  | V |  |
| VILC | CLK Logical Zero Input Voltage |  | 0.2VCC | V |  |
| VOH | Output High Voltage Command Outputs | $\begin{gathered} 3.0 \\ \text { VCC }-0.4 \end{gathered}$ |  | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & 1 \mathrm{OH}=-8.0 \mathrm{~mA} \\ & 1 \mathrm{OH}=-2.5 \mathrm{~mA} \end{aligned}$ |
|  | Output High Voltage Control Outputs | $\begin{gathered} 3.0 \\ \text { VCC }-0.4 \end{gathered}$ |  | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & 1 \mathrm{OH}=-4.0 \mathrm{~mA} \\ & 1 \mathrm{OH}=-2.5 \mathrm{~mA} \end{aligned}$ |
| VOL | Output Low Voltage Command Outputs |  | 0.5 | V | $1 \mathrm{OL}=+20.0 \mathrm{~mA}$ |
|  | Output Low Voltage Control Outputs |  | 0.4 | V | $10 \mathrm{~L}=+8.0 \mathrm{~mA}$ |
| IIL | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & O V \leq V I N \leq V C C \\ & \text { except } \overline{S_{0}}, \overline{S_{1}}, \overline{S_{2}} \end{aligned}$ |
| IBHH | Input Leakage Current-Status Bus | -50 | -300 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VIN}=2.0 \mathrm{~V} \\ & \frac{\mathrm{~S}_{0}}{}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{~S}_{2}} \text { (see Note 1) } \end{aligned}$ |
| 10 | Output Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VO} \leq \mathrm{VCC}$ |
| ICCSB | Standby Power Supply |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V} \\ & \text { VIN }=\text { VCC or GND } \\ & \text { Outputs Open } \end{aligned}$ |
| ICCOP | Operating Power Supply Current |  | 1 | $\mathrm{mA} / \mathrm{MHz}$ | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V} \\ & \text { Outputs Open } \end{aligned}$ |

CAPACITANCE
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{VCC}=\mathrm{GND}=\mathrm{OV} ; \mathrm{VIN}=+5 \mathrm{~V}$ or GND

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| CIN* $^{*}$ | Input Capacitance |  | 5 | pf | FREQ $=1 \mathrm{MHz}$ <br> Unmeasured pins <br> returned to GND |
| COUT* $^{*}$ | Output Capacitance |  | 15 | pf |  |

*Guaranteed and sampled, but not 100\% tested
Note 1: IBHH should be measured after raising the VIN on $\overline{\mathbf{S}_{\mathbf{0}}}, \overline{\mathbf{S}_{1}}, \overline{\mathbf{S}_{2}}$ to VCC and then lowering to 2.0V.

## A. C. CHARACTERISTICS

$$
\begin{aligned}
\mathrm{VCC}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND=0V}: \mathrm{TA} & =0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 88) \\
\mathrm{TA} & =-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(182 \mathrm{C} 88) \\
\mathrm{TA} & =-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 88)
\end{aligned}
$$

## TIMING REQUIREMENTS

| SYMBOL | PARAMETER | MIN | MAX | UNIT |
| :--- | :--- | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 125 |  | TEST CONDITIONS |
| TCLCH | CLK Low Time | 66 |  | ns |
| TCHCL | CLK High Time | 40 |  | ns |
| TSVCH | Status Active Setup Time | 35 |  | ns |
| TCHSV | Status Active Hold Time | 10 |  | ns |
| TSHCL | Status Inactive Setup Time | 35 |  | ns |
| TCLSH | Status Inactive Hold Time | 10 |  | ns |

TIMING RESPONSES


Note 1: TAELCH measurement is between 1.5 V and 2.5 V .
Note 2: TAEHCZ measured at 0.5 V change in VO .

## A. C. Test Circuits


*Includes stray and jig capacitance

| TEST <br> CONDITION | 10 H | IOL | V1 | R1 | $\mathbf{C 1}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | -4.0 mA | +8.0 mA | 2.13 V | $220 \Omega$ | 80 pf |
| 2 | -8.0 mA | +20.0 mA | 2.29 V | $91 \Omega$ | 300 pf |
| 3 | -8.0 mA | - | 1.5 V | $187 \Omega$ | 300 pf |
| 4 | -8.0 mA | - | 1.5 V | $187 \Omega$ | 50 pf |

TEST CONDITION DEFINITION TABLE

## A. C. Testing Input, Output Waveform

INPUT
$\mathrm{VIH}+0.4 \mathrm{~V}$
$\mathrm{VIL}-0.4 \mathrm{~V}$
A. C. Testing: All input signals (other than CLK) must switch between VIL -0.4 V and $\mathrm{VIH}+0.4 \mathrm{~V}$. CLK must switch between 0.4 V and 3.9 V . $T_{R}$ and $T_{F}$ must be less then or equal to 15 ns .

notes:

1. ADopessidata bus is shown only for reference purposes


## $82 C 88$

Waveforms (cont.)


DEN, PDEN QUALIFICATION TIMING


NOTE: CEN must be low or valid prior to T2 to prevent the command from being generated.
ADDRESS ENABLE ( $\overline{\mathrm{AEN}}$ ) TIMING (3-STATE ENABLE/DISABLE)

## Features

－COMPATIBLE WITH NMOS 8088
－DIRECT SOFTWARE COMPATIBLITY WITH 80C86，8086， 8088
－ 8 BIT DATA BUS INTERFACE
－ 16 BIT INTERNAL ARCHITECTURE
－COMPLETELY STATIC DESIGN

- OPERATION FROM DC TO 5 MHz
－LOW POWER OPERATION
－ICCSB $=500 \mu$ A MAXIMUM
$-I C C O P=10 \mathrm{~mA} / \mathrm{MHz}$ TYPICAL
－ 1 MBYTE OF DIRECT MEMORY ADDRESSING CAPABILITY
－ 24 OPERAND ADDRESSING MODES
－BIT，BYTE，WORD，AND BLOCK MOVE OPERATIONS
－ 8 and 16 BIT SIGNED／UNSIGNED ARITHMETIC
－BUS－HOLD CIRCUITRY ELIMINATES PULL－UP RESISTORS
－SCALED SAJI IV CMOS PROCESS
－SINGLE 5V POWER SUPPLY
－COMMERCIAL，INDUSTRIAL and MILITARY TEMPERATURE RANGES


## Description

The Harris 80 C 88 high performance 16 bit CMOS CPU is manufactured using a self－aligned silicon gate CMOS process（Scaled SAJI IV）．Two modes of opera－ tion，MINimum for small systems and MAXimum for larger applications such as multi－processing，allow user configuration to achieve the highest performance level．Full TTL compatibility and industry standard operation allow use of exist－ ing NMOS 8088 hardware and Harris CMOS 80C86 peripherals．Complete soft－ ware compatibility with the 80C86， 8086 and 8088 microprocessors allows use of existing software in new designs．

Pinout

|  |  |  |  |  | $\begin{aligned} & \text { MIN } \\ & \text { MODE } \end{aligned}$ | $\left(\begin{array}{c}\text { MAX } \\ \text { MODE }\end{array}\right\}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| GND | $\sqrt{1}$ |  | 40 | $\square$ | $\mathrm{V}_{\text {cc }}$ |  |
| A14 | ${ }^{2}$ |  | 39 | $\square$ | A15 |  |
| A13 | 3 |  | 38 | $\square$ | A16／S3 |  |
| A12 | $4^{4}$ |  | 37 | $\square$ | A17／S4 |  |
| A11 | 5 |  | 36 | $\square$ | A18／S5 |  |
| A10 | 6 |  | 35 | － | A19／S6 |  |
|  | 7 |  | 34 | 曰 | $\overline{\text { SSO }}$ | （HIGH） |
|  | 8 |  | 33 | 曰 | M $\mathrm{N} / \overline{\mathrm{MX}}$ |  |
| AD7 | 9 |  | 32 | $\square$ | $\overline{\text { RD }}$ |  |
| AD6 | 10 | $\begin{aligned} & 8088 \\ & \text { CPU } \end{aligned}$ | 31 | $\square$ | HOLD | （ $\overline{\text { RO／GTO }}$ |
| AD5 | 11. |  | 30 | $\square$ | HLDA | （ $\overline{\mathbf{R}} / \overline{\mathrm{GT} 1}$ ） |
| AD4 | 12 |  | 29 | $\square$ | WR | （LOCK） |
| AD3 | 13 |  | 28 | $\square$ | $10 / \bar{M}$ | （5） |
| AD2 | 14 |  | 27 | $\square$ | DT／R | （S1） |
| AD1 | 15 |  | 26 | $\square$ | DEN | （ $\overline{\mathbf{S O}}$ ） |
| ADO | 16 |  | 25 | $\square$ | ALE | （QSO） |
| NMI | 17 |  | 24 | $\square$ | INTA | （QS1） |
| INTR | 18 |  | 23 | $\square$ | TEST |  |
| CLK | 19 |  | 22 | $\square$ | READY |  |
| GND | 20 |  | 21 | 日 | RESET |  |

## Functional Diagram



CAUTION：Electronic devices are sensitive to electrostatic discharge．Proper I．C．handling procedures should be followed．

82C37A

Preview

## CMOS HIGH PERFORMANCE PROGRAMMABLE DMA CONTROLLER

## Features

－SCALED SAJII IV CMOS PROCESS
－COMPATIbLE WITH the NMOS 82C37A
－LOW POWER OPERATION
－COMMERCIAL，INDUSTRIAL AND MILITARY TEMPERATURE RANGES
－fully ttl compatible
－FOUR INDEPENDANT DMA CHANNELS
－HIGH PERFORMANCE UP TO 1.6 MBYTES／SEC TRANSFERS
－DIRECTLY EXPANDABLE TO ANY NUMBER OF CHANNELS
－UPGRADED CAPABILITIES ALLOW SOFTWARE READ OF MOST INTERNAL REGISTERS AND STATUS BITS

## Description

The Harris 82C37A Multimode Direct Memory Access（DMA）Controller is a peripheral interface circuit for microprocessor systems．It is designed to improve system performance by allowing external devices to directly transfer information from the system memory．Memory－to－memory transfer capabil－ ity is also provided．The 82C37A offers a wide variety of programmable con－ trol features to enhance data throughput and system optimization and to allow dynamic reconfiguration under program control．

The 82C37A is designed to be used in conjunction with an external 8－bit address register such as the 82 C 82 and may be expanded to any number of channels by cascading additional controller chips．

The three basic transfer modes allow programmability of the types of DMA service by the user．Each channel can be individually programmed to Auto－ initialize to its original condition following an End of Process（EOP）．

Each channel has a full 64 K address and word count capability．

## Pinout



## Block Diagram



CAUTION：These devices are sensitive to electrostatic discharge．Users should follow standard I．C．Handling Procedures．

## Preview

Features

- full eight bit parallel latching inverting buffer
- bIPOLAR 8283 COMPATIBLE
- three state non-inverting outputs
- PROPAGATION DELAY - 35nsec MAX.
- A.C. CHARACTERISTICS GUARANTEED FOR:
- full temperature range
- 10\% POWER SUPPLY TOLERANCE
$-\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$
- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT - $10 \mu \mathrm{~A}$ MAX. STANDBY
- OUTPUTS GUARANTEED VALID AT $\mathrm{V}_{\mathrm{CC}}=2.0$ VOLTS
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES
- 20 PIN PACKAGE ON 0.3"' CENTERS


## Description

The Harris 82C83 is an octal latching buffer manufactured using a selfaligned silicon gate CMOS process. This circuit provides an eight bit parallel latch/buffer in a 20 pin package. The active high strobe (STB) input allows transparent transfer of data and latches data on the negative transition of this signal. The active low output enable ( $\overline{\mathrm{OE}}$ ) permits simple interface to state-of-the-art microprocessor systems. The 82C83 provides inverted data at the outputs.

## Pinout

| DIo $\square_{0}$ | 20 | $V_{C C}$ |
| :---: | :---: | :---: |
| DI $1 \square_{2}$ | 19 | $\overline{\mathrm{DO}_{0}}$ |
| $\mathrm{DI}_{2} \square_{3}$ | 18 | $\overline{\mathrm{DO}} 1$ |
| $\mathrm{DI}_{3} \square_{4}$ | 17 | $\overline{\mathrm{DO}_{2}}$ |
| D14 $\square 5$ | 16 | $\overline{\mathrm{DO}}_{3}$ |
| $\mathrm{DI}_{5} \square_{6}$ | 15 | $\overline{\mathrm{DO}_{4}}$ |
| D16 $\square 7$ | 14 | $\overline{\mathrm{DO}}_{5}$ |
| $\mathrm{DI7}_{7} \square_{8}$ | 13 | $\overline{\mathrm{DO}}_{6}$ |
| $\overline{O E} \square 9$ | 12 | $\overline{\mathrm{DO}} 7$ |
| GND 10 | 11 | STB |


| PIN NAMES |  |
| ---: | :--- |
| $\mathrm{DI}_{0}-\mathrm{DII}_{7}$ | Data Input Pins |
| $\overline{\mathrm{DO}}_{0}-\overline{\mathrm{DO}}_{7}$ | Inverted Data Output Pins |
| STB | Active High Strobe Input |
| $\overline{\mathrm{OE}}$ | Active Low Output Enable |

## Functional Diagram



Truth Table

| STB | $\overline{O E}$ | $D I$ | $\overline{D O}$ |
| :---: | :---: | :---: | :---: |
| $X$ | $H$ | $X$ | $H i-Z$ |
| $H$ | $L$ | $L$ | $H$ |
| $H$ | $L$ | $H$ | $L$ |
| $\downarrow$ | $L$ | $X$ | ${ }^{*}$ |


| $H$ | $=$ Logic One | $\mathrm{Hi}-\mathrm{Z}$ | $=$ High Impedance |
| ---: | :--- | ---: | :--- |
| $L$ | $=$ Logic Zero | $\downarrow$ | $=$ Negative Transition |
| $X$ | $=$ Don't Care | ${ }^{*}$ | $=$ Latched to value of last data |

CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

## Features

- GENERATES THE SYSTEM CLOCK FOR CMOS OR NMOS MICROPROCESSORS
- OSCILLATOR - STOP CIRCUITRY ALLOWS MINIMUM POWER STANDBY
- PIN COMPATIBLE WITH BIPOLAR 8284A AND CMOS 82C84A
- USES A PARALLEL MODE CRYSTAL CIRCUIT OR EXTERNAL FREQUENCY SOURCE
- PROVIDES READY SYNCHRONIZATION
- GENERATES SYSTEM RESET OUTPUT FROM SCHMITT TRIGGER INPUT
- CAPABLE OF CLOCK SYNCHRONIZATION WITH OTHER 82C84As or 82C84Bs
- TTL COMPATIBLE INPUTS/OUTPUTS
- VERY LOW POWER CONSUMPTION
- 18 PIN CERAMIC OR PLASTIC PACKAGE
- SINGLE +5V POWER SUPPLY
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES AVAILABLE


## Description

The Harris 82 C 84 B is a high performance CMOS clock generator-driver which is designed to service the requirements of both CMOS and NMOS microprocessors such as the $80 C 86,80 C 88,8086$ and the 8088 . The chip contains a crystal controlled oscillator, a divide-by-three counter and complete "Ready" synchronization and reset logic.

Static CMOS design permits operation with an external frequency source from DC to 25 MHz . Crystal controlled operation to 25 MHz is guaranteed with the use of a parallel, fundamental mode crystal and two small load capacitors. User controlled halt circuitry stops the internal oscillator and reduces the 82C84B and system power supply currents to standby levels.

Power consumption is a fraction of that of the equivalent bipolar circuits. This speed-power characteristic of CMOS permits the designer to custom tailor his system design with respect to power and/or speed requirements.

## Pinout



| CONTROL <br> PIN | LOGICAL 1 | LOGICAL 0 |
| :---: | :---: | :---: |
| F/C | External <br> Clock | Crystal <br> Drive |
| RES | Normal | Reset |
| RDY1 | Bus Ready | Bus not <br> ready |
| RDY2 | AEN1 | Address <br> Disabled |
| AEN2 | Address <br> Enabled |  |
| ASYNC | 2 Stage Ready <br> Synchronization | 1 Stage Ready <br> Synchronization |
| CSYNC* | Oscillator <br> Stop | Oscillator <br> Run |

Note: F/C in low state

## Block Diagram



## Features

- FULL EIGHT bit bidirectional bus interface
- Industay standard 8286 COMPATIBLE PINOUT
- THREE STATE NON-INVERTING OUTPUTS
- propagation delay

35 NSEC

- A.C. CHARACTERISTICS GUARANTEED AT RATED $C_{L}$ - A SIDE - $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$
- B SIDE - $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$
- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT
$10 \mu \mathrm{~A}$ MAX Standby
- 20 PIN PLASTIC OR CERAMIC PACKAGE
- COMMERDIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES AVAILABLE


## Description

The Harris 82C86 is an octal bus transceiver manufactured using a self-aligned silicon gate CMOS process (Scaled SAJIIV). This circuit provides a full eight bit bidirectional bus interface in a 20 pin package. The Transmit ( T ) control determines the data direction. The active low output enable ( 0 E ) allows simple interface to the 80C86 and other microprocessors. The outputs of the 82C86 are noninverting.

Pinout TOP VIEW


PIN NAMES

| $A_{0}-A_{7}$ | LOCAL BUS DATA I/O PINS |
| :--- | :--- |
| $B_{0}-B_{7}$ | SYSTEM BUS DATA I/O PINS |
| $T$ | TRANSMIT CONTROL INPUT |
| $O E$ | ACTIVE LOW OUTPUT ENABLE |

## Functional Diagram



TRUTH TABLE

| $T$ | $\overline{O E}$ | $A$ | $B$ |
| :---: | :---: | :---: | :---: |
| $X$ | $H$ | $H i-Z$ | $H i-Z$ |
| $H$ | $L$ | $I$ | 0 |
| $L$ | $L$ | 0 | 1 |

$H=$ logical one
$L=$ logical zero
$1=$ input mode
$0=$ output mode
$X=$ don't care
$\hat{\mathrm{Hi}} \mathrm{Z}=$ high impedance

CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handing procedures should be followed.

## Features

- FULL EIGHT BIT BIDIRECTIONAL BUS INTERFACE
- Industay standard 8287 COMPATIBLE PINOUT
- three state inverting outputs
- PROPAGATION DELAY

35 NSEC

- A.C. Characteristics guaranteed at rated Cl $_{\text {L }}$
- A SIDE - $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$
- B SIDE - $\mathrm{C}_{L}=300 \mathrm{pF}$
- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT $10 \mu \mathrm{~A}$ MAX Standby
- 20 PIN PLASTIC OR CERAMIC Package
- Commercial, industrial and military temperature ranges available


## Description

The Harris 82 C 87 is an octal bus transceiver manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV). This circuit provides a full eight bit bidirectional bus interface in a 20 pin package. The Transmit ( T ) control determines the data direction. The active low output enable ( $\overline{O E}$ ) allows simple interface to state of the art microprocessors. Data at the outputs of the 82 C 87 are inverted.

## Pinout

 TOP VIEW

Functional Diagram


| T | $\overline{\mathrm{OE}}$ | A | B |
| :--- | :---: | :---: | :---: |
| X | H | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ |
| H | L | I | 0 |
| L | L | 0 | I |
| $\mathrm{H}=$ logical one |  |  |  |
| $\mathrm{L}=$ logical zero |  |  |  |
| $\mathrm{I}=$ input mode |  |  |  |
| $0=$ output mode |  |  |  |
| $X=$ don't care |  |  |  |
| $\mathrm{Hi}-\mathrm{Z}=$ high impedance |  |  |  |

[^12]
## Features

- Industar standard 8289 COMPATIBLE PINOUT
- COMPATIBLE WITH 5 AND 8 MHz 80C86
- PROVIDES MULTIMASTER SYSTEM BUS CONTROL AND ARBITRATION
- COMPATIBLE WITH IEEE bUS STANDARD (MULTIBUS ${ }^{\text {TM }}$ )
- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT
- $10 \mu \mathrm{~A}$ MAX standby
- $1 \mathrm{~mA} / \mathrm{MHz}$ Operating
- 20 pin plastic or ceramic package
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES AVAILABLE


## Description

The Harris 82 C89 bus arbiter is manufactured using a self-aligned silicon gate CMOS process (Scaled SAJIIV). This circuit along with the 82 C 88 bus controller, provides full bus arbitration and control for multi-processor systems. The 82C89 is typically used in medium to large 80C86 or 80C88 systems where access to the bus by several processors must be coordinated.
The 82C89 also provides high output current and capacitive drive to eliminate the need for additional bus buffering.

Pinout


## Functional Diagram


Product Index4-2
Product Information ..... 4-3

# CMOS Microprocessor and Peripherals Product Index 

Page
CMOS 12-BIT MICROPROCESSOR DATA SHEETS
HD-6120 12 Bit High Performance Microprocessor ..... 4-3
HD-6121 I/O Controller ..... 4-22
HM-6100 12 Bit Static Microprocessor ..... 4-30
HD-6101 Parallel Interface Element ..... 4-51
CMOS BUS DRIVERS DATA SHEETS
HD-6431 Hex Latching Bus Driver ..... 4-59
HD-6432 Hex Bi-directional Bus Driver ..... 4-62
HD-6433 Quad Bus Separator/Driver ..... 4-65
HD-6434 Octal Resettable Latch ..... 4-68
HD-6436 Octal Bus Buffer/Driver ..... 4-71
HD-6440 Latch Decoder/Driver ..... 4-74
HD-6495 Hex Bus Driver ..... 4-78
82 C 82 CMOS Octal Latching Bus Driver ..... 4-81
82C83 Octal Latching Inverting Bus Driver ..... 4-82
82C86 Octal Bus Transceiver ..... 4-83
82C87 Octal Bus Transceiver ..... 4-84

## CMOS HIGH SPEED 12 BIT MICROPROCESSOR

## Features

- LOW POWER, 50 MW OPERATING, 2 MW STATIC
- SINGLE SUPPLY - 5V
- OPERATION FROM DC TO 5.1 MHZ
- INDUSTRIAL AND MILITARY TEMPERATURE RANGES
- ON-CHIP CRYSTAL OSCILLATOR CIRCUITRY
- ON-CHIP EXTENDED MEMORY ADDRESSING-32K MAIN MEMORY, 32K CONTROL PANEL
- OPTIMIZED MICRO-CODE MINIMIZES THE NUMBER OF CLOCK CYCLES REQUIRED FOR ALL INSTRUCTIONS
- TWO ON-CHIP STACK POINTERS
- SIMPLIFIED MEMORY AND I/O CONTROL SIGNALS FOR EASY HARDWARE INTERFACING
- VECTORED INTERRUPT CAPABILITY
- SOFTWARE IS PAGE RELOCATABLE


## Description

The HD-6120 is a general purpose high speed, CMOS 12 bit microprocessor. It is designed to recognize the instruction set of Digital Equipment Corporation's PDP-8/E* minicomputer.
Many architectural, functional and processing enhancements have been designed into the 6120 such that it can provide much higher system performance than its predecessor, the 6100 .
The 6120 is targeted toward the experienced PDP-8* or 6100 user. Twelve bit accuracy, rapid interrupt response, battery backup and low power (sealed enclosure) capability all equate to a processor ideally suited to real time control applications such as data acquisition, industrial control and harsh environment military systems.

* trademark of digital equipment corp.


## Pinout



Functional Diagrams


| Supply Voltage |  |
| :--- | :--- |
| Operating Voltage Range | +8.0 VOLTS |
| Input/Output Voltage Applied | +4 V to +7 V |
| Storage Temperature Range | $\mathrm{VSS}-0.3 \mathrm{~V}$ to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| Operating Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Industrial ( $-9,-9+$ ) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Military ( $-2,-8$ ) | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Maximum Power Dissipation | 1 Watt |

CAUTION: Stresses above those listed in the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. ELECTRICAL CHARACTERISTICS; VCC $=5.0 \mathrm{~V} \pm 5 \%$; $\mathrm{T}_{\mathrm{A}}=$ Industrial or Military

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | LOGICAL ONE INPUT VOLTAGE | 70\% VCC |  | V |  |
| VIL | LOGICAL ZERO INPUT VOLTAGE |  | 30\% VCC | V |  |
| VIH(CLK) | LOGICAL ONE CLOCK VOLTAGE | VCC-0.5 |  | V | 50\% duty cycle $\mathrm{tr}, \mathrm{tt}_{\mathrm{t}} \leqslant 20 \mathrm{~ns}$ |
| VIL(CLK) | LOGICAL ZERO CLOCK VOLTAGE |  | VSS +0.5 | V | 50\% duty cycle <br> $\mathrm{tr}, \mathrm{tf} \leqslant 20 \mathrm{~ns}$ |
| VTH+ | SCHMITT TRIGGER POSITIVE THRESHOLD | 50\% VCC | VCC-0.5 | V | $\overline{\text { RESET, }} \overline{\text { DMAREQ, }} \overline{\text { CPREQ }}$ |
| VTH - | SCHMITT TRIGGER <br> NEGATIVE <br> THRESHOLD | 0.5 | 30\% VCC | V | $\overline{\text { RESET, }} \overline{\text { DMAREQ }}, \overline{\text { CPREQ }}$ |
| VOH | LOGICAL ONE OUTPUT VOLTAGE | VCC-0.5 |  | V | $\mathrm{IOH}=-1.6 \mathrm{~mA}$ |
| VOL | LOGICAL ZERO OUTPUT VOLTAGE |  | 0.5 | V | $\mathrm{IOL}=1.6 \mathrm{~mA}$ |
| IIL | INPUT LEAKAGE CURRENT | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{OV} \leqslant \mathrm{VIN} \leqslant \mathrm{VCC}$ |
| 10 | OUTPUT LEAKAGE CURRENT | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leqslant \mathrm{VO} \leqslant \mathrm{VCC}$ |
| ICC | POWER SUPPLY STANDBY CURRENT |  | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VIN}=\mathrm{VCC} \text { or } \mathrm{GND} \\ & \mathrm{VCC}=5.25 \mathrm{~V} \\ & \text { RESET STATE } \\ & \text { OUTPUTS OPEN } \end{aligned}$ |
| ICC* | POWER SUPPLY OPERATING |  | 10 | ma | $\begin{aligned} & \mathrm{VIN}=\mathrm{VCC} \text { or } \mathrm{GND} \\ & \mathrm{VCC}=5.25 \mathrm{~V} \\ & \mathrm{~F}=5.1 \mathrm{Mhz} \\ & \text { OUTPUTS OPEN } \end{aligned}$ |
| IOSH | HOLD CURRENT DURING DMAGNT | -0.2 | $\begin{gathered} -0.6 \\ -10.0 \end{gathered}$ | ma $\mu \mathrm{a}$ | $\begin{aligned} & \text { Vout }=\text { VCC }-1.0 \mathrm{~V} \\ & \text { Vout }=\text { OV } \\ & \text { LXMAR, } \overline{\text { LXPAR, }} \overline{\text { READ, }} \\ & \hline \text { WRITEE, OUT AND } \overline{\text { MEMSEL }} \end{aligned}$ |
| IOSS | HOLD CURRENT DURING IOT SAMPLE TIMES | -1.6 | -10.0 | ma | Vout $=\mathrm{OV}$ C0, C1, AND SKIP OUTPUTS |
| IOSS | HOLD CURRENT DURING IOT SAMPLE TIMES | -50 | -250 | $\mu \mathrm{a}$ | $\begin{aligned} & \text { Vout = OV } \\ & \text { INTREQ OUTPUT } \end{aligned}$ |
| CIN* | INPUT CAPACITANCE |  | 5 | pf | $\begin{aligned} & \mathrm{FREQ}=1 \mathrm{MHZ} \\ & \mathrm{TA}=25^{\circ} \mathrm{C} \\ & \mathrm{VIN}=\mathrm{VCC} \text { or GND } \end{aligned}$ |
| COUT* | OUTPUT <br> CAPACITANCE |  | 15 | pf | $\begin{aligned} & \mathrm{FREQ}=1 \mathrm{MHZ} \\ & \mathrm{TA}=25^{\circ} \mathrm{C} \\ & \mathrm{VIN}=\mathrm{VCC} \text { or GND } \end{aligned}$ |

* Guaranteed and sampled, but not $100 \%$ tested
A.C. ELECTRICAL CHARACTERISTICS; VCC $=5.0 \mathrm{~V} \pm 5 \%$; $\mathrm{T}_{\mathrm{A}}=$ Industrial or Military; $C_{L}=50 \mathrm{pf}, \operatorname{FREQ}=5.1 \mathrm{MHZ}$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| F | OPERATING FREQUENCY | 0 | 5.1 | Mhz |  |
| T | MINOR CYCLE PERIOD | 392 |  | ns | $T=2 / F$ |
| TL | LXMAR, LXPAR, LXDAR PULSE WIDTH | 125 |  | ns | $\mathrm{F}=5.1 \mathrm{Mhz}$ |
| TAS | ADDRESS SET UP TIME | 60 |  | ns |  |
| TAH | ADDRESS HOLD TIME | 180 |  | ns |  |
| TREAD | READ ACCESS TIME | 720 |  | ns |  |
| TRS | READ SET UP TIME | 135 |  | ns |  |
| TRH | READ HOLD TIME | 20 |  | ns | MEMORY OPERATIONS |
| TRP | READ PULSE WIDTH | 425 |  | ns |  |
| TRD | READ PULSE DELAY | 40 |  | ns |  |
| TWPD | WRITE PULSE DELAY | 200 |  | ns |  |
| TWS | WRITE SET UP TIME (ALL NON IOT) | 375 |  | ns |  |
| TWP | WRITE PULSE WIDTH (ALL NON IOT) | 425 |  | ns |  |
| TWH | WRITE HOLD TIME (ALL NON IOT) | 200 |  | ns |  |
| TWSIO | WRITE SET UP TIME (IOT) | 200 |  | ns |  |
| TWIO | WRITE PULSE WIDTH (IOT) | 375 |  | ns |  |
| TWHIO | WRITE HOLD TIME (IOT) | 125 |  | ns |  |
| TDA | READ ACK DELAY FOR NO WAIT |  | 150 | ns | $\dagger$ |
| TXA | WRITE ACK DELAY FOR NO WAIT |  | 150 | ns | $\mathrm{F}=5.1 \mathrm{Mhz}$ |

NOTE: All measurements are taken with input rise and fall times $\leqslant 20$ nsec.

## DECOUPLING CAPACITORS

The transient current required to charge and discharge the 50 pF load capacitance specified in the 6120 data sheet is determined by

$$
\mathrm{i}=\mathrm{CL}(\mathrm{dv} / \mathrm{dt})
$$

Assuming that all DX outputs change state at the same time and that $\mathrm{dv} / \mathrm{dt}$ is constant;

$$
\mathrm{i} \cong \mathrm{CL} \frac{(\mathrm{VCC} \times 80 \%)}{\mathrm{t}_{\mathrm{R}} / \mathrm{t}_{\mathrm{F}}}
$$

where $\mathrm{t}_{\mathrm{R}}=20 \mathrm{~ns}, \mathrm{VCC}=5.0$ volts, $\mathrm{C} L=50 \mathrm{pF}$ on each of twelve outputs.

$$
\begin{aligned}
\mathrm{i} & \cong\left(12 \times 50 \times 10^{-12}\right) \times(5.0 \mathrm{v} \times 0.8) /\left(20 \times 10^{-9}\right) \\
& \cong 120 \mathrm{~mA}
\end{aligned}
$$

This current spike may cause a large negative voltage spike on VCC, which could cause improper operation of the device. To filter out this noise, it is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between VCC and GND at each device, with placement being as near to the device as possible.
It is recommended that for systems with greater than 50 pF loading on the DX outputs that Harris HD-6432 CMOS Hex Bi-directional bus drivers be used to buffer the 6120 from the rest of the system. The HD-6432 bus driver has guaranteed performance specifications up to a 300 pF load.


MEMORY READ OPERATION


NOTE 1: This cycle is deleted on PAC1, PAC2, PPC1, PPC2 and control panel
Interrupt writes.

MEMORY WRITE OPERATION



MINOR CYCLES $\mid=T \rightarrow$

co, c1, EMA2 $\triangle 8 \mathbb{}$ DF $\quad 18 \times 8$
$\overline{\text { DATAF }} \overline{X P}$ 888

OR SWITCH REGISTER (OSR)


WRITE TO SWITCH REGISTER

| I/O | Pin | Symbol | Active Level | Description |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | OUT | Low | Bus timing control output which is low during all bus write or addressing operations. This signal is used to enable outbound bus drivers. |
| 0 | 2 | DMAGNT | High | Direct memory access grant output-DX, C0, C1, and EMA2 lines are high impedance. |
| 1 | 3 | DMAREQ | Low | Schmitt trigger input. Direct memory access request-DMA is granted at the end of the current bus operation. Upon DMA grant, the 6120 suspends program execution until the DMAREQ line is pulled high. |
| 1 | 4 | $\overline{\text { SKIP }}$ | Low | Input which causes the 6120 to skip the next instruction if low during an I/O instruction. |
| 1 | 5 | RUN/HLT |  | Pulsing the RUN//्मLT input causes the 6120 to alternately run and halt by changing the state of the internal RUNHLT flip flop on the positive transition of the RUN/HLt line. |
| 0 | 6 | RUN | Low | This output indicates the operating state of the 6120. It is low at all times except during the reset and halt states. |
| 1 | 7 | RESET | Low | Schmitt trigger input. Clears the AC and the memory extension registers and loads 7777 (octal) into the PC. RUNHLT is set. The STRTUP line controis whether execution starts in control panel or main memory. $\overline{R E S E T}$ must be held low at least 42 clock cycles after the clock starts running in order to initiallize the timing generator. LXDAR is held low while RESET is low, and remains low until after the positive transition of RESET and IOCLR. |
| 1 | 8 | ACK | High | This input indicates that peripheral or external memory is ready to transfer data. The 6120 read or write state gets extended as long as ACK is low. During this time the 6120 is in the lowest power state with clocks running. |
| 1 | 9 | OSCIN |  | Input to crystal oscillator amplifier. (Also external clock input.) |
| 0 | 10 | OSCOUT |  | Output of crystal oscillator amplifier. |
| 0 | 11 | IFETCH | Low | Instruction fetch cycle output. |
| 1/O | $\begin{aligned} & 12-19 \\ & 21-24 \end{aligned}$ | $\begin{aligned} & \text { DXO- } \\ & \text { DX11 } \end{aligned}$ | High | Multiplexed bidirectional data in, data out and address lines. ( $\mathrm{DXO}=\mathrm{MSB}, \mathrm{DX11}=\mathrm{LSB}$.) |
|  | 20 | vss |  | Most negative supply voltage. |
| 1/0 | 25 | Colco |  | Multiplexed extended memory address (EMA) actlve high output MSB and peripheral device control line active low input from the peripheral device during an I/O transfer. |
| 1/0 | 26 | $\mathrm{C}_{1 / \overline{C 1}}$ |  | Multiplexed EMA bit 1 and peripheral control line. See CO. |
| 0 | 27 | EMA2 | High | Low order extended memory address output. |
| 1 | 28 | STRTUP |  | This input is tied to either VCC or VSS. If tied to VSS, the 6120 makes a panel request (caused <br>  of panel memory. If STRTUP is tied to VCC, PWRON does not cause a panel request. Instead, the CPU starts running in location 7777 of field O of main memory. Location 0000 of main memory is not altered. |
| 1 | 29 | $\overline{\text { CPREQ }}$ | Low | Schmitt trigger input. External control panel request-a dedicated interrupt which bypasses the normal device interrupt request structure. CPREQ causes a control panel interrupt request by setting the bootstrap flag with the negative going transition of CPREQ. Therefore, this input is transition rather than level sensitive. |
| 1 | 30 | $\overline{\text { INTREQ }}$ | Low | Peripheral device interrupt request input. |
| 0 | 31 | INTGNT | Low | Peripheral device interrupt grant output. |
| 0 | 32 | $\overline{\text { DATAF }}$ | Low | Output which is low whenever the Data Field is placed on the C0, C1 and EMA2 lines. |
| 0 | 33 | $\overline{\text { LXPAR }}$ | Low | Output which causes control panel memory address register to be loaded. Same as LXMAR, but for control panel memory operations. |
| 0 | 34 | $\overline{\text { LXMAR }}$ | Low | Output which causes main memory address register to be loaded. Address is strobed into the main memory at the falling edge of LXMAR. |
| 0 | 35 | $\overline{\text { LXDAR }}$ | Low | Output which causes device address register to be loaded. Same as $\overline{\text { LXMAR }} \overline{\text { or } \overline{L X P A R}, ~ e x c e p t ~}$ for IOT operations. Also used to distinguish between IOCLR signals. See IOCLR below. |
| 0 | 36 | $\overline{\text { OCLR }}$ | Low | Output which is low when $\overline{\text { RESET }}$ is low, or when CAF instruction is given. Used to clear I/O flags. If caused by RESET, LXDAR is low during and after the tralling edge of IOCLR. |
| 0 | 37 | MEMSEL | Low | Memory select. During memory operations, this output pulses to VSS at bus read and write times. |
| 0 | 38 | $\overline{\text { WRITE }}$ | Low | Write pulse. This output is low during all bus data write operations; memory, $\mathrm{I} / \mathrm{O}$, and write to switch register. |
| 0 | 39 40 | READ vcc | Low | Read pulse. This output is low during all bus read operations; memory, l/O and switch register. It also serves the function of enabling inbound bus drivers. <br> Positive supply voltage. |

## ACCUMULATOR (AC)

The $A C$ is a 12 -bit register with which arithmetic and logical operations are performed. Data words may be fetched from memory to the AC or stored from the AC into memory. Arithmetic and logical operations involve two operands, one held in the AC and the other fetched from memory. The result of the operation is left in the AC. The AC may be cleared, complemented, tested, incremented or rotated under program control. The AC also serves as an input-output register. All programmed data transfers pass through the AC.
Link (L)
$L$ is a 1-bit flip flop that serves as a high-order extension of the AC. It is used as a carry flip flop for 2's complement arithmetic. A carry out of the ALU complements L. L can be cleared, set, complemented and tested under program control and rotated as a part of the AC.

## MQ REGISTER (MQ)

The MQ is a 12 -bit temporary register which is program accessible. The contents of AC may be transferred to the MQ for temporary storage. MQ can be OR'ed with the AC and the result stored in the AC. The contents of the AC and the MQ may also be exchanged.

## OUTPUT LATCH (OL)

While accessing memory or I/O, all data or addresses generated by the 6120 on the DX bus are held in the OL for the time required on the bus. This frees the 6120 internal bus for other uses during these operations. The output latch can also be read to the 6120 internal bus so that it can function as a temporary holding register for internal operations.

## PROGRAM COUNTER (PC)

The 12-bit PC contains the address of the memory location from which the next instruction is fetched. During an instruction fetch, the PC is transferred to OL and the PC is then incremented by 1 . When there is a branch to another address in memory, the branch address is set into the PC. Branching normally takes place under program control. A skip (SKP, SMA, SZA, SNL, etc.) instruction increments the PC by 1 (again), thus causing the next instruction to be skipped. The skip instruction may be unconditional or conditional on the state of the AC and/or LINK. During an input-output operation, a device can also cause the next instruction to be skipped.

## TEMPORARY REGISTER (TEMP)

The 12 -bit TEMP register latches the result of an ALU operation before it is sent to the destination register to avoid race conditions. The TEMP is also used as an internal register during instruction execution.

## INSTRUCTION REGISTER (IR)

During an instruction fetch, the 12-bit IR contains the instruction that is to be executed by the 6120 .

## STACK POINTERS (SP1 and SP2)

The stack pointers are two twelve-bit registers which hold the address of the next stack storage location. PPCX or PACX instructions cause post-decrement of the contents of stack pointer SPX. RTNX or POPX cause a pre-increment of the contents of the stack pointer. Stack pointers are loaded from, and read into, the AC. They may also be used as programcontrolled temporary registers.

## Memory Extension Control Registers

## INSTRUCTION FIELD (IF)

The 3-bit Instruction Field holds the memory field from which all instructions, all indirect address pointers and all directly addressed operands are obtained. It may be read into the AC, and loaded from the IB. It is cleared by RESET.

## INSTRUCTION BUFFER (IB)

The 3-bit Instruction Buffer serves as a holding register for instructions which change the IF. Instead of changing the IF directly, field bits are loaded into the IB, and transferred to the IF at the next JMP, JMS, RTN1 or RTN2. The IB may be loaded from instruction bits, from the AC or from the ISF. The IB is cleared by RESET.

## INSTRUCTION SAVE FIELD (ISF)

The 3-bit ISF is loaded with the contents of the IF upon granting of an interrupt. The ISF may be read into the AC. It is cleared by RESET.

## DATA FIELD (DF)

The 3-bit Data Field holds the memory field from which all indirectly addressed operands are obtained. The DF may be loaded from instruction bits, from the AC or from the DSF. It may be read into the AC. It is cleared by RESET.

## DATA SAVE FIELD (DSF)

The 3-bit DSF is loaded with the contents of the DF upon granting of an interrupt. The DSF may be read into the AC. It is cleared by RESET.

## Basic Timing and State Control

A 15-bit address is sent on the CO, C1, EMA2 and DX lines for memory reference instructions. The LXMAR or LXPAR signals cause an external register to store the address information if required. When executing an input-output instruction, LXDAR causes an external register to be loaded with device address and control information.

Memory data is read for an input transfer (READ). ACK controls the transfer duration. If ACK is low during input transfers, the 6120 waits with the READ line low. The high state of the ACK signal causes the 6120 to continue.

Output transfers are similar to input transfers. The address is defined as given above. ACK controls the length of time for which the WRITE signal is low, similar to the READ line control.

During an instruction fetch the instruction to be executed is retained internally and then executed. During the sequencing of the instruction the external request lines are sampled by the priority network. The state of this network decides whether the machine is going to fetch the next instruction in sequence or service one of the internal or external request lines.

## GENERAL DESCRIPTION

The external request lines and the internal request flags are sampled in an internal priority network. The internal priority is RESET, DMAREQ, RUN/HLT, CPREQ, INTREQ, and IFETCH. The state of the priority network determines the next operation.

## IFETCH

If no external or internal requests are pending, the 6120 fetches the next instruction pointed to by the contents of the PC. The $\overline{\text { IFETCH }}$ line is low during the cycle in which the instruction is fetched.

## RESET

$\overline{\text { RESET }}$ initializes all internal flags and clears the AC, LINK and MQ. All memory extension bits (IF, IB, DF, ISF and DSF) are cleared. The interrupt enable and interrupt inhibit flip flops are cleared. RUNHLT is set to the run state. The RUN line is held high by RESET. The states of SP1 and SP2 are undefined at power up, and are unaffected by RESET.
Upon application of power, the internal timing generator is completely initialized within 42 clock pulses after power is within limits with RESET held low.
The 6120 remains in the reset state as long as the $\overline{\text { RESET }}$ line
is low. $\overline{\text { LXMAR }}, \overline{\text { LXPAR }}, \overline{\text { READ }}, \overline{\text { WRITE }}, \overline{M E M S E L}, \overline{\text { INTGNT }}$ and IFETCH are held high. IOCLR is held low. After RESET is changed from low to high, $\overline{\mathrm{OCLR}}$ is made high. $\overline{\text { LXDAR }}$ is held low for one minor cycle after OCLR is high. DMAGNT and OUT are low. The first LXMAR or LXPAR occurs 5-1/2 minor cycles after IOCLR goes high. The PC is set to 7777 (octal) and execution commences in control panel or main memory, depending on whether the STRTUP input is low or high respectively. If execution commences in control panel memory, the FZ flag is set, the Panel Data flag is cleared, and 7777 is deposited in location 0000 of control panel memory before beginning instruction execution at location 7777. If execution commences in main memory, location 0000 of main memory is not modified.

## RUN/HLT

The RUN/HLT line changes the state of the RUNHLT flip flop. This flip flop is initially placed in the run state by RESET. Pulsing RUN/HLT low causes the 6120 to alternately run and halt. This is true whether executing in main memory or control memory. The RUN/HLT line is normally high. The 6120 recognizes the positive transition of the RUN//HLT signal. The HLT instruction ( 7402 octal) does not cause the RUNHLT flip flop to be cleared, but causes entry into panel mode with the HLTFLG set.

## Memory Organization

The 6120 has a basic addressing capacity of 4096 12-bit words. The addressing capacity is extended by the internal extended memory control hardware. The memory system is organized in 4096 word groups, called memory fields. The first 4096 words of memory are in field 0 . If a full 32 K block of memory is installed, the uppermost memory field will be numbered 7 . Two 32 K word blocks of memory may be connected to the 6120. One of these blocks is known as main memory and the other is known as panel memory.
In any given memory field, every location has a unique 4 digit octal (12 bit binary) address, 0000 to 7777 (0000 to 4095 decimal). Each memory field is subdivided into 32 pages of 128 words each. Memory pages are numbered sequentially from page 00 , containing octal addresses 0000-0177, to page 37 (octal), containing octal addresses 7600-7777. The most
significant 5 bits of a 12-bit memory address denote the page number and the 7 low order bits specify the address of the memory location within the given page.
During an instruction fetch cycle, the 6120 fetches the instruction pointed to by the IF, PC, and address strobes LXMAR or LXPAR. The contents of the PC are transferred to the OL. The PC is incremented by 1. The PC now contains the address of the 'next' sequential instruction. The OL now contains the address of the 'current' instruction which must be fetched from memory. Bits 0-4 of the OL identify the current page, that is, the page from which instructions are currently being fetched. Bits 5-11 of the OL identify the location within the current page. (Page zero, by definition, denotes the first 128 words of memory within a field, octal addresses 00000177.)

## Memory Reference Instructions (MRI)

The memory reference instructions operate on the contents of a memory location or use the contents of a memory location to operate on the AC or the PC. Bits 0-2 of a memory reference instruction specify the operation code, or opcode, and the 9 low-order bits specify the operand address. Bits $5-11$, the page address, identify the location of the operand on a given page, but they do not identify the page itself. The page is specified by bit 4 , called the page bit. If bit 4 is a 0 , the page address is interpreted as a location on page 0 . If bit 4 is a 1 , the page address is interpreted to be on the current page. The entire 12-bit address, consisting of the 7 low-order bits from the instruction and either 0 or the contents of the OL in the 5 high-order bits is known as the instruction address, or IA. The IF provides the 3 high-order bits of the complete 15 -bit address, IA.
Other locations are addressed by utilizing bit 3 . When bit 3 is a 0 , the operand is directly addressed, and IA is the location of the operand. When bit 3 is a 1 , the operand is indirectly addressed, and the contents of IA specify the location of the operand. To address a location that is not on page 0 or the current page, the absolute address of the desired location is stored in one of the 256 directly-addressable locations as a pointer address. The instruction addresses the operand
indirectly through this pointer. Upon execution, the MRI operates on the contents of the location identified by the address contained in the pointer location. The pointer is obtained from the current Instruction Field; the data is in the current Data Field.
It should be noted that locations 0010-0017 (octal) in page 0 of any field are autoindexed. If these locations are addressed as indirect pointers, the contents are incremented by 1 and restored before they are used as the operand address. These locations may, therefore, be used for indexing applications. During the memory write operation, the DF appears on CO, C2, and EMA2. Indirect reference to auto index registers from page 0 work as defined whether the page bit is " 1 " or " 0 ".
Data is represented in two's complement integer notation. In this system of notation, the negative of a number is formed by complementing each bit in the data word and adding " 1 " to the complemented number. The sign is indicated by the mostsignificant bit. In the 12-bit word used in the 6120, when bit 0 is a " 0 ", it denotes a positive number and when bit 0 is a " 1 ", it denotes a negative number. The number range for this system is +3777 to -4000 octal ( +2047 to -2048 decimal).

## Microprogramming

Group 1, 2 and 3 instructions are all microprogrammable. This means that as many as five discrete instructions can be combined into one instruction which can execute in the same amount of time required for a single discrete instruction. Instructions listed under Groups 1, 2 and 3 represent the most commonly used microcoded instructions for these groups and are not a complete listing of all possible instructions. The general rule of thumb is that if an instruction can be rep-
resented in machine code (using the "Microinstruction Format" templet), then it is a legal instruction. The logical sequence table which accompanies each "Microinstruction Format" templet shows the order in which the microcoded operations are performed. "Introduction to Programming" by Digital Equipment Corporation further explains the PDP-8* instruction set and the use of microprogramming. This handbook is also available from Harris Semiconductor.

* Trademark of Digital Equipment Corporation


## HD-6120 Oscillator Requirements

The HD-6120 has been designed to work with either a parallel resonant, fundamental mode crystal or an external frequency source.

## EXTERNAL CRYSTAL

When using an external crystal, two capacitors and a resistor are required to complete the oscillator circuit. Table 1 lists the required crystal characteristics and Figure 1 shows the correct circuit connections.

TABLE 1

| Parameter | Typical Characteristic |
| :--- | :--- |
| Frequency | $2.4-5.1 \mathrm{Mhz}$ |
| Type of Operation | Parallel resonant, AT cut, |
|  | Fundamental mode |
|  | $\mathrm{CL}=20 \mathrm{pf}$ or 32pf |
| Load Capacitance | $200 \Omega$ at 5.1 Mhz |
| Rseries (Max.) |  |

The load capacitors C1, C2 are chosen such that the total (including stray) capacitance seen by the crystal matches the specified load capacitance $\left(\mathrm{CL}_{\mathrm{L}}\right)$. For $\mathrm{C}_{L}=20 \mathrm{pf}$. a value of $\mathrm{C}_{1}=$
$\mathrm{C} 2=20 \mathrm{pf}$. is normally used. For $\mathrm{CL}=32 \mathrm{pf}$. C 1 and C 2 would be approximately 47 pf . The actual values are normally not critical unless an ultra precise frequency is desired.


FIGURE 1

## EXTERNAL FREQUENCY SOURCE

When using an external frequency source, the duty cycle should be $50 / 50$ with rise and fall times less than 20 ns. Input voltage levels should be $\mathrm{V}_{1 H} \geqslant \mathrm{VCC}-0.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IL}} \leqslant 0.5 \mathrm{~V}$. The OSCIN pin of the HD-6120 is used in this case with the OSCOUT pin left open. The Harris 82C84A CMOS Clock Generator is an excellent external frequency source which provides three outputs at different divide ratios $(\div 1, \div 3, \div 6)$.

## Memory Reference Instructions

## MICROINSTRUCTION FORMAT



| Mne- <br> monic | Opcode |  | Minor Cycles <br> Dir <br> Ind |  |  | Auto |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |$\quad$ Operation

* Add two Minor Cycles if a skip is taken.

Group 1 Operate Instructions
All group 1 instructions require 6 minor cycles, except those performing an RTR, RTL, or BSW instruction (8 minor cycles).

MICROINSTRUCTION FORMAT

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 0 | CLA | CLL | CMA | CML | R1 | R2 | R3 | IAC |
| Logical Sequence:$\begin{aligned} & 1-\mathrm{CLA}, \mathrm{CLL} \\ & 2-\mathrm{CMA}, \mathrm{CML} \\ & 3-I A C \end{aligned}$$4 \text { - RAR, RAL, RTR, RTL, BSW, R3L }$ |  |  |  |  |  |  | Bit | R1 | R2 | R3 | No Rotate BSW RAL |
|  |  |  |  |  |  |  |  | 0 | 0 | 0 |  |
|  |  |  |  |  |  |  |  | 0 | 0 | 1 |  |
|  |  |  |  |  |  |  |  | 0 | 1 | 0 |  |
|  |  |  |  |  |  |  |  | 0 | 1 | 1 | RTL |
|  |  |  |  |  |  |  |  | 1 | 0 | 0 | RAR |
|  |  |  |  |  |  |  |  | 1 | 0 | 1 | RTR |
|  |  |  |  |  |  |  |  | 1 | 1 | 0 | R3L |
|  |  |  |  |  |  |  |  | 1 | 1 | 1 | Do Not Use |


| Mne- <br> monic | Opcode | Logical <br> Sequence |  |
| :--- | :--- | :--- | :--- |
| NOP | 7000 | 1 | Operation |
| IAC | 7001 | 3 | No operation. |
| Increment accumulator-the contents of the AC is incremented by 1. Carry out complements the LINK. |  |  |  |
| RSW | 7002 | 4 | Byte swap-AC0-5 are exchanged with AC6-11 respectively. The LINK is not changed. |
| RTL | 7004 | 4 | Rotate accumulator left-the contents of the AC and LINK are rotated one binary position to the left. AC0 <br> is shifted to LINK and LINK is shifted to AC11. <br> RTL |
| RAR | 7006 | 4 | Rotate two left - equivalent to two RAL's. |
| RTR | 7010 | 4 | Rotate accumulator right-the contents of the AC and LINK are rotated one binary position to the right. <br> AC11 is shifted into the LINK, and LINK is shifted to AC0. |
| R3L | 7014 | 4 | Rotate two right - equivalent to two RAR's. |
| CML | 7020 | 2 | Rotate AC (but not LINK) left 3 places. AC0 is rotated into AC9, AC1 into AC10, etc. |
| CMA | 7040 | 2 | Complement LINK - the contents of the LINK is complemented. |
| CIA | 7041 | 2,3 | Complement accumulator - the contents of the AC is replaced by its 1's complement. |
| CLL | 7100 | 1 | Complement and increment accumulator - the contents of the AC is replaced by its 2 's complement. |
| CLL RAL | 7104 | 1,4 | Clear LINK - the LINK is made 0. |
| CLL RTL | 7106 | 1,4 | Clear LINK, rotate left. |
| CLL RAR | 7110 | 1,4 | Clear LINK, rotate two left. |
| CLL RTR | 7112 | 1,4 | Clear LINK, rotate right. |
| STL | 7120 | 1,2 | Clear LINK, rotate two right. |
| CLA | 7200 | 1 | Set the LINK - load binary 1 into LINK. |
| CLA IAC | 7201 | 1,3 | Clear accumulator - load AC with 0000. |
| GLK | 7204 | 1,4 | Clear and increment accumulator - load AC with 0001. |
| STA | 7240 | 1,2 | Get LINK - place LINK in AC11; clear AC0-10 and LINK. |
| CLA CLL | 7300 | 1 | Set accumulator - make AC=7777. |

## Group 2 Operate Instructions

All group 2 instructions require 7 minor cycles, except OSR and LAS (8 minor cycles).

MICROINSTRUCTION FORMAT

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | SMA | SZA | SNL | 0 | OSR | HLT | 0 |
| 1 | 1 | 1 | 1 | CLA | SPA | SNA | SZL | 1 |  |  |  |

```
Logical Sequence:
    1-(BIT 8=0) -SMA or SZA or SNL
    -(BIT 8=1) - SPA and SNA and SZL
    2-CLA
    3-OSR, HLT
```

| Mnemonic | Opcode | Logical Sequence | Operation |
| :---: | :---: | :---: | :---: |
| NOP | 7400 | 1 | No operation |
| HLT | 7402 | 3 | Set the HLTFLG. Causes entry into panel mode instead of executing the next instruction provided IIFF is not set. If IIFF is set, panel mode is entered after the JMP, JMS, RTN1 or RTN2 which clears IIFF. This instruction in panel mode does not cause a re-entry into panel mode, but does set HLTFLG. |
| OSR | 7404 | 3 | OR with switch register - the contents of an external device are "OR"ed with the contents of the AC, and the result stored in the AC. The contents of the DF are available for device selection. |
| SKP | 7410 | 1 | Skip - the content of the PC is incremented by 1 , to skip the next instruction. |
| SNL | 7420 | 1 | Skip on non-zero LINK - skip if LINK one |
| SZL | 7430 | 1 | Skip if LINK zero |
| SZA | 7440 | 1 | Skip on zero accumulator - skip if $\mathrm{AC}=0000$ |
| SNA | 7450 | 1 | Skip on non-zero accumulator |
| SZA SNL | 7460 | 1 | Skip if $\mathrm{AC}=0000$ or if LINK $=1$ |
| SNA SZL | 7470 | 1 | Skip if AC not 0000 and if LINK is zero |
| SMA | 7500 | 1 | Skip on minus accumulator ( $\mathrm{ACO}=1$ ) |
| SPA | 7510 | 1 | Skip on positive accumulator ( $\mathrm{ACO}=0$ ) |
| SMA SNL | 7520 | 1 | Skip if AC is minus or if LINK is 1 |
| SPA SZL | 7530 | 1 | Skip if AC is plus and if LINK is 0 |
| SMA SZA | 7540 | 1 | Skip if $A C$ is minus or zero |
| SPA SNA | 7550 | 1 | Skip if AC is positive and non-zero |
| $\begin{aligned} & \text { SMA SZA } \\ & \text { SNL } \end{aligned}$ | 7560 | 1 | Skip if AC is minus or if AC is $=0000$ or if LINK is 1 |
| $\begin{aligned} & \text { SPA SNA } \\ & \text { SZL } \end{aligned}$ | 7570 | 1 | Skip if AC is positive, nonzero and if LINK is zero |
| CLA | 7600 | 2 | Clear accumulator |
| LAS | 7604 | 2, 3 | Load accumulator from switch register |
| SZA CLA | 7640 | 1,2 | Skip if $A C=0000$, then clear $A C$ |
| SNA CLA | 7650 | 1,2 | Skip on non-zero accumulator, then clear AC |
| SMA CLA | 7700 | 1,2 | Skip on minus AC, then clear AC |
| SPA CLA | 7710 | 1,2 | Skip on positive AC, then clear AC |

## Group 3 Operate Instructions

If bits 6,8,9 or 10 are set to a one, instruction execution is not altered but the instruction becomes uninterruptable by eitherpanel or normal interrupts. That is, the next instruction is guaranteed to be fetched barring a reset, DMAREQ or RUN/HLT flip flop in the HLT state.

Group 3 Operate Instructions
All group 3 instructions require 6 minor cycles.
MICROINSTRUCTION FORMAT

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 1 | CLA | MQA | * | MQL | * | * | * | 1 |

Logical Sequence:
1-CLA
2-MQA, MQL
3-ALL OTHERS

*     - CAUSES INSTRUCTION TO IGNORE INTERRUPTS IF A "1"

BIT
$\begin{array}{lll}4 & 5 & 7\end{array}$
000
$\begin{array}{llll}0 & 0 & 1 & A C\end{array} M Q, O \rightarrow A C$
$\begin{array}{llll}0 & 1 & 0 & (M Q+A C) \rightarrow A C\end{array}$
$\begin{array}{lll}0 & 1 & 1\end{array} M Q \rightarrow A C$
$10 \quad 0 \quad 0 \rightarrow A C$
$\begin{array}{llll}1 & 0 & 1 & 0 \rightarrow A C: \\ 1 & 1 & 0 & M Q\end{array}$
$\begin{array}{llll}1 & 1 & 0\end{array} M Q \rightarrow A C$
$\begin{array}{llll}1 & 1 & 1 & M Q\end{array} \rightarrow A C, 0 \rightarrow M Q$

+ denotes logical OR

| Mnemonic | Opcode | Logical Sequence | Operation |
| :---: | :---: | :---: | :---: |
| NOP | 7401 | 3 | No operation |
| MQL | 7421 | 2 | $M Q$ register load-the $M Q$ is loaded with the contents of the $A C$ and the $A C$ is cleared. The original contents of the MQ is lost. |
| MQA | 7501 | 2 | $M Q$ "OR" with accumulator-the contents of the MQ is "OR"ed with the contents of the $A C$, and the result left in the AC. The MQ is not modified. |
| SWP | 7521 | 3 | Swap contents of AC and MQ-the contents of the AC and MQ are exchanged |
| CLA | 7601 | 1 | Clear accumulator |
| CAM | 7621 | 3 | Clear AC and MQ (actually a CLA MQL) |
| ACL | 7701 | 3 | Load AC with contents of MQ |
| CLA SWP | 7721 | 3 | Clear AC, then swap - the MQ is loaded into the AC; 0000 is loaded into the MQ |

## Stack Operation Instructions

The following IOT instructions are internally decoded to perform stack operations using internal stack pointers SP1 and SP2. These are internal IOT instructions; the IXDAR signal is not generated. If instructions are being fetched from main memory, the stacks are located in field 0 of main memory. If instructions are being fetched from panel memory, the stacks are located in field 0 of panel memory, except for the
case of a ReTurN from control panel memory via a RTN1 or RTN2 instruction. In this case, the main memory stack is accessed by the instruction fetched from panel memory. Two separate stacks may be maintained - one for the PC, the second for the AC. An increment of the stack pointer is defined as a pop off the stack.

| Mnemonic | Opcode | Operation |
| :---: | :---: | :---: |
| PPC1 | 6205 | PUSH PC ON STACK. The contents of the PC are incremented by one and the result is loaded into the memory location pointed to by the contents of SP1. SP1 is then decremented by 1. |
| PPC2 | 6245 | PUSH PC ON STACK. The same as PPC1 except that SP2 is used as the memory pointer. |
| PAC1 | 6215 | PUSH AC ON STACK. The contents of the AC is loaded Into the memory location pointed to by the contents of SP1. The contents of SP1 is then decremented by 1. |
| PAC2 | 6255 | PUSH AC ON STACK. The same as PAC1 except that SP2 is used as the memory pointer. |
| RTN1 | 6225 | RETURN. The contents of the stack pointer (SP1) is incremented by one. The contents of the instruction Buffer (IB) is loaded into the Instruction Field (IF) register. If a prior PEX Instruction was executed, the Control Panel Filp Flop (CTRLFF) is cleared. If the interrupt inhibit Filp Flop (IIFF) is set, then the Force Zero (FZ) flag is cleared. The contents of the memory location pointed to by SP1 is loaded into the PC. Prior PEX is cleared. |
| RTN2 | 6265 | Same as RTN1 except that SP2 is used as the stack pointer. |
| POP1 | 6235 | The contents of SP1 is incremented by 1. The contents of the memory location pointed to by SP1 is then loaded into the AC. |
| POP2 | 6275 | Same as POP1 except that SP2 is used as the stack pointer. |
| RSP1 | 6207 | The contents of SP1 is loaded into the AC. |
| RSP2 | 6227 | The contents of SP2 is loaded into the AC. |
| LSP1 | 6217 | The contents of the AC is loaded into SP1. The AC is cleared. |
| LSP2 | 6237 | The contents of the AC is loaded into SP2. The AC is cieared. |
| CAUTION: When swltching between main and control panel memory, the stack pointers must be saved and restored. |  |  |

Internal Control Instructions
Note that these instructions apply if the 6120 is executing
instructions from main memory or control panel.

\begin{tabular}{|c|c|c|c|}
\hline Mnemonic \& Opcode \& \multicolumn{2}{|c|}{Operation} <br>
\hline ION \& 6001 \& \multicolumn{2}{|l|}{Turn on Interrupt system. The Interrupt Enable Flip Flop is set. Neither INTREQ or any control panel request will be granted until after execution of the next instruction. ( 6 minor cycles.)} <br>
\hline IOF \& 6002 \& \multicolumn{2}{|l|}{Turn off interrupt. The interrupt enable flip flop is cleared immediately. If INTREQ is low while this instruction is being processed, the interrupt will not be recognized. ( 6 minor cycles.)} <br>
\hline RTF \& 6005 \& \multicolumn{2}{|l|}{Load the following from the AC:} <br>
\hline \& \& AC blt \& To <br>
\hline \& \& $$
\begin{aligned}
& \hline 0 \\
& 1 \\
& 4 \\
& 6-8 \\
& 9-11
\end{aligned}
$$ \& LINK GT IEFF IB DF <br>
\hline \& \& \multicolumn{2}{|l|}{\multirow[t]{2}{*}{The IIFF is set. The AC is cleared following the load operation. (8 minor cycles.) Skip if the GT flag is set. ( 7 minor cycles.)}} <br>
\hline SGT \& 6006 \& \& <br>
\hline CAF \& 6007 \& \multicolumn{2}{|l|}{The AC, LINK and GT flag are cleared. Interrupt enable flip flop is cleared. $\overline{O C L R}$ is generated with $\overline{\text { LXDAR }}$ high, causing peripheral devices to clear their flags. ( 7 minor cycles.)} <br>
\hline WSR \& 6246 \& \multicolumn{2}{|l|}{Write to switch register. The contents of the AC are written to an external device using a special I/O transfer. The AC is then cleared. The contents of the DF are available for device selection. DATAF is asserted. ( 7 minor cycles.)} <br>
\hline GCF \& 6256 \& \multicolumn{2}{|l|}{Get current fields. The following bits are loaded into the AC:} <br>
\hline \& \& AC blt \& Function <br>
\hline \& \& 0
1
2

3
4
5
$6-8$

$9-11$ \& | LINK |
| :--- |
| GT flag |
| 1 if INTREQ is low |
| 0 if INTREQ is high |
| PWRON flag |
| IEFF |
| 0 |
| IF 0-2 |
| DF 0-2 | <br>

\hline \& \& (9 minor cycles.) \& <br>
\hline
\end{tabular}

## Main Memory Control Instructions

Note that these instructions apply only if the 6120
is executing instructions from main memory.


## Panel Memory Control Instructions

The 6120's control panel is implemented in software. The software implementation of the control panel need not use any part of the main memory or change the processor state. This is an important feature, since the final version of the system may not have a control panel and the system designer would like to use the entire capacity of the main memory for the specific
system application.
Panel mode is entered because of the occurrence of any of four events. Each of these events sets a status flag, as well as causing the entry into panel mode. It should be noted that more than one event might happen simultaneously.

| Flag | Set by | Cleared by |
| :--- | :--- | :--- |
| PWRON | $\overline{\text { RESET low and }}$ | PRS and PEX |
| PNLTRP | STRTUP low <br> HLTFLG | HLT instruction mory) <br> (or any OPR2 instruction <br> with bit 10 a 1) |
| BTSTRP | High-to-low <br> transition of CPREQ | PGO |
|  |  | PRS if <br> BTSTRP <br> was set <br> when <br> status read |

Panel mode entry is functionally similar to the granting of an interrupt with some important differences. Entry into panel mode for any reason is inhibited by the interrupt inhibit flip flop. Note that this means that a PRQ or HLT instruction executed when the interrupt inhibit flip flop is set will not be recognized until after the interrupt inhibit flip flop is cleared on the next JMP, JMS, RTN1 or RTN2. Entry into panel mode is also inhibited immediately following the ION instruction but will be recognized after the instruction following the ION is executed.
When a panel request is granted, the PC is stored in location 0000 of the control panel memory and the 6120 resumes operation at location 7777 (octal) of the panel memory. During PC write, 0 appears on C0, C1 and EMA2. The states of the IB, IF, DF, ISF and DSF registers are not disturbed by entry into the control panel mode but execution is forced to commence in field zero. The panel memory would be organized with RAM in the lower pages and ROM or PROM in the higher pages of field zero. The control panel service routine would be stored in the nonvolatile ROMs, starting at 7777 (octal).

A ConTRoL panel Flip Flop, CTRLFF, which is internal to the 6120, is set when the CPREQ is granted. The CTRLFF prevents further CPREQs from being granted, bypasses the interrupt enable system and redefines several of the internal control instructions.

As long as the CTRLFF is set, $\overline{\text { LXPAR }}$ is used for all instruction, direct data and indirect pointer references. Also, while CTRLFF is set, the INTGNT line is held high but the interrupt grant flip flop is not cleared. IOTs executed while CTRLFF is set do not clear the interrupt grant flip flop.

Indirectly addressed data references by control panel AND, TAD, ISZ or DCA instructions reference panel memory or main memory as controlled by a Panel Data Flag (PDF) internal to the 6120. If set, this flag causes indirect references from control panel memory to address control panel memory using LXPAR. If cleared, this flag causes indirect references from control panel memory to address main memory using LXMAR.

The PDF is cleared unconditionally whenever the panel mode is entered for any reason. It is also cleared by an instruction called CPD (Clear Panel Data). The PDF is set by an instruction called SPD (Set Panel Data). The state of the Panel Data flag is ignored when not operating in panel mode.
Extended memory operations are implemented for panel mode instructions by a 1 -bit flag in the EMA logic (the Force Zero-FZ-flag). This flag is always set when panel mode is entered and before the first panel mode memory operation (the store of the PC at control panel memory location 0000). As long as the FZ flag is set, zero appears on C0, C1 and EMA2 in place of the IF except for special C0, C1, EMA2 contents defined during write intervals, which remain undisturbed by FZ being set. The IF remains unchanged, however, and may be read by the RIF instruction. The data field is unaffected by the FZ flag and functions as defined above, using the panel data flag to determine whether operands are in main or control panel memory. In particular if $F Z=0$ :

Control panel instruction fetch is to control panel field 0 .
Control panel indirect address fetch is to control panel field 0.
Control panel current page or page zero direct data operations are to control panel field 0.
Control panel indirect data operations are specified by DF. Main or control panel memory access is specified by the panel data flag.
The FZ flag is cleared in panel mode simultaneously with the (IF) $\longleftarrow$ (IB) transfer following the first panel mode instruction which may change the IF. These instructions are CIF (62X2), CDF CIF (62X3), RTF (6005), and RMF (6244). The (IF) - (IB) transfer (and hence the FZ clear) takes place during the first JMP, JMS, RTN1, or RTN2 following the instruction. Once the FZ flag is cleared, the EMA logic operates in control panel memory as it does in main memory with the exception that the panel data flag controls whether indirect data operations are to control panel or main memory. In particular:

Control panel instruction fetch is specified by IF.
Control panel indirect address fetch is specified by IF.
Control panel current page or page zero data operations are specified by IF.
Control panel indirect data operations are specified by DF. Main or control panel memory access is specified by the panel data flag.
Once the FZ flag is cleared in panel mode, it is not set until panel mode is entered again. The state of the FZ flag when not in panel mode is a "don't care".
Exiting from the control panel routine is normally achieved by executing the following sequence:

## PEX

JMP I 0000 /location 0000 in control panel memory
The second instruction in this sequence may be any JMP, JMS, RTN1 or RTN2 instruction. The use of JMS is not recommended, since the programmer has no means of preserving the FZ and panel data flags.
The PEX instruction will cause the next JMP, JMS, RTN1 or RTN2 instruction to reset the CTRLFF. Location 0000 in the control panel memory contains either the original return address deposited by the 6120 when the control panel routine was entered or it may be a new starting address defined by the control panel routine. The IF and DF registers may also contain their original field designations or may have been altered by the control panel routine. If an exit is made from the control panel routine with the HLTFLG set, one instruction is executed in main memory before control panel mode is reentered due to the HLTFLG being set. Note that this allows a software-controlled single step operation of programs in main memory. Caution: Single step operation will not occur for any uninterruptable instructions or any instructions which set the IIFF. Exiting from a control panel routine can also be achieved by activating the $\overline{\text { RESET }}$ line, since reset has a higher priority than control panel request. If the RUN/HLT line is pulsed while the 6120 is in the panel mode, the 6120 will halt at the completion of the current instruction.

## Panel Mode Control Instructions

Note that these instructions apply only if the 6120 is executing instructions from Control Panel Memory

| Mne- <br> monic | Opcode | Description |
| :--- | :---: | :--- | :--- |
| PRS | 6000 | Read panel status bits into AC0-4, 0 into remainder of AC. <br> The bits are read as follows: |

## Memory Extension Instructions

Most memory extension instructions require 6 minor cycles, except for RIB which requires 9 minor cycles.

The internal memory extension control extends the basic 4 K addressing structure of the 6120 to 32 K . It does so by appending three high-order bits to the memory address. These bits, which appear on C0, C1 and EMA2 lines, apply to addresses within main memory or control panel memory. The changing of memory fields is accomplished via internal control instructions.

The Instruction Field (IF) serves as an extension to the PC, providing three high-order bits during instruction fetches. Note
that there is no carry from the most-significant PC bit into the IF. The IF is also used for directly-addressed operands, and for indirect address pointers.

The Data Field (DF) serves to extend the address of indirectly addressed operands, externalIOTs, OSR and WSR functions.
The Instruction Save Field and Data Save Field are used to retain the contents of the IF and the DF which existed prior to an interrupt.

| Mne- <br> monic | Opcode | Operation |
| :--- | :--- | :--- |
| CDF | $62 \times 1$ | Change Data Field to $X$. X is loaded into DF. <br> CIF <br> Change Instruction Field to X. X is loaded into IB, and the IIFF is set. (The setstate IIFF causes the priority network to <br> ignore interrupt requests). The contents of IB are loaded into the IF at the end of the next JMP, JMS, RTN1 or RTN2 <br> instruction. At the same time the interrupt inhibit flip flop is cleared. <br> A microprogrammed combination of CDF and CIF. Both fields are set to X. <br> Load the contents of the Data Field register into bits 6-8 of the AC. DF0-2 goes to AC6-8 respectively. AC0-5 and 9-11 <br> are unchanged. <br> Load the contents of the Instruction Field register into bits 6-8 of the AC. IF0-2 goes to AC6-8 respectively. AC0-5 and <br> G-11 are unchanged. <br> RDF |
| RIF | $62 \times 2 \times 3$ the contents of the ISF and DSF into bits 6-11 of the AC. ISFO-2 goes to AC6-8 and DSFO-2 goes to AC9-11 |  |
| respectively. AC0-5 are unchanged. |  |  |
| RIB | 6214 |  |
| RMF | 6244 | Load the contents of ISF into IB, DSF into DF, and set the interrupt inhibit flip flop. This instruction is used to restore the <br> contents of the memory field registers to their values before an interrupt occurred. |

## Input/Output Instructions

Input/output transfer instructions, which have an opcode of 6, are used to initiate the operation of peripheral devices and to transfer data between peripherals and the 6120. Three types of data transfer may be used to receive or transmit information between the 6120 and one or more peripheral I/O devices. Programmed data transfer provides a straight-forward means of communicating with relatively slow I/O devices, such as
teletypes, cassettes, card readers and CRT displays. Interrupt transfers use the interrupt system to service several peripheral devices simultaneously, on an intermittent basis, permitting computational operations to be performed concurrently with I/O operations. Both programmed data transfers and program interrupt transfers use the accumulator as a buffer, or storage area, for all data transfers.

## IOT INSTRUCTION FORMAT

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 0 |  |  |  | 11 |  |  |  |  |

Bits $0-2$ are always set to 6 (110) to specify an IOT instruction. The next six bits, 3-8, contain the device selection code that determines the specific I/O device for which the IOT instruction is intended. Device selection codes 00 and 2 X specify internal operations, and may not be used by external devices. Up to $551 / O$ devices can be specified. The last three bits, $9-11$, contain the operation specification code that determines the specific operation to be performed. The nature of this operation for any given IOT instruction depends entirely upon the circuitry designed into the I/O device interface (see the 6121 specification).
Programmed data transfer begins when the 6120 fetches an instruction from the memory and recognizes that the current instruction is an external IOT. The 6120 sequences the IOT instruction through an execute phase. Bits 0-11 of the IOT
instruction are placed on DXO-11; the data field is placed on CO, C1 and EMA2; and DATAF is asserted. LXDAR then falls, signalling the beginning of the IOT execute phase. These bits must be latched in an external register, since they are then removed to free the DX bus for I/O data exchanges. Following the fall of LXDAR, the 6120 generates a write signal. During the WRITE, the 6120 reads the SKIP, C0 and C1 lines. SKIP, CO , and C1 define the type of I/O operation. If C1 is pulled low during the write signal, then the 6120 adds one minor cycle and performs a read operation after the write.
The control line SKIP, when low during the write portion of an IOT, causes the 6120 to skip the next instruction. This feature is used to sense the status of various signals in the device interface. The C0 and C1 lines are treated independently of the SKIP line.

| Control Lines <br> C0 |  | C1 | Operation |
| :--- | :--- | :--- | :--- |
| High | High | (Device $) \leftarrow(A C)$ | Description |
| Low | High | $($ Device $) \leftarrow(A C), C L A$ | The contents of the $A C$ is sent to the device. |
| High | Low | $(A C) \leftarrow(A C) V($ Device $)$ | Data is received from a device, "OR"ed with the data in the $A C$, and the result is stored in the $A C$. |
| Low | Low | $(A C) \leftarrow($ Device $)$ | Data is received from a device and loaded into the $A C$. |

## Interrupt Transfer

The program interrupt system may be used to initiate programmed data transfers in such a way that the time spent waiting for device status is greatly reduced. It also provides a means of performing programmed data transfers between the 6120 and peripheral devices while executing another program. This is accomplished by isolating the I/O handling routines from the mainline program and using the interrupt system to ensure that these routines are entered only when an I/O device is set, indicating that the device is actually ready to perform the next data transfer.
The interrupt system allows external conditions to interrupt the computer program (which must be in main memory) by driving INTREQ low. If no internal higher priority requests are outstanding and the interrupt system is enabled, the 6120 grants the device interrupt at the end of the current instruction. After an interrupt has been granted, the interrupt enable flip flop in the 6120 is reset so that no more interrupts are acknowledged until the interrupt system is re-enabled under program control.
The interrupt inhibit flip flop prevents interrupts (both device
and control panel) from occurring when there is a possibility that the IF is not equal to the IB. More specifically, the interrupt inhibit flip flop is set whenever the IB is loaded (i.e., by the instructions CIF, CDF CIF, RMF or RTF), and cleared whenever the IF is loaded from the IB (i.e., at the proper phase of JMP, JMS, RTN1 or RTN2 instructions). Device interrupts are recognized only if the interrupt system is enabled, the interrupt inhibit flip flop is cleared and INTREQ is low.
Upon recognition of an interrupt, the 6120 stores the PC in location 0000 of field 0 and clears the interrupt enable flip flop. Zero appears on C0, C1 and EMA2 when the PC is stored. At the same time, INTGNT goes low. During the interrupt grant sequence, IF is loaded into ISF and DF is loaded into DSF. IF, IB and DF are then cleared. The next instruction is fetched from location 0001 of main memory field 0 . INTGNT remains low until the trailing edge of the first LXDAR generated by a main memory IOT following the recognition of the interrupt. The granting of an interrupt requires 4 minor cycles. If a control panel interrupt is granted while $\overline{\text { INTGNT }}$ is low, INTGNT will be forced high as long as CTRLFF is set but will return to the low state when CTRLFF is cleared.

## Direct Memory Access

Direct memory access, sometimes called data break, is the preferred form of data transfer to use with high-speed storage devices such as magnetic disk or tape units. The DMA mechanism transfers data directly between memory and peripheral devices. The 6120 is involved only in setting up the transfer; the transfers take place with no 6120 intervention on a "cycle stealing" basis. The DMA transfer rate is limited only by the bandwidth of the memory and the data transfer characteristics of the device.
The external device generates a DMA request when it is ready to transfer data. The 6120 grants the DMAREQ by pulling the DMAGNT signal high at any point in any of the instructions, or between instructions, when the 6120 is not using the DX bus in performing a bus read, write or read-modify-write operation. The 6120 suspends its internal timing until the DMAREQ line is high. The DX lines, EMA2, C0 and C1 lines are tristated. $\overline{\text { LXPAR, }} \overline{\text { LXMAR, }}, \overline{M E M S E L, ~ O U T, ~} \overline{R E A D}$ and WRITE are all held high by a device on each of these lines which only has a
very small pull-up drive. These lines can then be pulled down by an external device. In this way, these control lines are stable until the external device can gain control of them. IFETCH and $\overline{\text { LXDAR }}$ are both held high. RUN is held low. The states of DATAF and INTGNT are undisturbed.
The external DMA device must not drive the bus until DMAGNT is high. The DMA device must:
a. Drive all signals with three-state devices.
b. Provide all address, data, LXPAR, LXMAR, and other control signals with the proper timing.
c. Return all control lines to the high state before relinquishing the bus.
d. Three-state all drivers at or before $\overline{\text { DMAREQ is pulled }}$ high by the device.
After the $\overline{\text { DMAREQ }}$ line is pulled high, the 6120 negates DMAGNT and re-establishes proper timing before proceeding.

Internal Flags

| Name | Set Conditions | Clear Conditions | Load Conditions | Comments |
| :---: | :---: | :---: | :---: | :---: |
| IEFF | ION inst. | 1. $\overline{\mathrm{RESET}}=\mathrm{low}$ <br> 2. IOF inst. <br> 3. During INTGNT sequence <br> 4. SKON inst. | RTF inst. | INTERRUPT ENABLE FLIP FLOP: Tested by the SKON instruction. GCF inst. loads state of IEFF into AC4. INTREQ is honored only if IEFF is set (1). |
| IIFF | 1. CIF inst. <br> 2. CIF CDF <br> 3. RMF <br> 4. RTF | 1. $\overline{\text { RESET }}=$ low <br> 2. JMP, JMS, RTN inst. | none | INTERRUPT INHIBIT FLIP FLOP: Suppresses any INTREQ or Control Panel mode request. |
| CTRLFF | Upon entry into panel mode | 1. $\overline{\mathrm{RESET}}=$ low <br> 2. Next JMP, JMS or RTN after PEX inst. | none | CONTROL PANEL FLIP FLOP: Indicates control panel operation. Interrupts are not honored when set. |
| FZ | Upon entry into panel mode | First JMP, JMS or RTN inst. executed with IIFF set. | none | FORCE ZERO FLAG: Forces control panel instruction field access to field zero. Indirect data accesses are not affected. |
| PDF | SPD inst. | 1. Panel mode entry <br> 2. CPD inst. | none | PANEL DATA FLAG: When set causes indirect data operations executed in control panel to access CP memory. Otherwise they are to main memory. PDF is ignored when executing in main memory. |
| RUNHLT | $\overline{\text { RESET }}=$ low | none | On the low to high transition of the RUN/HLT line | RUN HALT FLIP FLOP: When cleared the 6120 will halt after the first instruction in which this state is detected. The 6120 will respond to DMAREQ in this state. |
| HLTFLG | HLT inst. | 1. $\overline{\mathrm{RESET}}=$ low <br> 2. PG0 inst. | none | HALT FLAG: When set, panel mode will be entered unless the IIFF is set or RESET is low. IIFF can be cleared on the next JMP, JMS or RTN instruction at which point panel mode will be entered. |
| PNLTRP | PR0, PR1, PR2, PR3 inst. (main only) | 1. $\overline{\mathrm{RESET}}=$ low <br> 2. PRS inst. <br> 3. PEX inst. | none | PANEL TRAP FLAG: Same result as defined for HLTFLG. |
| BTSTRP | High to low transition of CPREQ | 1. $\overline{\text { RESET }}=$ low <br> 2. PRS inst. | none | BOOTSTRAP FLAG: Same result as defined for HLTFLG. |
| PWRON | RESET and STRTUP=10w | 1. $\overline{\text { RESET }}$ and STRTUP=high <br> 2. PRS inst. <br> 3. PEX inst. | none | POWER-ON FLAG: Causes entry into panel mode when RESET is released and this flag is set. |
| GT | none | $\overline{\mathrm{RESET}}=$ low | RTF inst. | GREATER THAN FLAG: General purpose flag which has no arithmetic significance. |

## CMOS I/O CONTROLLER

## Features

- LOW POWER, TYP. < 2 mW
- SINGLE SUPPLY - 5V
- INDUSTRIAL AND MILITARY TEMPERATURE RANGES
- 6120 COMPATIBLE INTERFACE
- CONTROLS ANY COMBINATION OF FIVE INPUT OR OUTPUT PORTS WITH HANDSHAKING
- ELIMINATES GATED READ AND WRITE SIGNALS THROUGH THE CONTROLLER
- CONFORMS TO DEC* CONVENTIONS REGARDING DEVICE ADDRESSING AND COMMANDS
- INDEPENDENT PROGRAMMING OF EACH DEVICE'S ADDRESS AND DATA DIRECTION
- COMPLETE INTERRUPT AND SKIP LOGIC FOR EACH DEVICE INCLUDING PRIORITY INTERRUPT VECTORING
- STROBE OUTPUTS ARE PROGRAMMABLE HIGH OR LOW TRUE
- SENSE INPUTS ARE PROGRAMMABLE FOR LEVEL OR EDGE SENSITIVITY
- ENABLE OUTPUTS FUNCTION AS USER PROGRAMMABLE CHIP SELECTS


## Description

The HD-6121 Input/Output Controller (IOC) is a high performance, CMOS support circuit for the 6120 microprocessor. Fully programmable, this device offers independent control of any combination of five, 12 bit input or output ports.

Used in conjunction with the 6120 microprocessor, the 6121 provides user programmable chip select decoding, priority vectored interrupt control, software readable status and I/O port handshaking signals.
 to be used without any additional hardware. Industrial control and other I/O intensive systems can profit greatly from the highly hardware/software efficient capability provided by the 6120/6121 chip set.

* trademark of Digital Equipment Corp.


## Functional Diagram



[^13]| Supply Voltage | +8.0 VOLTS | Operating Temperature Range |  |
| :--- | ---: | ---: | ---: |
| Operating Voltage Range | +4 V to +7 V | Industrial $(-9,-9+)$ | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Input/Output Voltage Applied | VSS -0.3 V to VCC +0.3 V | Military $(-2,-8)$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Maximum Power Dissipation | 1 Watt |
|  |  |  |  |
| CAUTION: Stresses above those listed in the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation |  |  |  |
| of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. |  |  |  |

D.C. ELECTRICAL CHARACTERISTICS; VCC $=5.0 \mathrm{~V} \pm 5 \%$; $\mathrm{T}_{\mathrm{A}}=$ Industrial or Military

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | LOGICAL ONE INPUT VOLTAGE | 70\% VCC |  | V |  |
| VIL | LOGICAL ZERO input voltage |  | 30\% VCC | V |  |
| VOH | LOGICAL ONE OUTPUT VOLTAGE | VCC-0.5 |  | V | $1 \mathrm{OH}=-1.6 \mathrm{~mA}$ Except for SKIP, $\overline{\text { INTREQ, }} \overline{\mathrm{C} 0}$ and $\overline{\mathrm{C} 1}$ which are open drain. |
| VOL | LOGICAL ZERO OUTPUT VOLTAGE |  | 0.5 | V | $\mathrm{IOL}=1.6 \mathrm{~mA}$ Except for SKIP INTREQ, C0 and C1. |
| VOL | LOGICAL ZERO OUTPUT VOLTAGE |  | 0.5 | V | $\mathrm{IOL}=15 \mathrm{~mA}$ <br> $\overline{\text { SKIP }}, \overline{\operatorname{INTREQ}}, \overline{\mathrm{CO}}, \overline{\mathrm{C} 1}$ OUTPUTS |
| IIL | INPUT LEAKAGE CURRENT | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{OV} \leqslant \mathrm{VIN} \leqslant \mathrm{VCC}$ |
| 10 | I/O, OUTPUT LEAKAGE CURRENT | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{OV} \leqslant \mathrm{VO} \leqslant \mathrm{VCC} \\ & \text { NOTE } 1 \end{aligned}$ |
| ICC | POWER SUPPLY CURRENT |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN }=\text { VCC or GND } \\ & \text { VCC }=5.25 \mathrm{~V} \\ & \text { OUTPUTS OPEN } \end{aligned}$ |
| CIN* | INPUT CAPACITANCE |  | 5 | $\mathrm{p} F$ | $\begin{aligned} & \text { FREQ }=1 \mathrm{MHZ} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \text { VIN }=\text { VCC or GND } \end{aligned}$ |
| COUT* | OUTPUT <br> CAPACITANCE |  | 15 | pF | $\begin{aligned} & \text { FREQ }=1 \mathrm{MHZ} \\ & \text { TA }=25^{\circ} \mathrm{C} \\ & \text { VIN }=\text { VCC or GND } \end{aligned}$ |

* Guaranteed and sampled, but not $100 \%$ tested

NOTE 1: APPLIES ONLY TO DXO THROUGH DX11, $\overline{C 0}, \overline{C 1}, \overline{\text { SKIP, AND }} \overline{\text { INTREQ }}$ WITH THE OUTPUT DRIVERS DISABLED OR OPEN DRAIN OUTPUTS OFF.
A.C. ELECTRICAL CHARACTERISTICS; VCC $=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{T}_{\mathrm{A}}=$ Industrial or Military;

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAS | ADDRESS SET UP TIME | 30 |  | ns |  |
| TAH | ADDRESS HOLD TIME | 70 |  | ns |  |
| TRWE | WRITE ENABLE DELAY |  | 100 | ns |  |
| TRWD | WRITE DISABLE DELAY |  | 100 | ns |  |
| TWS | WRITE SET UP TIME | 50 |  | ns |  |
| TWH | WRITE HOLD TIME | 50 |  | ns |  |
| TPDE | ENABLE OUTPUT DELAY |  | 125 | ns |  |
| TPDD | ENABLE OUTPUT DISABLE DELAY |  | 200 | ns |  |
| TRE | READ VECTOR ENABLE |  | 100 | ns |  |
| TRD | READ VECTOR DISABLE |  | 100 | ns |  |
| TWPD | WRITE PULSE DELAY | 100 |  | ns |  |
| TLXH | RESET DELAY, IOCLR TO LXDAR | 100 |  | ns |  |

NOTE: ALL MEASUREMENTS ARE TAKEN WITH INPUT RISE AND FALL TIMES $\leq 20$ NSEC

## Specifications HD-6121

## DECOUPLING CAPACITORS

The transient current required to charge and discharge the 50 pf load capacitance specified in the 6121 data sheet is determined by

$$
\mathrm{i}=\mathrm{C}_{\mathrm{L}}(\mathrm{dv} / \mathrm{dt})
$$

Assuming that all DX outputs change state at the same time and that dv/dt is constant;

$$
i \cong C_{L} \frac{(V C C \times 80 \%)}{t R / t F}
$$

where $t_{R}=20 \mathrm{~ns}, \mathrm{VCC}=5.0$ volts, $\mathrm{CL}_{\mathrm{L}}=50 \mathrm{pF}$ on each of twelve outputs.

$$
\begin{aligned}
\mathrm{I} & \cong\left(12 \times 50 \times 10^{-12}\right) \times(5.0 \mathrm{v} \times 0.8) /\left(20 \times 10^{-9}\right) \\
& \cong 120 \mathrm{~mA}
\end{aligned}
$$

This current spike may cause a large negative voltage spike on VCC, which could cause improper operation of the device. To filter out this noise, it is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between VCC and GND at each device, with placement being as near to the device as possible.


* Vector Operation Only

EXTERNAL IOT and VECTORED INTERRUPT OPERATION


| I/0 | PIN | SYMBOL | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | INTGNT | Low | Interrupt grant signal from the 6120. |
| 1 | 2 | PRT | Low | Input for priority string. Low implies no higher priority up the string. Device \#1 internally is the highest priority device. |
| 0 | $\begin{aligned} & 3,6,9, \\ & 12,15 \end{aligned}$ |  | High or Low | Output strobes set true by a transfer command. Cleared by a Set Flag command or by the corresponding sense input going true. Programmable polarity. |
| 1 | $\begin{aligned} & 4,7,10, \\ & 13,16 \end{aligned}$ | $\begin{aligned} & \text { SENSE } \\ & 1-5 \end{aligned}$ | High or Low | Status inputs from an external device. Can cause IOT skips or interrupts. Programmable edge or level sense and polarity. |
| 0 | $\begin{aligned} & 5,8,11, \\ & 14,17 \end{aligned}$ | $\begin{aligned} & \text { ENABLE } \\ & 1-5 \end{aligned}$ | Low | Bus transfer enable pulses for external devices. True during LXDAR. |
| 0 | 18 | PRO | Low | Output for priority string. Low implies enable for next device down the string. Device \#5 internally is the lowest priority device and drives this output. |
| 0 | 19 | $\overline{\text { SKIP }}$ | Low | True during $\overline{\text { XDDAR }}$ and $\overline{\text { WRITE }}$ to indicate to the 6120 that a skip is to occur on the current IOT. N-Channel open drain. |
|  | 20 | VSs |  | Power supply ground. |
| 0 | 21, 22 | $\overline{\mathrm{CO}}, \overline{\mathrm{C} 1}$ | Low | Control signals to the 6120 which specify the type of transfer required for an I/O instruction. See Table 1. N-Channel open drain. |
| 0 | 23 | $\overline{\text { INTREQ }}$ | Low | Interrupt request to the 6120. N -Channel open drain output. |
| 1 | 24 | $\overline{R E A D}$ | Low | 6120 bus read pulse. |
| I/O | 25-36 | DX11-0 | High | 6120 data/address bus. (DXO = MSB, DX11 = LSB) |
| 1 | 37 | WRITE | Low | 6120 bus write pulse. |
| 1 | 38 | $\overline{\text { LXDAR }}$ | Low | 6120 I/O transfer enable signal. True during the execute phase of external IOT instruction. Also true during power on reset. |
| 1 | 39 40 | $\overline{\text { OCLR }}$ VCC | Low | Reset from the 6120 generated by power on reset or CAF instruction. Positive supply voltage. |

## CONCEPT:

The concept of the IOC is to provide basic control and enable signals for the devices which it controls but not be involved in the critical speed timing of the DX bus transfers to and from these devices. Each input or output port still has its own output latch or input driver interface which results in maximum flexibility with regard to I/O device characteristics. Because these latches and input drivers are not included in the 6121, this 40 pin device is able to provide complete handshaking for five I/O ports.
Software programmable chip select decoding (ENABLE outputs) provides a means whereby I/O device addressing is readily changed with no change to the users PC board. This on-chip feature replaces the 2-5 IC's normally associated with chip select decoding.
Another feature of the 6121 IOC is an on-chip priority interrupt controller. The interrupt logic includes software programmable vectors and complete interrupt request/grant handshaking for the 6120 microprocessor. This on-chip feature of the 6121
eliminates a separate interrupt controller IC. Up to eleven 6121 IOCs can be daisy chained without the need for any interfacing logic. This results in vectored interrupt control of up to 55 I/O ports. The Priority In ( $\overline{\mathrm{PRI}})$ and Priority Out ( $\overline{\mathrm{PRO}}$ ) control signals are used for this I/O expansion capability.
Another major on-chip feature of the 6121 IOC is the inclusion of I/O port handshaking signals. These signals provide the capability of polling the status of an Input port (SENSE inputs) and that of signaling an Output port that it has received data (STROBE outputs). These signals can be thought of as "Input Buffer Full" and "Output Buffer Full" status lines. The characteristics of these signals are software programmable which greatly increases their flexibility.

## 6120 IOT INSTRUCTION SEQUENCING:

The 6121 is designed to interface with the 6120 external IOT sequence. This sequence begins when the 6120 fetches an instruction from the memory and recognizes that the current instruction is an external IOT. An external IOT is any IOT (Bits $0-2=6$ ) whose device code (Bits $3-8$ ) is not 00 or 2 X .

## EXTERNAL IOT COMMAND FORMAT



## Specification HD-6121

The 6120 sequences the IOT instruction through an execute phase. Bits 0-11 of the IOT instruction are available on DXO-11 as LXDAR falls near the start of the execute phase. The 6121 IOC accepts the IOT command on the falling edge of LXDAR and latches this information into an internal command latch. WRITE or READ is active low to enable data transfers between the 6120 and the peripheral device(s). The 6121 communicates with the 6120 through 3 control lines ... $\overline{\mathrm{C} 0}, \overline{\mathrm{C} 1}$ and SKIP. The type of data transfer during an IOT instruction is specified by the peripheral device by asserting the control lines as shown in Table 1.

The control line $\overline{\text { SKIP, when low during an IOT, causes the } 6120}$ to skip the next instruction. This feature is used to sense the status of various signals in the device interface. The $\overline{\mathrm{C}}$ and $\overline{\mathrm{C} 1}$ lines are treated independently of the SKIP line. The input command signals, $\overline{C 0}, \overline{C 1}$ and SKIP, are sampled during LXDAR low - WRITE low. The data from the 6120 is available to the device(s) during LXDAR low - WRITE low. If C1 is low at LXDAR low - WRITE low, a read is also performed and data is read from the peripheral into the 6120 during LXDAR low $\overline{R E A D}$ low.

TABLE 1-PROGRAMMED I/O CONTROL LINES

| $\begin{aligned} & \text { CONT } \\ & \overline{\mathrm{CO}} \end{aligned}$ | $\overline{\mathrm{L}} \mathrm{LIN}$ | OPERATION | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| High | High | (Device) «- (AC) | The contents of the AC is sent to the device. |
| Low | High | $\begin{aligned} & \text { (Device) } \longleftarrow \text {-(AC), } \\ & \text { Clear }(A C) \end{aligned}$ | The contents of the AC is sent to the device, then the AC is cleared. |
| High | Low | $(A C) \longleftarrow-(A C) V($ Device $)$ | Data is received from a device,"OR'ed" with the data in the AC and the result stored in the AC. |
| Low | Low | $(\mathrm{AC}) \longrightarrow$ (Device) | Data is received from a device and loaded into the AC. |

## INTERNAL DEVICE CONTROLLER <br> FLIP FLOP DEFINITIONS:

There are five device controllers within the 6121 IOC. Each controller has a set of control and status flip flops which are defined below:

FLAG FLIP FLOP - Internal device control status flip flop which only has meaning if the IS programming bit is a 1 . It is set by a SET FLAG IOT or by true going edge of sense input. It is cleared by the SKIP ON FLAG instruction only if it was sampled by that instruction as being set; by the interrupt vector operation; or by $\overline{\text { IOCLR}}$. If the flag is set, interrupts can be generated if otherwise enabled. If the IS programming bit is 0 , the flag flip flop is held in the cleared state.
FLAG SAMPLE FLIP FLOP - Internal device control flip flop which samples the state of the flag flip flop at the falling edge of LXDAR. The set state of this flip flop causes the skip line to be pulled and the flag flip flop to be cleared during WRITE pulses of a skip IOT.
STROBE FLIP FLOP - Internal device control flip flop which controls strobe output line. It is set by a transfer IOT at the trailing edge of the LXDAR pulse. It is cleared by IOCLR, the true going edge of the sense input (if the IS programming bit set) or the SET FLAG IOT command. The STROBE output reflects the state of this flip flop any time the strobe flip flop is cleared or at the end of LXDAR if the strobe flip flop is set.
INTERRUPT ENABLE FLIP FLOP - Internal device control flip flop which allows program enable of interrupts. This bit is set by OCLR. This bit is loaded by DX11 during WRITE of LOAD INTERRUPT ENABLE IOT. If this flip flop and the flag flip flop are both set, then the INTREQ pin is pulled low.
INTERRUPT SAMPLE FLIP FLOP - Internal device control flip flop which samples the state of the interrupt condition at
the falling edge of $\overline{\operatorname{INTGNT}}$. The falling edge of $\overline{\text { INTGNT }}$ sets the interrupt sample flip flop if the flag flip flop and interrupt enable flip flop are set and the priority input is true. If the flag flip flop is clear or the priority input is false at the fall of INTGNT, the state of the interrupt sample flip flop is not changed. The interrupt sample flip flop is cleared by the SKIP ON FLAG IOT, by the reset state of the interrupt enable flip flop or by $\overline{\mathrm{OCLR}}$. If this flip flop is set, the device's priority output is false (high).

## PROGRAMMING:

Immediately after power on reset, the five device controllers within the IOC are set to a state such that the first IOT command received with $\overline{\text { PRII }}$ low will be interpreted as a programming command to set up various IOC parameters. This is true only for power on reset and is not true for the reset generated by the 6120 CAF instruction. Power on reset from the 6120 is distinguished by LXDAR being low at the end of the OCLR pulse. During the reset caused by the CAF instruction, LXDAR is high throughout the IOCLR pulse. Each of the five device controllers within the IOC are programmed independently by separate IOT commands. If PRI is low, the first IOT programs the highest priority device (Device \#1). The second IOT programs the second highest priority device (Device \#2). This continues until all the devices in the IOC are programmed, at which time $\overline{\text { PRO }}$ is made low so that programming can commence on the next IOC (if any) down the priority chain. The IOC will not accept any operational IOT commands to any of the five devices until all five devices have been programmed. The programming IOT writes data from the 6120 accumulator. The lower 9 bits of the IOT instruction itself perform no programming function. The IOT instruction must be an external IOT, not device \#00 or 2X. The programming format from the accumulator is shown below:

PROGRAMMING COMMAND FORMAT


OP Output polarity
1=High true strobe output
$0=$ Low true strobe output
IP Input polarity
1=High true sense polarity
$0=$ Low true sense polarity
IS Input edge sensitivity
$1=$ Set flag flip flop and interrupt (if interrupts enabled) on true-going edge of sense input. Skip on flag flip flop set.
$0=$ Skip on sense line input level true. (No interrupt on sense true.)
DEVICE ADDRESS The 6 bit device address assigned to the device controller.
EN Enable output control select.
$1=$ Enable output is true (low) whenever the device is addressed. (Except for programming and vector operations.)
$0=$ Enable is true only when a transfer command (48 or $6_{8}$ ) is given.
C C line control.
$0=$ Transfer commands do not cause $C$ lines to be controlled.
1 =Transfer commands cause $C$ lines to be controlled.
I/O Input or output port select. This programming bit has no meaning if the " C " programming bit is set to a " 0 ".
$1=$ Transfer commands cause outputs to the device. ( $\overline{\mathrm{C} 1}$ is not pulled low.)
$0=$ Transfer commands cause inputs from the device. ( $\overline{\mathrm{C}} 1$ is pulled low.)
After all five devices of the IOC are programmed, they are ready to respond to IOT commands with their programmed addresses. Because of this, no operational IOT commands can be used until all system IOC's have been programmed. An
additional constraint is that each device must have its own unique address.
Note that unused devices must be turned off during programming simply by programming them with an internal IOT address ( 00 or 2 X ), and with the IS programming bit set to " 0 " to prevent interrupts. Also, sense inputs must be tied to ground. Internal 6120 IOT's do not generate LXDAR. The IOT controller is therefore made insensitive to all external IOT commands when programmed with an internal IOT address. Whenever a device controller within the IOC responds to its programming IOT, it pulls the $\overline{\mathrm{CO}}$ line low so that the 6120 will perform an output operation from the AC followed by clearing the $A C$.

## IOC COMMANDS:

Power on reset-This is indicated by the IOCLR input low and LXDAR low at the end of the IOCLR pulse. This operation sets up the IOC to be programmed as discussed above. Also, all five flag flip flops are cleared as are the flag sample and interrupt sample flip flops. The interrupt enable flip flops are all set. The strobe flip flops are cleared, the STROBE outputs are set low and the ENABLE outputs are set high. Note that if a controller is programmed for a low true STROBE output, then there will be a low to high transition on the strobe output when this device is programmed. Also, care must be taken to assure that the state of the flag, flag sample, interrupt sample, interrupt inhibit and strobe flip flops are not disturbed by the programming function.
The 6120 Clear All Flags (CAF) Instruction - This instruction is indicated to the IOC by IOCLR going low and LXDAR staying high during the IOCLR pulse. This operation performs exactly the same operation as power on reset on the device flag, flag sample, interrupt sample, interrupt enable and strobe flip flops. It does not set up the IOC for programming, nor does it disturb the state of any of the programming information stored within the IOC.

EXTERNAL IOT COMMAND FORMAT


## Each IOT is discussed below:

SET FLAG, CLEAR STROBE - If the device is programmed for edge sensitive SENSE input, this IOT command causes the internal flag flip flop to be set and also clears the STROBE output to the programmed false state. If the device is programmed for level sensitive SENSE input, then the flag flip flop is not set by this instruction, but the STROBE output is cleared.
SKIP ON FLAG, CLEAR FLAG - The skip on flag operation depends on whether the device is programmed for edge or level sensitivity. If programmed for level sensitivity and the SENSE input is logic true, then the SKIP line is pulled low during the IOT WRITE pulse; the clear flag operation has no meaning. If programmed for edge sensitivity, then the state of the flag flip flop is sampled to the flag sample flip flop at the falling edge of LXDAR. During the IOT WRITE pulse, the SKIP line will be pulled low if the flag sample flip flop is true. If the flag sample flip flop is set, then the flag flip flop will be cleared some time before or at the trailing edge of LXDAR.

CLEAR ACCUMULATOR - This command only functions if the $C$ line control programming bit (bit $10=1$ ) has been programmed for the device to control the C lines and the device has been programmed as an input device (bit $11=0$ ). When enabled by the above two programming conditions, this command will cause $\overline{\mathrm{CO}}$ to be pulled low during the IOT WRITE pulse. This will cause the 6120 accumulator to be cleared.
DATA TRANSFER ( 48 or $6_{8}$ ) - Either transfer command will unconditionally set the STROBE output to its true state. If the "C" programming bit is set, the transfer commands will also cause the " $C$ " lines to be controlled to specify the type of I/O transfer to be performed. If not, then the IOC device does not control the " $C$ " lines. If the device " $/ / O$ " programming bit is 1 , then $\overline{\mathrm{C}} 1$ is not pulled low and an output transfer is specified by either $4_{8}$ or $6_{8}$. If the $I / O$ programming bit is 0 , then an input transfer is specified by pulling $\overline{\mathrm{C}} 1$ low during the WRITE pulse. Command $4_{8}$ does not pull $\overline{C D}$ low. For an output, this corresponds to not clearing the AC after the output. For an input, this corresponds to "OR'ing" the input data with the AC. Command $6_{8}$ always pulls $\overline{C O}$ low. For an output, this causes the $A C$ to be cleared following the output. For an input, this corresponds to the input data being loaded into the AC. The STROBE output is cleared when the flag flip flop is set by the SENSE transition or by a SET FLAG command.
LOAD INTERRUPT ENABLE-This command causes a write of 6120 AC bit 11 to the addressed device's interrupt enable flip flop. This write holds neither $\overline{\mathrm{C} 0}$ nor $\overline{\mathrm{C} 1}$ low so that a write without a clear of the AC is performed. The device is incapable of generating interrupts if the interrupt enable flip flop is cleared.

## INTERRUPT LOGIC:

A device controller within the IOC is capable of generating an interrupt by pulling the $\overline{\text { INTREQ }}$ line low if all of the following conditions are true:

1. The device is programmed for edge sensitive SENSE input, and
2. The device flag flip flop has been set, and
3. The device interrupt enable flip flop is set, and
4. The priority string input for that device is true.

Normally, with no system interrupts outstanding, all device priority inputs and outputs are low. At the highest priority IOC, the $\overline{P R I}$ input must be tied to Vss.
Whenever the interrupt conditions are met at any device on the IOC, the INTREQ line is pulled low and the following sequence of events occurs:

1. The $6120 \overline{\text { INTREQ }}$ being low causes $\overline{\text { INTGNT }}$ low. All IOC driving device controllers which have the interrupt condition met set their interrupt sample flip flops. Note that this is an edge triggered set and is not a "load". All device controllers which have their interrupt sample flip flops set will hold their respective priority outputs high. All device controllers with a high priority input hold their priority outputs high and also are inhibited from driving the INTREQ bus low.
2. When the first IOT is executed with INTGNT low, one of two events occurs, depending on the IOT command:
a. If the command issued is a SKIP ON FLAG (18) command, then the normal operation of the IOT command occurs in the addressed device. A SKIP ON FLAG (18) instruction will clear the interrupt sample flip flop of the addressed device and will clear the flag flip flop if it is set.
b. If the command is not a SKIP ON FLAG (18) command, then the fact that $\overline{N T G N T}$ is low causes special action. During the WRITE pulse $\overline{\mathrm{CO}}$ and $\overline{\mathrm{C} 1}$ are both pulled low by the highest priority device with its interrupt sample flip flop set. No other device (not even the addressed device) will respond on this IOT. This IOT specifies a JAM read cycle. The 6120 then generates a $\overline{\text { READ }}$ pulse which causes the device address of the highest priority device with its interrupt sample flip flop set to put its device address on DX6-11 and all zeros on DX0-5. Also, the flag flip flop of that device is cleared, causing it to remove the INTREQ drive. The interrupt sample flip flop is not cleared at this time so that the priority output of that device continues to be held false (high).
c. Near the end of the interrupt service routine of that particular device, the software should (with the 6120 interrupts disabled) execute a SKIP ON FLAG IOT to the device. This will clear the interrupt sample flip flop of the device, which in turn will set the priority output of that device true, enabling interrupts from devices lower in the chain.

## SOFTWARE NOTES:

1. When performing the interrupt vector operation from the 6120, the accumulator must be loaded with a "no interrupt" vector address (such as zero) before the vector IOT is issued. This vector is left in the accumulator if no internal vector is returned by a device controller.
2. Before a device's interrupts are turned off by resetting its interrupt enable flip flop with a 6XX5 command the 6120's interrupts must be turned off. Failure to do so can result in an unidentifiable interrupt from the device.
3. When turning on a device's interrupt with a $6 \times X 5$ command, an immediate interrupt will result if the device's flag is set and the 6120 interrupts are turned on.
4. Because the IOC programming sequence relies on an exact sequence of IOT instructions to be executed and IOCLR enables interrupts, the programming instructions must be executed with the 6120's interrupts off.
5. Use of the level sensitive "Skip on Flag, Clear Flag" operation ( $6 \times \times 1$ ), requires that a redundant skip instruction followed by a NOP be used to guarantee that the "Flag Sample Flip Flop" is reset.

## TESTING NOTE:

The $\overline{\text { PRO }}$ line cannot go true after any $\overline{\mathrm{OCLR}}$ true pulse (either in programming or in a CAF) until there is at least one READ pulse. In addition, no external IOT commands can be executed during an $\overline{O C L R}$ true pulse.

SUMMARY OF 6120, 6121 CONDITIONS:
The following table provides a brief summary of all the 6120 and 6121 Operations.

| $\begin{gathered} \hline \text { IOT } \\ \text { BIT } \\ 9 \end{gathered}$ | $\begin{gathered} \text { OMM } \\ \text { BIT } \\ 10 \end{gathered}$ | $\begin{gathered} \hline \text { ANDS } \\ \text { BIT } \\ 11 \end{gathered}$ | PROGR c c | G BITS 1/0 | OUT | UTS | $\begin{gathered} 6120 \\ \text { OPERATION } \end{gathered}$ | $\begin{gathered} 6121 \\ \text { OPERATION } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 1 | 1 | Hiz | Hiz | Output (AC) | NOP |
| 1 | 0 | 0 | 1 | 1 | Hiz | Hiz | Output (AC) | Generate ENABLE. (Output to device.) Set STROBE output. |
| 1 | 1 | 0 | 1 | 1 | Low | Hiz | Output (AC) <br> then $(A C) \longleftarrow 0$ | Generate ENABLE. (Output to device.) Set STROBE output. |
| 0 | 1 | 0 | 1 | 0 | Low | Hiz | Output (AC) <br> then $(A C) \longleftarrow 0$ | NOP except for low $\overline{\mathrm{CO}}$ output. Result is only to clear 6120 AC. |
| 1 | 0 | 0 | 1 | 0 | Hiz | Low | $\begin{aligned} & (A C) \longleftarrow \text { Input } \\ & V(A C) \end{aligned}$ | Generate ENABLE. (Input from device.) Set STROBE output. |
| 1 | 1 | 0 | 1 | 0 | Low | Low | $(\mathrm{AC}) \longleftarrow$ Input | Generate ENABLE. (Input from device.) Set STROBE output. |
| 1 | 0 | 1 | X | X | Hiz | Hiz | Output (AC) | Load interrupt enable flip flop from DX11. |
| 0 | 0 | 0 | X | X | Hiz | Hiz | Output (AC) | Set flag flip flop if its prog. bit is set. Clear STROBE output. |
|  | 0 | 1 | X | X | Hiz | Hiz | Output (AC) | Pull $\overline{\text { SKIP }}$ low and clear Flag F.F. if flag sample flip flop is a 1 during the write pulse. |
| X | 1 | 1 | X | X | Hiz | Hiz | Output (AC) | No operation. |
| Vector Read Programming IOT |  |  | X | X | Low | Low | $(\mathrm{AC}) \longleftarrow$ - $n$ nut | Place interrupt vector on DX bus, clear Flag F.F. |
|  |  |  | X | X | Low | Hiz | Output (AC) <br> then $(A C) \longleftarrow 0$ | Load programming information to device programming register from the DX bus during write. |

## BUFFERED BUS 6120/6121 INTERFACING EXAMPLE



NOTE: This simplified example does not show the extended Memory Addressing and other features of the 6120.

HARRIS

## Features

- LOW POWER - TYP.<5.0 $\quad$ W
- SINGLE +5V POWER SUPPLY
- FULL TEMPERATURE RANGE -550 $\mathbf{~ T O ~ + 1 2 5 0} \mathbf{C}$
- STATIC OPERATION
- SINGLE PHASE CLOCK, ON CHIP CRYSTAL OSC.
- SOFTWARE COMPATIBLE WITH PDP-8/E
- 12-BIT DATA WORD
- OVER 90 SINGLE WORD INSTRUCTIONS
- RELOCATABLE MEMORY ORGANIZATION
- BASIC ADDRESSING TO 4K 12 BIT WORDS
- PROVISION FOR DEDICATED CONTROL PANEL
- 128 GENERAL PURPOSE REGISTERS
- 8 AUTOINDEXING REGISTERS
- FLEXIBLE PROGRAMMED I/O TRANSFERS
- VECTORED INTERRUPT CAPABILITY


## Description

The HM-6100 is a single address, fixed word length, parallel transfer microprocessor using 12-bit two's complement arithmetic. It is a general purpose processor which recognizes the instruction set of Digital Equipment Corporation's PDP-8/E Minicomputer.

Standard features include indirect addressing and facilities for instruction skipping, program interrupts as a function of input/output device conditions, and auto-restart. Five 12-bit registers are used to control microprocessor operations, address memory, perform arithmetic or logical operations, and store data. The device design is optimized to minimize the number of external components required for interfacing with standard memory and peripheral devices.

## Pinout

| vce | $1{ }^{\bullet}$ | 40 | $\square$ datar |
| :---: | :---: | :---: | :---: |
| RUN | 2 | 39 | $\square$ INTGNT |
| DMAGNT | 3 | 38 | $\square$ CPSEL |
| DMAREQ | 4 | 37 | $\square$ MEMSEL |
| CPREQ | 5 | 36 | IFETCH |
| RUN/HLT | 6 | 35 | $\overline{\text { SKP }}$ |
| RESET | 7 | 34 | - $\overline{\mathrm{C}}$ |
| INTREQ | 8 | 33 | $\square \overline{\mathrm{c} 1}$ |
| XTA | 9 | 32 | $\overline{\text { co }}$ |
| LXMAR | 10 | 31 | $\square$ SWSEL |
| WAIT | 11 | 30 | ] DEVSEL |
| Хтв | 12 | 29 | $\square$ LINK |
| ХTC [ | 13 | 28 | $]$ DX11 |
| OSC OUT | 14 | 27 | $7 \mathrm{DX10}$ |
| OSC IN | 15 | 26 | GGND |
| DX0 | 16 | 25 | D D9 |
| DX1 | 17 | 24 | 7 DX8 |
| DX2 | 18 | 23 | $\square$ DX7 |
| DX3 | 19 | 22 | D DX6 |
| DX4 4 | 20 | 21 | コ DX5 |

## Functional Diagram



## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage (VCC - GND) | -0.3 V to +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | (GND -0.3 V ) to (VCC +0.3 V ) |
| Storage Temperature Range $-65^{\circ} \mathrm{C}$ to $150{ }^{\circ} \mathrm{C}$ <br> Operating Temperature Range  <br> Industrial HM-6100-9 $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Military HM-6100-2 $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ l |  |

ELECTRICAL CHARACTERISTICS $\quad V C C=5.0 \pm 10 \%$ Volts, $T_{A}=$ Industrial or Military
D.C.

| SYMBOL | PARAMETER | MIN | TYP | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical " 1 " Input Voltage | 70\% VCC |  |  | v |  |
| VIHC | Logical "1" Osc. Input Voltage | Vcc-. 5 |  |  | v |  |
| VIL | Logical "0" Input Voltage |  |  | 20\% Vcc | $v$ |  |
| VILC | Logical "0" Osc. Input Voltage |  |  | GND +. 5 | v |  |
| IIL | Input Leakage (1) | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | OVSVINSVCC |
| VOH | Logical '1" Output Volt. (2) | 2.4 |  |  | v | $1 \mathrm{OH}=-0.2 \mathrm{~mA}$ |
| VOL | Logical "0" Output Volt. (2) |  |  | 0.45 | $v$ | $1 \mathrm{OL}=2.0 \mathrm{~mA}$ |
| 10 | Output Leakage | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $\mathrm{ov} \leq \mathrm{V}$ S VCC |
| ICC1 | Supply Current (Static) |  |  | 400 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{VCC}$, Freq. $=0$ |
| ICC2 | Supply Current (Operating) |  |  | 2.5 | mA | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{Freq}=2.0 \mathrm{MHz}$ |
| Cl | Input Capacitance (3) |  | 5 | 7 | pF |  |
| co | Output Capacitance (3) |  | 8 | 10 | pF |  |
| CIO | Input/Output Capacitance (3) |  | 8 | 10 | pF |  |
| cosc | Oscillator IN/OUT CAP. (3) |  | 30 |  | pF |  |


|  |  | $\begin{gathered} \mathrm{TA}=25^{\circ} \mathrm{C} \\ \mathrm{VCC}=5.0 \mathrm{~V} \\ \text { (1) } \end{gathered}$ |  | $\begin{gathered} T A=\text { Indust. } \\ \text { VCC }= \\ 5.0 \pm 10 \% V \end{gathered}$ |  | $\begin{gathered} \text { TA }=\text { Military } \\ \text { VCC }= \\ 5.0 \pm 10 \% V \end{gathered}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | MIN | MAX | UNITS | TEST CONDITIONS |
| fmax | Max Operating Frequency |  | 4.0 |  | 3.33 |  | 2.5 | MHz | $\mathrm{CL}=50 \mathrm{pF}$ |
| TS | Major State Time | 500 |  | 600 |  | 800 |  | ns | See Timing Diagram |
| TLX | LXMAR Pulse Width | 220 |  | 230 |  | 355 |  | ns |  |
| TAS | Address Setup Time | 80 |  | 85 |  | 200 |  | ns |  |
| TAH | Address Hold Time | 150 |  | 125 |  | 175 |  | ns |  |
| TAL | Access Time from LXMAR |  | 450 |  | 520 |  | 745 | ns |  |
| TEN | Output Enable (Memory) |  | 250 |  | 300 |  | 470 | ns |  |
| TEND | Output Enable (1/O) |  | 300 |  | 470 |  | 655 | ns |  |
| TWP | Write Pulse Width | 200 |  | 235 |  | 330 |  | ns |  |
| TDS | Data Setup (Memory) | 160 |  | 135 |  | 250 |  | ns |  |
| TDSD | Data Setup (1/0) | 185 |  | 225 |  | 350 |  | ns |  |
| TDH | Data Hold Time | 125 |  | 125 |  | 170 |  | ns |  |
| TST | Status Signals Valid |  | 250 |  | 300 |  | 325 | ns |  |
| TRS | Request Inputs Setup | 0 |  | 0 |  | 0 |  | ns |  |
| TRH | Request Inputs Hold | 200 |  | 250 |  | 300 |  | ns |  |
| Tws | Wait Setup Time | 0 |  | 50 |  | 50 |  | ns |  |
| TWH | Wait Hold Time | 100 |  | 100 |  | 150 |  | ns | $\dagger$ |
| TRHS | Run Halt Setup Time | 0 |  | 50 |  | 50 |  | ns |  |
| TRHP | Run Halt Pulse Width | 100 |  | 100 |  | 150 |  | ns |  |

NOTE 1: All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information - not guaranteed.

| Supply Voltage | 8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | Gnd -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | -650 C to 1500 C |
| Operating Temperature Range |  |
| Industrial HMM-6100C-9 | -400 C to +850 C |

ELECTRICAL CHARACTERISTICS
VCC $=5.0 \pm 5 \%$ Volts, $T_{A}=$ Industrial

|  | SYMBOL | PARAMETER | MIN | TYP | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. | VIH | Logical "1" Input Voltage | 70\% VCC |  |  | V |  |
|  | VIHC | Logical "1" Osc. Input Voltage | VCC-. 5 |  |  | V |  |
|  | VIL | Logical " 0 " Input Voltage |  |  | . 8 | V |  |
|  | VILC | Logical "0' Osc. Input Voltage |  |  | GND + . 5 | V |  |
|  | IIL | Input Leakage (1) | -10 |  | +10 | $\mu \mathrm{A}$ | OVSVINSVCC |
|  | VOH | Logical "1" Output Volt. (2) | 2.4 |  |  | V | $1 \mathrm{OH}=-0.2 \mathrm{~mA}$ |
|  | VOL | Logical "0" Output Volt. (2) |  |  | 0.45 | V | $1 O L=1.6 \mathrm{~mA}$ |
|  | 10 | Output Leakage | -10 |  | +10 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leq \mathrm{VO} \leq \mathrm{VCC}$ |
|  | ICC1 | Supply Current (Static) |  |  | 600 | $\mu \mathrm{A}$ | $V I N=V C C$, Freq. $=0$ |
|  | ICC2 | Supply Current (Operating) |  |  | 5.0 | mA | $V C C=5.5 \mathrm{~V}, \mathrm{Freq}=2.0 \mathrm{MHz}$ |
|  | Cl | Input Capacitance (3) |  | 5 | 7 | pF |  |
|  | CO | Output Capacitance (3) |  | 8 | 10 | pF |  |
|  | ClO | Input/Output Capacitance (3) |  | 8 | 10 | pF |  |
|  | cosc | Oscillator IN/OUT CAP. (3) |  | 30 |  | pF |  |

Notes: (1) Except pin 14 and 15
(2) Except pin 14
(3) Guaranteed and sampled, but not $100 \%$ tested.

|  |  | $\begin{gathered} \mathrm{TA}=25^{\circ} \mathrm{C} \\ \mathrm{VCC}=5.0 \mathrm{~V}(1) \end{gathered}$ |  | $\begin{aligned} T A & =\text { Indust } . \\ V C C & =5.0 \pm 5 \% \end{aligned}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | UNIT | TEST CONDITION |
| fMAX | Max operating Freq. |  | 3.33 |  | 2.5 | MHz | $C L=50 \mathrm{pF}$ |
| TS | Major State Time | 600 |  | 800 |  | ns | See Timing Diagram |
| TLX | LXMAR Pulse Width | 270 |  | 335 |  | ns |  |
| TAS | Address Setup Time | 100 |  | 120 |  | ns |  |
| TAH | Address Hold Time | 150 |  | 175 |  | ns |  |
| TAL | Access Time from LXMAR |  | 500 |  | 650 | ns |  |
| TEN | Output Enable (Memory) |  | 300 |  | 400 | ns |  |
| TEND | Output Enable (1/O) |  | 350 |  | 575 | ns |  |
| TWP | Write Pulse Width | 250 |  | 320 |  | ns |  |
| TDS | Data Setup (Memory) | 180 |  | 240 |  | ns |  |
| TDSD | Data Setup (1/O) | 200 |  | 275 |  | ns |  |
| TDH | Data Hold Time | 130 |  | 175 |  | ns |  |
| TST | Status Signals Valid |  | 300 |  | 350 | ns |  |
| TRS | Request Inputs Setup | 0 |  | 0 |  | ns |  |
| TRH | Request Inputs Hold | 100 |  | 130 |  | ns |  |
| TWS | Wait Setup Time | 0 |  | 0 |  | ns |  |
| TWH | Wait Hold Time | 100 |  | 130 |  | ns | , |
| TRHS | Run Halt Setup Time | 0 |  | 70 |  | ns |  |
| TRHP | Run Halt Pulse Width | 100 |  | 130 |  | ns |  |

Note 1: All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information - not guaranteed.

The HM-6100 generates all the timing and state signals internally. A crystal is used to control the CPU operating frequency. The CPU divides the crystal frequency by two. With a 4 MHz crystal, the internal states will be of 500 ns duration. The major timing states are described in Figure 1.

T1 For memory reference instructions, a 12-bit address is sent on the DataX, DX, lines. The Load External Address Register, LXMAR, is used to clock an external register to store the address information externally, if required. When executing an Input-Output I/O instruction, the instruction being executed is sent on the DX lines to be stored externally. The external address register then contains the device address and control information.

Various CPU request lines are priority sampled if the next cycle is an Instruction Fetch cycle. Current state of the CPU is available externally.

T2 Memory/Peripheral data is read for an input transfer (READ). WAIT controls the transfer duration. If $\overline{\text { WAIT }}$ is active during input transfers, the CPU waits in the T2 state. The wait duration is an integral multiple of the crystal frequency -250 ns for 4 MHz .

For Memory reference instructions, the Memory Select, $\overline{M E M S E L}$, lines are active. For I/O instruction the $\overline{\text { DEVSEL, }}$, line is active. Control lines, therefore, distinguish the contents of the external register as memory or device address.

External device sense lines $\overline{\mathrm{CO}}, \overline{\mathrm{C} 1}, \overline{\mathrm{C} 2}$, and SKP are sampled if the instruction being executed is an $\mathrm{I} / \mathrm{O}$ instruction.

Control Panel Memory Select, $\overline{\text { CPSEL }}$, and Switch Register Select, $\overline{\text { SWSEL, }}$, become active low for data transfers between the HM-6100 and Control Panel Memory and the Switch Register, respectively.

T3, T4, T5
ALU operation and internal register transfers.
T6 This state is entered for an output transfer (WRITE). The address is defined during T1. WAIT controls the time for which the WRITE data must be maintained.

The following illustrates the timing of the CPU when its operating frequency is low enough that propagation delays can be ignored. It effectively shows the timing of the CPU when it is single clocked.


FIGURE 1 - Static Timing

The dynamic or high frequency timing illustrates the propagation delays at specified operating frequencies. (Refer to specifications) It defines the interface requirements for memory and I/O devices on the bus.


FIGURE 2 - Dynamic Timing

## Microprocessor Architecture

The block diagram of the CPU architecture, shown on the front page, consists of the following major functional segments:

- CPU Registers
- Arithmetic and Logic Unit
- Dx-Bus Multiplexer
- Timing and Control Unit

Each one is briefly described below.

## CPU REGISTERS

The CPU consists of five, 12-bit registers, of which three are user programmable; 1) Accumulator (AC), 2) Program Counter (PC), and 3) Multiply Quotient (MQ). The remaining two registers are the Instruction Register (IR) and the Memory Address Register (MAR) which are used exclusively for internal operations. The CPU registers are defined as follows.

## ACCUMULATOR AND LINK (AC/L)

All arithmetic and logical operations are performed in the AC. For any arithmetic operation, the AC data and memory data are combined in the ALU and the result is temporarily stored in the AC. Under software control, the AC can be cleared, set, complemented, incremented, tested or rotated. Using the Operate Microinstructions, a variety of register operate instructions can be derived.

The link is a one-bit extension of the AC. It can be complemented with a carry out of the ALU or cleared, set, complemented, tested and rotated along with the rest of the AC. It also serves as the carry output for two's complement arithmetic.

## MULTIPLY QUOTIENT (MO)

The MQ register can be used as a temporary storage for the AC. The MQ may be OR'ed with the AC and the result stored in the AC or the contents of the AC and MQ may be swapped. The MQ is used in conjunction with the AC to perform multiplication, division, and double-precision operations.

## PROGRAM COUNTER (PC)

The PC supports both memory and input-output device operations. For memory operations, the PC is controlled exclusively by internal logic and instructions fetched from memory. During an instruction fetch cycle the contents of the PC are transferred to the memory address register (MAR) while the current instruction is being decoded. The PC is then loaded with a new address or simply incremented for the next instruction depending upon the type of instruction. The next instruction obtained from memory is then loaded into the Instruction Register. For example, if the instruction is a JMP $X$, then the branch address $X$ is loaded into the PC for program controlled branching.

Branching can also be controlled by an external device during input-output operations. This feature allows I/O controlled vectored interrupts.

MEMORY ADDRESS REGISTER (MAR)
The MAR contains the address of the memory location that is currently selected for memory or I/O read-write operations. It is also used for microprogram control during data transfers to and from memory and peripherals.

## INSTRUCTION REGISTER (IR)

The instruction fetched from memory is held in the IR while being interpreted by the Instruction Decoder. The IR specifies the initial step of the microprogram sequence for each instruction and is also used to store temporary data for microprogram control.

## ARITHMETIC AND LOGIC UNIT (ALU)

The ALU performs 12-bit arithmetic, logical and rotate operations. Its input is derived from the AC and any one of the other CPU registers. The type of operations performed by the ALU include:

| ADD | Left-right shifts and rotates |
| :--- | :--- |
| Logical AND | Increment |
| Logical OR | Complement |
| Test AC | Set/Clear |

## DX-BUS MULTIPLEXER

To keep the CPU pin count to a reasonable 40 and still maintain a 12 -bit word structure, the address and data paths are multiplexed by the DX-Bus Multiplexer. It handles data, address and instruction transfers between the CPU and memory or peripheral devices on a time-multiplexed basis.

## TIMING AND CONTROL UNIT

The Timing and Control Unit generates the state and cycle timing signals from a single-phase clock and maintains the proper sequences of events required for any processing task. It also decodes the instruction obtained from the IR and combines the result with various timing signals and external control inputs to provide control and gating signals required by other functional units (both internal and external to the CPU).

## Memory Organization

The HM-6100 has a basic addressing capacity of 4096 12-bit words. The addressing capacity may be extended to 32 K words by Extended Memory Control hardware. Every location has a unique 4 digit octal ( 12 bit binary) address, 00008 to 77778 ( 000010 to 409510 ). The Memory is subdivided into 32 PAGES of 128 words each. Memory Pages are numbered sequentially from Page 008 , containing addresses $0000-01778$, to Page 378 , containing addresses 76008 77778 . The first 5 bits of a 12-bit MEMORY ADDRESS denote the PAGE NUMBER and the low order 7 bits specify the PAGE ADDRESS of the memory location within the given Page.


FIGURE 3 - Memory Organization

## Memory and Processor Instructions

The HM-6100 instructions are 12-bit words stored in memory. The HM-6100 makes no distinction between instruction and data; it can manipulate instructions as stored variables or execute data as instructions. There are three general classes of HM-6100 instructions. They are Memory Reference Instructions (MRI), Operate Instructions (OPR), and Input/Output Transfer Instructions (IOT).

During an instruction fetch cycle, the HM-6100 fetches the instruction pointed to by the PC. The contents of the PC are transferred to the MAR. The PC is incremented by 1. The PC now contains the address of the "current" instruction which must be fetched from memory. Bits $0-4$ of the MAR identify the CURRENT PAGE, that is, the Page from which instructions are currently being fetched and bits 5-11 of the MAR identify the location within the Current Page. (PAGE ZERO ( 0 ) , 00008 - 01778 , by definition, denotes the first 128 words of memory and is called the Register Page.)

Since the HM-6100 is a static design it can operate at any crystal frequency from 0 to 8 MHz . State times required for execution are given for each instruction. Execution time can be calculated from the equation:

$$
T=N *(2 *(1 / F))
$$

where $N$ is the number of state times and $F$ is the crystal or input clock frequency.

## MEMORY REFERENCE INSTRUCTIONS (MRI)

The Memory Reference Instructions operate on the contents of a memory location or use the contents of a memory location to operate on the AC or the PC. The first 3 bits of a Memory Reference Instruction specify the operation code, or OPCODE, and the low order 9 bits, the OPERAND address, as shown in Figure 4.


FIGURE 4 - Memory Reference Instruction Format
Bits 5 through 11, the PAGE ADDRESS, identify the location of the OPERAND on a given page, but they do not identify the page itself. The page is specified by bit 4 , called the CURRENT PAGE OR REGISTER PAGE BIT. If bit 4 is a 0 , the page address is interpreted as a location on the Register Page. If bit 4 is a 1 , the page address specified is interpreted to be on the Current Page.

By this Method, 256 locations may be directly addressed, 128 on the REGISTER PAGE and 128 on the CURRENT PAGE. Other locations are addressed by using bit 3. When bit 3 is a 0 , the operand address is a DIRECT ADDRESS. An INDIRECT ADDRESS (pointer address) identifies the location that contains the desired address (effective address). To address a location that is not directly addressable, not in the REGISTER PAGE or in the CURRENT PAGE, the absolute address of the desired location is stored in one of the 256 directly addressable locations (pointer address). Upon execution, the MRI will operate on the contents of the location identified by the address contained in the pointer location. Note that locations 00108-00178 in the Register Page are AUTOINDEXED. When these locations are used for index registers their contents are incremented by 1 and restored before they are used as the operand address. These locations are therefore convenient for indexing applications.

Combinations of mode and page bits yield four (4) addressing modes:

- Current Page, Direct
- Current Page, Indirect
- Register Page, Direct
- Register Page, Indirect

A fifth addressing mode results from use of the AUTOINDEX registers:

- Register Page, Autoindexed

TABLE 1

| MNEMONIC | $\begin{array}{\|c} \text { OP } \\ \text { CODE } \end{array}$ | NUMBER OF STATES |  |  | OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | DIRECT | INDIRECT | AUTOINDEXED |  |
| AND | OXXX | 10 | 15 | 16 | LOGICAL AND: Causes a bit-by-bit boolean AND between the contents of the Accumulator and the contents of the effective address ( $X X X$ ) specified by the instruction. The result is left in the AC and the data word in the referenced location is not altered. |
| TAD | $1 \times X X$ | 10 | 15 | 16 | TWO'S COMPLEMENT ADD: Performs a binary two's complement addition between the specified data word and the contents of the AC; the result is left in the AC. If a carry out occurs, the state of the Link is complemented. If the AC is initially cleared, this instruction acts as a LOAD from memory. |
| ISZ | 2 XXX | 16 | 21 | 22 | INCREMENT AND SKIP IF ZERO: The contents of the effective address are incremented by 1 and restored. If the result is zero, the next sequential instruction is skipped. |
| DCA | 3 XXX | 11 | 16 | 17 | DEPOSIT AND CLEAR THE ACCUMULATOR: The contents of the $A C$ are stored in the effective address and the $A C$ is cleared. |
| JMS | 4XXX | 11 | 16 | 17 | JUMP TO SUBROUTINE: The contents of the PC are stored in the effective address and the effective address +1 is stored in the PC. The link, AC, and MQ are unchanged. |
| JMP | 5XXX | 10 | 15 | 16 | JUMP: The effective address is loaded into the PC thus causing program execution to branch to a new location. |
| IOT | 6XXX | 17 |  |  | INPUT/OUTPUT TRANSFER: Used to initiate the operation of peripheral devices and to transfer data between the peripherals and the CPU. |
| OPI | $7 \times \times X$ | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ |  |  | OPERATE Instructions: Used to perform logical operations on the contents of the major registers. <br> 2 - Cycle OPERATE <br> 3 - Cycle OPERATE |

## Operate Instructions

The Operate Instructions, which have an OPCODE of $78(111)$, consist of 3 groups of microinstructions. Group 1 microinstructions, which are identified by the presence of a 0 in bit 3, are used to perform logical operations on the contents of the accumulator and link. Group 2 micro instructions, which are identified by the presence of a 1 in bit 3 and a 0 in bit 11, are used primarily to test the contents of the accumulator and then conditionally skip the next sequential instruction. Group 3 microinstructions have a 1 in bit 3 and a 1 in bit 11 and are used to perform logical operations on the contents of the $A C$ and $M Q$.

The basic OPR instruction format is shown in Figure 5. Operate microinstructions from any group may be microprogrammed with other operate microinstructions of the same group. The actual code for a microprogrammed combination of two, or more, microinstructions is the bitwise logical OR of the octal codes for the individual microinstructions. When more than one operation is microprogrammed into a single instruction, the operations are performed in a prescribed sequence, with logical sequence number 1 microinstructions performed first, logical sequence number 2 microinstructions performed second, logical sequence number 3 microinstructions performed third, and so on. Two operations with the same logical sequence number, within a given group of microinstructions, are performed simultaneously.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 1 | A |  |  |  |  |  |  |  | B |


| MICROINSTRUCTION | A | B |
| :---: | :---: | :---: |
| Group 1 | 0 | $0 / 1$ |
| Group 2 | 1 | 0 |
| Group 3 | 1 | 1 |

FIGURE 5 - Basic OPR Instruction Format

## GROUP 1 MICROINSTRUCTIONS

Figure 6 shows the instruction format of a group 1 microinstruction. Any one of bits 4 to 11 may be set, loaded with a binary 1 , to indicate a specific group 1 microinstruction. If more than one of these bits is set, the instruction is a microprogrammed combination of group 1 microinstructions, which will be executed according to the logical sequence shown in Figure 6.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 0 | CLA | CLL | CMA | CML | RAR | RAL | $0 / 1$ | IAC |

```
Logical Sequences:
    1-CLA CLL
    2-CMA CML
    3-IAC
    4-RAR RAL RTR RTL BSW
```

| BIT 8 | BIT 9 | BIT 10 | FUNCTION |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | BSW |
| 0 | 1 | 0 | RAL |
| 0 | 1 | 1 | RTL |
| 1 | 0 | 0 | RAR |
| 1 | 0 | 1 | RTR |

FIGURE 6 - Group 1 Microinstruction Format

Table 2-1 lists commonly used group 1 microinstructions, their assigned mnemonics, octal number, instruction format, logical sequence, the operation they perform, and the number of states. The same format is followed in Table 3 and 4 which corresponds to group 2 and 3 microinstructions, respectively.

There are several commonly used microprogrammed combinations of group 1 microinstructions. These are listed in Table 2-2. When writing programs it is necessary to load various constants into the AC for such purposes as initiallizing counters and to provide comparisons. Table 2-3 lists those constants which can be loaded directly via microprogrammed combinations of group 1 instructions.

TABLE 2-1

| MNEMONIC | $\begin{aligned} & \text { OCTAL } \\ & \text { CODE } \end{aligned}$ | LOGICAL SEQUENCE | $\begin{aligned} & \text { NUMBER } \\ & \text { OF } \\ & \text { STATES } \end{aligned}$ | OPERATION |
| :---: | :---: | :---: | :---: | :---: |
| NOP | 7000 | 1 | 10 | NO OPERATION - This instruction causes a 10 state delay in program execution, without affecting the state of the HM-6100. It may be used for timing synchronization or as a convenient means of deleting an instruction from a program. |
| CLA | 7200 | 1 | 10 | CLEAR ACCUMULATOR - The accumulator is loaded with binary 0 's. |

FIGURE 2-1 Continued

| MNEMONIC | OCTAL CODE | LOGICAL SEQUENCE | $\begin{aligned} & \text { NUMBER } \\ & \text { OF } \\ & \text { STATES } \end{aligned}$ | OPERATION |
| :---: | :---: | :---: | :---: | :---: |
| CLL | 7100 | 1 | 10 | CLEAR LINK - The link is loaded with a binary 0. |
| CMA | 7040 | 2 | 10 | COMPLEMENT ACCUMULATOR - The content of each bit of the AC is complemented. This has the effect of replacing the contents of the AC with its one's complement. |
| CML | 7020 | 2 | 10 | COMPLEMENT LINK - The content of the link is complemented. |
| IAC | 7001 | 3 | 10 | INCREMENT ACCUMULATOR - The content of the AC is incremented by one (1) and the carry out componments the Link (L). |
| BSW | 7002 | 4 | 15 | BYTE SWAP - The right six (6) bits of the AC are exchanged or SWAPPED with the left six bits. $A C(0)$ is swapped with $A C(6), A C(1)$ with $A C(7)$, etc. The link is not affected. |
| RAL | 7004 | 4 | 15 | ROTATE ACCUMULATOR LEFT - The content of the AC and $L$ are rotated one binary position to the left. $A C(0)$ is shifted to $L$ and $L$ is shifted to $A C(11)$. The ROTATE instructions use what is commonly called a circular shift, meaning that any bit rotated off one end of the accumulator will reappear at the other end. |
| RTL | 7006 | 4 | 15 | ROTATE TWO LEFT - The contents of the AC and $L$ are rotated two binary positions to the left. $A C(1)$ is shifted to $L$ and $L$ is shifted to $A C(10)$. |
| RAR | 7010 | 4 | 15 | ROTATE ACCUMULATOR RIGHT - The contents of the AC and L are rotated one binary position to the right. $A C(11)$ is shifted to $L$ and $L$ is shifted to AC(0). |
| RTR | 7012 | 4 | 15 | ROTATE TWO RIGHT - The contents of the $A C$ and $L$ are rotated two binary positions to the right. $A C(10)$ is shifted to $L$ and $L$ is shifted to $A C(1)$. |

TABLE 2-2

| MNE- <br> MONIC | OCTAL <br> CODE | LOGICAL <br> SEQUENCE | NUMBER <br> OF <br> STATES | OPERATION |
| :---: | :---: | :---: | :---: | :--- |
| CLA CLL | 7300 | 1 | 10 | CLEAR ACCUMULATOR - CLEAR LINK <br> COMPLEMENT AND INCREMENT ACCUMULATOR - The con- <br> tent of the AC is replaced with its two's complement. The carry <br> out complements the link. This is a microprogrammed combina- <br> tion of CMA and IAC. |
| STL | 7041 | 2,3 | 10 | 1,2 |
| STA | 7240 | 1,2 | 10 | SET THE LINK - The LINK is loaded with a binary 1 correspond- <br> ing with a microprogrammed combination of CLL and CML. <br> SET THE ACCUMULATOR - Each bit of the AC is set to 1 corr- <br> esponding to a microprogrammed combination of CLA and CMA. |
| CLA IAC | 7201 | 1,3 | 10 | Sets the accumulator to a 1. |

TABLE 2-2 Continued

| MNEMONIC | $\begin{aligned} & \text { OCTAL } \\ & \text { CODE } \end{aligned}$ | LOGICAL SEQUENCE | NUMBER OF STATES | OPERATION |
| :---: | :---: | :---: | :---: | :---: |
| GLK | 7204 | 1,4 | 15 | GET LINK - The AC is cleared and the content of the link is shifted into $\mathrm{AC}(11)$ while a 0 is shifted into the link. This is a microprogrammed combination of CLA and RAL. |
| CLL RAL | 7104 | 1,4 | 15 | CLEAR LINK - ROTATE ACCUMULATOR LEFT |
| CLL RTL | 7106 | 1,4 | 15 | CLEAR LINK - ROTATE TWO LEFT |
| CLL RAR | 7110 | 1,4 | 15 | CLEAR LINK - ROTATE ACCUMULATOR RIGHT |
| CLL RTR | 7112 | 1, 4 | 15 | CLEAR LINK - ROTATE TWO RIGHT |

TABLE 2-3

| MNEMONIC | OCTAL <br> CODE | LOGICAL <br> SEQUENCE | NUMBER <br> OF <br> STATES | DECIMAL <br> CONSTANT | INSTRUCTIONS COMBINED |
| :---: | :---: | :---: | :---: | :---: | :--- |
| NL0000 | 7300 | 1 | 10 | 0 | CLA CLL |
| NL0001 | 7301 | 1,3 | 10 | 1 | CLA CLL IAC |
| NL0002 | 7305 | $1,3,4$ | 15 | 2 | CLA CLL IAC RAL |
| NL0003 | 7325 | $1,2,3,4$ | 15 | 3 | CLA CLL CML IAC RAL |
| NL0004 | 7307 | $1,3,4$ | 15 | 4 | CLA CLL IAC RTL |
| NL0006 | 7327 | $1,2,3,4$ | 15 | 6 | CLA CLL CML IAC RTL |
| NL0100 | 7303 | $1,3,4$ | 15 | CLA IAC BSW |  |
| NL2000 | 7332 | $1,2,4$ | 15 | 1024 | CLA CLL CML RTR |
| NL3777 | 7350 | $1,2,4$ | 15 | 2047 | CLA CLL CMA RAR |
| NL4000 | 7330 | $1,2,4$ | 15 | -0 | CLA CLL CML RAR |
| NL5777 | 7352 | $1,2,4$ | 15 | -1025 | CLA CLL CMA RTL |
| NL6000 | 7333 | $1,2,3,4$ | 15 | -1024 | CLA CLL CML IAC RTR |
| NL7775 | 7346 | $1,2,4$ | 15 | -3 | CLA CLL CMA RTL |
| NL7776 | 7344 | $1,2,4$ | 15 | -2 | CLA CLL CMA RAL |
| NL7777 | 7340 | 1,2 | 10 | -1 | CLA CLL CMA |

## GROUP 2 MICROINSTRUCTIONS

Figure 7 shows the instruction format of group 2 microinstructions, Bits $4-10$ may be set to indicate a specific group 2 microinstruction. If more than one of bits 4-7 or 9-10 is set, the instruction is a microprogrammed combination group 2 microinstructions, which will be executed according to the logical sequence shown in Figure 7.


FIGURE 7 - Group 2 Microinstruction Format
Skip microinstructions may be microprogrammed with CLA, OSR, or HLT microinstructions. Skip microinstructions which have a 0 in bit 8 , however, may not be microprogrammed with skip microinstructions which have a 1 in bit 8. When two or more skip microinstructions are microprogrammed into a single instruction, the resulting condition on which the decision will be based is the logical OR of the individual conditions when bit 8 is 0 , or when bit 8 is 1 , the decision will be based on the logical AND.

TABLE 3-1

| MNE- <br> MONIC | $\begin{aligned} & \text { OCTAL } \\ & \text { CODE } \end{aligned}$ | LOGICAL SEQUENCE | NUMBER OF STATES | OPERATION |
| :---: | :---: | :---: | :---: | :---: |
| NOP | 7400 | 1 | 10 | NO OPERATION - See Group 1 microinstructions. |
| CLA | 7600 | 2 | 10 | CLEAR ACCUMULATOR - The accumulator is loaded with binary O's. |
| HLT | 7402 | 3 | 10 | HALT - Program stops at the conclusion of the current machine cycle. If HLT is combined with others in OPR 2, the other operations are completed before the end of the cycle. |
| SKP | 7410 | 1 | 10 | SKIP - The content of the PC is incremented by 1, to skip the next instruction. |
| SNL | 7420 | 1 | 10 | SKIP ON NON-ZERO LINK - The content of $L$ is sampled; the next sequential instruction is skipped if $L$ contains a 1 . If $L$ contains a 0 , the next instruction is executed. |
| SZL | 7430 | 1 | 10 | SKIP ON ZERO LINK - The instruction is skipped if the link contains a 0 . |
| SZA | 7440 | 1 | 10 | SKIP ON ZERO ACCUMULATOR - The content of the AC is sampled; the next sequential instruction is skipped if all AC bits are 0 . If any bit in the AC is a 1 , the next instruction is executed. |
| SNA | 7450 | 1 | 10 | SKIP ON NON-ZERO ACCUMULATOR - The next instruction is skipped if any one bit of the AC contains a 1. If every bit in the AC is 0 , the next instruction is executed. |
| SMA | 7500 | 1 | 10 | SKIP ON MINUS ACCUMULATOR - If the content of AC(0) contains a negative two's complement number, the next sequential instruction is skipped. If $\mathrm{AC}(0)$ contains a 0 , the next instruction is executed. |
| SPA | 7510 | 1 | 10 | SKIP ON POSITIVE ACCUMULATOR - If the content of AC(0) contains a 0 , indicating a positive two's complement number, the next sequential instruction is skipped. |
| OSR | 7404 | 3 | 15 | OR WITH SWITCH REGISTER - The content of the Switch Regist-ter is inclusively OR'ed with the content of the AC and the result stored in the AC. The HM-6100 sequences the OSR instruction through a 2-cycle execute phase referred to as OPR 2A and OPR 2B. This instruction provides the simplest way to input data to the HM6100 from peripherals. |
| LAS | 7604 | 1, 3 | 15 | LOAD ACCUMULATOR WITH SWITCH REGISTER - The content of the AC is loaded with the content of the SR, bit for bit. This is equivalent to a microprogrammed combination of CLA and OSR. |

Table 3-2 lists every legal combination of skip microinstructions, along with the resulting condition upon which the decision to skip or execute the next sequential instruction is based. When these combinations include a CLA, the accumulator is cleared after the decision is made. This is a useful trick to save code when a new value will be TAD'ed into the $A C$.

TABLE 3-2

| MNEMONIC | OCTAL <br> CODE | LOGICAL <br> SEQUENCE | NUMBER <br> OF <br> STATES | OPERATION |
| :--- | :---: | :---: | :---: | :--- |
| SZA SNL | 7460 | 1 | 10 | Skip if $A C=0$ or $L=1$ or both. |
| SNA SZL | 7470 | 1 | 10 | Skip if $A C \neq 0$ and $L=0$. |
| SMA SNL | 7520 | 1 | 10 | Skip if $A C<0$ or $L=1$ or both. |
| SPA SZL | 7530 | 1 | 10 | Skip if $A C \geq 0$ and $L=0$. |
| SMA SZA | 7540 | 1 | 10 | Skip if $A C \leq 0$. |
| SPA SNA | 7550 | 1 | 10 | Skip if $A C>0$. |
| SMA SZA SNL | 7560 | 1 | 10 | Skip if $A C \leq 0$ or $L=1$ or both. |
| SPA SNA SZL | 7570 | 1 | 10 | Skip if $A C>0$ and $L=0$. |

When writing an actual program, it is useful to think in terms of the FORTRAN relational operators - .LT., .EQ., etc.when trying to compare numbers. The following method along with Table $3-3$ will provide this.

| CLA CLL | / Initialize AC and Link |
| :--- | :--- |
| TAD B | /Fetch 2nd number |
| CML CMA IAC | /Create " $-B^{\prime \prime}$ (AC \& L act like a 13 bit accumulator) |
| TAD A | /Fetch 1st number |
| Test CLA | /Use instructions from Table $3-3$ to provide test |
|  | /The CLA is optional to provide a clear AC after test |
| JMP FAIL | /Branch to FAIL routine if test failed |
| $\ldots$ | /Test passed, continue with program |

TABLE 3-3

| SKIP IF | UNSIGNED <br> COMPARE | SIGNED <br> COMPARE |
| :--- | :--- | :--- |
| A. NE. B | SNA | SNA |
| A. LT. B | SNL | SMA |
| A. LE. B | SNL SZA | SMA SZA |
| A. EQ. B | SZA | SZA |
| A. GE. B | SZL | SPA |
| A. GT. B | SZL SNA | SPA SAN |

## GROUP 3 MICROINSTRUCTIONS

Figure 8 shows the instruction format of group 3 microinstructions which requires bits 3 and 11 to contain a 1 . Bits 4 , 5 or 7 may be set to indicate a specific group 3 microinstruction. If more than one of the bits is set, the instruction is a microprogrammed combination of group 3 microinstructions following the logical sequence listed in Figure 8.


FIGURE 8 - Group 3 Microinstruction Format

TABLE 4

| MNEMONIC | OCTAL CODE | LOGICAL SEQUENCE | NUMBER OF STATES | OPERATION |
| :---: | :---: | :---: | :---: | :---: |
| NOP | 7401 | 3 | 10 | NO OPERATION - See group 1 microinstructions. |
| CLA | 7600 | 1 | 10 | CLEAR ACCUMULATOR |
| MQA | 7501 | 2 | 10 | MQ REGISTER INTO ACCUMULATOR - The content of the MO is logical OR'ed with the content of the AC and the result is loaded into the AC. The original content of the $A C$ is lost but the original content of the MO is retained. This instruction provides the programmer with an inclusive OR operation. |
| MQL | 7421 | 2 | 10 | MO REGISTER LOAD - The content of the AC is loaded into the $M Q$, the $A C$ is cleared and the original content of the $M Q$ is lost. This is similar to a DCA instruction. |
| ACL | 7701 | 1,2 | 10 | CLEAR ACCUMULATOR AND LOAD MQ REGISTER INTO ACCUMULATOR - This is equivalent to a microprogrammed combination of CLA and MQA. It is similar to the two instruction combination of CLA and TAD. |
| CAM | 7621 | 1, 2 | 10 | CLEAR ACCUMULATOR AND MQ REGISTER - The content of the $A C$ and MO are loaded with binary 0 's. This is equivalent to a microprogram combination of CLA and MQL. |
| SWP | 7521 | 2 | 10 | SWAP ACCUMULATOR AND MQ REGISTER - The content of the $A C$ and $M Q$ are interchanged by accomplishing a microprogrammed combination of MQA and MQL. |
| CLA SWP | 7721 | 1, 2 | 10 | CLEAR ACCUMULATOR AND SWAP ACCUMULATOR AND MQ REGISTER - The content of the AC is cleared. The content of the MQ is loaded into the $A C$ and the MQ is cleared. |

## Input Output Transfer Instructions (IOT)

The input/output transfer instructions, which have an OPCODE of 68 are used to initiate the operation of peripheral devices and to transfer data between peripherals and the HM-6100. Three types of data transfer may be used to receive or transmit information between the HM-6100 and one or more peripheral I/O devices. PROGRAMMED DATA TRANSFER provides a straightforward means of communicating with relatively slow I/O devices, such as Teletypes, cassettes, card readers and CRT displays. INTERRUPT TRANSFERS use the interrupt system to service several peripheral devices simultaneously, on an intermittent basis, permitting computational operations to be performed concurrently with the data I/O operations. Both Programmed Data Transfers and Program Interrupt Transfers use the accumulator as a buffer, or storage area, for all data transfers. Since data may be transferred only between the accumulator and the peripheral, only one 12 bit word at a time may be transferred. DIRECT MEMORY ACCESS, DMA, Transfers variable-size blocks of data between high-speed peripherals and the memory with minimum of program control required by the HM-6100.

## IOT INSTRUCTION FORMAT

The Input/Output Transfer instruction format is represented in Figure 9.


The first three bits, $0-2$, are always set to $6_{8}(110)$ to specify an IOT instruction. The next 9 bits, $3-11$, are user definable and can provide a minimal implementation when each bit controls one operation. When following PDP-8/E format, the next six bits, 3-8, contain the device selection code that determines the specific I/O device for which the IOT instruction is intended and, therefore, permit interface with up to $64 \mathrm{I} / \mathrm{O}$ devices. The last three bits, 9-11, contain the operation specification code that determines the specific operation to be performed. The nature of this operation for any given IOT instruction depends entirely upon the circuitry designed into the I/O device interface.

## PROGRAMMED DATA TRANSFER

Programmed Data Transfer is the easiest, simplest, most convenient and most common means of performing data I/O. For microprocessor applications, it may also be the most cost effective approach. The data transfer begins when the HM-6100 fetches an instruction from the memory and recognizes that the current instruction is an IOT (2). This is referred to an IFETCH and consists of five (5) internal states. The HM-6100 sequences the IOT instruction through a 2-cycle execute phase referred to as IOTA and IOTB. Bits 0-11 of the IOT instruction are available on DXO-11 at IOTA $\wedge$ LXMAR (3). These bits must be latched in an external address register. $\overline{\text { DEVSEL }}$ is active low to enalbe data transfers between the HM-6100 and the peripheral device (4) \& (5). Input-Output Instruction Timing is shown in Figure 10. The selected peripheral device communicates with the $\mathrm{HM}-6100$ through 4 control lines $-\overline{\mathrm{CO}}, \overline{\mathrm{C} 1}, \overline{\mathrm{C} 2}$ and $\overline{\mathrm{SKP}}$. In the HM-6100 the type of data transfer, during an IOT instruction, is specified by the peripheral device(s) by asserting the control lines as shown in Tables 5-1 and 5-2.

The control line $\overline{\mathrm{SKP}}$, when low during an IOT, causes the HM-6100 to skip the next sequential instruction. This feature is used to sense the status of various signals in the device interface. The $\mathrm{CO}, \mathrm{C} 1$, and C 2 lines are treated independently of the $\overline{\text { SKP }}$ line. In the case of a RELATIVE or ABSOLUTE JUMP, the skip operation is performed after the jump. The input signals to the $\mathrm{HM}-6100, \mathrm{DXO}-11, \overline{\mathrm{C} 0}, \overline{\mathrm{C} 1}, \overline{\mathrm{C} 2}$ and $\overline{\mathrm{SKP}}$, are sampled during IOTA on the rising edge of time state 3 (4). The data from the HM-6100 is available to the device during $\overline{\mathrm{DEVSEL}} \wedge \overline{\mathrm{XTC}}$ (5). The IOTB cycle is internal to the HM-6100 to perform the operations requested during IOTA. Both IOTA and IOTB consists of six (6) internal states.


FIGURE 10 - Input-output instruction timing

TABLE 5-1
AC DATA TRANSFERS

| CONTROL LINES |  |  |  | OPERATION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { SKP }}$ | $\overline{C O}$ | $\overline{C 1}$ | $\overline{\text { C2 }}$ |  |  |
| H | H | H | H | $D E V-A C$ | The content of the AC is sent to the device. |
| H | L | H | H | DEV - AC; CLA | The content of the $A C$ is sent to a device and then the $A C$ is cleared. |
| H | H | L | H | $\begin{aligned} & A C \backsim A C V D E V \\ & D E V — A C \end{aligned}$ | Data is received from a device OR'ed with the data in the AC and the result is stored in the AC. The new AC content is sent to the device. |
| H | L | L | H | $\begin{aligned} & A C=D E V ; \\ & D E V-A C \end{aligned}$ | Data is received from a device and loaded into the AC. The new AC content is sent to the device. |
| L | H | H | H | $\begin{aligned} & D E V-A C ; \\ & P C-P C+1 \end{aligned}$ | The content of the AC is sent to the device and the microprocessor skips the next sequential instruction. |
| L | L | H | H | $\begin{aligned} & D E V — A C ; C L A ; \\ & P C=P C+1 \end{aligned}$ | The content of the AC is sent to a device, the AC is cleared, and the microprocessor skips the next sequential instruction. |
| L | H | L | H | $\begin{aligned} & A C-A C V D E V ; \\ & D E V-A C ; \\ & P C-P C+1 \end{aligned}$ | Data is OR'ed into the AC, the new AC sent to the device, and the microprocessor skips the next sequential instruction. |
| L | L | L | H | $\begin{aligned} & A C-D E V ; \\ & D E V-A C \\ & P C-P C+1 \end{aligned}$ | Data is loaded into the AC, the new AC contents sent to the device, and the next sequential instruction skipped. |

TABLE 5-2
PC VECTOR TRANSFERS

| CONTROL LINES |  |  |  | OPERATION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { SKP }}$ | $\overline{\mathbf{c o}}$ | $\overline{\text { C1 }}$ | $\overline{\text { C2 }}$ |  |  |
| H | * | H | L | PC - PC + DEV | Data from the device is added to the contents of the PC. <br> This is referred to as a RELATIVE JUMP. |
| H | * | L | L | PC — DEV | Data is received from a device and loaded into the PC. This is referred to as an ABSOLUTE JUMP. |
| L | * | H | L | $\begin{aligned} & P C — P C+D E V ; \\ & P C=P C+1 \end{aligned}$ | The RELATIVE JUMP is performed and then the microprocessor skips the next sequential instruction. |
| L | * | L | L | $\begin{aligned} & P C — D E V ; \\ & P C=P C+1 \end{aligned}$ | The ABSOLUTE JUMP is executed and then the next sequential instruction is skipped. |

## PROGRAM INTERRUPT TRANSFERS

The program interrupt system may be used to initiate programmed data transfers in such a way that the time spent waiting for device status is greatly reduced or eliminated altogether. It also provides a means of performing concurrent programmed data transfers between the HM-6100 and the peripheral devices. This is accomplished by isolating the I/O handling routines from the mainline program and using the interrupt system to ensure that these routines are entered only when an I/O device status is set, indicating that the device is actually ready to perform the next data transfer, or that is requires some sort of intervention from the running program.

TABLE 6
PROCESSOR IOT INSTRUCTIONS

| MNEMONIC | $\begin{aligned} & \text { OCTAL } \\ & \text { CODE } \end{aligned}$ | OPERATION |
| :---: | :---: | :---: |
| SKON | 6000 | SKIP IF INTERRUPT ON - If Interrupt system is enabled, the next sequential instruction is skipped. The Interrupt system is disabled. |
| ION | 6001 | INTERRUPT TURN ON - The internal interrupt acknowledge system is enabled. The interrupt system is enabled after the CPU executes the next sequential instruction. |
| IOF | 6002 | INTERRUPT TURN OFF - The interrupt system is disabled. Note that the interrupt system is automatically disabled when the CPU acknowledges an INT request. |
| SRQ | 6003 | SKIP IF INT REQUEST - The next sequential instruction is skipped if the INT request bus is low. |
| GTF | 6004 | GET FLAGS - The following machines states are read into the indicated bits of AC. <br> bit 0-Link <br> bit 1 - Greater than flag* bit 4 - Interrupt Enable FF* <br> bit 2 - INT request bus <br> bit 5 - User flag* <br> bit 3-Interrupt Inhibit FF* bit 6-11-Save Field Register* <br> * These bits are modified by external devices driving the $D X$ bus and the $\bar{C}$-lines $(\overline{C O}=L$, $\overline{\mathrm{C}}=\mathrm{L}$ ). For example, bits 1 and 6-11 are part of the Extended Memory Control. |
| RTF | 6005 | RETURN FLAGS - Link is restored from AC (0). Interrupt system is enabled after the next sequential instruction is executed. All AC bits are available externally to restore external states. (ex. Extended memory control). ( $\overline{\mathrm{CO}}=\mathrm{H}, \overline{\mathrm{C}}=\mathrm{H}$ ) |
| SGT | 6006 | SKIP ON GREATER THAN FLAG - Operation is determined by external devices, if any. This flag is external and must control the skip line. |
| CAF | 6007 | CLEAR ALL FLAGS - AC and link are cleared. Interrupt system is disabled. |

The interrupt system allows certain external conditions to interrupt the computer program by driving the INTREQ input to the HM-6100 low. If no higher priority requests are outstanding and the interrupt system is enabled, the HM6100 grants the device interrupt at the end of the current instruction. After an interrupt has been granted, the Interrupt Enable Flip-Flop in the HM-6100 is reset so that no more interrupts are acknowledged until the interrupt system is re-enabled under program control.

The current content of the Program Counter, PC, is deposited in location $0_{000}^{8}$ of the memory and the program fetches the instruction from location $0_{0018}$. The return address is available in location $0000{ }_{8}$. This address must be saved, possibly in a software stack, if nested interrupts are permitted. The INTGNT signal is activated by the HM-6100 when a device interrupt is acknowledged. This signal is reset by executing any IOT instruction. The INTGNT is also useful in implementing an External Vectored Priority Interrupt network.

The user program controls the interrupt mechanism of the HM-6100 by executing the processor IOT instructions listed in Table 6. Several of these interrupt IOT instructions are also used if the memory is extended beyond 4 K words.

## DIRECT MEMORY ACCESS (DMA)

Direct Memory Access, sometimes called data break, is the perferred form of data transfer for use with high-speed storage devices such as magnetic disk or tape units. The DMA mechanism transfers data directly between memory and peripheral devices. The HM-6100 is involved only is setting up the transfer; the transfers take place with no processor intervention on a "cycle stealing" basis. The DMA transfer rate is limited only by the bandwidth of the memory and the data transfer characteristics of the device.

The device generates a DMA Request when it is ready to transfer data. The HM-6100 grants the DMAREQ by activating the DMAGNT signal at the end of the current instruction. The HM-6100 suspends any further instruction fetches until the DMAREO line is released. The DX lines are tri-stated, all SEL lines are high, and the external timing signals XTA, XTB, and XTC are active. The device which generated the DMAREQ must provide the address and necessary control signals to the memory for data transfers. The DMAREQ line can also be used as a level sensitive "pause" line.

## Control Panel Interrupt Transfer

The HM-6100 CPU provides a unique Control Panel (CP) feature through its CPREO input and CPSEL output lines. After acknowledging the control panel request, the CPU generates the necessary timing to execute program code in CP memory while also providing the capability to transfer data between CP memory and the user memory using the AC as a buffer. This allows the user memory to be examined and/or modified by the CP software. The CPU will output the $\overline{M E M S E L}$ signal for all user memory references while the $\overline{\text { CPSEL }}$ signal is generated for CP memory references as shown in Figure 11.


FIGURE 11 - Control Panel Block Diagram

The designer can make use of the control panel features to implement various functions that will be "transparent" to the user's (main) memory. Some of the more common functions include:

- Binary Loader and Punch
- Register Examination and Modification
- Single Cycle
- Octal Debug with Breakpoints
- Octal listing
- Auto Bootstrap

When a $\overline{\text { CPREQ }}$ is granted the PC is stored in location 0000 of Panel Memory and the HM-6100 resumes operation at location 7777 of the Panel Memory. The $\overline{\text { CPREQ }}$ bypasses the interrupt enable system and the processor IOT instruction, ION and IOF, are ignored while the HM-6100 is in the Control Panel Mode. Once a CPREO is granted, the HM6100 will not recognize any $\overline{\text { DMAREO }}$ or $\overline{\text { INTREQ }}$ until the CPREQ has been fully serviced.

During Control Panel program execution access to the user memory is gained through use of indirect TAD, AND, DCA and ISZ instructions. The CPU will transfer control from $\overline{C P S E L}$ to $\overline{M E M S E L}$ during the execute phase of these instructions. The instructions are always fetched from control panel memory.

Exiting from the control panel routine is achieved by executing the following sequence:

- ION
- JMP I 0000 /Exit via location 0000 in Panel Memory

Location 0000 contains either the original return address deposited by the HM-6100 when the CP routine was entered, or it may be a new starting address defined by the CP routine.

## Internal Priority Structure

After an instruction is completely sequenced, the major state generator scans the internal priority network as shown in in Figure 12. The state of the priority network decides the next sequence of the HM-6100.

The CPU samples the $\overline{\operatorname{RESET}}$ line, the request lines $\overline{\mathrm{CPREO}}, \overline{\mathrm{DMAREO}}$, and $\overline{\text { INTREQ}}$, and the state of its internal RUN flip-flop during the last execute cycle of each instruction. The worst case response time of the HM-6100 to an external request is, therefore the time required to execute the longest instruction preceded by any 6 -state execution cycle. For the HM-6100, this is an autoindexed ISZ, 22 states, preceded by any 6 -state execution cycle instruction. The worst case response time is, therefore, 28 states, $14 \mu \mathrm{~s}$ at 4 MHz clock frequency.

When the HM-6100 is initially powered up, the state of the timing generator is undefined. The generator is automatically initialized with a maximum of 34 clock pulses. The request inputs, as the HM-6100 is powered on, must span at least 58 clock pulses to be recognized, 34 clocks for the counter to initialize and a maximum of two HM-6100 cycles ( 20 to 24 clocks) for the state generator to sample the request lines. A positive transition of RUN/HLT should occur at least 10 clock pulses after $\overline{\text { RESET }}$ to be recognized.

The priority hierarchy is:

- $\overline{\text { RESET }}$ - If the $\overline{\text { RESET }}$ line is asserted at the sample time, the processor immediately sets its program counter to 7777, clears the Accumulator and Link, and puts the processor in the HALT state. While halted, the processor continues to cycle and generate the timing signals XTA, XTB, and XTC. During reset the DX line is tristated and the SEL lines are high.
- $\overline{\text { CPREQ }}$ - If the $\overline{\text { RESET }}$ line is not found to be asserted, but the $\overline{\text { CPREQ }}$ line is, the processor grants the control panel interrupt request at the end of the current cycle.
- RUN/ $\overline{\text { LLT }}$ - If neither of the foregoing lines are asserted, but the processor finds its internal RUN FF in the halt state, it enters the HALT cycle at the end of the last execute cycle. Pulsing the RUN/HLT line low causes the HM-6100 to alternately run and halt. The internal RUN FF changes state on the rising edge of the RUN/HLT line. While halted the processor continues to generate the timing signals XTA, XTB, and XTC.
- $\overline{\text { DMAREQ - DMA requests are granted at the end of the current cycle only if none of the above actions are }}$ pending.
- INTREQ - An interrupt request is granted at the end of the current cycle only if none of the higher priority lines preempts it.
- IFETCH - If none of the above actions are indicated, the processor will fetch the next sequential instruction in the next cycle.


FIGURE 12 - Major processor states and number of clock cycles in each state.

## Use of Wait Input

The HM-6100 samples the $\overline{\text { WAIT }}$ line during input-output data transfers. The WAIT line, if active low, controls the transfer duration. If $\overline{W A I T}$ is active during input transfers (READ), the CPU waits in the T2 state. For an output transfer (WRITE), $\overline{W A I T}$ controls the time for which the write data is maintained on the DX lines by extending the T6 state. When operating at the max frequency, the internal delay of the HM-6100 causes the falling edge select lines to be past the WAIT setup time for WRITE. The rising edge of the select line for READ can be used to activate WAIT for a WRITE. The wait duration is an integral multiple of the oscillator time period (Figure 13).


FIGURE 13 - WAIT sequencing steps.

## HM-6100 Oscillator Requirements

## USING AN EXTERNAL CRYSTAL

An inexpensive crystal can be used thereby eliminating the need for a clock generator. The crystal operates at parallel resonance, and thus is looks inductive in the circuit. An "AT" cut crystal should be used because it has a low temperature coefficient and can be used over a wide temperature range. The Feedback resistor and shunt capacitance are included internally. The crystal parameters needed are:

- Frequency
- Mod of Resonance - Parallel (anti-resonant)
- Maximum Power level-1 milliwatt
- Load Capacitance - 32pF
- Series Resistance (max) - $250 \Omega$

For precise frequency determination the effect of the stray circuit capacitance and internal 30 pF capacitance must be taken into account.


FIGURE 14 - Oscillator input schematic

## USING AN EXTERNAL CLOCK GENERATOR

When a system clock is needed, eg. for a baud rate generator for UARTs, the HM-6100 can be externally clocked, thus eliminating the need for separate crystals. The external clock can be connected to the oscillator output pin while grounding oscillator input. This has the effect of over driving the small internal oscillator inverter causing an increase in supply current.

Duty cycle - 50/50
Trise, $T_{\text {fall }}-20 \mathrm{~ns}$

## PIN DEFINITIONS

| PIN | SYMBOL | ACtive LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | VCC |  | Supply voltage. |
| 2 | RUN | H | The signal indicates the run state of the CPU and may be used to power down the external circuitry |
| 3 | DMAGNT | H | Direct Memory Access Grant-DX lines are three-state. |
| 4 | $\overline{\text { DMAREQ }}$ | L | Direct Memory Access Request-DMA is granted at the end of the current instruction. Upon DMA grant, the CPU suspends program execution until the DMAREQ line is released. |
| 5 | CPREQ | L | Control Panel Request-a dedicated interrupt which bypasses the normal device interrupt request structure. |
| 6 | RUN/ $\overline{\text { HLT }}$ | L | Pulsing the Run/Halt line causes the CPU to alternately run and halt by changing the state of the internal RUN/HLTT flip flop. |
| 7 | RESET | L | Clears the AC and loads 77778 into the PC. CPU is halted. |
| $\begin{aligned} & 8 \\ & 9 \end{aligned}$ | $\begin{aligned} & \text { INTREQ } \\ & \text { XTA } \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | Peripheral device interrupt request. External coded minor cycle timingsignifies input transfers to the HM-6100. |


| PIN | SYMBOL | active LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 10 | LXMAR | H | The Load External Address Register is used to store memory and peripheral address externally. |
| 11 | $\overline{\text { WAIT }}$ | L | Indicates that peripherals or external memory is not ready to transfer data. The CPU state gets extended as long as $\overline{\text { WAIT }}$ is active. The CPU is in the lowest power state with clocks running. |
| 12 | XTB | H | External coded minor cycle timingsignifies output transfers from the HM-6100. |
| 13 | XTC | H | External coded minor cycle timingused in conjunction with the Select Lines to specify read or write operations. |
| 14 | OSC OUT |  | Crystal input to generate the internal timing (also external clock input). |
| 15 | OSC IN |  | See Pin 14-OSC OUT (also external clock ground) |
| 16 | DX0 |  | DataX-multiplexed data in, data out and address lines. |
| 17 | DX1 |  | See Pin 16-DX0. |
| 18 | DX2 |  | See Pin 16-DX0. |
| 19 | DX3 |  | See Pin 16-DX0. |
| 20 | DX4 |  | See Pin 16-DX0. |



| PIN | SYMBOL | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 21 | DX5 |  | See Pin 16-DX0. |
| 22 | DX6 |  | See Pin 16-DX0. |
| 23 | DX7 |  | See Pin 16-DX0. |
| 24 | DX8 |  | See Pin 16-DX0. |
| 25 | DX9 |  | See Pin 16-DX0. |
| 26 | GND |  | Ground |
| 27 | DX10 |  | See Pin 16-DX0. |
| 28 | DX11 |  | See Pin 16-DX0. |
| 29 | LINK | H | Link flip flop. |
| 30 | DEVSEL | L | Device Select for I/O transfers. |
| 31 | SWSEL | L | Switch Register Select for the OR THE SWITCH REGISTER INSTRUCTION (OSR). OSR is a Group 2 Operate Instruction which reads a 12 bit external switch register and OR's it with the contents of the AC. |
| 32 | $\overline{\mathrm{CO}}$ | L | Control line inputs from the peripheral device during an I/O transfer (Table 5). |


| PIN | SYMBOL | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 33 | $\overline{\mathrm{C} 1}$ | L | See Pin 32-C0. |
| 34 | $\overline{\mathrm{C}}$ | L | See Pin 32-C0. |
| 35 | SKP | L | Skips the next sequential instruction if active during an $\mathrm{I} / \mathrm{O}$ instruction. (Table 5) |
| 36 | IFETCH | H | Instruction Fetch Cycle |
| 37 | MEMSEL | L | Memory Select for memory transfers. |
| 38 | CPSEL | L | The Control Panel Memory Select becomes active, instead of the MEMSEL, for control panel routines. Signal may be used to distinguish between control panel and main memories. |
| $\begin{aligned} & 39 \\ & 40 \end{aligned}$ | INTGNT DATAF | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | Peripheral device Interrupt Grant Data Field pin indicates the execute phase of indirectly addressed AND, TAD, ISZ and DCA instructions so that the data transfers are controlled by the Data Field, DF, and not the Instruction Field, IF, if Extended Memory Control hardware is used to extend the addressing space from 4 K to 32 K words. |

## Features

- HM-6100 COMPATIBLE
- LOW POWER STANDBY - $500 \mu$ W MAX
- SINGLE SUPPLY 4-11 VOLTS
- FULL TEMPERATURE RANGE -550 ${ }^{\circ} \mathrm{C}$ TO $\mathbf{+ 1 2 5}^{\circ} \mathrm{C}$
- STATIC OPERATION
- 4 PROGRAMMABLE OUTPUTS (FLAGS)
- 4 PROGRAMMABLE SENSE INPUTS
- CONTROL FOR TWO 12 BIT INPUT PORTS
- CONTROL FOR TWO 12 BIT OUTPUT PORTS
- PRIORITY VECTORED INTERRUPTS
- UP TO 31 PIE'S PER SYSTEM
- 16 INSTRUCTIONS FOR PIE CONTROL


## Description

The HD-6101 Parallel Interface Elements (PIE) are high speed, low power, silicon gate CMOS general purpose devices which provide addressing interrupt and control for a variety of peripheral functions, such as UARTs, FIFOs, Keyboards, etc. Data transfers between the HM-6100 CMOS Microprocessor and the HD-6101 are via Input-Output Transfer (IOT) instructions, control lines and DX bus.

Data transfers between peripheral devices and the DX bus are controlled by the PIE via 2 read, 2 write, 4 sense and 4 flag functions. Internal PIE registers are programmed under software control for write polarities, sense levels or edges, flag values and interrupt enables. Another software controlled register stores the address for vectored interrupt operation.

## Pinout

| VCC 510 | 40 | POUT |
| :---: | :---: | :---: |
| INTGNT 2 | 39 | ] $\overline{\text { SPP }} / \overline{\text { NT }}$ |
| PRIN 3 | 38 | WRITE 2 |
| SENSE 4 [4 | 37 | READ 2 |
| SENSE 3 -5 | 36 | WRITE 1 |
| SENSE 2 C | 35 | READ 1 |
| SENSE 1 [ 7 | 34 | $\overline{\mathrm{C} 2}$ |
| SEL 3 [8 | 33 | $\overline{\mathrm{C} 1}$ |
| SEL 40 | 32 | FLAG 1 |
| LXMAR 10 | 31 | FLAG 2 |
| SEL 5011 | 30 | FLAG 3 |
| SEL 612 | 29 | FLAG 4 |
| XTC 13 | 28 | DEVSEL |
| SEL 7 -14 | 27 | GND |
| DX0 15 | 26 | D D 11 |
| DX10 16 | 25 | DX10 |
| DX2 17 | 24 | DX9 |
| DX3 18 | 23 | DX8 |
| DX4 19 | 22 | DX7 |
| DX5 [20 | 21 | DX6 |

## Functional Diagram



## ABSOLUTE MAXIMUM RATINGS

Supply Voltage (VCC - GND)
Input or Output Voltage Applied
Storage Temperature Range Operating Temperature Range

Industrial HD-6101-9
Military HD-6101-2

$$
\begin{array}{r}
-0.3 \mathrm{~V} \text { to }+8.0 \mathrm{~V} \\
\text { (GND }-0.3 \mathrm{~V}) \text { to (VCC }+0.3 \mathrm{~V}) \\
-65{ }^{\circ} \mathrm{C} \text { to }+150{ }^{\circ} \mathrm{C} \\
\\
-40^{\circ} \mathrm{C} \text { to }+850^{\circ} \mathrm{C} \\
-55^{\circ} \mathrm{C} \text { to }+125{ }^{\circ} \mathrm{C}
\end{array}
$$

ELECTRICAL CHARACTERISTICS $\quad \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=$ Industrial or Military
D.C.

| SYMBOL | PARAMETER | MINIMUM | TYPICAL | MAXIMUM | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical "1" Input Voltage | 70\% VCc |  |  | V |  |
| VIL | Logical '0' Input Voltage |  |  | 20\% VCC | V |  |
| IIL | Input Leakage | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $O V \leqslant V_{I N} \leqslant$ VCC |
| VOH | Logical "1" Output Voltage(1) | 2.4 |  |  | V | $1 \mathrm{OH}=-0.2 \mathrm{~mA}$ |
| VOL | Logical "0" Output Voltage |  |  | 0.45 | V | $\mathrm{IOL}=2.0 \mathrm{~mA}$ |
| 10 | Output Leakage | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $0 V \leqslant V O \leqslant V C C$ |
| ICC | Supply Current (Static) |  | 1.0 | 100 | $\mu \mathrm{A}$ | $\mathrm{VIN}_{\text {IN }}=\mathrm{VCC}^{\text {c }}$, Freq. $=0$ |
| CI | Input Capacitance (2) |  | 5 | 7 | pF |  |
| Co | Output Capacitance (2) |  | 8 | 10 | pF |  |
| ClO | Input/Output Capacitance(2) |  | 8 | 10 | pF |  |

NOTE: (1) Except pins 33, 34, 39
(2) Guaranteed and sampled, but not $100 \%$ tested.
A.C.

|  |  | $\begin{aligned} T_{A} & =25^{\circ} \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V}(1) \end{aligned}$ |  | TA = <br> INDUSTRIAL $V C C=5 V \pm 10 \%$ |  | $\begin{gathered} \text { TA }= \\ \text { MILITARY } \\ \text { VCC = 5V } \pm 10 \% \end{gathered}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | MIN | MAX | UNITS | TEST CONDITIONS |
| tDR | Delay: $\overline{\text { DEVSEL }}$ to $\overline{\text { READ }}$ |  | 200 |  | 300 |  | 330 | ns | $C L L=50 \mathrm{pF}$ |
| tDW | Delay: $\overline{\text { DEVSEL }}$ to WRITE | 100 | 220 | 140 | 300 | 150 | 330 | ns | See Timing |
| tDF | Delay: $\overline{\text { DEVSEL }}$ to FLAG |  | 200 |  | 375 |  | 415 | ns | Diagram |
| tDC | Delay: $\overline{\mathrm{DEVSEL}}$ to $\overline{\mathrm{C} 1}, \overline{\mathrm{C} 2}$ |  | 160 |  | 460 |  | 510 | ns |  |
| tDI | Delay: $\overline{\mathrm{DEVSEL}}$ to $\overline{\mathrm{SKP}} / \overline{\mathrm{NTT}}$ |  | 210 |  | 460 |  | 510 | ns |  |
| tDA | Delay: $\overline{\text { DEVSEL }}$ to DX |  | 350 |  | 460 |  | 510 | ns |  |
| tLX | LXMAR Pulse Width | 200 |  | 240 |  | 265 |  | ns |  |
| tAS | Address Set-Up Time | 60 |  | 80 |  | 90 |  | ns |  |
| tAH | Address Hold Time | 100 |  | 125 |  | 140 |  | ns |  |
| tDS | Data Set-Up Time | 50 |  | 80 |  | 80 |  | ns |  |
| tDH | Data Hold Time | 100 |  | 100 |  | 110 |  | ns | 1 |

NOTE (1): All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information - not guaranteed.

## ABSOLUTE MAXIMUM RATINGS

Supply Voltage (VCC - GND)
Input or Output Voltage Applied
Storage Temperature Range
Operating Temperature Range
Industrial HD-6101C-9
-0.3 V to +8.0 V
(GND - 0.3V) to (VCC +0.3 V )
$-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

## ELECTRICAL CHARACTERISTICS $\quad V_{C C}=5.0 \mathrm{~V} \pm 5 \% ; T_{A}=$ Industrial

| D.C. | SYMBOL | PARAMETER | MINIMUM | TYPICAL | MAXIMUM | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | VIH | Logical ' 1 '" Input Voltage | 70\% Vcc |  |  | V |  |
|  | VIL | Logical '0' Input Voltage |  |  | . 8 | V |  |
|  | IIL | Input Leakage | -10 |  | +10 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{VIN}^{1} \leqslant \mathrm{VCC}$ |
|  | VOH | Logical "1" Output Voltage(1) | 2.4 |  |  | V | $1 \mathrm{OH}=-0.2 \mathrm{~mA}$ |
|  | VOL | Logical '0' Output Voltage |  |  | 0.45 | V | $1 \mathrm{OL}=1.6 \mathrm{~mA}$ |
|  | 10 | Output Leakage | -10 |  | +10 | $\mu \mathrm{A}$ | $O V \leqslant V O \leqslant V C C$ |
|  | ICC | Supply Current (Static) |  | 1.0 | 800 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{C C}$, Freq. $=0$ |
|  | Cl | Input Capacitance (2) |  | 5 | 7 | pF |  |
|  | Co | Output Capacitance (2) |  | 8 | 10 | pF |  |
|  | ClO | Input/Output Capacitance (2) |  | 8 | 10 | pF |  |

NOTES: (1) Except pins 33, 34, 39
(2) Guaranteed and sampled, but not $100 \%$ tested.

| A.C. |  |  | $\begin{aligned} T A & =25^{\circ} \mathrm{C} \\ \mathrm{VCC} & =5.0 \mathrm{~V}(1) \end{aligned}$ |  | $T A=$ <br> INDUSTRIAL $V C C=5 V \pm 5 \%$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | UNITS | TEST CONDITIONS |
|  | tDR | Delay: $\overline{\text { DEVSEL }}$ to $\overline{\text { READ }}$ |  | 230 |  | 375 | ns | $C L=50 \mathrm{pF}$ |
|  | tDW | Delay: $\overline{\text { DEVSEL }}$ to WRITE | 100 | 240 | 125 | 375 | ns | See Timing |
|  | tDF | Delay: $\overline{\text { DEVSEL }}$ to FLAG |  | 230 |  | 475 | ns | Diagram |
|  | tDC | Delay: $\overline{\mathrm{DEVSEL}}$ to $\overline{\mathrm{C} 1}, \overline{\mathrm{C} 2}$ |  | 190 |  | 560 | ns |  |
|  | tDI | Delay: $\overline{\mathrm{DEVSEL}}$ to $\overline{\mathrm{SKP}} / \overline{\mathrm{NNT}}$ |  | 250 |  | 560 | ns |  |
|  | tDA | Delay: $\overline{\text { DEVSEL }}$ to DX |  | 400 |  | 560 | ns |  |
|  | tLX | LXMAR Pulse Width | 230 |  | 300 |  | ns |  |
|  | tAS | Address Set-Up Time | 80 |  | 100 |  | ns |  |
|  | tAH | Address Hold Time | 120 |  | 150 |  | ns |  |
|  | tDS | Data Set-Up Time | 60 |  | 90 |  | ns |  |
|  | tDH | Data Hold Time | 120 |  | 150 |  | ns | $\dagger$ |

NOTE (1): All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information - not guaranteed.

## Timing Diagram

Timing for a typical transfer is shown below. During an instruction fetch the processor places the contents of the PC on the bus (1) and obtains from memory an IOT instruction of the form $6 \times X X$ (2). During IOTA of the execute phase the processor places that instruction back on the DX lines (3) and pulses LXMAR transferring address and control information for the IOT transfer to all peripheral devices. A low going pulse on DEVSEL while XTC is high (4) is used by the addressed PIE along with the decoded control information to generate CPU control signals $\overline{\mathrm{C} 1}, \overline{\mathrm{C} 2}$, and $\overline{\mathrm{SKP}}$. Also at this time either the Control Register A or the Interrupt Vector Register are outputed
on the DX lines, or control outputs $\overline{\text { READ1 }}$ and $\overline{\text { READ2 }}$ are generated to gate peripheral data to the DX lines. A low going pulse on DEVSEL while XTC is low (5) is used to generate WRITE 1 and WRITE 2 controls. These signals are used to latch accumulator data into peripheral devices.

All PIE timing is generated from HM-6100 signals LXMAR, $\overline{\text { DEVSEL, }}$, and XTC. No additional timing signals, clocks, or one shots are required.

Propagation delays, pulse width, data setup and hold times are specified for direct interfacing with the HM-6100.


## Pie Address and Instructions

The HM-6100 communicates with the PIE and with peripherals through the PIE via IOT commands. During the IOTA cycle an instruction of the form $6 \times X X$ is loaded into all PIE instruction registers. The bits are interpreted as shown below.

The 5 address bits (3-7) are compared with the pin programmable select inputs SEL3, SEL4, SEL5, SEL6, SEL7 to address 1 of 31 possible PIEs. Address zero is reserved for IOT's internal to the HM-6100. The four control bits are decoded by the PIE to select one of 16 instructions which are described below.

| PIE INSTRUCTION FORMAT |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| 1 | 1 | 0 |  | ADDRESS |  |  |  | CONTROL |  |  |  |


| CONTROL | MNEMONICS | ACTION |
| :---: | :---: | :---: |
| 0000 | READ1 | The READ instructions generate a pulse on the appropriate read outputs. This signal is used by |
| 1000 | READ2 | the peripheral device to gate onto the DX bus to be "OR'ed" with the HM-6100 accumulator data. The HM-6100 accumulator is cleared prior to reading peripheral data when $\overline{\mathrm{CO}}$ is asserted low. |
| 0001 | WRITE1 | The WRITE instructions generate a pulse on the appropriate write output. This signal is used by |
| 1001 | WRITE2 | peripherals to load the HM-6100 accumulator data on the DX lines into peripheral data registers. The HM-6100 AC is cleared after the write operation when the $\overline{\mathrm{CO}}$ input is asserted low. |
| 0010 | SKIP1 | The SKIP instructions test the state of the sense flip flops. If the input conditions have set the |
| 0011 | SKIP2 | sense flip flop, the PIE will assert the $\overline{\mathrm{SKP}} / \overline{\mathrm{INT}}$ output causing the HM-6100 to skip the next |
| 1010 | SKIP3 | program instruction. The sense flip flop is then cleared. If the sense flip flop is not set, the PIE |
| 1011 | SKIP4 | not assert the $\overline{\mathrm{SKP}} / \overline{\mathrm{NT}}$ output and the HM-6100 will execute the next instruction. |
| 0100 | RCRA | The Read Control Register $A$ instruction gates the contents of CRA onto the DX lines during time 4 to be "OR" transferred to the HM-6100 AC. |
| 0101 | WCRA | The Write Control Register A, Write Control Register B and Write Vector Register instructions |
| 1101 | WCRB | transfer HM-6100 AC data on the DX lines during time 5 of IOTA into the appropriate register. |
| 1100 | WVR |  |
| 0110 | SFLAG1 | The SET FLAG instructions set the bits FL1 and FL3 in control register $A$ to a high level. PIE |
| 1110 | SFLAG3 | outputs FLAG1 and FLAG3 follow the data stored in bits FL1 and FL3 of CRA. |
| 0111 | CFLAG1 | The CLEAR FLAG instructions clear the bits FL1 and FL3 in control register A to a low level. |
| 1111 | CFLAG3 |  |
| ${ }^{(6007)} 8$ | CAF | HM-6100 internal IOT instruction CLEAR ALL. FLAGS clears the interrupt requests by clearing the sense flip flops. |

## Programmable Outputs

FLAGs (1-4) - The FLAGs are general purpose outputs that can be set and cleared under program control. GLAG1 follows bit FL1 in Control Register A and etc. FLAGs can be changed by loading new data into CRA via
the WCRA commands. In addition, FLAG1 and FLAG3 can be set and cleared directly by the commands SFLAG1, CFLAG1, SFLAG3 and CFLAG3.

## Programmable Sense Inputs

The sense inputs are used to set sense flip flops (SENSE FF) inside the PIE. For each sense input there are two FF's, one for skip and one for interrupt. Conditions for setting each SENSE FF, levels or edges and positive or negative polarities, are set by control bits SL and SP in CRB.

The SENSE FF's are sampled when LXMAR is high. Interrupt requests are generated only when the sense flip flops are set by an edge and interrupts are enabled by writing to control reg A. Sense flip flops are reset on the following conditions.

| CONDITION | SENSE FLIP FLOPS |  |
| :--- | :--- | :--- |
|  | SKIP FF | INTERRUPT FF |
| CAF Instruction (60078) | Clears AII | Clears AII |
| SKIP Instruction | Clears Corresponding FF | Clears Corresponding FF |
| Vectored Interrupt | Not Cleared | Clears Highest Priority FF <br> on Selected PIE After <br> Vectoring |
| Interrupt Disabled (IE = $\left.{ }^{\prime \prime} 0^{\prime \prime}\right)$ | Not Cleared | Disables Interrupt by Holding |
|  |  | Corresponding FF in Reset <br> State |

## Controls for Input and Output Ports

READ (1-2) - The $\overline{\text { READ outputs are activated by the }}$ read instructions and are used by peripheral devices to get data onto the DX lines for transfer to the HM-6100. Read lines are active low.

WRITE (1-2) - The WRITE outputs are activated by the write instructions and are used by peripheral devices to load HM-6100 AC data from the DX lines into peripheral data registers. Output polarity is controlled by the WRITE POLARITY bits of CRA. A logic one causes pulses to be positive while a logic zero causes pulses to be negative.

1/O CONTROL LINES - There are three I/O control lines from the PIE to the microprocessor - $\overline{\mathrm{C} 1}, \overline{\mathrm{C} 2}$, and $\overline{\mathrm{INT}} / \overline{\mathrm{SKP}}$. The type of data transfer, during an IOT in-
struction, is specified by the PIE's assertion of the $\overline{\mathrm{C} 1}$ and $\overline{\mathrm{C} 2}$ control lines as shown below.

Interrupt and skip information are time multiplexed on the same line ( $\overline{\mathrm{SKP}} / \overline{\mathrm{INT}}$ ). Since the HM-6100 samples skip and interrupt data at separate times there is no degradation in system performance. The PIE samples the sense flip flops and generates an interrupt request for enabled bits (IE1-4) when LXMAR is high. Interrupt requests are asserted by the PIE driving the $\overline{\mathrm{NT}} / \overline{\mathrm{SKP}}$ line low. During IOTA of SKIP instructions the $\overline{\operatorname{INT}} / \overline{\mathrm{SKP}}$ reflects the SENSE FF data when DEVSEL is low and XTC is high. If the SENSE flip flop is set, the $\overline{\mathrm{INT}} / \overline{\mathrm{SKP}}$ line is driven low to cause the HM-6100 to skip the next instruction. All these outputs are open drain.

| CONTROL LINES |  |  |  | OPERATION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathbf{S K P}}$ | $\overline{\mathbf{C o}}{ }^{*}$ | $\overline{C 1}$ | $\overline{\mathrm{C}}$ |  |  |
| H | H | H | H | PIE - AC | The contents of the AC is sent to the PIE. |
| H | H | L | H | $A C-A C V P I E$ | Data is received from the PIE, OR'ed with the data in the AC and the result stored in the AC. |
| H | H | L | L | PC - Vector Address | Vector address received from PIE and loaded into PC. This is referred to as an absolute jump. |
| L | H | H | H | $P C-P C+1$ | Forces Microprocessor to skip next sequential instruction. |

NOTE: *The $\overline{\mathrm{CO}}$ line must be connected to VCC using a pull-up resistor.

## Programmable Registers

## CONTROL REGISTER A (CRA)

The CRA can be read and written by the HM-6100 via the RCRA and WCRA commands.

The format and meaning of control bits are shown below.
FL (1-4) - Data on FLAG outputs corresponds to data in FL (1-4). Changing the FL bits under software control changes the corresponding FLAG outputs.

IE (1-4) - A high level on INTERRUPT ENABLE enables interrupts for the SENSE inputs.

Otherwise these inputs provide conditional skip testing as defined by the SKIP1-4 instructions.

WP (1-2) - A high level on WRITE POLARITY bits causes positive pulses at the WRITE outputs.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FL4 | FL3 | FL2 | FL1 | WP2 | $*$ | WP1 | $*$ | IE4 | IE3 | IE2 | IE1 |

* $=$ Don't Care


## CONTROL REGISTER B (CRB)

The CRB can be written by the HM-6100 via the WCRB instruction. It has no read back capability. The format and meaning of control bits are shown.

SL (1-4) - A high level on the SENSE LEVEL bits causes the SENSE inputs to be level sensitive. A low level in the SL bits causes the SENSE inputs to be edge sensitive. An interrupt request is generated only if a sense line is set
up to be edge sensitive and interrupts are enabled via the IE bits of CRA.

SP (1-4) - A high level on the SENSE POLARITY bits causes the flip flop to be set by high level or positive going edge. A low level causes the flip flop to be set by a low level or negative going edge.


* $=$ Don't Care


## VECTOR REGISTER

A hardware priority network uniquely selects a PIE to provide a vectored address. The first IOT command of any type, after the HM-6100 signal INTERRUPT GRANT goes high, resets the INTGNT line to a low level. The INTGNT signal is used to freeze the priority network and enable vector generation. The highest priority PIE has PIN tied to VCC. The lowest priority PIE is the last one on
the chain. Within the PIE, SENSE1 has the highest priority and SENSE 4 has the lowest. The vector address generated by the PIE consists of 10 bits from the vector register and two bits that indicate the sense input within the highest priority PIE that generated the interrupt. If PIN is tied to GND, then the PIE will respond as a non-vectored interrupt device.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | VECTOR REGISTER |  |  |  | VPRI |  |  |  |  |  |


| VPRI | CONDITIONS |
| :---: | :---: |
| 00 | SENSE 1 |
| 01 | SENSE 2 |
| 10 | SENSE 3 |
| 11 | SENSE 4 |

## Pin Definitions

| PIN | SYMBOL | ACTIVE <br> LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | $\mathrm{V}_{\mathrm{Cc}}$ |  | Positive voltage |
| 2 | INTGNT | H | A high level on INTERRUPT GRANT inhibits recognition of new interrupt requests and allows the priority chain time to uniquely specify a PIE. |
| 3 | PRIN | H | A high level ON PRIORITY IN and an interrupt request will select a PIE for vectored interrupt. |
| 4 | SENSE 4 | PROG | The SENSE input is controlled by the SL (sense level) and SP (sense polarity) bits of control register B. A high SL level will cause the sense flip flop to be set by a level while a low SL level causes then sense flip flop to be set by an edge. A high SP level will cause the sense flip flop to be set by a positive going edge or high level. A high IE (interrupt enable) level generates an interrupt request whenever the sense flip flop is set by an edge. |
| 5 | SENSE 3 | PROG | See pin 4 - SENSE 4 |
| 6 | SENSE 2 | PROG | See pin 4 - SENSE 4 |
| 7 | SENSE 1 | PROG | See pin 4 -SENSE 4 |


| PIN | SYMBOL | ACTIVE <br> LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 8 | SEL 3 | true | Matching SELECT(3-7) inputs with PIE addressing on $\mathrm{DX}(3-7)$ during IOTA selects a PIE for programmed input output transfers. |
| 9 | SEL 4 | true | See Pin 8 --SEL 3 |
| 10 | LXMAR | H | A positive pulse on LOAD EXTERNAL ADDRESS REGISTER loads address and control data from $\mathrm{DX}(3-11)$ into the address register. |
| 11 | SEL 5 | true | See Pin 8 -SEL 3 |
| 12 | SEL 6 | true | See Pin 8 - SEL 3 |
| 13 | XTC | H | The XTC input is a timing signal produced by the microprocessor. When XTC is high a low going pulse on DEVSEL initiates a "read" operation. When XTC is low, a low going pulse on DEVSEL initiates a write operation. |
| 14 | SEL 7 | true | See Pin 8 -SEL 3 |
| 15 | D× 0 | true | Data transfers between the microprocessor and PIE take place via these input/output pins. |
| 16 | DX 1 | true | See Pin 15 - DX 0 |
| 17 | DX 2 | true | See Pin $15-$ DX 0 |
| 18 | DX 3 | true | See Pin $15-$ DX 0 |
| 19 | DX 4 | true | See Pin 15 - DX 0 |
| 20 | DX 5 | true | See Pin 15 - DX 0 |



| PIN | SYMBOL | ACTIVE <br> LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 21 | DX 6 | true | See Pin $15-\mathrm{DX} 0$ |
| 22 | DX 7 | true | See Pin 15 - DX 0 |
| 23 | DX 8 | true | See Pin 15 - DX 0 |
| 24 | DX 9 | true | See Pin 15 - DX 0 |
| 25 | DX 10 | true | See Pin $15-\mathrm{DX} 0$ |
| 26 | DX 11 | true | See Pin $15-$ DX 0 |
| 27 | GND |  |  |
| 28 | DEVSEL | L | The DEVSEL input is a timing signal produced by the microprocessor during IOT instructions. It is used by the PIE to generate timing for controlling PIE registers and "read" and "write" operations. |
| 29 | FLAG 4 | PROG | The FLAG outputs reflect the data stored in control register A. Flags (1-4) can be set or reset by changing data in CRA via a WRA (write control register A) command. FLAG1 and FLAG3 can be controlled directly by PIE commands SFLAG1, CFLAG1, SFLAG3 and CFLAG3. |
| 30 | FLAG 3 | PROG | See Pin 29 - FLAG 4 |
| 31 | FLAG 2 | PROG | See Pin 29 - FLAG 4 |
| 32 | FLAG 1 | PROG | See Pin 29 - FLAG 4 |
| 33 | $\overline{\mathrm{C} 1}$ | L | The PIE decodes address, control and priority information and asserts outputs $\overline{\mathrm{C} 1}$ and $\overline{\mathrm{C} 2}$ during the IOTA cycle to control the type of data transfer. These outputs are open drain for bussing and require a pullup register to V CC . <br> $\overline{\mathrm{C} 1}(\mathrm{~L}), \overline{\mathrm{C} 2}(\mathrm{~L})$ - vectored interrupt <br> $\overline{\mathrm{C} 1}(\mathrm{~L}), \overline{\mathrm{C} 2}(\mathrm{H})-\overline{\operatorname{READ1}}, \overline{\text { READ2 }}$ or RRA commands <br> $\overline{\mathrm{C} 1}(\mathrm{H}), \overline{\mathrm{C} 2}(\mathrm{H})$ - all other instructions |


| PIN | SYMBOL | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 34 | $\overline{\mathrm{C} 2}$ | L | See Pin $33-\overline{\mathrm{Cl}}$ |
| 35 | $\overline{\text { READ1 }}$ | PROG | Outputs $\overline{\operatorname{READ1}}$ and $\overline{\operatorname{READ2}}$ are used to gate data from peripheral devices onto the DX bus for input to the HM-6100 Note the data does not pass through the PIE. |
| 36 | WRITE1 | PROG | Outputs WRITE1 and WRITE2 are used to gate data from the HM-6100 DX bus into peripheral devices. Data does not pass through the PIE. |
| 37 | $\overline{\text { READ2 }}$ | PROG | See Pin $35-\overline{\text { READ1 }}$ |
| 38 | WRITE2 | PROG | See Pin $36-$ Write 1 |
| 39 | $\overline{\text { SKP }} / \overline{\mathrm{INT}}$ | L | The PIE asserts this line low to generate interrupt requests and to signal the HM-6100 when sense flip flops are set during SKIP instructions. This output is open drain. |
| 40 | POUT | H | A high level on priority out indicates no higher priority PIE interrupt requests are outstanding. This output is tied to the PIN input of the next lower priority PIE in the chain. |

Features

- SINGLE POWER SUPPLY
- HIGH NOISE IMMUNITY
- industrial and military grades
- DRIVECAPACITY
- SOURCE CURRENT
- SINK CURRENT
- propagation delay


## Description

The HD-6431 is a self-aligned silicon gate CMOS Latching Three-State Bus Driver. This circuit consists of 6 non-inverting latching drivers with separate input and output. A high on the strobe line $L$ allows data to go through the latches and a transition to low latches the data. A high on the Three-State control $\overline{\mathrm{E}}$ forces the buffers to the high impedance mode without disturbing the latched data. New data may be latched in while the buffers are in the high impedance mode.

Outputs guaranteed valid at VCC 2.0V for Battery Backup Applications.

## Pinout



Truth Table

| CONTROL <br> INPUTS | DATA PORT <br> STATUS |  |  |
| :---: | :---: | :---: | :---: |
| E | L | A | Y |
| $H$ | L | X | HI-Z* |
| $H$ | $H$ | $X$ | HI-Z |
| L |  | X | $*$ |
| L | $H$ | L | L |
| L | $H$ | $H$ | $H$ |

* Data is latched to the value of the last input X = Don't Care
$\mathrm{HI}-\mathrm{Z}=$ High Impedance $\downarrow=$ Transition from High to Low level


## Functional Diagram



## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage <br> Input or Output Voltage Applied <br> Storage Temperature Range <br> Operating Temperature Range <br> Industrial HD-6431-9 | +8.0 V <br> Military HD-6431-2/8 <br> Operating Voltage Range |
| :--- | ---: |

## ELECTRICAL CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$; $\mathrm{T}_{\mathrm{A}}=$ Industrial or Military

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | Logical "1" Input Voltage | 70\% V CC |  | V |  |
| VIL | Logical "0' Input Voltage |  | 20\% VCC | V |  |
| IIL | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical "1" Output Voltage | $\mathrm{V}_{\text {CC }}-0.4$ |  | V | $\begin{aligned} & \mathrm{I} \mathrm{OH}=-4.0 \mathrm{~mA}, \\ & \overline{\mathrm{E}}=\text { Low } \end{aligned}$ |
| $\mathrm{V}_{\text {OL }}$ | Logical " 0 " Output Voltage |  | 0.4 | V | $\begin{aligned} & \mathrm{IOL}=6.0 \mathrm{~mA} \\ & \overline{\mathrm{E}}=\mathrm{Low} \end{aligned}$ |
| ${ }^{1} 0$ | Output Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\frac{\mathrm{OV} \leq \mathrm{V}_{\mathrm{O}} \leq \mathrm{V}_{\mathrm{CC}}}{\overline{\mathrm{E}}=\mathrm{High}}$ |
| ICC | Supply Current |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ |
| $\mathrm{CIN}^{\text {IN }}$ | Input Capacitance* |  | 5 | pF | $\begin{aligned} & V_{I N}=0 V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| $\mathrm{Co}_{0}$ | Output Capacitance* |  | 15 | pF | $\begin{aligned} & V_{I N}=0 V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |

* Guaranteed and sampled, but not $100 \%$ tested.
$C_{L}=300 \mathrm{pF}$

|  |  | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ 25^{\circ} \mathrm{C} \end{gathered}$ |  | $\begin{aligned} & \mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{TA}=\text { Indus. or } \mathrm{Mil} . \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | UNITS |
| $\begin{gathered} \text { tPD } \\ \text { tEN } \\ \text { tDIS } \\ \text { tSET } \\ \text { tHOLD } \\ \text { tPW } \\ \text { t }_{\text {R }} \\ \text { t } F \end{gathered}$ | Propagation Delay <br> Enable Time <br> Disable Time <br> Input Setup Time <br> Input Hold Time <br> Pulse Width <br> Output Rise Time <br> Output Fall Time | $\begin{aligned} & 15 \\ & 15 \\ & 25 \end{aligned}$ |  | $\begin{aligned} & 15 \\ & 15 \\ & 30 \end{aligned}$ | $\begin{aligned} & 75 \\ & 90 \\ & 90 \\ & \\ & 90 \\ & 80 \end{aligned}$ |  |

NOTE (1) All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information-not guaranteed.


## DECOUPLING CAPACITORS

The transient current required to charge the load capacitance is given by $I T=C \frac{d v}{d t}$. Assuming that all outputs may change state at the same time and that $\frac{d v}{d t}$ is constant; $I_{T}=\left(\Sigma C_{L}\right)\left(\frac{v_{C C} \times 80 \%}{t_{R} \text { or } t_{F}}\right)$ eg. $\left[t_{R}=80 \mathrm{~ns}, V_{C C}=5.0 \mathrm{~V}\right.$, each $C_{L}=300 \mathrm{pF}, I_{T}=(4)\left(300 \times 10^{-12}\right) \frac{5.0 \times 0.8}{80 \times 10^{-9}}=90 \mathrm{~mA}$.] This current spike may cause a large negative voltage
spike on $V_{C C}$, which if it becomes a diode drop less than any input, may cause the device to latch up. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between $\mathrm{V}_{\mathrm{CC}}$ and GND at each device to filter out this noise.

## PROPAGATION DELAYS





The above example will illustrate the calculation of a more useful propagation delay. The system on this example uses a 5 volt supply with a tolerance of $\pm 10 \%$, an ambient temperature of as high as $125^{\circ} \mathrm{C}$, and a calculated load capacitance of 150 pF . This application requires the HD-6431-2. The table of A.C. specs shows the tPD at 4.5 V and $125^{\circ} \mathrm{C}$ is 75 nsec. Use the graph in Figure 1 to get the degradation multiple for 150 pF . The number shown is 0.84 . The adjusted propagation delay, to the $10 \%$ or $90 \%$ point, is there-
fore $75 \times 0.84$ or 63 nsec . To obtain the rise and fall times check the A.C. specs for the rise and fall times at 4.5 V and $125^{\circ} \mathrm{C}$ to obtain a worst case rise time of 90 nsec . Use Figure 2 to find it's degradation multiple to be 0.65 . The adjusted rise time is, therefore, $90 \times 0.65$ or 58 nsec . To obtain the standard $50 \%$ to $50 \%$ propagation delay, add the adjusted propagation delay to half of the adjusted rise time to get a propagation delay of 92 nsec . The rise time was used here because it is always the worst case.

## Features

- SINGLE POWER SUPPLY
- HIGH NOISE IMMUNITY
- INDUSTRIAL AND MILITARY GRADES
- DRIVE CAPACITY
- SOURCE CURRENT
- sink current
- propagation delay


## Description

The HD-6432 is a self-aligned silicon gate CMOS bi-directional bus driver. This circuit consists of 12 drivers organized as 6 bi-directional pairs. Four enable lines select drive direction or Three-State mode.

Outputs guaranteed valid at VCC 2.0V for Battery Backup Applications.

## Pinout

TOP VIEW


Truth Table

| CONTROL <br> INPUTS |  |  |  | DATA PORT <br> STATUS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EAB | $\overline{E A B}_{\text {AB }}$ | EBA | $\bar{E}_{\text {BA }}$ | A | B |
| L | X | H | L | 0 | I |
| X | $H$ | $H$ | L | 0 | 1 |
| $H$ | L | X | H | I | O |
| H | L | L | X | I | O |
| L | X | L | X | ISOLATED |  |
| X | $H$ | X | H | ISOLATED |  |
| L | X | X | H | ISOLATED |  |
| X | $H$ | L | X | ISOLATED |  |
| H | L | H | L | NOT |  |
|  |  |  |  | ALLOWED |  |

$I=$ Input, $O=$ Output, $X=$ Don't Care

Functional Diagram


## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| $\quad$ Industrial HD-6432-9 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| $\quad$ Military HD-6432-2/8 | +4 to +7 V |

## ELECTRICAL CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=$ Industrial or Military

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | Logical "1" Input Voltage | $70 \% V_{\text {CC }}$ |  | V |  |
| $V_{\text {IL }}$ | Logical "0" Input Voltage |  | 20\% VCC | V |  |
| IIL | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{VOH}^{\text {O }}$ | Logical "1" Output Voltage | $V_{\text {CC }}-0.4$ |  | $v$ | $\mathrm{I}^{\mathrm{OH}}=-4.0 \mathrm{~mA}$ |
| $\mathrm{VOL}_{\text {OL }}$ | Logical "0' Output Voltage |  | 0.4 | V | $1 \mathrm{OL}=6.0 \mathrm{~mA}$ |
| 10 | Output Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & 0 V \leq v_{O} \leq v_{C C} \\ & E_{A B}=E_{B A}=\text { Low } \end{aligned}$ |
| ${ }^{\prime} \mathrm{Cc}$ | Supply Current |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.5 V \end{aligned}$ |
| $\mathrm{CIN}^{\text {IN }}$ | Input Capacitance* |  | $5$ | pF | $\begin{aligned} & V_{I N}=O V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| $C_{1 / O}$ | I/O Capacitance* |  | 20 | pF | $\begin{aligned} & V_{I N}=0 V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |

* Guaranteed and sampled, but not $100 \%$ tested.
A.C.
$C_{L}=300 \mathrm{pF}$

|  |  | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ 25^{\circ} \mathrm{C} \end{gathered}$ |  | $\begin{aligned} & \mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{TA}_{\mathrm{A}}=\text { Indus. or Mil. } \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | UNITS |
| ${ }^{\text {tPD }}$ | Propagation Delay |  | 45 |  | 55 | ns |
| ten | Enable Time |  | 65 |  | 75 | ns |
| ${ }^{\text {t DIS }}$ | Disable Time |  | 100 |  | 110 | ns |
| $t_{R}$ | Output Rise Time |  | 100 |  | 110 | ns |
| ${ }^{\text {t }}$ F | Output Fall Time |  | 70 |  | 80 | ns |

NOTE (1): All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information-not guaranteed.


All inputs have $\mathrm{t}_{\mathbf{R}}, \mathrm{t}_{\mathbf{F}} \leq \mathbf{2 0 n s}$.


OUTPUT TEST CIRCUIT FOR PROPAGATION DELAYS


OUTPUT TEST CIRCUIT
FOR THREE-STATE DELAYS

## DECOUPLING CAPACITORS

The Transient current required to charge the load capacitance is given by $I T=C \frac{d v}{d t}$. Assuming that all outputs may change state at the same time and that $\frac{d v}{d t}$ is constant; $I_{T}=\left(\Sigma C_{L}\right)\left(\frac{V_{C C} \times 80 \%}{t_{R} \text { or } t_{F}}\right)$ eg. $\left[t_{R}=100 \mathrm{~ns} \quad V_{C C}=5.0 \mathrm{~V}\right.$ each $C_{L}=300 \mathrm{pF} \quad I_{T}=(6)\left(300 \times 10^{-12}\right) \frac{5.0 \times 0.8}{100 \times 10^{-9}}=72 \mathrm{~mA}$. $]$ This current spike may cause a large negative voltage
spike on $V_{C C}$, which if it becomes a diode drop less than any input, may cause the device to latch up. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between VCC and GND at each device to filter out this noise.

## PROPAGATION DELAYS



The above example will illustrate the calculation of a more useful propagation delay. The system on this example uses a 5 volt supply with a tolerance of $\pm 10 \%$, an ambient temperature of as high as $125^{\circ} \mathrm{C}$, and a calculated load capacitance of 150 pF . This application requires the HD-6432-2. The table of A.C. specs shows the tPD at 4.5 V and $125^{\circ} \mathrm{C}$ is 55 nsec . Use the graph in Figure 1 to get the degradation multiple for 150 pF . The number shown is 0.84 . The adjusted propagation delay, to the $10 \%$ or $90 \%$ point, is there-
fore $55 \times 0.84$ or 46 nsec. To obtain the rise and fall times check the A.C. specs for the rise and fall times at 4.5 V and $125^{\circ} \mathrm{C}$ to obtain a worst case rise time of 110 nsec . Use Figure 2 to find it's degradation multiple to be 0.65 . The adjusted rise time is, therefore, $110 \times 0.65$ or 72 nsec . To obtain the standard $50 \%$ to $50 \%$ propagation delay, add the adjusted propagation delay to half of the adjusted rise time to get a propagation delay of 82 nsec . The rise time was used here because it is always the worst case.

## Features

- SINGLE POWER SUPPLY
- high noise immunity
- INDUSTRIAL AND MILITARY GRADES
- drive capacity
- SOURCE CURRENT
- sink current
- PROPAGATION DELAY


## Description

The HD-6433 is a self-aligned silicon gate CMOS bus separator/driver. This circuit consists of 8 drivers organized as 4 pairs of bus separators which allow a unidirectional input bus and a unidirectional output bus to be interfaced with a bi-directional bus.

Outputs guaranteed valid at VCC 2.0V for Battery Backup Applications.

## Pinout



Truth Table

| CONTROL <br> INPUTS | FUNCTION |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\bar{E}_{A}$ | $\bar{E}_{B}$ | A | B | Y |
| L | L | I | 0 | 0 |
| L | $H$ | I | D | 0 |
| $H$ | L | D | O | I |
| $H$ | $H$ | ISOLATED |  |  |

$1=$ Input, $0=$ Output,
$D=$ Disconnected

## Functional Diagram



## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | GND -0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| $\quad$ Industrial HD-6433-9 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| $\quad$ Military HD-6433-2/8 | +4 to +7 V |

## ELECTRICAL CHARACTERISTICS

|  | SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. | $\mathrm{V}_{\text {IH }}$ | Logical "1" Input Voltage | 70\% V CC |  | V |  |
|  | VIL | Logical " 0 " Input Voltage |  | 20\% V Cc | v |  |
|  | IIL | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
|  | $\mathrm{V}_{\mathrm{OH}}$ | Logical "1" Output Voltage | $\mathrm{V}_{\text {cc }}-0.4$ |  | $v$ | $1 \mathrm{OH}=-4.0 \mathrm{~mA}$ |
|  | $\mathrm{VOL}^{\text {OL }}$ | Logical " 0 " Output Voltage |  | $0.4$ | V | $1 \mathrm{OL}=6.0 \mathrm{~mA}$ |
|  | $\mathrm{I}_{0}$ | Output Leakage | $-1.0$ | $1.0$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0 V \leq V_{O} \leq V_{C C} \\ & \bar{E}_{A}=\bar{E}_{B}=H i g h \end{aligned}$ |
|  | ${ }^{1} \mathrm{CC}$ | Supply Current |  | $10$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.5 V \end{aligned}$ |
|  | CIN | Input Capacitance* |  | 5 | pF | $\begin{aligned} & V_{I N}=O V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
|  | $\mathrm{Cl}_{1 / \mathrm{O}}$ | I/O Capacitance* |  | 20 | pF | $\begin{aligned} & V_{I N}=0 V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
|  | $\mathrm{Co}_{0}$ | Output Capacitance* |  | 15 | pF | $\begin{aligned} & V_{I N}=O V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |

* Guaranteed and sampled, but not $100 \%$ tested.
$C_{L}=300 \mathrm{pF}$

| A.C. |  |  | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \text { (1) } \\ 25^{\circ} \mathrm{C} \end{gathered}$ |  | $\begin{aligned} & \text { VCC = 5.0V } \pm 10 \% \\ & \text { TA = Indust. or Mil. } \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | UNITS |
|  | ${ }^{\text {tPD }}$ | Propagation Delay |  | 40 |  | 50 | ns |
|  | ${ }^{\text {t E N }}$ | Enable Time |  | 60 |  | 70 | ns |
|  | ${ }^{t}$ DIS | Disable Time |  | 90 |  | 100 | ns |
|  | ${ }^{\text {t }}$ R | Output Rise Time |  | 85 |  | 95 | ns |
|  | $t^{\prime}$ | Output Fall Time |  | 70 |  | 80 | ns |

note (1)
All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information-not guaranteed.


## DECOUPLING CAPACITORS

The transient current required to charge the load capacitance is given by $I_{T}=C \frac{d v}{}$. Assuming that all outputs may change state at the same time and that $\frac{d v}{d t}$ is constant; $I_{T}=\left(\Sigma C_{L}\right)\left(\frac{V_{C C} \times 80 \%}{t_{R} \text { or } t_{F}}\right)$ eg. $\left[t_{R}=85 n s, V_{C C}=5.0 \mathrm{~V}\right.$, each $C_{L}=300 \mathrm{pF}, I_{T}=(4)\left(300 \times 10^{-12}\right) \frac{5.0 \times 0.8}{85 \times 10^{-9}}=56.5 \mathrm{~mA}$.] This current spike may cause a large negative voltage
spike on VCC, which if it becomes a diode drop less than any input, may cause the device to latch up. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between VCC and GND at each device to filter out this noise.

## PROPAGATION DELAYS





The above example will illustrate the calculation of a more useful propagation delay. The system on this example uses a 5 volt supply with a tolerance of $\pm 10 \%$, an ambient temperature of as high as 1250 C , and a calculated load capacitance of 150pF. This application requires the HD-6433-2. The table of A.C. specs shows the tPD at 4.5 V and $125^{\circ} \mathrm{C}$ is 50 nsec. Use the graph in Figure 1 to get the degradation multiple for 150 pF . The number shown is 0.84 . The adjusted propagation delay, to the $10 \%$ or $90 \%$ point, is there-
fore $50 \times 0.84$ or 42 nsec . To obtain the rise and fall times check the A.C. specs for the rise and fall times at 4.5 V and $125{ }^{\circ} \mathrm{C}$ to obtain a worst case rise time of 95 nsec . Use Figure 2 to find it's degradation multiple to be 0.65. The adjusted rise time is, therefore, $95 \times 0.65$ or 62 nsec . To obtain the standard $50 \%$ to $50 \%$ propagation delay, add the adjusted propagation delay to half of the adjusted rise time to get a propagation delay of 73 nsec . The rise time was used here because it is always the worst case.

## CMOS OCTAL RESETTABLE LATCHED BUS DRIVER

## Features

- SINGLE POWER SUPPLY
- HIGH NOISE IMMUNITY
- INDUSTRIAL AND MILITARY GRADES
- DRIVE CAPACITY
- SOURCE CURRENT
- SINK CURRENT
- PROPAGATION DELAY


## Description

The HD-6434 is a self-aligned silicon gate CMOS latching Three State bus driver. This circuit consists of 8 non-inverting latching drivers with separate input and output. A low on both strobe lines ( $\overline{\mathrm{L}}$ ) allows data to go through the latches and a transition to high latches the data. A high on either Three State control ( $\bar{E}$ ) forces the buffers to the high impedance mode without disturbing the latched data. A low on either reset line $(\bar{R})$ forces each of the latches to a low level. New data may be latched in while the buffers are in the high impedance mode.

Qutputs guaranteed valid at VCC 2.0V for Battery Backup Applications.

## Pinout

top VIEW

| $4 \mathrm{Y} \mathrm{C}^{1}$ | 24 | $\mathrm{V}_{\mathrm{CC}}$ |
| :---: | :---: | :---: |
| $3 \mathrm{Y} \mathrm{Cl}^{2}$ | 23 | $\square^{5} Y$ |
| $2 \mathrm{Y} \mathrm{C}_{3}$ | 22 | $\square^{6}$ |
| 1 Y -4 | 21 | $7 Y$ |
| ${ }^{1} \mathrm{~A} \mathrm{C}_{5}$ | 20 | -8Y |
| 2A 46 | 19 | $8^{8}$ |
| $3 \mathrm{~A}-7$ | 18 | 7 A |
| 4 A -8 | 17 | $\square{ }^{6} A$ |
| $\bar{R}_{1} \square_{9}$ | 16 | ${ }^{5} A$ |
| $\overline{\mathrm{R}}_{2} \square_{10}$ | 15 | $\bar{L}_{2}$ |
| $\bar{E}_{1} \square_{11}$ | 14 | $\bar{L}_{1}$ |
| GND 12 | 13 | $\bar{E}_{2}$ |

Truth Table

| CONTROL INPUTS |  |  |  |  |  |  | DATA |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\bar{R}_{1}$ | $\overline{\mathrm{R}}_{2}$ | $\overline{\mathrm{E}}_{1}$ | $\overline{\mathrm{E}}_{2}$ | $\overline{\mathrm{~L}}_{1}$ | $\overline{\mathrm{~L}}_{2}$ | A | Y |  |
| X | X | H | X | X | X | X | $\mathrm{Hi}-\mathrm{Z}$ |  |
| X | X | X | H | X | X | X | $\mathrm{Hi}-\mathrm{Z}$ |  |
| L | X | L | L | X | X | X | L |  |
| X | L | L | L | X | X | X | L |  |
| H | H | L | L | L | L | L | L |  |
| H | H | L | L | L | L | H | H |  |
| H | H | L | L | A | L | X | $*$ |  |
| H | H | L | L | L | L | X | $*$ |  |

$X=$ Don't Care $\mathrm{Hi}-\mathrm{Z}=$ High Impedance $\mathrm{L}=$ Low $H=$ High * = Data is latched to the value of the last input $A=$ Transition from a Low to High level

## Functional Diagram



## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range |  |
| Industrial HD-6434-9 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Military HD-6434-2/8 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Operating Voltage Range | +4 V to +7 V |

## ELECTRICAL CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=$ Industrial or Military

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | Logical "1" Input Voltage | 70\% V ${ }_{\text {cc }}$ |  | V |  |
| $V_{\text {IL }}$ | Logical ' 0 ' Input Voltage |  | 20\% V ${ }_{\text {CC }}$ | V |  |
| IIL | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| VOH | Logical "1" Output Voltage | $V_{\text {CC }}-0.4$ |  | V | $\begin{aligned} & \mathrm{IOH}=-6.0 \mathrm{~mA}, \\ & \mathrm{E}_{1}=\overline{\mathrm{E}}_{2}=\text { Low } \end{aligned}$ |
| $\mathrm{VOL}_{\text {OL }}$ | Logical "0" Output Voltage |  | 0.4 | V | $\begin{aligned} & \mathrm{IOL}=9.0 \mathrm{~mA} \\ & \overline{\mathrm{E}}_{1}=\bar{E}_{2}=\text { Low } \end{aligned}$ |
| 10 | Output Leakage | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & 0 V \leq V_{O} \leq V_{C C} \\ & \dot{E}_{1}=\bar{E}_{2}=H i g h \end{aligned}$ |
| ICC | Supply Current |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.5 V \end{aligned}$ |
| $\mathrm{CIN}^{\text {IN }}$ | Input Capacitance* |  | 5 | pF | $\begin{aligned} & V_{I N}=O V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| $\mathrm{CO}_{0}$ | Output Capacitance* |  | 15 | pF | $\begin{aligned} & V_{I N}=O V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |

* Guaranteed and sampled, but not $100 \%$ tested.

|  |  |  | $\begin{aligned} \mathrm{VCC} & =5.0 \mathrm{~V} \\ \text { TEMP } & =25^{\circ} \mathrm{C} \\ \mathrm{C}_{L} & =50 \mathrm{pF}(1) \end{aligned}$ | ```VCC }\pm5.0\textrm{V}\pm10 TEMP = IND OR MIL CL = 300pF``` |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A.C. | SYMBOL | PARAMETER | TYP | MIN | MAX |  |
|  | tPD | Propagation Delay | 40 |  | 50 | ns |
|  | ten | Enable Time | 45 |  | 50 | ns |
|  | tDIS | Disable Time | 45 |  | 50 | ns |
|  | tSET | Input Setup Time | 25 | 35 |  | ns |
|  | thold | Input Hold Time | 40 | 45 |  | ns |
|  | tPW | Pulse Width | 45 | 65 |  | ns |
|  | tR | Output Rise Time | 45 |  | 50 | ns |
|  | tF | Output Fall Time | 30 |  | 50 | ns |
|  | treset | Reset Delay Time | 75 |  | 125 | ns |

(1) All devices guaranteed at worst case limits. Room temperature, $5 \mathrm{~V}, \mathrm{CL}=50 \mathrm{pF}$ data provided for information only - not guaranteed.

## Switching Waveforms



All inputs have $t_{R}, t_{F} \leq 20 n s$.


OUTPUT TEST CIRCUIT FOR PROPAGATION DELAYS


OUTPUT TEST CIRCUIT FOR THREE-STATE DELAYS

## DECOUPLING CAPACITORS

The instantaneous current required to switch a large capacitance load may cause a voltage spike on VCC, which if it becomes a diode drop less than any input, may cause the device to latch up. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between VCC and GND at each device to filter out this noise.

## PROPAGATION DELAYS




TYPICAL CURVES

Features

- SINGLE POWER SUPPLY
- HIGH NOISE IMMUNITY
- INDUSTRIAL AND MILITARY GRADES
- DRIVE CAPACITY
- SOURCE CURRENT
- SINK CURRENT
- PROPAGATION DELAY


## Description

The HD-6436 is a self-aligned silicon gate CMOS Three State buffer driver. The circuit consists of 8 noninverting buffers with separate inputs and outputs which permit this driver to be used for bi-directional or uni-directional busing. A high on either Three State control line $\bar{E}_{1}$ or $\overline{\mathrm{E}}_{2}$ will force the drivers to the high impedance mode.

Outputs guaranteed valid at $\mathrm{V}_{\mathrm{CC}}=\mathbf{2 . 0 \mathrm { V }}$ for Battery Backup Applications.

Pinout
TOP VIEW

| $4 \mathrm{Y}-1$ | 20 | CC |
| :---: | :---: | :---: |
| $3 \mathrm{Y} \mathrm{O}_{2}$ | 19 | $\square 5$ |
| $2 \mathrm{Y} \mathrm{C}^{3}$ | 18 | 6 |
| 1 Y -4 | 17 | 7 Y |
| $1^{1} \mathrm{~A} 5$ | 16 | $8 Y$ |
| $2 \mathrm{~A} \square^{6}$ | 15 | 8 A |
| $3 \mathrm{~A}-7$ | 14 | $7{ }^{7}$ |
| 4A 8 | 13 | $\square 6$ A |
| $\bar{E}_{1} \square^{-1}$ | 12 | $\square{ }^{5}$ |
| GNDE10 | 11 | $\square \bar{E}_{2}$ |

## Truth Table

| CONTROL <br> INPUTS |  | INPUT | OUTPUT |
| :---: | :---: | :---: | :---: |
| $\bar{E}_{1}$ | $\bar{E}_{2}$ | $A$ | $Y$ |
| $L$ | $L$ | $L$ | $L$ |
| $L$ | $L$ | $H$ | $H$ |
| $L$ | $H$ | $X$ | $H i-Z$ |
| $H$ | $L$ | $X$ | $\mathrm{Hi}-Z$ |
| $H$ | $H$ | $X$ | $H i-Z$ |

$L=$ Low, $H=$ High X = Don't Care
$\mathrm{Hi}-\mathrm{Z}=$ High Impedance

Functional Diagram


## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | GND -0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150{ }^{\circ} \mathrm{C}$ |
| Operating Temperature Range |  |
| Industrial HD-6436-9 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Military HD-6436-2/8 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Operating Voltage Range | +4 V to +7 V |

## ELECTRICAL CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=$ Industrial or Military

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | Logical "1" Input Voltage | 70\% V Cc |  | V |  |
| $V_{\text {IL }}$ | Logical " 0 ' Input Voltage |  | 20\% VCC | $v$ |  |
| IIL | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| VOH | Logical "1" Output Voltage | $V_{\text {cC }}-0.4$ |  | V | $\begin{aligned} & \mathrm{IOH}^{2}=-6.0 \mathrm{~mA}, \\ & \mathrm{E}_{1}=\bar{E}_{2}=\text { Low } \end{aligned}$ |
| VOL | Logical "0" Output Voltage |  | 0.4 | V | $\begin{aligned} & I O L=9.0 \mathrm{~mA} \\ & \bar{E}_{1}=E_{2}=\text { Low } \end{aligned}$ |
| 10 | Output Leakage | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & o V \leq V_{0} \leq V_{C C} \\ & E_{1}=E_{2}=H i g h \end{aligned}$ |
| ${ }^{1} \mathrm{Cc}$ | Supply Current |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.5 V \end{aligned}$ |
| $C_{\text {IN }}$ | Input Capacitance* |  | 5 | pF | $\begin{aligned} & V_{I N}=0 V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHZ} \end{aligned}$ |
| Co | Output Capacitance* |  | 15 | pF | $\begin{aligned} & V_{I N}=0 V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |

* Guaranteed and sampled, but not $100 \%$ tested.
A.C.

|  |  | $\begin{aligned} & \text { VCC }=5.0 \mathrm{~V} \\ & \text { TEMP }=25^{\circ} \mathrm{C} \\ & C_{L}=50 \mathrm{pF} \end{aligned}$ | $\begin{aligned} \text { VCC } & =5.0 \mathrm{~V} \pm 10 \% \\ \text { TEMP } & =\text { IND OR MIL } \\ C L & =300 \mathrm{pF} \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | TYP | MAX | UNITS |
| tPD | Propagation Delay | 35 | 55 | ns |
| tEN | Enable Time | 50 | 65 | ns |
| tDIS | Disable Time | 50 | 55 | ns |
| tR | Output Rise Time | 30 | 55 | ns |
| t F | Output Fall Time | 25 | 55 | ns |

(1) All Devices guaranteed at worst case limits. Room temperature, 5V, CL $=50 \mathrm{pF}$ data provided for information only - not guaranteed.

## Switching Waveforms



All inputs have $t_{R}, t_{F} \leq 20 n s$.


OUTPUT TEST CIRCUIT FOR PROPAGATION DELAYS


OUTPUT TEST CIRCUIT
FOR THREE-STATE DELAYS

## DECOUPLING CAPACITORS

The instantaneous current required to switch a large capacitance load may cause a voltage spike on VCC, which if it becomes a diode drop less than any input, may cause the device to latch up. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between VCC and GND at each device to filter out this noise.

## PROPAGATION DELAYS



TYPICAL CURVES

## Features

- HIGH SPEED DECODING FOR MEMORY ARRAYS
- INCORPORATES 3 ENABLE INPUTS TO SIMPLIFY EXPANSION
- LOW POWER . . . . . . . . . . . . . . . TYPICALLY<50 $\mu$ W @ 5V STANBDY
- HIGH NOISE IMMUNITY
- AVAILABLE IN BOTH MILITARY AND INDUSTRIAL TEMPERATURE RANGE
- HIGH CAPACITANCE DRIVE . . . . . . . . . . . . . . . . . . . . . . . . 200pF
- HIGH OUTPUT DRIVE . . . . . . . . . . . . . . IOH $=-2 \mathrm{~mA}, \mathrm{I}_{\mathrm{OL}}=2.4 \mathrm{~mA}$
- SINGLE POWER SUPPLY


## Description

The HD-6440 is a self aligned silicon CMOS gate latched decoder. One of 8 output lines is decoded, and brought to a low state, from the 3 input lines. There are two latch enables ( $\overline{L_{1}}, L_{2}$ ), one complemented and one not, to eliminate the need for external gates. The output is enabled by three different output enables ( $\overline{G_{1}}, \overline{G_{2}}, G_{3}$ ), two of them complemented and one not. Each output remains in a high state until it is selected, at which time it will go low.

When using high speed CMOS memories, the delay time of the HD-6440 and the enable time of the memory is usually less than the access time of the memory. This assures that memory access time will not be lengthened by the use of the HD-6440 latched decoder driver. The latch is useful for memory mapping or for systems which use a multiplexed bus.

Outputs guaranteed valid at VCC 2.0V for Battery Backup Applications.

## Pinout



Truth Table

| InPuTS |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: |
| ENABLE |  | ADDRESS |  |  |
| $\overline{\mathbf{G}}_{1} \overline{\mathrm{G}}_{\mathbf{2}} \mathrm{G}_{\mathbf{3}}$ | $\bar{L}_{1} \mathrm{~L} 2$ | $A_{2} A_{1} A_{0}$ | $\mathrm{Y}_{0} \mathrm{Y}_{1} \mathrm{Y}_{2} \mathrm{Y}_{3} \mathrm{Y}_{4} \mathrm{Y}_{5} \mathrm{Y}_{6} \mathrm{Y}_{7}$ | FUNCTION |
| $\times \times$ L | $\mathrm{x} \times$ | $\times \times \times$ | HHHHHHHH |  |
| $\times \mathrm{H} \times$ | $\times \times$ | $\times \times \times$ | HHHHHHHH | DISABLE |
| $\mathrm{H} \times \mathrm{X}$ | $\times \mathrm{x}$ | $\times \times \times$ | HHHHHHHH |  |
| $L$ L $H$ | L H | L L L | LHHHHHHH |  |
| L L H | L H | L L H | HLHHHHHH |  |
| L L H | L H | L H L | HHLHHHHH |  |
| L L H | L H | L H H. | HHHLHHHH |  |
| L L H | L H | H L L | HHHHLHHH | decooe |
| L L H | L H | H L H | H H H H H L H H |  |
| L L H | L H | H H L | H H H H H L H |  |
| L L H | L H | HH | HHHHHHHL |  |
| L L H | $\times$ L | $\times \times \times$ | $\mathrm{Y}_{0} \mathrm{Y}_{1} \mathrm{Y}_{2} \mathrm{Y}_{3} \mathrm{Y}_{4} \mathrm{Y}_{5} \mathrm{Y}_{6} \mathrm{Y}_{7}$ |  |
| L L H | $\mathrm{H} \times$ | $\mathrm{X} \times \times$ | $\mathrm{Y}_{0} \mathrm{Y}_{1} \mathrm{Y}_{2} \mathrm{Y}_{3} \mathrm{Y}_{4} \mathrm{Y}_{5} \mathrm{Y}_{6} \mathrm{Y}_{7}$ | ATCHED |
| $L=\text { Low },$ |  |  | High, $\quad X=$ Don't Care |  |
| $Y_{n}=$ Data is latched to the value of the last input |  |  |  |  |

Functional Diagram


## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | $\mathrm{GND}-0.3 \mathrm{~V}$ to $\mathrm{VCC}+0.3$ |
| Storage Temperature Range | $-65{ }^{\circ} \mathrm{C}$ to $+150{ }^{\circ} \mathrm{C}$ |
| Operating Temperature Range |  |
| Industrial HD-6440-9 |  |
| Military HD-6440-2/8 | $-40{ }^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ |
| Operating Voltage Range | $-550^{\circ} \mathrm{C}$ to $+125{ }^{\circ} \mathrm{C}$ |
| +4 to +7 V |  |

## ELECTRICAL CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=$ Industrial or Military

| D.C. | SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | VIH | Logical "1" Input Voltage | 70\% Vcc |  | v |  |
|  | VIL | Logical "0" Input Voltage |  | 20\% VCC | v |  |
|  | IIL | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VIN} \leq \mathrm{VCC}$ |
|  | VOH | Logical " 1 " Output Voltage | Vcc-0.4 |  | $v$ | $1 \mathrm{OH}=-2.0 \mathrm{~mA}$ |
|  | VOL | Logical "0" Output Voltage |  | 0.4 | v | $1 \mathrm{OL}=2.4 \mathrm{~mA}$ |
|  | ICC | Supply Current |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
|  | CIN | Input Capacitance* |  | 5 | pF | $V I N=O V ; T_{A}=25^{\circ} \mathrm{C} ; \mathrm{f}=1 \mathrm{MHz}$ |
|  | Co | Output Capacitance* |  | 15 | pF | $V I N=O V ; T A=25{ }^{\circ} \mathrm{C} ; f=1 \mathrm{MHz}$ |

"Guaranteed and sampled, but not $100 \%$ tested.


NOTE:
(1) All devices guaranteed at worse case limits. Room temperature, 5V data provided for information not guaranteed.


All Inputs have $t_{R}, t_{F} \leq 20 \mathrm{~ns}$
OUTPUT TEST CIRCUIT FOR PROPAGATION DELAYS


## DECOUPLING CAPACITORS

The Transient current required to charge the load capacitance is given by $I_{T}=C \frac{d v}{d t}$. Assuming that all outputs may change state at the same time and that $\frac{d v}{d t}$ is constant; $I_{T}=\left(\Sigma C_{L}\right)\left(\frac{v_{C C} \times 80 \%}{t_{R} \text { or } t_{F}}\right)$ eg. $\left[t_{R}=60 \mathrm{~ns}, V_{C C}=5.0 \mathrm{~V}\right.$, each $\mathrm{C}_{\mathrm{L}}=200 \mathrm{pF}, \mathrm{I}_{\mathrm{T}}=(2)\left(200 \times 10^{-12}\right) \frac{5.0 \times 0.8}{60 \times 10^{-9}}=26.7 \mathrm{~mA}$. This current spike may cause a large negative voltage spike on $V_{\text {CC }}$, which if it becomes a diode drop less than any input, may cause the device to latch up. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between $\mathrm{V}_{\mathrm{C}}$ and GND at each device to filter out this noise.

## PROPAGATION DELAY





The above example will illustrate the calculation of a more useful propagation delay. The system on this example uses a 5 volt supply with a tolerance of $\pm 10 \%$, an ambient temperature of as high as $125^{\circ} \mathrm{C}$, and a calculated load capacitance of 150 pF . This application requires the HD-6440-2. The table of A.C. specs shows the tPD at 4.5 V and $125^{\circ} \mathrm{C}$ is 100 nsec . Use the graph in Figure 1 to get the degradation multiple for 150 pF . The number shown is 0.97 . The adjusted propagation delay, to the $10 \%$ or $90 \%$ point, is
therefore $100 \times 0.97$ or 97 nsec . To obtain the rise and fall times check the A.C. specs for the rise and fall times at 4.5 V and $125^{\circ} \mathrm{C}$ to obtain a worst case rise time of 90 nsec . Use Figure 2 to find it's degradation multiple to be 0.85 . The adjusted rise time is, therefore, $90 \times 0.85$ or 76.5 nsec. To obtain the standard $50 \%$ to $50 \%$ propagation delay, add the adjusted propagation delay to half of the adjusted rise time to get a propagation delay of 135 nsec . The rise time was used here because it is always the worst case.

## Battery Backup Applications

The HD-6440 is especially well suited for use in battery backup systems in conjunction with low power CMOS RAM arrays. When designing a RAM array in conjunction with the HD-6440, the following criteria should be met:

1. As RAM VCC drops, the inputs logical one voltages should follow so as not to exceed VCC +0.3 V and logical zero voltages do not go below GND -0.3V.
2. $\bar{G}_{1}$ or $\bar{G}_{2}$ must be held high at CMOS VCC, or $\mathrm{G}_{3}$ held low. $\mathrm{L}_{1}, \mathrm{~L}_{2}$ and address inputs should be held at either GND or CMOS VCC.
3. $\mathrm{Y}_{0}-\mathrm{Y}_{7}$ will maintain a VOH of $\mathrm{VCC}-0.3$ or greater at 1 OH of $100 \mu \mathrm{~A}$ provided the HD-6440 VCC is $\geq 2.0 \mathrm{~V}$.
4. When exiting from the battery backup mode, VCC should ramp without ring on discontinuities.
5. The HD-6440 can begin operation when VCC reaches the minimum operating voltage.
6. The HD-6440 should be disabled one tDIS before VCC reaches the minimum operating voltage.

TIMING DIAGRAM


## Features

- SINGLE POWER SUPPLY
- high noise immunity
- INDUSTRIAL AND MILITARY GRADES
- DRIVE CAPACITY 300pF
- SOURCE CURRENT 4mA
- sink current
- PROPAGATION DELAY


## Description

The HD-6495 is a self aligned silicon gate CMOS Three-State buffer driver. The circuit consists of 6 non-inverting buffers with separate inputs and outputs which permit this driver to be used for bi-directional or uni-directional busing. A high on either Three-State control line $\bar{E}_{1}$ or $\bar{E}_{2}$ will force the drivers to the high impedance mode.

Outputs guaranteed valid at VCC 2.0V for Battery Backup Applications.

Pinout


Truth Table

| CONTROL <br> INPUTS |  | INPUT | OUTPUT |
| :---: | :---: | :---: | :---: |
| $\bar{E}_{\mathbf{1}}$ | $\bar{E}_{\mathbf{2}}$ | A | $Y$ |
| L | L | L | L |
| L | L | $H$ | $H$ |
| L | $H$ | $X$ | $H I-Z$ |
| $H$ | L | $X$ | $H \mathrm{H}-Z$ |
| $H$ | $H$ | $X$ | $H I-Z$ |

X = DON'T CARE
HI-Z $=$ HIGH IMPEDANCE

## Functional Diagram



| Supply Voltage | +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| $\quad$ Industrial HD-6495-9 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| $\quad$ Military HD-6495-2/8 | +4 to +7 V |

## ELECTRICAL CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=$ Industrial or Military

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{1 \mathrm{H}}$ | Logical "1" Input Voltage | 70\% V CC |  | V |  |
| $V_{\text {IL }}$ | Logical " 0 " Input Voltage |  | 20\% V ${ }_{\text {CC }}$ | V |  |
| IIL | Input Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical "1" Output Voltage | $\mathrm{V}_{\text {CC }}-0.4$ |  | V | $\begin{aligned} & \mathrm{I} \mathrm{OH}=-4.0 \mathrm{~mA}, \\ & \mathrm{E}_{1}=\overline{\mathrm{E}}_{2}=\text { Low } \end{aligned}$ |
| $\mathrm{v}_{\mathrm{OL}}$ | Logical " 0 " Output Voltage |  | 0.4 | V | $\begin{aligned} & \mathrm{IOL}=6.0 \mathrm{~mA} \\ & \overline{\mathrm{E}}_{1}=\overline{\mathrm{E}}_{2}=\mathrm{Low} \end{aligned}$ |
| ${ }^{1} \mathrm{O}$ | Output Leakage | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{oV} \leq \mathrm{V}_{\mathrm{O}} \leq \mathrm{V}_{\mathrm{CC}} \\ & \overline{\mathrm{E}}_{1}=\overline{\mathrm{E}}_{2}=\mathrm{High} \end{aligned}$ |
| ${ }^{\prime} \mathrm{Cc}$ | Supply Current |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ |
| $C_{\text {IN }}$ | Input Capacitance* |  | 5 | pF | $\begin{aligned} & V_{I N}=O V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| $\mathrm{Co}_{0}$ | Output Capacitance* |  | 15 | pF | $\begin{aligned} & V_{I N}=O V ; T_{A}=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |

D.C.

* Guaranteed and sampled, but not $100 \%$ tested.
A.C.

$$
C_{L}=300 \mathrm{pF}
$$

|  |  | $\begin{gathered} \mathrm{V}_{\mathrm{Cc}}=5.0 \mathrm{~V} \\ 25^{\circ} \mathrm{C} \end{gathered}$ |  | $\begin{aligned} & \text { VCC }=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{TA}^{2}=\text { Indus. or Mil. } \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | UNITS |
| tPD <br> ten <br> tDIS <br> ${ }^{\mathrm{t}} \mathrm{R}$ <br> ${ }^{\prime}$ F | Propagation Delay <br> Enable Time <br> Disable Time <br> Output Rise Time <br> Output Fall Time |  | $\begin{aligned} & 35 \\ & 90 \\ & 90 \\ & 85 \\ & 65 \end{aligned}$ |  | $\begin{gathered} 45 \\ 100 \\ 100 \\ 95 \\ 75 \end{gathered}$ | ns <br> ns <br> ns <br> ns ns |

NOTE (1)
All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information-not guaranteed.


All inputs have $t_{R}, t_{F} \leq 20 n s$.


OUTPUT TEST CIRCUIT
FOR PROPAGATION DELAYS


OUTPUT TEST CIRCUIT FOR THREE-STATE DELAYS

## DECOUPLING CAPACITORS

The transient current required to charge the load capacitance is given by $I_{T}=C \frac{d v}{d t}$. Assuming that all outputs may change state at the same time and that $\frac{d v}{d t}$ is constant; $I_{T}=\left(\Sigma C_{L}\right)\left(\frac{V_{C C} \times 80 \%}{t_{R} \text { or } t F}\right)$ eg. $\left[t_{R}=85 n s, V_{C C}=5.0 \mathrm{~V}\right.$, each $C_{L}=300 \mathrm{pF}, I_{T}=(6)\left(300 \times 10^{-12}\right) \frac{5.0 \times 0.8}{85 \times 10^{-9}}=84.7 \mathrm{~mA}$.] This current spike may cause a large negative voltage
spike on $V_{C C}$, which if it becomes a diode drop less than any input, may cause the device to latch up. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic disk decoupling capacitor be placed between VCC and GND at each device to filter out this noise.

## PROPAGATION DELAYS





The above example will illustrate the calculation of a more useful propagation delay. The system on this example uses a 5 volt supply with a tolerance of $\pm 10 \%$, an ambient temperature of as high as 1250 C , and a calculated load capacitance of 150 pF . This application requires the HD-6495-2. The table of A.C. specs shows the tPD at 4.5 V and $125^{\circ} \mathrm{C}$ is 45 nsec. Use the graph in Figure 1 to get the degradation multiple for 150 pF . The number shown is 0.84 . The adjusted propagation delay, to the $10 \%$ or $90 \%$ point, is
therefore $45 \times 0.84$ or 38 nsec. To obtain the rise and fall times check the A.C. specs for the rise and fall times at 4.5 V and $125^{\circ} \mathrm{C}$ to obtain a worst case rise time of 95 nsec . Use Figure 2 to find it's degradation multiple to be 0.65 . The adjusted rise time is, therefore, $95 \times 0.65$ or 62 nsec . To obtain the standard $50 \%$ to $50 \%$ propagation delay, add the adjusted propagation delay to half of the adjusted rise time to get a propagation delay of 69 nsec . The rise time was used here because it is always the worst case.

## CMOS OCTAL LATCHING

Advance Information

## Fastures

- FULL EIGHT BIT PARALLEL LATCHING BUFFER
- BIPOLAR 8282 COMPATIBLE
- THREE STATE NON-INVERTING OUTPUTS
- PROPAGATION DELAY - 35nsec MAX.
- A.C. CHARACTERISTICS GUARANTEED FOR:
- FULL TEMPERATURE RANGE
- 10\% POWER SUPPLY TOLERANCE
- $C L=300 \mathrm{pF}$
- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT - 10 $\mu$ A MAX. STANDBY
- OUTPUTS GUARANTEED VALID AT VCC $=2.0$ VOLTS
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES
- 20 PIN PACKAGE ON 0.3' CENTERS


## Description

The Harris 82 C 82 is an octal latching buffer manufactured using a selfaligned silicon gate CMOS process. This circuit provides an eight bit parallel latch/buffer in a 20 pin package. The active high strobe (STB) input allows transparent transfer of data and latches data on the negative transition of this signal. The active low output enable ( $\overline{O E}$ ) permits simple interface to state-of-the-art microprocessor systems.

Functional Diagram


PIN NAMES
DIo-DI7 Data Input Pins DOO-DO7 Data Output Pins

STB Active High Strobe Input Active Low Output Enable

Truth Table

| STB | $\overline{O E}$ | $D I$ | $D O$ |
| :---: | :---: | :---: | :---: |
| $X$ | $H$ | $X$ | $H i-Z$ |
| $H$ | $L$ | $L$ | $L$ |
| $H$ | $L$ | $H$ | $H$ |
| $\dagger$ | $L$ | $X$ | $*$ |

$H=$ Logic One
$x=$ Don't Care $\quad$ " Latched to value of last data

CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

## Preview

The Harris 82 C 83 is an octal latching buffer manufactured using a selfaligned silicon gate CMOS process. This circuit provides an eight bit parallel latch/buffer in a 20 pin package. The active high strobe (STB) parallel latch/buffer in a 20 pin package. The active high strobe (STB)
input allows transparent transfer of data and latches data on the negative transition of this signal. The active low output enable ( $\overline{\mathrm{OE}})$ permits simple
interface to state-of-the-art microprocessor systems. The 82 C 83 provides transition of this signal. The active low output enable ( $\overline{O E}$ ) permits simple
interface to state-of-the-art microprocessor systems. The 82 C 83 provides inverted data at the outputs.

- 20 PIN PACKAGE ON $0.3^{\prime \prime}$ CENTERS


## Description

- full eight bit parallel latching inverting buffer
- bIPOLAR 8283 COMPATIBLE
- three state non-inverting outputs
- PROPAGATION DELAY - 35 nsec MAX.
- A.C. CHARACTERISTICS GUARANTEED FOR:
- FULL TEMPERATURE RANGE
- 10\% POWER SUPPLY TOLERANCE

$$
C_{L}=300 \mathrm{pF}
$$

- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT - $10 \mu$ A MAX. STANDBY
- OUTPUTS GUARANTEED VALID AT VCC $=2.0$ VOLTS
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES



## Functional Diagram



Truth Table

| STB | $\overline{O E}$ | $D I$ | $\overline{D O}$ |
| :---: | :---: | :---: | :---: |
| $X$ | $H$ | $X$ | $H_{i-Z}$ |
| $H$ | $L$ | $L$ | $H$ |
| $H$ | $L$ | $H$ | $L$ |
| $H$ | $L$ | $X$ | $*$ |


| $H$ | $=$ Logic One | $H i-Z$ | $=$ High Impedance |
| ---: | :--- | ---: | :--- |
| $L$ | $=$ Logic Zero | $t$ | $=$ Negative Transition |
| $X$ | $=$ Don't Care | $*$ | $=$ Latched to value of last data |

## Features

- FULL EIGHT BIT BIDIRECTIONAL BUS INTERFACE
- INDUSTRY STANDARD 8286 COMPATIBLE PINOUT
- THREE STATE NON-INVERTING OUTPUTS
- PROPAGATION DELAY
- A.C. CHARACTERISTICS guaranteed at rated $C_{L}$ - A SIDE - $C_{L}=100 \mathrm{pF}$
- B SIDE $-C_{L}=300 \mathrm{pF}$
- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT
- 20 PIN PLASTIC OR CERAMIC PACKAGE
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES AVAILABLE


## Description

The Harris $82 \mathrm{C86}$ is an octal bus transceiver manufactured using a self-aligned silicon gate CMOS process (Scaled SAJIIV). This circuit provides a full eight bit bidirectional bus interface in a 20 pin package. The Transmit ( T ) control determines the data direction. The active low output enable ( $\overline{\mathrm{OE})}$ allows simple interface to the 80C86 and other microprocessors. The outputs of the 82C86 are noninverting.

Pinout
TOP VIEW


PIN NAMES

| $A_{0}-A_{7}$ | LOCAL BUS DATA I/O PINS |
| :--- | :--- |
| $B_{0}-B_{7}$ | SYSTEM BUS DATA I/O PINS |
| $T$ | TRANSMIT CONTROL INPUT |
| $O E$ | ACTIVE LOW OUTPUT ENABLE |

## Functional Diagram



| TRUTH TABLE |  |  |  |
| :---: | :---: | :---: | :---: |
| T | $\overline{O E}$ | A | B |
| X | H | Hi-2 | $\mathrm{Hi}-\mathrm{Z}$ |
| H | L | 1 | 0 |
| L | L | 0 | 1 |
| $\begin{aligned} & \mathrm{H}=\text { logical one } \\ & \mathrm{L}=\text { logical zero } \\ & 1=\text { = input mode } \\ & 0=\text { output mode } \\ & X=\text { don't care } \\ & \text { Hi-Z }=\text { high impedance } \\ & \hline \end{aligned}$ |  |  |  |
|  |  |  |  |
|  |  |  |  |
|  |  |  |  |
|  |  |  |  |
|  |  |  |  |

CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

## CMOS OCTAL INVERTING BUS TRANSCEIVER

## Features

- FULL EIGHT BIT BIDIRECTIONAL BUS INTERFACE
- INDUSTRY STANDARD 8287 COMPATIBLE PINOUT
- THREE STATE INVERTING OUTPUTS
- PROPAGATION DELAY


## Preview

- a.C. CHARACTERISTICS guaranteed at rated $C_{L}$
- A SIDE - $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$
- B SIDE - $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$
- SINGLE 5V POWER SUPPLY
- POWER SUPPLY CURRENT
$10 \mu \mathrm{~A}$ MAX Standby
- 20 PIN PLASTIC OR CERAMIC PACKAGE
- COMMERCIAL, INDUSTRIAL AND MILITARY TEMPERATURE RANGES AVAILABLE


## Description

The Harris 82 C 87 is an octal bus transceiver manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV). This circuit provides a full eight bit bidirectional bus interface in a 20 pin package. The Transmit ( T ) control determines the data direction. The active low output enable ( $\overline{\mathrm{OE}}$ ) allows simple interface to state of the art microprocessors. Data at the outputs of the 82C87 are inverted.


PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{7}$ | LOCAL BUS DATA I/O PINS |
| :--- | :--- |
| $\overline{\mathrm{B}}_{0}-\overline{\mathrm{B}}_{7}$ | SYSTEM BUS DATA I/O PINS |
| T | TRANSMIT CONTROL INPUT |
| OE | ACTIVE LOW OUTPUT ENABLE |

Functional Diagram


TRUTH TABLE

| $T$ | $\overline{O E}$ | $A$ | $\bar{B}$ |
| :--- | :---: | :---: | :---: |
| $X$ | $H$ | $H i-Z$ | $H i-Z$ |
| $H$ | $L$ | $I$ | 0 |
| $L$ | $L$ | 0 | 1 |
| $H=$ logical one |  |  |  |
| $L=$ logical zero |  |  |  |
| $I=$ input mode |  |  |  |
| $O=$ output mode |  |  |  |
| $X=$ don't care |  |  |  |
| $H i-Z=$ high impedance |  |  |  |

CAUTION: Electronic devices are sensitive to electrostatic discharge: Proper I.C. handling procedures should be followed.

Data
Communications
Product Index ..... 5-2
Product Information ..... 5-3

## CMOS Data Communication Product Index

Page
CMOS DATA COMMUNICATION DATA SHEETS
HD-15530 Manchester Encoder-Decoder ..... 5-3
HD-15531 Manchester Encoder-Decoder ..... 5-10
HD-15531B Programmable Manchester Encoder-Decoder ..... 5-18
HD-6408 Asynchronous Serial Manchester Adapter ..... 5-25
HD-6409 Manchester Encoder-Decoder ..... 5-30
HD-6406 Programmable Asynchronous ..... 5-39
Communication Interface
82C52 Serial Controller Interface ..... 5-50
HD-6402 LSI Universal Asynchronous Receiver Transmitter ..... 5-51
HD-4702 Programmable Bit Rate Generator ..... 5-56

## CMOS Manchester Encoder-Decoder

## Features

- SUPPORT OF MIL-STD-1553
- $\mathbf{1 . 2 5}$ MEGABIT/SEC DATA RATE
- SYNC IDENTIFICATION AND LOCK-IN
- CLOCK RECOVERY
- MANCHESTER II ENCODE, DECODE
- SEPARATE ENCODE AND DECODE
- LOW OPERATING POWER: 50mW AT 5 VOLTS
- FULL MILITARY TEMPERATURE RANGE


## Pinout

VALID WORD
ENCODER SHIFT CLOCK
TAKE DATA

## Description

The Harris HD-15530 is a high performance CMOS device intended to service the requirements of MIL-STD-1553 and similar Manchester II encoded, time division multiplexed serial data protocals. This LSI chip is divided into two sections, an Encoder and a Decoder. These sections operate completely independent of each other, except for the Master Reset function.

This circuit meets many of the requirements of MIL-STD-1553. The Encoder produces the sync pulse and the parity bit as well as the encoding of the data bits. The Decoder recognizes the sync pulse and identifies it as well as decoding the data bits and checking parity.

This integrated circuit is fully guaranteed to support the 1 MHz data rate of MIL-STD-1553 over both temperature and voltage. It interfaces with CMOS, TTL or N channel support circuitry, and uses a standard 5 volt supply.

The HD-15530 can also be used in many party line digital data communications applications, such as an environmental control system driven from a single twisted pair cable or fiber optic cable throughout the building.

Block Diagrams

## ENCODER



## DECODER



CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

| Supply Voltage <br> Input or Output Voltage Applied <br> Storage Temperature Range <br> Operating Temperature Range <br> Industrial HD-15530-9 | GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| :--- | ---: |
| Military HD-15530-2/8 | -650 C to +1500 |
|  | -400 C to +850 C |
|  | -550 C to +1250 C |

ELECTRICAL CHARACTERISTICS $\quad \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \mathrm{~T}_{\mathrm{A}}=$ Industrial or Military

| SYMBOL | PARAMETER | MINIMUM | TYPICAL | MAXIMUM | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical " 1 " Input Voltage | 70\% Vcc |  |  | V |  |
| VIL | Logical "0" Input Voltage |  |  | 20\% VCC | V |  |
| VIHC | Logical "1" Input Voltage (Clock) | VCC -0.5 |  |  | V |  |
| VILC | Logical ' 0 ' Input Voltage (Clock) |  |  | GND +0.5 | $V$ |  |
| IIL | Input Leakage | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $O \mathrm{~V} \leqslant \mathrm{VIN} \leqslant \mathrm{VCC}$ |
| VOH | Logical " 1 " Output Voltage | 2.4 |  |  | V | $1 \mathrm{OH}=-3 \mathrm{~mA}$ |
| VOL | Logical " 0 "' Output Voltage |  |  | 0.4 | V | $1 \mathrm{OL}=1.8 \mathrm{~mA}$ |
| ICCSB | Supply Current Standby |  | 0.5 | 2 | mA | $V I N=V C C=5.5 V$ |
| ICCOP | Supply Current Operating* |  | 8.0 | 10.0 | mA | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| CIN | Input Capacitance* Output Capacitance* |  | 5.0 8.0 | $\begin{gathered} 7.0 \\ 10.0 \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ |  |
|  | *Guaranteed and sampled but not 100\% tested. |  |  |  |  |  |

ENCODER TIMING $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \mathrm{~T}_{\mathrm{A}}=$ Industrial or Military


DECODER TIMING $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \mathrm{~T}_{\mathrm{A}}=$ Industrial or Military

| FDC | Decoder Clock Frequency | 0 |  | 15 | MHz | $C L=50 \mathrm{pF}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TDCR | Decoder Clock Rise Time |  |  | 8 | ns |  |
| TDCF | Decoder Clock Fall Time |  |  | 8 | ns |  |
| FDD | Data Rate | 0 |  | 1.25 | MHz |  |
| TDR | Decoder Reset Pulse Width | 150 |  |  | ns |  |
| TDRS | Decoder Reset Setup Time | 75 |  |  | ns |  |
| TMR | Master Reset Pulse Width | 150 |  |  | ns |  |
| TD1 | Bipolar Data Pulse Width | TDC +10 |  |  | ns |  |
| TD2 | Sync Transition Span |  | 18TDC |  | ns |  |
| TD3 | One Zero Overlap |  |  | TDC -10 | ns |  |
| TD4 | Short Data Transition Span |  | 6TDC |  | ns |  |
| TD5 | Long Data Transition Span |  | 12TDC |  | ns |  |
| TD6 | Sync Delay (ON) | -20 |  | 110 | ns |  |
| TD7 | Take Data Delay (ON) | 0 |  | 110 | ns |  |
| TD8 | Serial Data Out Delay |  |  | 80 | ns |  |
| TD9 | Sync Delay (OFF) |  |  |  | ns |  |
| TD10 | Take Data Delay (OFF) | 0 |  | 110 | ns |  |
| TD11 | Valid Word Delay | 0 |  | 110 | ns | $\downarrow$ |

## Pin Assignments

| PIN | SECTION | NAME | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | Decoder | VALID WORD | Output high indicates receipt of a valid word. |
| 2 | Encoder | ENCODER SHIFT CLOCK | Output for shifting data into the Encoder. This clock shifts data on a low-to-high transition. |
| 3 | Decoder | TAKE DATA | Output is high during receipt of data after identification fo a sync pulse. |
| 4 | Decoder | SERIAL DATA OUT | Delivers received data in correct NRZ format. |
| 5 | Decoder | DECODER CLOCK | Input drives the transition finder, and the synchronizer which in turn supplies the clock to the balance of the Decoder. |
| 6 | Decoder | BIPOLAR ZERO IN | A high input should be applied when the bus is in its negative state. This pin must be held high when the Unipolar input is used. |
| 7 | Decoder | BIPOLAR ONE IN | A high input should be applied when the bus is in its positive state, this pin must be held low when the Unipolar input is used. |
| 8 | Decoder | UNIPOLAR DATA IN | With pin 6 high and pin 7 low, this pin enters unipolar data into the transition finder circuit. If not used this input must be held low. |
| 9 | Decoder | DECODER SHIFT CLOCK | Output which delivers a frequency (Decoder Clock $\div 12$ ), synchronized by the recovered serial data stream. |
| 10 | Decoder | COMMAND SYNC | Output of a high from this pin occurs during output of decoded data which was preceded by a Command (or Status) synchronizing character. A low output indicates a Data synchronizing character. |
| 11 | Decoder | DECODER RESET | A high input to this pin during a rising edge of DECODER SHIFT CLOCK resets the decoder bit counting logic to a condition ready for a new word. |
| 12 | Both | GROUND | Ground supply pin. |
| 13 | Both | MASTER RESET | A high on this pin clears 2:1 counters in both the Encoder and Decoder. |
| 14 | Encoder | $\div 6$ OUT | Output from 6:1 divider which is driven by the ENCODER CLOCK. |
| 15 | Encoder | BIPOLAR ZERO OUT | An active low output designed to drive the zero or negative sense of a bipolar line driver. |
| 16 | Encoder | OUTPUT INHIBIT | A low on this input forces pin 15 and pin 17 high, the inactive states. |
| 17 | Encoder | $\overline{\text { BIPOLAR }} \overline{\text { ONE }} \overline{O U T}$ | An active low output designed to drive the one or positive sense of a bipolar line driver. |
| 18 | Encoder | SERIAL DATA IN | Accepts a serial data stream at a data rate equal to ENCODER SHIFT CLOCK. |
| 19 | Encoder | ENCODER ENABLE | A high on this input initiates the encode cycle. (Subject to the preceding cycle being complete.) |
| 20 | Encoder | SYNC SELECT | Actuates command sync for an input high and data sync for an input low. |
| 21 | Encoder | SEND DATA | Is an active high output which enables the external source of serial data. |
| 22 | Encoder | SEND CLOCK IN | Clock input at a frequency equal to the data rate $\times 2$. |
| 23 | Encoder | ENCODER CLOCK | Input to the 6:1 divider. |
| 24 | Both | VCC | Positive supply pin. |

The Encoder requires a single clock with a frequency of twice the desired data rate applied at the SEND CLOCK input. An auxillary divide by six counter is provided on chip which can be utilized to produce the SEND CLOCK by dividing the DECODER CLOCK.

The Encoder's cycle begins when ENCODER ENABLE is high during a falling edge of ENCODER SHIFT CLOCK (1). This cycle lasts for one word length or twenty ENCODER SHIFT CLOCK periods. At the next low-to-high transition of the ENCODER SHIFT CLOCK, a high at SYNC SELECT input actuates a command sync or a low will produce a data sync for that word (2). When the Encoder is ready to accept data, the SEND D.ATA output will go high and remain high for sixteen ENCODER SHIFT CLOCK periods (3). During these sixteen periods the data should be
clocked into the SERIAL DATA input with every low-to-high transition of the ENCODER SHIFT CLOCK (3) (4). After the sync and the Manchester II coded data are transmitted through the BIPOLAR $\overline{O N E}$ and BIPOLAR $\overline{Z E R O}$ outputs, the Encoder adds on an additional bit which is the parity for that word (5). At any time a low on OUTPUT INHIBIT input will force both bipolar outputs to a high state but will not affect the Encoder in any other way.

To abort the Encoder transmission a positive pulse must be applied at MASTER RESET. Anytime after or during this pulse, a low to high transition on SEND CLOCK clears the internal counters and initializes the Encoder for a new word.


## Decoder Operation

The Decoder requires a single clock with a frequency of 12 times the desired data rate applied at the DECODER CLOCK input. The Manchester II coded data can be presented to the Decoder in one of two ways. The BIPOLAR ONE and BIPOLAR ZERO inputs will accept data from a comparator sensed transformer coupled bus as specified in Military Spec 1553. The UNIPOLAR DATA input can only accept non-inverted Manchester II coded data. (e.g. from BIPOLAR ZERO OUT of an Encoder.)

The Decoder is free running and continuously monitors its data input lines for a valid sync character and two valid Manchester data bits to start an output cycle. When a valid sync is recognized (1), the type of sync is indicated on COMMAND/ $\overline{D A T A}$ SYNC output. If the sync character was a command sync, this output will go high (2) and remain high for sixteen DECODER SHIFT CLOCK periods (3), otherwise it will remain low. The TAKE DATA output will go high and remain high (2) - (3) while the

Decoder is transmitting the decoded data through SERIAL DATA OUT. The decoded data available at SERIAL DATA OUT is in a NRZ format. The DECODER SHIFT CLOCK is provided so that the decoded bits can get shifted into an external register on every low-to-high transition of this clock (2) - (3).

After all sixteen decoded bits have been transmitted (3) the data is checked for odd parity. A high on VALID WORD output (4) indicates a successful reception of a word without any Manchester or parity errors. At this time the Decoder is looking for a new sync character to start another output sequence.

At any time in the above sequence a high input on DECODER RESET during a low-to-high transition of DECODER SHIFT CLOCK will abort transmission and initialize the Decoder to start looking for a new sync character.


Encoder Timing


Decoder Timing



## Applications

How to Make Our MTU Look Like a Manchester Encoded UART


Typical Timing Diagrams for a Manchester Encoded UART
ENCODER TIMING


The 1553 standard defines a time division multiplexed data bus for application within aircraft. The bus is defined to be bipolar, and encoded in a Manchester II format, so no DC component appears on the bus. This allows transformer coupling and excellent isolation among systems and their environment.

The HD-15530 supports the full bipolar configuration, assuming a bus driver configuration similar to that in Figure 1. Bipolar inputs from the bus, like Figure 2, are also accommodated.

The signaling format in MIL-STD-1553 is specified on the assumption that the network of 32 or fewer terminals are controlled by a central control unit by means of Command Words. Terminals respond with Status Words. These control words reference Data Words. Each word is preceded by a synchronizing pulse, and followed by parity bit, occupying a total of $20 \mu \mathrm{sec}$. The word formats are shown in Figure 4. The special abbreviations are as follows:

P Parity, which is defined to be odd, taken across all 17 bits.

R/T Receive on logical zero, transmit on ONE.
ME Message Error if logical 1.
TF Terminal Flag, if set, calls for controller to request self-test data.

The paragraphs above are intended only to suggest the content of MIL-STD-1553 and do not completely describe its bus requirements, timing or protocols.


FIGURE 3 - MIL-STD-1553 Character Formats

\section*{| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |}

COMMAND WORD (FROM CONTROLLER TO TERMINAL)

|  | 5 | 1 | 5 | 5 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: |

DATA WORD (SENT EITHER DIRECTION)


STATUS WORD (FROM TERMINAL TO CONTROLLER)



FIGURE 2 - Simplified MIL-STD-1553 Receiver

## Features

- SUPPORT OF MIL-STD-1553
- 1.25 MEGABIT/SEC DATA RATE
- SYNC IDENTIFICATION AND LOCK-IN
- CLOCK RECOVERY
- VARIABLE FRAME LENGTH TO 32 BITS
- MANCHESTER II ENCODE, DECODE
- SEPARATE ENCODE AND DECODE
- LOW OPERATING POWER: 50 mW @ 5 VOLTS
- FULL MILITARY TEMPERATURE RANGE

Pinout

| Vcc 1 | 40 | b count C1 |
| :---: | :---: | :---: |
| VALID WORD 2 | 39 | $1]$ COUNT C4 |
| TAKE DATA' 3 | 38 | data sync |
| take data 4 | 37 | fencoder clock |
| SERIAL DATA OUT 5 | 36 | count C3 |
| SYNCHRONOUS DATA 6 | 35 | ] N.C. |
| SYNCHRONOUS DATA SEL. 7 | 34 | ]encoder shift clock |
| SYNCHRONOUS CLOCK [8 | 33 | Send clock in |
| decoder clock 9 | 32 | $\square$ SEND DATA |
| SYNCHRONOUS CLOCK SEL. 10 | 31 | I Encoder parity sel. |
| BIPOLAR ZERO IN 11 | 30 | g sync select |
| BIPOLAR ONE IN 12 | 29 | gencoder enable |
| UNIPOLAR DATA IN 13 | 28 | SERIAL DATA IN |
| decoder Shift clock 14 | 27 | BIPOLAR ONE OUT |
| TRANSITION SEL. 15 | 26 | OUTPUT INHIBIT |
| N.C. 16 | 25 | $\square \overline{\text { BIPOLAR }}$ ZERO OUT |
| COMMAND SYNC 17 | 24 | ] $\div 6$ OUT |
| DECODER PARITY SEL. 18 | 23 | ]count C2 |
| DECODER RESET 19 | 22 | ]master Reset |
| COUNT CO 20 | 21 | JGND |

## Description

The Harris HD-15531 is a high performance CMOS device intended to service the requirements of MIL-STD-1553 and similar Manchester II encoded, time division multiplexed serial data protocals. This LSI chip is divided into two sections, an Encoder and a Decoder. These sections operate independently of each other, except for the Master Reset and frame length functions.

This circuit provides many of the requirements of MIL-STD-1553. The Encoder produces the sync pulse and the parity bit as well as the encoding of the data bits. The Decoder recognizes the sync pulse and identifies it as well as decoding the data bits and checking parity.

The HD-15531 also surpasses the requirements of

MIL-STD-1553 by allowing the frame length to be programmable. The frame length may be programmed from 2 to 28 data bits plus sync and parity. This chip also allows selection of either even or odd parity for the Encoder and Decoder separately.

This integrated circuit is fully guaranteed to support the 1 MHz data rate of MIL-STD-1553 over both temperature and voltage. It interfaces with CMOS, TTL or N channel support circuitry, and uses a standard 5 volt supply.

The HD-15531 can also be used in many party line digital data communications applications, such as an environmental control system driven from a single twisted pair of fiber optic cable throughout a building.

## Block Diagrams

ENCODER


DECODER


CAUTION: These devices are sensitive to electrostatic discharge. Users should follow standard I.C. Handling Procedures.

The 1553 standard defines a time division multiplexed data bus for application within aircraft. The bus is defined to be bipolar, and encoded in a Manchester II format, so no DC component appears on the bus. This allows transformer coupling and excellent isolation among systems and their environment.

The HD-15531 supports the full bipolar configuration, assuming a bus driver configuration similar to that in Figure 1. Bipolar inputs from the bus, like Figure 2, are also accommodated.

The signaling format in MIL-STD-1553 is specified on the assumption that the network of 32 or fewer terminals are controlled by a central control unit by means of Command Words, and Data. Terminals respond with Status Words, and Data. Each word is preceded by a synchronizing pulse, and followed by parity bit, occupying a total of $20 \mu \mathrm{sec}$. The word formats are shown in Figure 4. The special abbreviations are as follows:

P Parity, which is defined to be odd, taken across all 17 bits.

R/T Receive on logical zero, transmit on ONE.
ME Message Error if logical 1.
TF Terminal Flag, if set, calls for controller to request self-test data.

The paragraphs above are intended only to suggest the content of MIL-STD-1553, and do not completely describe its bus requirements, timing or protocols.


FIGURE 1 - Simplified MIL-STD-1553 Driver


FIGURE 2 - Simplified MIL-STD-1553 Receiver


FIGURE 3 - MIL-STD-1553 Character Formats

\section*{| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |}

COMMAND WORD (FROM CONTROLLER TO TERMINAL)

dATA WORD (SENT EITHER DIRECTION)


STATUS WORD (FROM TERMINAL TO CONTROLLER)


FIGURE 4 - MIL-STD-1553 Word Formats

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +7.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | $-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range |  |
| Industrial HD-15531-9 |  |
| Military HD-15531-2/8 | $-40{ }^{\circ} \mathrm{C}$ to $+855^{\circ} \mathrm{C}$ |
|  | $-550^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

ELECTRICAL CHARACTERISTICS $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \mathrm{~T}_{\mathrm{A}}=$ Industrial or Military

|  | SYMBOL | PARAMETER | MINIMUM | TYPICAL | MAXIMUM | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. | VIH | Logical "1" Input Voltage | 70\% VCC |  |  | V |  |
|  | VIL | Logical "0" Input Voltage |  |  | 20\% Vcc | $v$ |  |
|  | VILC | Logical " 1 " Input Voltage (Clock) | Vcc -0.5 |  |  | $v$ |  |
|  | VILC | Logical "0" Input Voltage (Clock) |  |  | GND +0.5 | $v$ |  |
|  | IIL | Input Leakage | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{VIN} \leqslant \mathrm{VCC}$ |
|  | VOH | Logical "1" Output Voltage | 2.4 |  |  | v | $1 \mathrm{OH}=-3 \mathrm{~mA}$ |
|  | VOL | Logical "0" Output Voltage |  |  | 0.4 | V | $\mathrm{IOL}=1.8 \mathrm{~mA}$ |
|  | ICCSB | Supply Current Standby |  | 0.5 | 2.0 | mA | $V I N=V C C=5.5 \mathrm{~V}$ Outputs Open |
|  | ICCOP | Supply Current Operating* |  | 8.0 | 10.0 | mA | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & f=15 \mathrm{MHz} \end{aligned}$ |
|  | $\begin{aligned} & \text { CIN } \\ & \text { CO } \end{aligned}$ | Input Capacitance* Output Capacitance* |  | $\begin{aligned} & 5.0 \\ & 8.0 \end{aligned}$ | $\begin{gathered} 7.0 \\ 10.0 \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ |  |
| A.C. | *Guaranteed and sampled but not $100 \%$ tested. |  |  |  |  |  |  |
|  | ENCODER TIMING |  |  |  |  |  |  |
|  | FEC | Encoder Clock Frequency | 0 |  | 15 | MHz | $\mathrm{CL}=50 \mathrm{pF}$ |
|  | FESC | Send Clock Frequency | 0 |  | 2.5 | MHz |  |
|  | TECR | Encoder Clock Rise Time |  |  | 8 | ns |  |
|  | FED | Data Rate | 0 |  | 1.25 | MHz |  |
|  | TMR | Master Reset Pulse Width | 150 |  |  | ns |  |
|  | TE1 | Shift Clock Delay |  |  | 125 | ns |  |
|  | TE2 | Serial Data Setup | 75 |  |  | ns |  |
|  | TE4 | Serial Data Hold Enable Setup | 75 90 |  |  | ns |  |
|  | TE5 | Enable Pulse Width | 100 |  |  | ns |  |
|  | TE6 | Sync Sotup | 55 |  |  | ns |  |
|  | TE7 | Sync Pulse Width | 150 0 |  |  | ns |  |
|  | TE9 | Bipolar Output Delay |  |  | $\begin{gathered} 50 \\ 130 \end{gathered}$ | ns | 1 |
|  | DECODER TIMING |  |  |  |  |  |  |
| A.C. | FDC | Decoder Clock Frequency | 0 |  | 15 | MHz | $\mathrm{CL}=50 \mathrm{pF}$ |
|  | FDS | Decoder Synchronous Clock | 0 |  | 2.5 | MHz |  |
|  | TDCR | Decoder Clock Rise Time |  |  | 8 | ns |  |
|  | TDCF | Decoder Clock Fall Time |  |  | 8 | ns |  |
|  | FDD | Data Rate | 0 |  | 1.25 | MHz |  |
|  | TDR | Decoder Reset Pulse Width | 150 |  |  | ns |  |
|  | TDRS | Decoder Reset Setup Time | $\begin{gathered} 75 \\ 150 \end{gathered}$ |  |  | ns |  |
|  | TMR | Master Reset Pulse Width Bipolar Data Pulse Width | $\begin{gathered} 150 \\ T D C+10 \end{gathered}$ |  |  | ns |  |
|  | TD2 | Sync Transition Span |  | 18TDC |  | ns | 1 |
|  | TD3 | One Zero Overlap |  |  | TDC -10 | ns | 1 |
|  | TD4 | Short Data Transition Span |  | 6TDC |  | ns |  |
|  | TD5 | Long Data Transition Span |  | 12TDC |  | ns | (1) |
|  | TD6 | Sync Delay (ON) | -20 |  | 110 | ns |  |
|  | TD7 | Take Data Delay (ON) | 0 |  | 110 | ns |  |
|  | TD8 | Serial Data Out Delay Sync Delay (OFF) | 0 |  | 110 | ns |  |
|  | TD10 | Take Data Delay (OFF) | 0 |  | 110 | ns |  |
|  | TD11 | Valid Word Delay | 0 |  | 110 | ns |  |
|  | $\begin{aligned} & \text { TD12 } \\ & \text { TD13 } \end{aligned}$ | Synchronous Clock To Shift Clock Delay Synchronous Data Setup | 75 |  | 75 | ns | , |
|  | NOTE (1) : TDC $=$ Decoder Clock Period $=\frac{1}{F_{D C}}$ <br> These parameters are guaranteed but not $100 \%$ tested. |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |

## Pin Assignments

| PIN | SECTION | NAME | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | Both | VCC | Positive supply pin. |
| 2 | Decoder | VALID WORD | Output high indicates receipt of a valid word. |
| 3 | Decoder | TAKE DATA' | A continuous, free running signal provided for host timing or data handling. When data is present on the bus, this signal will be synchronized to the incoming data and will be identical to take data. |
| 4 | Decoder | TAKE DATA | Output is high during receipt of data after identification of a sync pulse |
| 5 | Decoder | SERIAL DATA OUT | Delivers received data in correct NRZ format. |
| 6 | Decoder | SYNCHRONOUS DATA | Input presents Manchester data directly to character identification logic. SYNCHRONOUS DATA SELECT must be held high to use this input. If not used this pin should be held high. |
| 7 | Decoder | SYNCHRONOUS DATA SELECT | In high state allows the synchronous data to enter the character identification logic. |
| 8 | Decoder | SYNCHRONOUS CLOCK | Input provides externally synchronized clock to the decoder. This input should be tied high when not in use. |
| 9 | Decoder | DECODER CLOCK | Input drives the transition finder, and the synchronizer which in turn supplies the clock to the balance of the decoder. |
| 10 | Decoder | SYNCHRONOUS CLOCK SELECT | In high state directs the SYNCHRONOUS CLOCK to control the decoder character identification logic. A low state selects the DECODER CLOCK |
| 11 | Decoder | BIPOLAR ZERO IN | A high input should be applied when the bus is in its negative state. This pin must be held high when the unipolar input is used. |
| 12 | Decoder | BIPOLAR ONE IN | A high input should be applied when the bus is in its positive state. This pin must be held low when the unipolar input is used. |
| 13 | Decoder | UNIPOLAR DATA IN | With pin 11 high and pin 12 low, this pin enters unipolar data into the transition finder circuit. If not used this input must be held low. |
| 14 | Decoder | DECODER SHIFT CLOCK | Output which delivers a frequency (DECODER CLOCK $\div 12$ ), synchronized by the recovered serial data stream. |
| 15 | Decoder | TRANSITION SELECT | A high input to this pin causes the transition finder to synchronize on every transition of input data. A low input causes the transition finder to synchronize only on mid-bit transitions. |
| 16 | Blank | N.C. | Not connected. |
| 17 | Decoder | COMMAND SYNC | Output of a high from this pin occurs during output of decoded data which was preceded by a Command (or Status) synchronizing character |
| 18 | Decoder | DECODER PARITY SELECT | An input for parity sense, calling for even parity with input high and odd parity with input low. |
| 19 | Decoder | DECODER RESET | A high input to this pin during a rising edge of DECODER SHIFT CLOCK resets the decoder bit counting logic to a condition ready for a new word. |
| 20 | Both | COUNT CO | One of five binary inputs which establish the total bit count to be encoded or decoded. |
| 21 | Both | GROUND | Supply pin. |
| 22 | Both | MASTER RESET | A high on this pin clears 2:1 counters in both the encoder and decoder. |
| 23 | Both | COUNT C2 | See pin 20. |
| 24 | Encoder | $\div 6$ OUT | Output from 6:1 divider which is driven by the ENCODER CLOCK. |
| 25 | Encoder | $\overline{\text { BIPOLAR }} \overline{\text { ZERO OUT }}$ | An active low output designed to drive the zero or negative sense of a bipolar line driver. |
| 26 | Encoder | OUTPUT INHIBIT | A low on this pin forces pin 25 and 27 high, the inactive states. |
| 27 | Encoder | $\overline{\text { BIPOLAR ONE OUT }}$ | An active low output designed to drive the one or positive sense of a bipolar line driver. |
| 28 | Encoder | SERIAL DATA IN | Accepts a serial data stream at a data rate equal to ENCODER SHIFT CLOCK. |
| 29 | Encoder | ENCODER ENABLE | A high on this pin initiates the encode cycle. (Subject to the preceeding cycle being complete.) |
| 30 | Encoder | SYNC SELECT | Actuates a Command sync for an input high and Data sync for an input low. |
| 31 | Encoder | ENCODER PARITY SELECT | Sets transmit parity odd for a high input, even for a low input. |
| 32 | Encoder | SEND DATA | Is an active high output which enables the external source of serial data |
| 33 | Encoder | SEND CLOCK IN | Clock input at a frequency equal to the data rate X 2 . |
| 34 | Encoder | ENCODER SHIFT CLOCK | Output for shifting data into the Encoder. This shift clock shifts data on a low-to-high transition. |
| 35 | Blank | N.C. | Not connected. |
| 36 | Both | COUNT C3 | See pin 20. |
| 37 | Encoder | ENCODER CLOCK | Input to the 6:1 divider. |
| 38 | Decoder | DATA SYNC | Output of a high from this pin occurs during output of decoded data which was preceded by a Data synchronizing character. |
| 39 | Both | COUNT C4 | See pin 20. |
| 40 | Both | COUNT ${ }^{1} 1$ | See pin 20. |

## Encoder Operation

The Encoder requires a single clock with a frequency of twice the desired data rate applied at the SEND CLOCK input. An auxiliary divide by six counter is provided on chip which can be utilized to produce the SEND CLOCK by dividing the DECODER CLOCK. The frame length is set by programming the COUNT inputs. Parity is selected by programming ENCODER PARITY SELECT high for odd parity or low for even parity.

The Encoder's cycle begins when ENCODER ENABLE is high during a falling edge of ENCODER SHIFT CLOCK (1). This cycle lasts for one word length or K +4 ENCODER SHIFT CLOCK periods, where K is the number of bits to be sent. At the next low-to-high transition of the ENCODER SHIFT CLOCK, a high at SYNC SELECT input actuates a Command sync or a low will produce a Data sync for that word (2). When the Encoder is ready
to accept data, the SEND DATA output will go high for K ENCODER SHIFT CLOCK periods (4). During these K periods the data should be clocked into the SERIAL DATA input with every low-to-high transition of the ENCODER SHIFT CLOCK (3) - (4). After the sync and Manchester II encoded data are transmitted through the $\overline{B I P O L A R} \overline{O N E}$ and $\overline{B I P O L A R} \overline{Z E R O}$ outputs, the Encoder adds on an additional bit with is the parity for that word (5). At any time a low on OUTPUT INHIBIT input will force both bipolar outputs to a high state but will not affect the Encoder in any other way.

To abort the Encoder transmission a positive pulse must be applied at MASTER RESET. Any time after or during this pulse, a low-to-high transition on SEND CLOCK clears the internal counters and initializes the Encoder for a new word.


## Decoder Operation

To operate the Decoder asynchronously requires a single clock with a frequency of 12 times the desired data rate applied at the DECODER CLOCK input. To operate the Decoder synchronously requires a SYNCHRONOUS CLOCK at a frequency 2 times the data rate which is synchronized with the data at every high-to-low transition applied to the SYNCHRONOUS DATA input. The Manchester II coded data can be presented to the Decoder asynchronously in one of two ways. The BIPOLAR ONE and BIPOLAR ZERO inputs will accept data from a comparator sensed transformer coupled bus as specified in Military Spec 1553. The UNIPOLAR DATA input can only accept noninverted Manchester II coded data. (e.g. from $\overline{B I P O L A R} \overline{Z E R O} \overline{O U T}$ on an Encoder).

The Decoder is free running and continuously monitors its data input lines for a valid sync character and two valid Manchester data bits to start an output cycle. When a valid sync is recognized (1), the type of sync is indicated by a high level at either COMMAND SYNC or DATA SYNC output. If the sync character was a command sync the COMMAND SYNC output will go high (2) and remain high for K SHIFT CLOCK periods (3), where $K$ is the number of
bits to be received. If the sync character was a data sync the DATA SYNC output will go high. The TAKE DATA output will go high and remain high (2) - (3) while the Decoder is transmitting the decoded data through SERIAL DATA OUT. The decoded data available at SERIAL DATA OUT is in NRZ format. The DECODER SHIFT CLOCK is provided so that the decoded bits can get shifted into an external register on every low-to-high transition of this clock (2)-(3).

After all $K$ decoded bits have been transmitted (3) the data is checked for parity. A high input on DECODER PARITY SELECT will set the Decoder to check for even parity or a low input will set the Decoder to check for odd parity. A high on VALID WORD output (4) indicates a successful reception of a word without any Manchester or parity errors. At this time the Decoder is looking for a new sync character to start another output sequence.

At any time in the above sequence a high input on DECODER RESET during a low-to-high transition of DECODER SHIFT CLOCK will abort transmission and initialize the Decoder to start looking for a new sync character.


Frame Count

| $\begin{aligned} & \text { DATA } \\ & \text { BITS } \end{aligned}$ | $\begin{gathered} \text { FRAME } \\ \text { LENGTH } \\ \text { (BITPERIODS) } \end{gathered}$ | PIN WORD |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | C4 | C3 | $\mathrm{C}_{2}$ | C1 | co |
| 2 | 7 | L | L | H | L |  |
| 3 4 | 7 | L | L | H H | H H | L H |
| 5 | 9 | $L$ | H | L | L | L |
| 6 | 10 | $\stackrel{L}{L}$ | H | L | L | H |
| 7 | 11 | L | H H | L | H | L |
| 8 | 12 13 | L | H H | H | ${ }_{\text {H }}^{\text {L }}$ | L |
| 10 | 14 | L | H | H | L | H |
| 11 | 15 | L | H | H | H | L |
| 12 | 16 | L | H | H | H | H |
| 13 | 17 | H | L | L | L | $\stackrel{L}{L}$ |
| 14 15 | 18 | H H | L | L | L | ${ }_{\text {H }}^{\text {L }}$ |
| 16 | 20 | H H | L | L | H | H |
| 17 | 21 | H | L | H | L | L |
| 18 | 22 | H | L | H | L | H |
| 19 | 23 | ${ }_{\mathrm{H}}^{\mathrm{H}}$ | L | H | $\stackrel{H}{H}$ | $\stackrel{L}{L}$ |
| 20 21 | 24 | H H | L | ${ }_{\text {H }}^{\text {L }}$ | ${ }_{\text {H }}^{\text {L }}$ | ${ }_{\text {H }}^{\text {L }}$ |
| 22 | 26 | H | H H | L | $L$ | H |
| 23 | 27 | H | H | L | H | L |
| 24 | 28 29 | H H | H H | $\stackrel{L}{\text { L }}$ | ${ }_{\text {H }}^{\text {L }}$ | ${ }_{\text {H }}^{\text {H }}$ |
| 26 | 30 | H | H | H | $L$ | H |
| 27 | 31 32 | H | H H | H H | H | $\stackrel{L}{\mathrm{~L}}$ |
| 28 | 32 | H | H | H | H | H |

The above Table demonstrates all possible combinations of frame lengths ranging from 6 to 32 bits. The pin word described here is common to both the Encoder and Decoder.

Encoder Timing


ENCODER SHIFT CLOCK


## Decoder Timing



DECODER SHIFT CLOCK COMMAND/DATA SYNC take data

decoder shift clock

decoder shift clock
COMMAND/̄̄ATA SYNC
take data
VALID WORD

decoder shift clock
decoder reset



Applications
How to Make Our MTU Look Like a Manchester Encoded UART


Typical Timing Diagrams for a Manchester Encoded UART
ENCODER TIMING


## Features

- 2.5 MEGABIT/SEC DATA RATE
- SYNC IDENTIFICATION AND LOCK-IN
- Clock recovery
- VARIABLE fRAME LENGTH TO 32 bits
- manchester il encode and decode
- half Or full duplex operation
- FULL MILITARY OR INDUSTRIAL TEMPERATURE RANGES
- WORD TYPE SELECT AND RECOGNITION
- DETECTS ALL SINGLE, DOUBLE, OR TRIPLE SAMPLING ERRORS


## Pinout

| vec 5 | 40 | COUNT $\mathrm{C}_{1}$ |
| :---: | :---: | :---: |
| VALID WORD 2 | 39 | COUNT C4 |
| TAKE DATA' 3 | 38 | 1 DATA SYNC |
| TAKE DATA 4 | 37 | f encoder clock |
| SERIAL DATA OUT 5 | 36 | COUNT C3 |
| SYNCHRONOUS DATA 6 | 35 | 1 N.C. |
| SYNCHRONOUS DATA SEL. 77 | 34 | Iencoder shift clock |
| SYNCHRONOUS CLOCK 8 | 33 | Send clock in |
| decoder clock 9 | 32 | 1 SEND DATA |
| SYNCHRONOUS CLOCK SEL. 10 | 31 | $]$ ENCODER PARITY SEL. |
| BIPOLAR ZERO IN 11 | 30 | ISYNC SELECT |
| bipolar one in 12 | 29 | Encoder enable |
| UNIPOLAR DATA IN 13 | 28 | 1 SERIAL DATA IN |
| DECODER SHIFT CLOCK 14 | 27 | G BIPOLAR ONE OUT |
| TRANSITION SEL. 15 | 28 | OUTPUT |
| N.C. ${ }^{16}$ | 25 | - BIPOLAR EERO OUT |
| COMMAND SYNC 17 | 24 | 1+6 OUT |
| DECODER PARITY SEL. 18 | 23 | COUNT C2 |
| decoder reset 19 | 22 | master reset |
| COUNT CO 20 | 21 | GND |

## Description

The Harris HD-15531B Programmable Manchester Encoder-Decoder (MED) is intended to be used as a high speed, low power, serial data link controller in applications where data integrity combined with low overhead is important. It is manufactured using Harris' Self Aligned Junction Isolated (SAJI) CMOS process.

This LSI chip is divided into two sections, an encoder and a decoder. These sections operate independently of each other except for the Master Reset and frame length select function. In addition to encoding/ decoding of NRZ data the HD-15531B frames variable length data (2-28 bits) with one of two types
of synchronization characters and a parity bit. Independent selection of even or odd parity for the encoder and decoder is included.

An internal error detection algorithm will detect all single, double or triple sampling errors. In addition, this algorithm will typically detect better than $99 \%$ of four or more errors in any one word.

Ideal applications include party line Local Area Networks as well as data acquisition systems where 8,12 or 16 bit A/D converters are typically used for the digital transmission of data.

## Block Diagrams

## ENCODER



DECODER


CAUTION: These devices are sensitive to electrostatic discharge. Users should follow standard IC Handling Procedures.

| Supply Voltage <br> Input or Output Voltage Applied <br> Storage Temperature Range <br> Operating Temperature Range <br> Industrial HD $-15531 \mathrm{~B}-9$ | +7.0 V |
| :--- | ---: |
|  | Military HD $-15531 \mathrm{~B}-2 / 8$ |

ELECTRICAL CHARACTERISTICS $\operatorname{VCC}=5.0 \mathrm{~V} \pm 10 \% \quad \mathrm{~T}_{\mathrm{A}}=$ Industrial or Military

\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{D.C.} \& SYMBOL \& PARAMETER \& MINIMUM \& TYPICAL \& MAXIMUM \& UNITS \& TEST CONDITIONS \\
\hline \& \[
\begin{gathered}
\text { VIH } \\
\text { VIL } \\
\text { VIHC } \\
\text { VILC } \\
\text { IIL } \\
\text { VOH } \\
\text { VOL } \\
\text { ICCSB } \\
\\
\text { ICCOP } \\
\text { CIN } \\
\text { CO }
\end{gathered}
\] \& \begin{tabular}{l}
Logical "1" Input Voltage \\
Logical " 0 " Input Voltage \\
Logical "1" Input Voltage (Clock) \\
Logical " 0 " Input Voltage (Clock) \\
Input Leakage \\
Logical "1" Output Voltage \\
Logical "0" Output Voltage \\
Supply Current Standby \\
Supply Current Operating* \\
Input Capacitance* \\
Output Capacitance*
\end{tabular} \& \[
\begin{gathered}
70 \% \text { VCC } \\
\text { VCC }-0.5 \\
-1.0 \\
2.4
\end{gathered}
\] \& \[
\begin{gathered}
0.5 \\
16.0 \\
5.0 \\
8.0
\end{gathered}
\] \& \[
\begin{gathered}
20 \% \text { VCC } \\
\text { GND }+0.5 \\
+1.0 \\
0.4 \\
2.0 \\
\\
20.0 \\
\\
7.0 \\
10.0
\end{gathered}
\] \& \begin{tabular}{l}
V \\
V \\
V \\
v \\
\(\mu \mathrm{A}\) \\
V \\
V \\
mA \\
mA \\
pF \\
pF
\end{tabular} \& \[
\begin{aligned}
\& O V \leqslant V I N \leqslant V C C \\
\& I O H=-3 m A \\
\& I O L=1.8 \mathrm{~mA} \\
\& V I N=V C C=5.5 \mathrm{~V} \\
\& \text { Outputs Open } \\
\& V C C=5.5 \mathrm{~V} \\
\& \mathrm{f}=30 \mathrm{MHz}
\end{aligned}
\] \\
\hline \multicolumn{8}{|c|}{*Guaranteed and sampled but not 100\% tested.} \\
\hline \& \multicolumn{7}{|l|}{ENCODER TIMING} \\
\hline A.C. \& \[
\begin{gathered}
\hline \text { FEC } \\
\text { FESC } \\
\text { TECR } \\
\text { TECF } \\
\text { FED } \\
\text { TMR } \\
\text { TE1 } \\
\text { TE2 } \\
\text { TE3 } \\
\text { TE4 } \\
\text { TE5 } \\
\text { TE6 } \\
\text { TE7 } \\
\text { TE8 } \\
\text { TE9 }
\end{gathered}
\] \& \begin{tabular}{l}
Encoder Clock Frequency Send Clock Frequency Encoder Clock Rise Time Encoder Clock Fall Time Data Rate \\
Master Reset Pulse Width \\
Shift Clock Delay \\
Serial Data Setup \\
Serial Data Hold \\
Enable Setup \\
Enable Pulse Width \\
Sync Setup \\
Sync Pulse Width \\
Send Data Delay \\
Bipolar Output Delay
\end{tabular} \& 0
0
0
150
50
50
90
100
55
150
0 \& \& \[
\begin{gathered}
\hline \hline 30 \\
5 \\
8 \\
8 \\
2.5 \\
80 \\
\\
\\
\\
\\
\\
\\
50 \\
130
\end{gathered}
\] \& \begin{tabular}{l}
MHz \\
MHz \\
ns \\
ns \\
MHz \\
ns \\
ns \\
ns \\
ns \\
ns \\
ns \\
ns \\
ns \\
ns \\
ns
\end{tabular} \&  \\
\hline \& \multicolumn{7}{|l|}{DECODER TIMING} \\
\hline A.C. \& FDC FDS TDCR TDCF FDD TDR TDRS TMR TD1 TD2 TD3 TD4 TD5 TD6 TD7 TD8 TD9 TD10 TD11 -TD12 TD13 \& \begin{tabular}{l}
Decoder Clock Frequency \\
Decoder Synchronous Clock \\
Decoder Clock Rise Time \\
Decoder Clock Fall Time \\
Data Rate \\
Decoder Reset Pulse Width \\
Decoder Reset Setup Time \\
Master Reset Pulse Width \\
Bipolar Data Pulse Width \\
Sync Transition Span \\
One Zero Overlap \\
Short Data Transition Span \\
Long Data Transition Span \\
Sync Delay (ON) \\
Take Data Delay (ON) \\
Serial Data Out Delay \\
Sync Delay (OFF) \\
Take Data Delay (OFF) \\
Valid Word Delay \\
Synchronous Clock To Shift Clock Delay \\
Synchronous Data Setup
\[
\begin{aligned}
\& \text { TDC = Decoder C } \\
\& \text { These parameters }
\end{aligned}
\]
\end{tabular} \& \begin{tabular}{l}
0
0 \\
0
0 \\
TDC + 10 \\
\(-20\) \\
0 \\
0 \\
0 \\
0 \\
75 \\
ck Period = \\
re guaranteed
\end{tabular} \& \begin{tabular}{l}
18TDC \\
6TDC 12TDC
\end{tabular} \& \begin{tabular}{l}
30
5
8
8
2.5

TDC -10
110
110
80
110
110
110
75 <br>
\% tested.
\end{tabular} \& MHz

MHz
ns
ns
MHz
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns \&  <br>
\hline
\end{tabular}

| PIN | SECTION | NAME | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | Both | VCC | Positive supply pin. |
| 2 | Decoder | VALID WORD | Output high indicates receipt of a valid word. |
| 3 | Decoder | TAKE DATA' | A continuous, free running signal provided for host timing or data handling. When data is present on the bus, this signal will be synchronized to the incoming data and will be identical to take data. |
| 4 | Decoder | TAKE DATA | Output is high during receipt of data after identification of a sync pulse |
| 5 | Decoder | SERIAL DATA OUT | Delivers received data in correct NRZ format. |
| 6 | Decoder | SYNCHRONOUS DATA | Input presents Manchester data directly to character identification logic. SYNCHRONOUS DATA SELECT must be held high to use this input. If not used this pin should be held high. |
| 7 | Decoder | SYNCHRONOUS DATA SELECT | In high state allows the synchronous data to enter the character identification logic. |
| 8 | Decoder | SYNCHRONOUS CLOCK | Input provides externally synchronized clock to the decoder. This input should be tied high when not in use. |
| 9 | Decoder | DECODER CLOCK | Input drives the transition finder, and the synchronizer which in turn supplies the clock to the balance of the decoder. |
| 10 | Decoder | SYNCHRONOUS CLOCK SELECT | In high state directs the SYNCHRONOUS CLOCK to control the decoder character identification logic. A low state selects the DECODER CLOCK |
| 11 | Decoder | BIPOLAR ZERO IN | A high input should be applied when the bus is in its negative state. This pin must be held high when the unipolar input is used. |
| 12 | Decoder | BIPOLAR ONE IN | A high input should be applied when the bus is in its positive state. This pin must be held low when the unipolar input is used. |
| 13 | Decoder | UNIPOLAR DATA IN | With pin 11 high and pin 12 low, this pin enters unipolar data into the transition finder circuit. If not used this input must be held low. |
| 14 | Decoder | DECODER SHIFT CLOCK | Output which delivers a frequency (DECODER CLOCK $\div 12$ ), synchronized by the recovered serial data stream. |
| 15 | Decoder | TRANSITION SELECT | A high input to this pin causes the transition finder to synchronize on every transition of input data. A low input causes the transition finder to synchronize only on mid-bit transitions. |
| 16 | Blank | N.C. | Not connected. |
| 17 | Decoder | COMMAND SYNC | Output of a high from this pin occurs during output of decoded data which was preceded by a Command (or Status) synchronizing character |
| 18 | Decoder | DECODER PARITY SELECT | An input for parity sense, calling for even parity with input high and odd parity with input low. |
| 19 | Decoder | DECODER RESET | A high input to this pin during a rising edge of DECODER SHIFT CLOCK resets the decoder bit counting logic to a condition ready for a new word. |
| 20 | Both | COUNT Co | One of five binary inputs which establish the total bit count to be encoded or decoded. |
| 21 | Both | GROUND | Supply pin. |
| 22 | Both | MASTER RESET | A high on this pin clears 2:1 counters in both the encoder and decoder. |
| 23 | Both | COUNT C2 | See pin 20. |
| 24 | Encoder | $\div 6$ OUT | Output from 6:1 divider which is driven by the ENCODER CLOCK. |
| 25 | Encoder | $\overline{\text { BIPOLAR } \overline{\text { ZERO }} \overline{\text { OUT }}}$ | An active low output designed to drive the zero or negative sense of a bipolar line driver. |
| 26 | Encoder | OUTPUT INHIBIT | A low on this pin forces pin 25 and 27 high, the inactive states. |
| 27 | Encoder | $\overline{\text { BIPOLAR ONE OUT }}$ | An active low output designed to drive the one or positive sense of a bipolar line driver. |
| 28 | Encoder | SERIAL DATA IN | Accepts a serial data stream at a data rate equal to ENCODER SHIFT CLOCK. |
| 29 | Encoder | ENCODER ENABLE | A high on this pin initiates the encode cycle. (Subject to the preceeding cycle being complete.) |
| 30 | Encoder | SYNC SELECT | Actuates a Command sync for an input high and Data sync for an input low. |
| 31 | Encoder | ENCODER PARITY SELECT | Sets transmit parity odd for a high input, even for a low input. |
| 32 | Encoder | SEND DATA | Is an active high output which enables the external source of serial data |
| 33 | Encoder | SEND CLOCK IN | Clock input at a frequency equal to the data rate $\times 2$. |
| 34 | Encoder | ENCODER SHIFT CLOCK | Output for shifting data into the Encoder. This shift clock shifts data on a low-to-high transition. |
| 35 | Blank | N.C. | Not connected. |
| 36 | Both | COUNT C3 | See pin 20. |
| 37 | Encoder | ENCODER CLOCK | Input to the 6:1 divider. |
| 38 | Decoder | DATA SYNC | Output of a high from this pin occurs during output of decoded data which was preceded by a Data synchronizing character. |
| 39 | Both | COUNT C4 | See pin 20. |
| 40 | Both | COUNT C1 | See pin 20. |

The Encoder requires a single clock with a frequency of twice the desired data rate applied at the SEND CLOCK input. An auxiliary divide by six counter is provided on chip which can be utilized to produce the SEND CLOCK by dividing the DECODER CLOCK. The frame length is set by programming the COUNT inputs. Parity is selected by programming ENCODER PARITY SELECT high for odd parity or low for even parity.

The Encoder's cycle begins when ENCODER ENABLE is high during a falling edge of ENCODER SHIFT CLOCK (1). This cycle lasts for one word length or K + 4 ENCODER SHIFT CLOCK periods, where K is the number of bits to be sent. At the next low-to-high transition of the ENCODER SHIFT CLOCK, a high at SYNC SELECT input actuates a Command sync or a low will produce a Data sync for that word (2). When the Encoder is ready
to accept data, the SEND DATA output will go high for K ENCODER SHIFT CLOCK periods (4). During these K periods the data should be clocked into the SERIAL DATA input with every low-to-high transition of the ENCODER SHIFT CLOCK (3) - (4). After the sync and Manchester II encoded data are transmitted through the $\overline{\text { BIPOLAR }} \overline{O N E}$ and $\overline{\text { BIPOLAR }} \overline{\text { ZERO }}$ outputs, the Encoder adds on an additional bit with is the parity for that word (5). At any time a low on OUTPUT INHIBIT input will force both bipolar outputs to a high state but will not affect the Encoder in any other way.

To abort the Encoder transmission a positive pulse must be applied at MASTER RESET. Any time after or during this pulse, a low-to-high transition on SEND CLOCK clears the internal counters and initializes the Encoder for a new word.


## Decoder Operation

To operate the Decoder asynchronously requires a single clock with a frequency of 12 times the desired data rate applied at the DECODER CLOCK input. To operate the Decoder synchronously requires a SYNCHRONOUS CLOCK at a frequency 2 times the data rate which is synchronized with the data at every high-to-low transition applied to the SYNCHRONOUS DATA input. The Manchester II coded data can be presented to the Decoder asynchronously in one of two ways. The BIPOLAR ONE and BIPOLAR ZERO inputs will accept data from a comparator sensed transformer coupled bus as specified in Military Spec 1553. The UNIPOLAR DATA input can only accept noninverted Manchester II coded data. (e.g. from $\overline{\text { BIPOLAR }} \overline{Z E R O} \overline{O U T}$ on an Encoder).

The Decoder is free running and continuously monitors its data input lines for a valid sync character and two valid Manchester data bits to start an output cycle. When a valid sync is recognized (1), the type of sync is indicated by a high level at either COMMAND SYNC or DATA SYNC output. If the sync character was a command sync the COMMAND SYNC output will go high (2) and remain high for K SHIFT CLOCK periods (3), where $K$ is the number of
bits to be received. If the sync character was a data sync the DATA SYNC output will go high. The TAKE DATA output will go high and remain high (2) - (3) while the Decoder is transmitting the decoded data through SERIAL DATA OUT. The decoded data available at SERIAL DATA OUT is in NRZ format. The DECODER SHIFT CLOCK is provided so that the decoded bits can get shifted into an external register on every low-to-high transition of this clock (2)-(3).

After all $K$ decoded bits have been transmitted (3) the data is checked for parity. A high input on DECODER PARITY SELECT will set the Decoder to check for even parity or a low input will set the Decoder to check for odd parity. A high on VALID WORD output (4) indicates a successful reception of a word without any Manchester or parity errors. At this time the Decoder is looking for a new sync character to start another output sequence.

At any time in the above sequence a high input on DECODER RESET during a low-to-high transition of DECODER SHIFT CLOCK will abort transmission and initialize the Decoder to start looking for a new sync character.


Frame Count

| $\begin{aligned} & \text { DATA } \\ & \text { BITS } \end{aligned}$ | $\begin{gathered} \text { FRAME } \\ \text { (BENGTH } \\ \text { (BITPRIODS) } \end{gathered}$ | PIN WORD |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | C4 | $\mathrm{C}_{3}$ | $\mathrm{C}_{2}$ | C1 | co |
| 2 | 6 | L | L | H | L | H |
| 3 | 7 | L | L | H | H | L |
| 4 | 8 | L | L | H | H | H |
| 5 | $\stackrel{9}{10}$ | L | H H | L | L | H |
| 7 | 11 | L | H | L | H | L |
| 8 | 12 | L | H | L | H | H |
| 9 | 13 | L | H | H | L | L |
| 10 | 14 | L | H | H | L | H |
| 11 | 15 | L | H | H $H$ | $\stackrel{H}{H}$ | L |
| 12 | 16 | L | ${ }_{\mathrm{H}}$ | $\xrightarrow{H}$ | ${ }_{4}^{H}$ | ${ }_{\text {H }}$ |
| 14 | 18 | H H | $L$ | L | L | H |
| 15 | 19 | H | L | $L$ | H | L |
| 16 | 20 | H | L | L | H | H |
| 17 | 21 | ${ }_{\mathrm{H}}^{\mathrm{H}}$ | L | H + | L | $\stackrel{L}{L}$ |
| 18 19 | 22 23 | H H | L | H H | $\xrightarrow{\text { L }}$ | ${ }_{\text {H }}^{\text {H }}$ |
| 20 | 24 | H | L | H | H | H |
| 21 | 25 | H | H | $L$ | L | L |
| 22 | 26 | H | H | L | L | H |
| 23 | 27 | ${ }_{\mathrm{H}}^{\mathrm{H}}$ | ${ }_{\mathrm{H}}^{\mathrm{H}}$ | L | $\xrightarrow{H}$ | $\stackrel{L}{L}$ |
| 24 25 | 28 29 | H H | H H | H | L | L |
| 26 | 30 | H | H | H | L | H |
| ${ }_{28}^{27}$ | 31 32 | H H | H H | H H | H H | $\stackrel{\text { L }}{\text { H }}$ |

The above Table demonstrates all possible combinations of frame lengths ranging from 6 to 32 bits. The pin word described here is common to both the Encoder and Decoder.

## Encoder Timing



Decoder Timing




## Applications

How to Make Our MTU Look Like a Manchester Encoded UART


## Typical Timing Diagrams for a Manchester Encoded UART

ENCODER TIMING


## DECODER TIMING



The following is a partial listing of technical articles that have been published which discuss Harris Semiconductors line of Manchester Encoder-Decoders.

- 'Manchester Terminal Unit in CMOS LSI", Military Electronics, April 1979
- "Manchester II Transfers Data with Integrity, Speed" Electronic Design, March 19, 1981
- "Encoding Schemes in Serial Data Communiations", Electronic Engineering, July 1981
- "Pulse Codes in Serial Data Communications", Computer Design, January 1982
- "Improve Datacomm Links by Using Manchester Code", Electric Design News, February17, 1982
- "For Data-Comm Links, Manchester Chip Could be the Best", Electronic Design, August 5, 1982

Additional literature is available from Harris in the form of Technical Briefs (TB-15, 20, 28, 29, 43) and Article Reprints of published articles.

## Features

Pinout

| TOP VIEW |  |  |
| :---: | :---: | :---: |
| vw 1 | 24 | Vcc |
| Esc [2 | 23 | EC |
| TD 3 | 22 | sCl |
| SDO 4 | 21 | sD |
| DC 5 | 20 | ss |
| Bzi ${ }^{6}$ | 19 | Ee |
| BOI 7 | 18 | SDI |
| UDI 8 | 17 | - $\overline{000}$ |
| Dsc 9 | 16 | - 0 |
| cos 10 | 15 | $\overline{\text { Bzo }}$ |
| dr 11 | 14 | dbs |
| GND 12 | 13 | MR |

## Description

The HD-6408 is a CMOS/LSI Manchester Encoder/ Decoder for creating a very high speed asynchronous serial data bus. The Encoder converts serial NRZ data (typically from a shift register) to Manchester II encoded data adding a sync pulse and parity bit. The Decoder recognizes this sync pulse and identifies it as a Command Sync or a Data Sync. The data is then decoded and shifted out in the NRZ code (typically into a shift register). Finally, the parity bit is checked. If there were no Manchester or parity errors the Decoder responds with a valid word
signal. This Decoder puts the Manchester code to full use to provide clock recovery and excellent noise immunity at these very high speeds.

The HD-6408 can be used in many commercial applications such as, security systems, environmental control systems, serial data links and many others. It utilizes a single 12X clock and achieves data rates of up to one million bits per second with a very minimum overhead of only 4 bits out of 20 , leaving 16 bits for data.

## Block Diagrams



CAUTION: These devices are sensitive to electronic discharge.
Proper I.C. handling procedures should be followed.

| Supply Voltage | +7.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | $-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range | $-40{ }^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

## ELECTRICAL CHARACTERISTICS $\quad V_{C C}=5.0 \mathrm{~V} \pm 10 \% \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$

## D.C.

| SYMBOL | PARAMETER | minimum | TYPICAL | MAXIMUM | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical " 1 " Input Voltage | 70\% Vcc |  |  | V |  |
| VIL | Logical "0" Input Voltage |  |  | 20\% Vcc | $v$ |  |
| VIHC | Logical "1" Input Voltage (Clock) | Vcc -0.5 |  |  | v |  |
| VILC | Logical " 0 " Input Voltage (Clock) |  |  | GND +0.5 | $v$ |  |
| IIL | Input Leakage | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{VIN}^{5} \leqslant \mathrm{Vcc}$ |
| VOH | Logical '"1" Output Voltage | 2.4 |  |  | v | $1 \mathrm{OH}=-3 \mathrm{~mA}$ |
| VOL | Logical ' 0 " Output Voltage |  |  | 0.4 | V | $1 \mathrm{OL}=1.8 \mathrm{~mA}$ |
| ICCSB | Supply Current Standby |  | 0.5 | 2 | mA | $V I N=V C C=5.5 \mathrm{~V}$ |
| ICCOP | Supply Current Operating* |  | 8.0 | 10.0 | mA | $\begin{aligned} & \mathrm{VCc}=5.5 \mathrm{~V}, \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| CIN CO | Input Capacitance* Output Capacitance* |  | 5.0 8.0 | 7.0 10.0 | $\mathrm{pF}$ |  |
| *Guaranteed and sampled but not $100 \%$ tested. |  |  |  |  |  |  |
| ENCODER TIMING $\mathrm{V}_{\text {CC }}=5.0 \mathrm{~V} \pm 5 \% \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ |  |  |  |  |  |  |
| FEC | Encoder Clock Frequency | 0 |  | 12 | MHz | $C L=50 \mathrm{pF}$ |
| FESC | Send Clock Frequency | 0 |  | 2.0 | MHz |  |
| TECR | Encoder Clock Rise Time |  |  | 8 | ns |  |
| TECF | Encoder Clock Fall Time |  |  | 8 | ns |  |
| FED | Data Rate Master Reset Pulse Width | 0 150 |  | 1.0 | MHz |  |
| TMR | Master Reset Pulse Width Shift Clock Delay | 150 |  | 125 | ns ns |  |
| TE2 | Serial Data Setup | 75 |  |  | ns |  |
| TE3 | Serial Data Hold | 75 |  |  | ns |  |
| TE4 | Enable Setup | 90 |  |  | ns |  |
| TE5 | Enable Pulse Width | 100 |  |  | ns |  |
| TE6 | Sync Setup | 55 |  |  | ns |  |
| TE7 | Sync Pulse Width | 150 |  |  | ns |  |
| TE8 | Send Data Delay Bipolar Output Delay | 0 |  | $\begin{gathered} 50 \\ 130 \end{gathered}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |

DECODER TIMING $V_{C C}=5.0 \mathrm{~V} \pm 5 \% T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

| FDC | Decoder Clock Frequency | 0 |  | 12 | MHz | $C \mathrm{~L}=50 \mathrm{pF}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TDCR. | Decoder Clock Rise Time |  |  | 8 | ns | 4 |
| TDCF | Decoder Clock Fall Time |  |  | 8 | ns |  |
| FDD | Data Rate | 0 |  | 1.0 | MHz |  |
| TDR | Decoder Reset Pulse Width | 150 |  |  | ns |  |
| TDRS | Decoder Reset Setup Time | 75 |  |  | ns |  |
| TMR | Master Reset Pulse Width | 150 |  |  | ns |  |
| TD1 | Bipolar Data Pulse Width | TDC +10 |  |  | ns | (1) |
| TD2 | Sync Transition Span |  | 18TDC |  | ns | (1) |
| TD3 | One Zero Overlap |  |  | TDC -10 | ns | (1) |
| TD4 | Short Data Transition Span |  | 6TDC |  | ns | (1) |
| TD5 | Long Data Transition Span |  | 12TDC |  | ns | (1) |
| TD6 | Sync Delay (ON) | -20 |  | 110 | ns |  |
| TD7 | Take Data Delay (ON) | 0 |  | 110 | ns |  |
| TD8 | Serial Data Out Delay |  |  | 80 | ns |  |
| TD9 | Sync Delay (OFF) |  |  | 110 | ns |  |
| TD10 | Take Data Delay (OFF) | 0 |  | 110 | ns |  |
| TD11 | Valid Word Delay | 0 |  | 110 | ns | $\cdots$ |


| PIN | SYMBOL | SECTION | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | VW | Decoder | Output high indicates receipt of a VALID WORD. |
| 2 | ESC | Encoder | ENCODER SHIFT CLOCK is an output for shifting data into the Encoder. This clock shifts data on a low-to-high transition. |
| 3 | TD | Decoder | TAKE DATA output is high during receipt of data after identification of a sync pulse. |
| 4 | SDO | Decoder | SERIAL DATA OUT delivers recelved data in correct NRZ format. |
| 5 | DC | Decoder | DECODER CLOCK input drives the transition finder, and the synchronizer which in turn supplies the clock to the balance of the Decoder. |
| 6 | BZI | Decoder | A high input should be applied to BIPOLAR ZERO IN when the bus is in its negative state. This pin must be held high when the Unipolar input is used. |
| 7 | BOI | Decoder | A high input should be applied to BIPOLAR ONE IN when the bus is in its positive state, this pin must be held low when the Unipolar input is used. |
| 8 | UDI | Decoder | With pin 6 high and pin 7 low, this pin enters UNIPOLAR DATA IN to the transition finder circuit. If not used this input must be held low. |
| 9 | DSC | Decoder | DECODER SHIFT CLOCK output delivers a frequency (DECODER CLOCK $\div 12$ ), synchronized by the recovered serial data stream. |
| 10 | CDS | Decoder | COMMAND/DATA SYNC output high occurs during output of decoded data which was preceded by a Command synchronizing character. A low output indicates a Data synchronizing character. |
| 11 | DR | Decoder | A high input to DECODER RESET during a rising edge of DECODER SHIFT CLOCK resets the decoder bit counting logic to a condition ready for a new word. |
| 12 | GND | Both | GROUND supply pin. |



| PIN | SYMBOL | SECTION | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 13 | MR | Both | A high on MASTER RESET clears the $\mathbf{2 : 1}$ counters in both the encoder and decoder and the $\div 12$ counter. |
| 14 | DBS | Encoder | DIVIDE BY SIX is an output from 6:1 divider which is driven by the ENCODER CLOCK. |
| 15 | $\overline{\text { BZO }}$ | Encoder | $\overline{B I P O L A R} \overline{\text { ZERO }} \overline{O U T}$ is an active low output designed to drive the zero or negative sense of a bipolar line driver. |
| 16 | ठा | Encoder | A low on OUTPUT INHIBIT forces pin 15 and 17 high, their Inactive states. |
| 17 | $\overline{\mathrm{BOO}}$ | Encoder | $\overline{\text { BIPOLAR }} \overline{\text { ONE }} \overline{O U T}$ is an active low output designed to drive the one or positive sense of a bipolar line driver. |
| 18 | SDI | Encoder | SERIAL DATA IN accepts a serial data stream at a data rate equal to ENCODER SHIFT CLOCK. |
| 19 | EE | Encoder | A high on ENCODER ENABLE initiates the encode cycle. (Subject to the preceding cycle being complete.) |
| 20 | SS | Encoder | SYNC SELECT actuates a Command sync for an input high and Data sync for an input low. |
| 21 | SD | Encoder | SEND DATA is an active high output which enables the external source of serial data. |
| 22 | SCl | Encoder | SEND CLOCK IN is 2 X the Encoder data rate. |
| 23 | EC | Encoder | ENCODER CLOCK is the input to the 6:1 divider. |
| 24 | VCC | Both | Positive supply pin. |

## Encoder Operation

The Encoder requires a single clock with a frequency of twice the desired data rate applied at the SClock input. An auxiliary divide by six counter is provided on chip which can be utilized to produce the SClock by dividing the DClock.

The Encoder's cycle begins when EE is high during a falling edge of ESC (1). This cycle lasts for one word length or twenty ESC periods. At the next low-to-high transition of the ESC, a high at SS input actuates a Command sync or a low will produce a Data sync for that word (2). When the Encoder is ready to accept data, the SD output will go high and remain high for sixteen ESC periods (3) - (4) .

During these sixteen periods the data should be clocked into the SDInput with every high-to-low transition of the ESC (3) - (4). After the sync and Manchester II encoded data are transmitted through the $\overline{\mathrm{BOO}}$ and $\overline{\mathrm{BZO}}$ outputs, the Encoder adds on an additional bit which is the (odd) parity for that word (5) . At any time a low on $\bar{O}$ will force both bipolar outputs to a high state but will not affect the Encoder in any other way.

To abort the Encoder transmission a positive pulse must be applied at MR. Any time after or during this pulse, a low-to-high transition on SCl clears the internal counters an initializes the Encoder for a new word.


## Decoder Operation

The Decoder requires a single clock with a frequency of 12 times the desired data rate applied at the DClock input. The Manchester II coded data can be presented to the Decoder in one of two ways. The BOI and BZI inputs will accept data from a differential output comparator. The UDI input can only accept noninverted Manchester II coded data (e.g. from $\overline{\mathrm{BZO}}$ of an Encoder).

The Decoder is free running and continuously monitors its data input lines for a valid sync character and two valid Manchester data bits to start an output cycle. When a valid sync is recognized (1), the type of sync is indicated by the CDS output. If the sync character was a command, this output will go high (2) and remain high for sixteen DSC periods (3), otherwise it will remain low. The TD output will go high and remain high (2) - (3) while the Decoder is transmitting the decoded data through SDO.

The decoded data available at SDO is in a NRZ format. The DSC is provided so that the decoded bits can get shifted into an external register on every low-to-high transition for this clock (2)-(3).

After all sixteen decoded bits have been transmitted (3) the data is checked for odd parity. A high on VW output (4) indicates a successful reception of a word without any Manchester or parity errors. At this time the Decoder is looking for a new sync character to start another output sequence.

At any time in the above sequence a high input on DR during a low-to-high transition of DSC will abort transmission and initialize the Decoder to start looking for a new sync character.


## Encoder Timing



Decoder Timing


## Features

- CONVERTER OR REPEATER MODE
- INDEPENDENT MANCHESTER ENCODER AND DECODER OPERATION
- static to one megabit/SEC data rate guaranteed
- Low bit error rate
- digital pll clock recovery
- ON CHIP OSCILLATOR
- SINGLE POWER SUPPLY
- LOW OPERATING POWER: 50 mW AT 5 VOLTS
- INDUSTRIAL OR MILITARY TEMPERATURE RANGE
- 20 PIN PACKAGE


## Description

The HD-6409 Manchester Encoder-Decoder (MED) is a high speed, low power device manufactured using self-aligned silicon gate technology. The device is intended for use in serial data communication, and can be operated in either of two modes. In the converter mode, the MED converts Nonreturn-to-Zero code (NRZ) into Manchester code and decodes Manchester code into Nonreturn-to-Zero code. For serial data communication, Manchester code does not have some of the deficiencies inherent in Nonreturn-to-Zero code. For instance, use of the MED on a serial line eliminates DC components, provides clock recovery, and gives a relatively high degree of noise immunity. Because the MED converts the most commonly used code (NRZ) to Manchester code, the advantages of using Manchester code are easily realized in a serial data link.
In the Repeater mode, the MED accepts Manchester code input and reconstructs it with a recovered clock. This minimizes the effects of noise on a serial data link. A digital phase lock loop generates the recovered clock. A maximum data rate of 1 MHz requires only 50 mW of power.
Manchester code is used in magnetic tape recording and in fiber optic communication, and generally is used where data accuracy is imperative. Because it frames blocks of data, the HD-6409 easily interfaces to protocol controllers.

Pinout
TOP VIEW


## Logic Symbal



## Functional Diagram



CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

| PIN | MNEMONIC NAME |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 (I) | BZI | Bipolar Zero Input | Used in conjunction with pin 2, Bipolar One Input (BOI), to input Manchester II encoded data to the decoder. BZI and BOI are logical complements. When using pin 3, Unipolar Data Input (UDI) for data input, BZI must be held high. |
| 2 (1) | BOI | Bipolar One Input | Used in conjunction with pin 1, Bipolar Zero Input (BZI), to input Manchester II encoded data to the decoder. BOI and BZI are logical complements. When using pin 3, Unipolar Data Input (UDI) for data input, BOI must be held low. |
| 3 (1) | UDI | Unipolar Data Input | An alternate to bipolar input (BZI, BOI), Unipolar Data Input (UDI) is used to input Manchester II encoded data to the decoder. When using pin 1 (BZI) and pin 2 (BOI) for data input, UDI must be held low. |
| 4 (I/O) | SD/CDS | Serial Data/Command Data Sync | In the converter mode, SD/CDS is an input used to receive serial NRZ data. NRZ data is accepted synchronously on the fallingedge of encoder clock output (ECLK). In the repeater mode, SD/CDS is an output indicating the status of last valid sync pattern received. A high indicates a command sync and a low indicates a data sync pattern. |
| 5 (0) | SDO | Serial Data Out | The decoded serial NRZ data is transmitted out synchronously with the decoder clock (DCLK). SDO is forced low when $\overline{\mathrm{RST}}$ is low. |
| 6 (0) | $\overline{\text { SRST }}$ | $\overline{\text { Serial Reset }}$ | In the converter mode, $\overline{\text { RRST }}$ follows $\overline{\text { RST. In }}$ the repeater mode, when $\overline{\text { RST }}$ goes low, SRST goes low and remains low after $\overline{\text { RST }}$ goes high. $\overline{\text { SRST goes high only when RST is high, }}$ the reset bit is zero, and a valid synchronization sequence is received. |
| 7 (0) | $\overline{N V M}$ | $\overline{\text { Nonvalid Manchester }}$ | A low on $\overline{N V M}$ indicates that the decoder has received invalid Manchester data and present data on Serial Data Out (SDO) is invalid. A high indicates that the sync pulse and data were valid and SDO is valid. $\overline{\text { NVM }}$ is set low by a low on $\overline{\mathrm{RST}}$, and remains low after $\overline{\mathrm{RST}}$ goes high until valid sync pulse followed by two valid Manchester bits is received. |
| 8 (0) | DCLK | Decoder Clock | The decoder clock is a 1 X clock recovered from BZI and BO to synchronously output received NRZ data (SDO). |
| 9 (1) | $\overline{\mathrm{RST}}$ | $\overline{\text { Reset }}$ | In the converter mode, a low on $\overline{\mathrm{RST}}$ forces SDO, DCLK, $\overline{N V M}$, and $\overline{\text { SRST }}$ low. A high on $\overline{\text { RST }}$ enables SDO and DCLK, and forces $\overline{\text { SRST }}$ high. $\overline{\text { NVM }}$ remains tow after $\overline{\text { RST }}$ goes high until a valid sync pulse followed by two Manchester bits is received, after which it goes high. In the repeater mode, $\overline{\text { RST }}$ has the same effect on SDO, DCLK and $\overline{\text { NVM }}$ as in the converter mode. When $\overline{\operatorname{RST}}$ goes low, $\overline{\operatorname{SRST}}$ goes low and remains low after $\overline{\operatorname{RST}}$ goes high. $\overline{\text { SRST }}$ goes high only when $\overline{\mathrm{RST}}$ is high, the reset bit is zero and a valid synchronization sequence is received. |

(I) - Input
(O) - Output

## Pin Assignment And Functions (Continued)

| PIN | MNEMONIC NAME |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 10 (1) | GND | Ground | Ground |
| 11 (0) | Co | Clock Output | Buffered output of clock input Ix. May be used as clock signal for other peripherals. |
| 12 (1) | 1 x | Clock Input | Ix is the input for an external clock or, if the internal oscillator is used, $1 \mathbf{x}$ and $\mathbf{O x}$ are used for the connection of the crystal. |
| 13 (1) | 0 x | Clock Drive | If the internal oscillator is used, Ox and Ix are used for the connection of the crystal. |
| 14 (I) | MS | Mode Select | MS must be held low for operation in the converter mode, and high for operation in the repeater mode. |
| 15 (I) | $\overline{\text { CTS }}$ | Clear to Send | In the converter mode, a high disables the encoder, forcing outputs $\overline{\mathrm{BOO}}, \overline{\mathrm{BZO}}$ high and ECLK low. A high to low transition of $\overline{\mathrm{CTS}}$ initiates transmission of a Command sync pulse. A low on $\overline{\mathrm{CTS}}$ enables $\overline{\mathrm{BOO}}, \overline{\mathrm{BZO}}$, and ECLK. In the repeater mode, the function of $\overline{\mathrm{CTS}}$ is identical to that of the converter mode with the exception that a transition of $\overline{\mathrm{CTS}}$ does not initiate a synchronization sequence. |
| 16 (0) | ECLK | Encoder Clock | In the converter mode, ECLK is a 1 X clock output used to receive serial NRZ data to SD/CDS. In the repeater mode, ECLK is a 2 X clock which is recovered from BZI and BOI data by the digital phase locked loop. |
| 17 (I) | SS | Speed Select | A logic high on SS sets the data rate at $1 / 32$ times the clock frequency while a low sets the data rate at $1 / 16$ times the clock frequency. |
| 18 (0) | $\overline{\text { BZO }}$ | $\overline{\text { Bipolar Zero Output }}$ | $\overline{\mathrm{BZO}}$ and its logical complement $\overline{\mathrm{BOO}}$ are the Manchester data outputs of the encoder. The inactive state for these outputs is in the high state. |
| 19 (0) | $\overline{\mathrm{BOO}}$ | $\overline{\text { Bipolar One Out }}$ | see pin 18 |
| 20 (1) | VCC | VCC | Positive Power Supply |

(I) - Input
(O) - Output

| ABSOLUTE MAXIMUM RATINGS * |  | OPERATING RANGE |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | +7.0V | Operating Tempe | rature Range |  |
| Input or Output Voltage Applied | GND -0.3V | Industrial Military | HD-6409-9 HD-6409-2/8 | $\begin{aligned} & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \end{aligned}$ |
|  | to VCC +0.3V | Operating Voltag | Range |  |
| Storage Temperature | $-65{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Industrial Military | $\begin{aligned} & \text { HD-6409-9 } \\ & \text { HD-6409-2/8 } \end{aligned}$ | $\begin{aligned} & 4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} \\ & 4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} \end{aligned}$ |

*CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

| SYMBOL | PARAMETER | MIN | TYPICAL | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { VIH } \\ \text { VIL } \\ \text { VIHR } \\ \text { VILR } \\ \text { VIHC } \\ \text { VILC } \\ \text { IIL } \\ \text { VOH } \\ \text { VOL } \\ \text { ICCO } \\ \text { ICCOP } \\ \text { CIN } \\ \text { COUT } \\ \hline \end{gathered}$ | Logic-1 Input Voltage <br> Logic-0 Input Voltage <br> Logic-1 Input Voltage (Reset) <br> Logic-0 Input Voltage ( $\overline{\text { Reset }}$ ) <br> Logic-1 Input Voltage (Clock) <br> Logic-0 Input Voltage (Clock) <br> Input Leakage <br> Logic-1 Output Voltage <br> Logic-0 Output Voltage <br> Supply Current Quiescent <br> Supply Current Operating* <br> Input Capacitance* <br> Output Capacitance* | $\begin{gathered} 70 \% \text { VCC } \\ \text { VCC -0.5 } \\ \text { VCC }-0.5 \\ -1.0 \\ \text { VCC }-0.4 \end{gathered}$ | $\begin{aligned} & 1.0 \\ & 7.0 \\ & 6.0 \\ & 8.0 \end{aligned}$ | $\begin{gathered} 20 \% \text { VCC } \\ \text { GND }+0.5 \\ \text { GND }+0.5 \\ +1.0 \\ 0.4 \\ 100 \\ 12.0 \\ 8.0 \\ 15.0 \end{gathered}$ | V <br> v <br> v <br> v <br> v <br> $v$ <br> $\mu \mathrm{A}$ <br> v <br> v <br> $\mu \mathrm{A}$ <br> mA <br> pF <br> pF | $\begin{aligned} & O V \leqslant V I N \leqslant V C C \\ & I O H=-2.0 \mathrm{~mA} \\ & I O L=2.0 \mathrm{~mA} \\ & \mathrm{VIN}=\mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{fco}=16 \mathrm{MHz} \end{aligned}$ |
| $\mathrm{f}_{\mathrm{c}}$ tc $t 1$ t2 t3 t4 $t 5$ t6 t7 t8 t9 | Clock Frequency <br> Clock Period <br> Bipolar Pulse Width <br> Sync Transition Span <br> One-Zero Overlap <br> Short Data Transition Span <br> Long Data Transition Span <br> Output Rise \& Fall Time <br> Clock Out Co Rise \& Fall Time <br> Input Rise \& Fall Time <br> Clock High Duty Cycle <br> Clock Low Duty Cycle | $t_{c}-10$ <br> 20 <br> 20 | $\begin{gathered} 16 \\ 1 / \mathrm{fc}_{\mathrm{c}} \\ 1.5 \times \mathrm{CR} \times \mathrm{tc}_{\mathrm{c}}(1)(2) \\ 0.5 \times \mathrm{CR} \times \mathrm{tc}_{\mathrm{c}} \text { (1)(2) } \\ \mathrm{CR} \times \mathrm{tc}_{\mathrm{c}} \end{gathered}$ | $\begin{gathered} \mathrm{t}_{\mathrm{c}}-10 \\ \\ 50 \\ 1 /\left(5 \times \mathrm{f}_{\mathrm{c}}\right) \\ 1 /\left(5 \times \mathrm{f}_{\mathrm{c}}\right) \end{gathered}$ | MHz s ns ns ns ns ns ns s s ns ns | $\text { Ix or } X_{\text {tal }}$ $C L=20 \mathrm{pF} \text { for } \mathrm{Co},$ <br> 50pF Otherwise 50ns Max. <br> TCYCLE $=62 \mathrm{~ns}$ Fig. 5 |

CONVERTER MODE

## ENCODER SECTION

| tCE1 | SD Setup Time | 70 |  |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tCE2 | SD Hold Time | 0 |  |  | ns |  |
| tCE3 | SD to $\overline{\mathrm{BZO}}, \overline{\mathrm{BOO}}$ Prop Delay |  | 1 | 1.5 | DBP |  |
| tCE4 | $\overline{\mathrm{CTS}}$ Low to $\overline{\mathrm{BZO}}, \overline{\mathrm{BOO}}$ Enabled |  | 1 | 1.5 | DBP |  |
| tCE5 | CTS Low to ECLK Enabled |  | 10.5 |  | DBP |  |
| tCE6 | CTS High to ECLK Disabled |  | 1.0 | 1.5 | DBP |  |
| tCE7 | $\overline{\mathrm{CTS}}$ High to $\overline{\mathrm{BZO}}, \overline{\mathrm{BOO}}$ Disabled |  | 2.0 | 2.5 | DBP |  |
| DECODER SECTION |  |  |  |  |  |  |
| tCD1 | UDI to SDO, $\overline{\text { NVM }}$ | 2.5 |  | 3 | DBP (3) |  |
| tCD2 | DCLK to SDO, $\overline{\mathrm{NVM}}$ |  |  | 40 | ns |  |
| tCD3 | $\overline{\text { RST }}$ Low to DCLK, SDO, |  | 0.5 | 1.5 | DBP (3) | $C L=50 \mathrm{pF}$ |
|  | $\overline{\text { NVM Low }}$ |  |  |  |  |  |
| tCD4 | RST High to DCLK Enabled |  | 0.5 | 1.5 | DBP (3) | $C L=50 \mathrm{pF}$ |
| REPEATER MODE |  |  |  |  |  |  |
| tR1 | UDI to $\overline{\mathrm{BOO}}, \overline{\mathrm{BZO}}$ |  | 1 |  | DBP (3) |  |
| tR2 | ECLK to $\overline{\mathrm{BZO}}$ |  |  | 40 | ns |  |
| tR3 | UDI to SDO, $\overline{\text { NVM }}$ | 2.5 |  | 3 | DBP (3) |  |

NOTES: (1) CR - Clock Rate, either 16X or 32 X
(2) $\mathrm{t}_{\mathrm{C}}=1 / \mathrm{f}_{\mathrm{C}}$
(3) DBP - Data Bit Period, $C R=16 \mathrm{X}$, one $D B P=16$ Clock cycles; $C R=32 X$, one $D B P=32$ clock cycles

* Guaranteed and sampled but not $100 \%$ tested.


## Converter Mode

## ENCODER OPERATION

The encoder uses free running clocks at 1 X and 2 X the data rate derived from the system clock IX for internal timing. $\overline{\mathrm{CTS}}$ is used to control the encoder outputs, ECLK, $\overline{\mathrm{BOO}}$ and $\overline{B Z O}$. A free running $1 \times$ ECLK is transmitted out of the encoder to drive the external circuits which supply the NRZ data to the MED at pin SD/CDS.

A low on $\overline{\mathrm{CTS}}$ enables encoder outputs ECLK, $\overline{\mathrm{BOO}}$ and $\overline{B Z O}$, while a high on CTS forces BZO, BOO high and hoids ECLK low. When $\overline{C T S}$ goes from high to low (1), a synchronization sequence is transmitted out on $\overline{\mathrm{BOO}}$ and $\overline{\mathrm{BZO}}$. A synchronization sequence consists of eight Manchester
" 0 " bits followed by a command sync pulse. (2) A command sync pulse is a three bit wide pulse with the first $11 / 2$ bits high followed by $1 \frac{1}{2}$ bits low. (3) Serial NRZ data is clocked into the encoder at SD/CDS on the high to low transition of ECLK during the command sync pulse. The NRZ data received is encoded into Manchester II data and transmitted out on $\overline{\mathrm{BOO}}$ and $\overline{\mathrm{BZO}}$ following the command sync pulse. (4) Following the synchronization sequence, input data is encoded and transmitted out continuously without parity check or word framing. The length of the data block encoded is defined by CTS. Manchester data out is inverted.


FIGURE 1

## DECODER OPERATION

The decoder requires a single clock with a frequency 16X or 32 X the desired data rate. The rate is selected on the speed select with SS low producing a 16 X clock and high a 32 X clock. For long data links the 32X mode should be used as this permits a wider timing jitter margin. The internal operation of the decoder utilizes a free running clock synchronized with incoming data for its clocking.

The Manchester II encoded data can be presented to the decoder in either of two ways. The Bipolar One and $\mathrm{Bi}-$ polar Zero inputs will accept data from differential inputs such as a comparator sensed transformer coupled bus. The Unipolar Data input can only accept noninverted Manchester II encoded data, i.e. Bipolar Zero Out of an encoder. The decoder continuously monitors this data input for a valid sync pattern. Note that while the MED encoder section can generate only a command sync pattern, the decoder can recognize either a command or data sync pattern. A data sync is a logically inverted command sync.

There is a three bit delay between UDI, BOI or BZI input and the decoded NRZ data transmitted out of SDO.

Control of the decoder outputs is provided by the $\overline{\mathrm{RST}}$ pin. When $\overline{R S T}$ is low, SDO, DCLK and $\overline{\text { NVM }}$ are forced low. When $\overline{\text { RST }}$ is high, SDO is transmitted out synchronously with the recovered clock DCLK. The NVM output remains low after a low to high transition on RST until a valid sync pattern is received.

The decoded data at SDO is in NRZ format. DCLK is provided so that the decoded bits can be shifted into an external register on every high to low transition of this clock.

Three bit periods after an invalid Manchester bit is received on UDI, or BOI and BZI, $\overline{N V M}$ goes low synchronously with the questionable data output on SDO. Further, the decoder does not reestablish proper data decoding until another sync pattern is recognized.


For expanded view see Figure 8.
FIGURE 2

## Repeater Mode

Manchester II data can be presented to the repeater in either of two ways. The inputs Bipolar One In and Bipolar Zero In will accept data from differential inputs such as a comparator or sensed transformer coupled bus. The input Unipolar Data In accepts only non-inverted Manchester II coded data. The decoder requires a single clock with a frequency 16 X or 32 X the desired data rate. This clock is selected to 16 X with Speed Select low and 32 X with Speed Select high. For long data links the 32X mode should be used as this permits a wider timing jitter margin.

The inputs UDI, or BOI, BZI are delayed approximately $1 / 2$ bit period and repeated as outputs $\overline{\mathrm{BOO}}$ and $\overline{\mathrm{BZO}}$. The $2 X$ ECLK is transmitted out of the repeater synchronously with $\overline{\mathrm{BOO}}$ and $\overline{\mathrm{BZO}}$.

A low on $\overline{\mathrm{CTS}}$ enables ECLK, $\overline{\mathrm{BOO}}$, and $\overline{\mathrm{BZO}}$. In contrast to the converter mode, a transition on CTS does not initiate a synchronization sequence of eight 0 's and a command sync. The repeater mode does recognize a command or data sync pulse. SD/CDS is an output which reflects the state of the most recent sync pulse received, with high indicating a command sync and low indicating a data sync.

When $\overline{\text { RST }}$ is low, the outputs SDO, DCLK, and $\overline{\text { NVM }}$ are low, and SRST is set low. SRST remains low after RST goes high and is not reset until a sync pulse and two valid manchester bits are received with the reset bit low. With RST high, NRZ Data is transmitted out of Serial Data Out synchronously with the $1 \times$ DCLK.


FIGURE 3

## Switching Waveforms



FIGURE 4


FIGURE 5

NOTE: Reference parameters $\mathbf{t 6}, \mathbf{t 7}, \mathbf{t 8}, \mathbf{t 9}$

## Encoder Timing



FIGURE 6


## Decoder Timing



NOTE: Manchester Data In is not synchronous with Decoder Clock.
Decoder Clock is synchronous with decoded NRZ out of SDO.

FIGURE 8


FIGURE 9

## Repeater Timing



FIGURE 10

## MANCHESTER CODE

Nonreturn to Zero (NRZ) code represents the binary values logic-0 and logic-1 with a static level maintained throughout the data cell. In contrast, Manchester code represents data with a level transition in the middle of the data cell. Manchester has bandwidth, error detection, and synchronization advantages over NRZ code.

The Manchester II code Bipolar One and Bipolar Zero shown below are logical complements. The direction of the transition indicates the binary value of data. A logic-0 in Bipolar One is defined as a low to high transition in the middle of the data cell, and a logic-1 as a high to low mid bit transition. Manchester I code is not properly decoded by the HD-6409. Manchester II is also known as Biphase-L code.

The bandwidth of NRZ is from DC to the clock frequency $\mathrm{fc} / 2$, while that of Manchester is from fc/2 to fc. Thus, Manchester can be AC or transformer coupled, which has considerable advantages over DC coupling. Also, the ratio of maximum to minimum frequency of Manchester extends one octave, while the ratio for NRZ is the range of 5-10 octaves. It is much easier to design a narrow band than a wideband amp.

Secondly, the mid bit transition in each data cell provides the code with an effective error detection scheme. If noise produces a logic inversion in the data cell such that
there is no transition, an error indiction is given, and synchronization must be re-established. This places relatively stringent requirements on the incoming data.

The synchronization advantages of using the HD-6409 and Manchester code are several fold. One is that Manchester is a self clocking code. The clock in serial data communication defines the position of each data cell. Non self clocking codes, as NRZ, often require an extra clock wire or clock track (in magnetic recording). Further, there can be a phase variation between the clock and data track. Crosstalk between the two may be a problem. In Manchester, the serial data stream contains both the clock and the data, with the position of the mid bit transition representing the clock, and the direction of the transition representing data. There is no phase variation between the clock and the data.

A second synchronization advantage is a result of the number of transitions in the data. The decoder resynchronizes on each transition, or at least once every data cell. In contrast, receivers using NRZ, which does not necessarily have transitions, must resynchronize on frame bit transitions, which occur far less often, usually on a character basis. This more frequent resynchronization eliminates the cumulative effect of errors over sucessive data cells. A final synchronization advantage concerns the HD-6409's sync pulse used to initiate synchronization. This three bit wide pattern is sufficiently distinct from Manchester data that a false start by the receiver is unlikely.


FIGURE 11

## Crystal Oscillator Mode



## LC Oscillator Mode



## Features

Pinout

Top View


## Description

The HD-6406 (PACI) is a high performance programmable Universal Asynchronous Receiver/Transmitter (UART) and Baud Rate Generator (BRG) on a single chip. Utilizing Harris Semiconductor's advanced Scaled SAJI IV CMOS process, the PACI will support data rates from DC to 1Mbaud ( $0-16 \mathrm{MHz}$ clock). In addition to all standard UART functions, the PACI includes a complete Data Communications Equipment (DCE) interface.

Provision is made for DMA control of the PACI so that operation at the higher data rates is not hindered by slow microprocessor response times. An ALE control input permits direct interfacing to multiplexed data/address buses common to many microprocessors.

The interrupt structure of the PACI is user-programmable and can be configured to provide a single interrupt for any status change. A subsequent read of an internal status register will identify the source of the interrupt. If desired, the PACl can also provide separate hardware interrupt outputs for the receiver, transmitter and modem status changes. Separate error condition outputs can be used to pinpoint the exact cause of any detected error condition.

## Block Diagram



CAUTION: These devices are sensitive to electrostatic discharge. Users should follow standard IC Handling Procedures.

| 1/0 | PIN | SYMBOL | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1,39 | $\overline{\mathrm{CSO}}, \mathrm{CS1}$ | Low, High | CHIP SELECTS: The chip select inputs act as enable signals for the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ input signals during all non-DMA bus operations. |
| 1 | 2 | $\overline{\mathrm{RD}}$ | Low | READ: The $\overline{R D}$ input causes data to be output to the data bus (D0-D7). The data output depends upon the state of the address inputs (AO, A1) during non-DMA operations. During DMA read operations (RXDACK true) the address inputs are ignored and the contents of the Receiver Buffer Register is output providing the DR bit in the Modem Status Register (MSR) is true. |
| 1 | 3 | $\overline{W R}$ | Low | WRITE: The $\overline{W R}$ input causes data from the data bus (D0-D7) to be input to the PACI. Addressing and chip select action is the same as for read operations with the exception that TXDACK provides the select qualifier for DMA write operations providing the TBRE bit in the MSR is true. |
| 1/0 | 4-11 | D0-D7 | High | DATA BITS 0-7: The Data Bus provides eight, 3-state input/output lines for the transfer of data, control and status information between the PACI and the CPU. For character formats of less than 8 bits, the corresponding D7, D6 and D5 are considered "don't cares" for data writes and are 0 for data reads. These lines are normally at their high impedance state except during read operations. DO is the LSB and is the first serial data bit received or transmitted. |
| 1 | 12,13 | A0, A1 | High | ADDRESS 0, 1: The address lines select the various internal registers during CPU bus operations. Qualified DMA operations ignore the address inputs and access the appropriate receive or transmit buffer register. |
| 1 | 14 | ALE | High | ADDRESS LATCH ENABLE: ALE true enables the internal transparent address latches for the A0, A1 inputs. The address is latched when ALE goes false (low). |
| 1 | 15 | $\overline{\text { TXDACK }}$ | Low | TRANSMIT DMA ACKNOWLEDGE: A true TXDACK notifies the PACI that a transmit DMA cycle has been granted. It acts as a chip select which enables the $\overline{W R}$ input to access the Transmitter Buffer Buffer Register when the TBRE bit in the MSR is true. |
| 1 | 16 | $\overline{\text { RXDACK }}$ | Low | RECEIVE DMA ACKNOWLEDGE: A true $\overline{\text { RXDACK }}$ notifies the PACI that a receive DMA cycle has been granted. It acts as a chip select which enables the $\overline{\mathrm{RD}}$ input to access the Receiver Buffer Register when the DR bit in the MSR is true. |
| 1,0 | 17, 18 | IX, OX |  | CRYSTAL/CLOCK: Crystal connections for the internal Baud Rate Generator. IX can also be used as an external clock input in which case OX should be left open. |
| 0 | 19 | SDO | High | SERIAL DATA OUTPUT: Serial data output from the PACI transmitter circuitry. A Mark ( 1 ) is high and a Space ( 0 ) is low. SDO is held in the Mark condition when the transmitter is disabled with CTS false, RST true, when the Transmitter Register is empty, or when in the Loop Mode. |
|  | 20 | GND | Low | GROUND: Power supply ground connection. |
| 0 | 21 | TC | High | TRANSMISSION COMPLETE: TC goes true when a complete character, including stop bits, has been been transmitted and TBRE is true. TC is reset with a data write to TBR. RST will set TC true. |
| 1 | 22 | $\overline{\text { RLSD }}$ | Low | RECEIVE LINE SIGNAL DETECT: The logical state of this input is reflected in the $\overline{\operatorname{RLSD}}$ bit of the Modem Status Register. Any change of state will cause an interrupt on INTR if INTEN and MIEN are true. |
| 1 | 23 | $\overline{\mathrm{CTS}}$ | Low | CLEAR TO SEND: The logical state of the $\overline{\mathrm{CTS}}$ line is reflected in the CTS bit of the Modem Status Register. Any change of state of CTS causes INTR to be set true when INTEN and MIEN are true. A false level on $\overline{\text { CTS }}$ will inhibit transmission of data on the SDO output and will hold SDO in the Mark (high) state. If $\overline{\mathrm{CTS}}$ goes false during transmission, the current character being transmitted will be completed. $\overline{\mathrm{CTS}}$ does not affect the Loop mode of operation. |
| 1 | 24 | $\overline{\text { DSR }}$ | Low | DATA SET READY: The logical state of the $\overline{\mathrm{DSR}}$ line is reflected in the Modem Status Register. Any change of state of $\overline{\text { DSR }}$ will cause INTR to be set if INTEN and MIEN are true. The state of this signal does not affect any other circuitry within the PACl . |
| 1 | 25 | $\overline{\mathrm{RI}}$ | Low | RING INDICATOR: The logical state of the $\overline{R I}$ line is reflected in the Modem Status Register. Any change of state of $\overline{R I}$ will cause INTR to be set if INTEN and MIEN are true. The state of this signal does not affect any other circuitry with in the PACI. |
| 0 | 26 | $\overline{\text { DTR }}$ | Low | DATA TERMINAL READY: The $\overline{\text { DTR }}$ signal can be set (low) by writing a logic 1 to the appropriate bit in the Modem Control Register (MCR). This signal is cleared (high) by writing a logic 0 to the same bit in the MCR or whenever a RST (High) is applied to the PACI. |

## Pin Description

| 1/0 | PIN | SYMBOL | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 27 | $\overline{\text { RTS }}$ | Low | REQUEST TO SEND: The $\overline{R T S}$ signal can be set (low) by writing a logic 1 to the appropriate bit in the MCR. This signal is cleared (High) by writing a logic 0 to the same bit in the MCR or whenever a RST (High) is applied to the PACI. |
| 0 | 28 | CO |  | CLOCK OUT: This output is user programmable to provide either buffered IX output or a buffered Baud Rate Generator (16x) clock output. The buffered Ix (Crystal or external clock source) output is provided when the BRSR bit 7 is set to a zero. Writing a logic one to BRSR bit 7 causes the CO output to provide a buffered version of the internal Baud Rate Generator clock which operates at sixteen times the programmed baud rate. |
| 0 | 29 | TBRE | High | TRANSMITTER BUFFER REGISTER EMPTY: The TBRE output is set (high) whenever the Transmitter Buffer Register (TBR) has transferred its data to the Transmit Register. Application of a RST to the PACI will also set the TBRE output. TBRE is cleared (Low) whenever data is written to the TBR. |
| 1 | 30 | RST | High | RESET: The RST input forces the PACI into an "Idle" mode in which all serial data activities are suspended. The Modem Control Register (MCR) along with its associated outputs are cleared. The UART Status Register (USR) is cleared except for the TBRE and TC bits which are set. The PACI remains in an "Idle" state until programmed to resume serial data activities. The RST input is a Schmitt trigger input. |
| 1 | 31 | SIE | High | SINGLE INTERRUPT ENABLE: A true (high) level on the SIE input enables interrupts caused by the DR and TBRE status bits. This enables the user to utilize a single hardware interrupt signal (INTR) for any status change within the PACI. |
| 1 | 32 | SFD | High | STATUS FLAGS DISABLE: Holding the SFD input true (high) prevents the true state of the USR bits PE, OE, FE and TC from causing an interrupt. This control input, like the SIE input, enables the user to define what status changes will effect the INTR output. |
| 0 | 33 | INTR | High | INTERRUPT REQUEST: The INTR output is enabled by the INTEN bit in the Modem Control Register (MCR). The MIEN bit and the SIE and SFD control inputs selectively enable various status changes to provide an input to the INTR logic. Figure 9 shows an overall view of the relationship of these interrupt control signals. |
| 1 | 34 | SDI | High | SERIAL DATA INPUT: Serial data input to the PACI receiver circuits. A Mark (1) is high, and a Space ( 0 ) is low. Data inputs on SDI are disabled when operating in the loop mode, when RST is true or when the Receiver Enable (REN) bit in the MCR register is false. |
| 0 | 35 | OE | High | OVERRUN ERROR: A true level on the OE output indicates that the Receiver Buffer Register (RBR) was full when a character was received. Transfer to the RBR will not occur. OE is updated each time a character is transferred to the RBR. RST high will set OE low. |
| 0 | 36 | FE | High | FRAMING ERROR: A true level on the FE output indicates that there were invalid stop bits in the last received character. The FE output is updated each time a character is transferred to the RBR. RST high will reset $F E$. |
| 0 | 37 | PE | High | PARITY ERROR: PE is set true whenever the parity of a received character does not match the programmed parity. The PE output is updated each time a character is transferred to the RBR. PE is reset whenever RST is true or when no parity check is programmed. |
| 0 | 38 | DR | High | DATA READY: A true level indicates that a character has been received, transferred to the RBR and is ready for transfer to the CPU. DR is reset on a data read of the RBR or when RST is true. |
|  | 40 | VCC | High | +5 VOLT SUPPLY: Positive power supply connection. |

## Functional Description

## RESET

During and after power-up, the PACI should be given a RST high for at least two IX clock cycles in order to initialize and drive the PACl's circuits to an idle mode until proper programming can be done. A high on RST causes the following events to occur:

- Resets the internal BRG circuits, clock counters and bit counters. The Baud Rate Select Register (BRSR) is not affected.
- Clears the UART Status Register (USR) except for TC and TBRE which are set. The Modem Control Register (MCR) is also cleared. All of the discrete lines, memory elements and miscellaneous logic associated with these register bits are also cleared or turned off. Note that the UART Control Register (UCR) is not affected.

Following removal of the reset condition (RST low), the PACl remains in the idle mode until programmed to its desired system configuration.

## PROGRAMMING THE HD-6406 PACI

The complete functional definition of the PACI is programmed by the systems software. A set of control words (UCR, BRSR and MCR) must be sent out by the CPU to initialize the PACI to support the desired communication format. These control words will program the character length, number of stop bits, even/odd/no parity, baud rate etc. Once programmed, the PACI is ready to perform its communication functions.

The control registers can be written to in any order, however the MCR should be written to last because it controls the interrupt enables, modem control outputs and the receiver enable bit. Once the PACl is programmed and operational these registers can be updated any time that the PACl is not immediately transmitting or receiving data.

Table 1 shows the required control signals to access the PACI's internal registers.

| ALE | CSO | CS1 | A1 | AO | $\overline{W R}$ | $\overline{\mathrm{RD}}$ | OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 or Z | 0 | 1 | 0 | 0 | 5 | 1 | Data bus $\longrightarrow$ TBR |
| 1 or ${ }^{1}$ | 0 | 1 | 0 | 0 | 1 | z | RBR $\longrightarrow$ Data bus |
| 1 or ${ }^{1}$ | 0 | 1 | 0 | 1 | 4 | 1 | Data bus $\longrightarrow$ UCR |
| 1 or $\bar{z}$ | 0 | 1 | 0 | 1 | 1 | 2 | USR $\longrightarrow$ Data bus |
| 1 or $\bar{z}$ | 0 | 1 | 1 | 0 | 4 | 1 | Data bus $\longrightarrow$ MCR |
| 1 or $\bar{z}$ | 0 | 1 | 1 | 0 | 1 | z | MCR $\longrightarrow$ Data bus |
| 1 or $\bar{z}$ | 0 | 1 | 1 | 1 | 5 | 1 | Data bus $\longrightarrow$ BRSR |
| 1 or ${ }^{\text {d }}$ | 0 | 1 | 1 | 1 | 1 | $\underline{2}$ | MSR $\longrightarrow$ Data bus |

TABLE 1
The Address Latch Enable (ALE) input acts as an address latch control signal during these operations. If ALE is left high, the address inputs A0, A1 must be held true during the entire bus operation (demultiplexed bus operation). For multiplexed bus applications the address inputs A0, A1 are latched when ALE goes low. In this case AO and A1 are not required to be held true for the entire bus cycle.

DMA control of the PACI is discussed in a later section of this data sheet and involves reading and writing of the Receiver and Transmitter Buffer Registers (RBR and TBR).

The following descriptions discuss the control registers in detail.

## UART CONTROL REGISTER (UCR)

The UCR is a write only register which configures the UART transmitter and receiver circuits. Data bits D7 and D6 are not used but should always be set to a zero in order to insure software compatability with future product upgrades. During the Echo Mode, the transmitter always repeats the received word and parity, even when the UCR is programmed with different or no parity.

UCR


FIGURE 1

## BAUD RATE SELECT REGISTER (BRSR)

The PACl is designed to operate with a single crystal or external clock driving the IX input pin. The Baud Rate Select Register is used to select which divide ratio (one of 72) the internal Baud Rate Generator circuitry will use. The internal circuitry is seperated into two separate counters, a Prescaler and a Divisor Select. The Prescaler can be set to any one of four division rates, $\div 1, \div 3, \div 4$ or $\div 5$. This Prescaler design has been optimized to provide standard baud rates using any one of three popular crystal frequencies. By using one of these common system clock frequencies, $1.8432 \mathrm{MHz}, 2.4576 \mathrm{MHz}$ or 3.072 MHz and a Prescaler of $\div 3, \div 4$ or $\div 5$ respectively, the Prescaler output will provide a constant $614,400 \mathrm{~Hz}$. When this frequency is further divided by the Divisor Select counter, any of the standard baud rates from 50 to 38.4 KBaud can be selected (see Table 2). Non-standard baud rates up to 1 Mbaud can be selected by using different input frequencies (up to 16 MHz ) and/or different Prescaler and Divisor Select ratios. The baud rate generator provides a clock which is 16 times the desired baud rate. For example, in order to operate at a 1 Mbaud data rate a 16 MHz crystal, a Prescale rate of $\div 1$, and a Divisor Select rate of "external" would be used to provide a 16 MHz clock as the output of the Baud Rate Generator to the Transmitter and Receiver Circuts.

The CO select bit in the BRSR selects whether a buffered version of the external frequency input (IX input) or the Baud Rate Generator output (16X baud rate clock) will be output on the CO output (pin 28). The Baud Rate Generator output will always be a $50 \%$ nominal duty cycle except when "external" is selected and the Prescaler is set to $\div 3$ or $\div 5$.

BRSR


FIGURE 2

| BAUD RATE | DIVISOR |
| :---: | :---: |
| 38.4 K | external |
| 19.2 K | 2 |
| 9600 | 4 |
| 7200 | $16 / 3$ |
| 4800 | 8 |
| 3600 | $32 / 3$ |
| 2400 | 16 |
| $2000^{*}$ | $58 / 3$ |
| 1800 | 22 |
| 1200 | 32 |
| 600 | 64 |
| 300 | 128 |
| 200 | 192 |
| 150 | 256 |
| $134.5^{*}$ | 288 |
| $110^{*}$ | 352 |
| 75 | 512 |
| 50 | 768 |

TABLE 2
Note: These baud rates are based upon the following input frequency/Prescale divisor combinations. 1.8432 MHz and Prescale $=\div 3$
2.4576 MHz and Prescale $=\div 4$
3.072 MHz and Prescale $=\div 5$
*All baud rates are exact except for:

| BAUD RATE | ACTUAL | PERCENT <br> ERROR |
| :---: | :---: | :---: |
| 2000 | 1986.2 | $0.69 \%$ |
| 134.5 | 133.33 | $0.87 \%$ |
| 110 | 109.71 | $0.26 \%$ |

## MODEM CONTROL REGISTER

The MCR is a general purpose control register which can be written to and read from. The $\overline{R T S}$ and $\overline{D T R}$ outputs are directly controlled by their associated bits in this register. Note that a logic one asserts a true logic level (low) at these output pins. The Interrupt Enable (INTEN) bit is the overall control for the INTR output pin. When INTEN is false, INTR is held false (low). The Operating Mode bits configure the PACl into one of four possible modes. "Normal" configures the PACI for normal full or half duplex communications. "Transmit Break" enables the transmitter to only transmit break characters (Start, Data and Stop bits all are logic zero). The Echo Mode causes any data that is received on the SDI input pin to be re-transmitted on the SDO output pin. Note that this output is a buffered version of the data seen on the SDI input and is not a re-synchronized output (see Figure4). The Loop Test Mode internally routes transmitted data to the receiver circuitry for the purpose of self test. The transmit data is disabled from the SDO output pin. The Receiver Enable bit gates off the input to the receiver circuitry when in the false state. Modem Interrupt Enable will permit any change in modem status line inputs ( $\overline{C T S}$, $\overline{R T}, \overline{R L S D}, \overline{\mathrm{DSR}}$ ) to cause an interrupt when this bit is enabled. Bit D7 must always be written to with a logic zero to insure correct PACI operation.

MCR


FIGURE 3


FIGURE 4 - Loop and Echo Mode Functionality

## UART STATUS REGISTER (USR)

The USR provides a single register that the controlling system can examine to ascertain if errors have occured or if other status changes in the PACI require the system's attention. For this reason, the USR is usually the first register read by the CPU to determine the cause of an interrupt or to poll the status of the PACI. Three error flags OE, FE and PE report the status of any error conditions detected in the receiver circuitry. These error flags are updated with every character received during reception of the stop bits. The Overrun Error (OE) indicates that a character in the Receiver Register has been received and cannot be transferred to the Receiver Buffer Register (RBR) because the RBR was not read by the CPU. Framing Error (FE) indicates that the last character received contained improper stop bits. This could be caused by the total absence of the required stop bit(s) or by a stop bit(s) that was too short to be properly detected. Parity Error (PE) indicates that the last character received contained a parity error based on the programmed parity of the receiver and the calculated parity of the received characters data and parity bits.

The Received Break (RBRK) status bit indicates that the last character received was a break character. A break character would be considered to be an invalid data character in that the entire character including parity and stop bits are a logic zero.
The Modem Status bit is set whenever a transition is detected on any of the Modem input lines ( $\overline{\mathrm{RI}}, \overline{\mathrm{RLSD}}, \overline{\mathrm{CTS}}$ or $\overline{\mathrm{DSR}})$. A subsequent read of the Modem Status Register will show the state of these four signals. Assertion of this bit will cause an interrupt (INTR) to be generated if the MIEN and INTEN bits in the MCR register are enabled.

The Transmission Complete (TC) bit indicates that both the TBR and Transmitter Registers are empty and the PACI has completed transmission of the last character it was commanded to transmit. The assertion of this bit will cause an interrupt (INTR) if the SFD (pin 32) input is low and the INTEN bit in the MCR register is true.

USR


$$
\begin{aligned}
& 0=\text { No Error } \\
& 1=\text { Error } \\
& 0=\text { No error } \\
& 1=\text { Error } \\
& 0=\text { No error } \\
& 1=\text { Error } \\
& 0=\text { No break } \\
& 1=\text { Break } \\
& 0=\text { No status change } \\
& 1=\text { Status change } \\
& 0=\text { Not complete } \\
& 1=\text { Complete } \\
& 0=\text { Not empty } \\
& 1=\text { Empty } \\
& 0=\text { Not ready } \\
& 1=\text { Ready }
\end{aligned}
$$

FIGURE 5
The Transmitter Buffer Register Empty (TBRE) bit indicates that the TBR register is empty and ready to receive another character. Assertion of this bit will cause an interrupt if the SIE (pin 31) input is high and the INTEN bit in the MCR is enabled.

The Data Ready (DR) bit indicates that the RBR has been loaded with a received character and that the CPU may access this data. An interrupt will be generated (INTR) if SIE input is high and the INTEN bit is enabled.

## MODEM STATUS REGISTER (MSR)

The MSF; provides a means whereby the CPU can read the modem signal inputs by accessing the data bus interface of the PACI. Like all of the register images of external pins in the PACl , true logic levels are represented by a high (1) signal level. By following this consistent definition the system software need not be concerned with whether external signals are high or low true. In particular the modem signal inputs are low true, thus a 0 (true assertion) at a modem input pin is represented by a 1 (true) in the MSR.

Any change of state of any of the modem input signals will set the Modem Status (MS) bit in the USR register. When this happens an interrupt (INTR) will be generated if the MIEN and INTEN bits of the MCR are enabled.

The Ring Indicator ( $\overline{\mathrm{RI} \text { ) input indicates to the PACI that }}$ the modem is receiving a ringing signal.

The Receive Line Signal Detect ( $\overline{R L S D}$ ) input is used to notify the PACl that the signal quality received by the modem is within acceptable limits.

The Data Set Ready ( $\overline{\mathrm{DSR}}$ ) input is a status indicator from the modem to the PACI which indicates that the modem is ready to provide received data to the PACI receiver circuitry.

Clear to Send ( $\overline{\mathrm{CTS}}$ ) is both a status and control signal from the modem that tells the PACI that the modem is ready to receive transmit data from the PACI transmitter output (SDO). A high (false) level on this input will inhibit the PACI from beginning transmission and if asserted in the middle of a transmission will only permit the PACl to finish transmission of the current character.


## FIGURE 6

## RECEIVER BUFFER REGISTER (RBR)

The receiver circuitry in the PACI is programmable for 5,6 , 7 or 8 data bits per character. For words of less than 8 bits, the data is right justified to the LSB (DO). Bit DO of a data word is always the first data bit received. The unused bits in a less than 8 bit word, at the parallel interface, are set to 0 by the PACI. Received data at the SDI input pin is shifted into the Receiver Register by an internal 1X clock
which has been synchronized to the incoming data based on the position of the start bit. When a complete character has been shifted into the Receiver Register, the assembled data bits are parallel loaded into the Receiver Buffer Register. Both the DR output pin and DR flag in the USR register are set. This double buffering of the received data permits continuous reception of data without losing any of the received data. While the Receiver Register is shifting a new character into the PACI, the Receiver Buffer Register is holding a previously received character for the system CPU to read. Failure to read the data in the RBR before complete reception of the next character can result in the loss of the data in the Receiver Register. The OE flag in the USR register indicates the overrun condition.

RBR


Note: The LSB, Bit 0 is the first serial data bit received.
FIGURE 7

## TRANSMITTER BUFFER REGISTER (TBR)

The Transmitter Buffer Register (TBR) accepts parallel data from the microprocessor data bus (D0-D7) and holds it until the Transmitter Register is empty and ready to accept a new character for transmission. The transmitter always has the same word length and number of stop bits as the receiver. For words of less than 8 bits the unused bits at the microprocessor data bus are ignored by the transmitter. Bit 0 , which corresponds to DO at the data bus, is always the first serial data bit transmitted. Provision is

TBR


Note: The LSB, Bit 0 is the first serial data bit transmitted.
FIGURE 8
made for the transmitter parity to be the same or different from the receiver. The TBRE output pin and flag (USR register) reflect the status of the TBR. The TC output pin and flag (USR register) indicates when both the TBR and TR are empty.

## PACI INTERRUPT STRUCTURE

The PACI has provision for both software and hardware masking of interrupts generated for the INTR output pin. The two input pins, SIE and SFD, provide the mask control for the receiver and transmitter status interrupts. Two control bits in the MCR register, MIEN and INTEN, control modem status interrupts and overall PACI interrupts respectively. Figure 9 illustrates the logical control function provided by these signals.

The modem status inputs ( $\overline{\mathrm{RLSD}}, \overline{\mathrm{RI}}, \overline{\mathrm{DSR}}$ and $\overline{\mathrm{CTS}}$ ) will trigger the edge detection circuitry with any change of status. Reading the MSR register will clear the detect circuit but has no effect on the status bits themselves. These status bits always reflect the state of the input pins regardless of the mask control signals. Note that the state (high or low) of the status bits are inverted versions of the actual input pins.

The edge detection circuits for the USR register signals will trigger only for a positive edge (true assertion) of these status bits. Reading the USR register not only clears the edge detect circuit but also clears (sets to 0 ) all of the status bits. The output pins associated with these status bits are not affected by reading the USR register.


FIGURE 9

## DMA CONTROL OF THE PACI

Because of the high data rates possible with the PACl , provision for DMA control of the transmitter and receiver buffer registers has been included in the design. The $\overline{\text { RXDACK }}$ and TXDACK inputs in conjunction with the $\overline{R D}$ and $\overline{W R}$ inputs are driven by the system DMA controller to access the RBR and TBR registers respectively.

Reading of the RBR via the $\overline{\mathrm{RXDACK}}$ control signal requires that the DR bit in the USR is set (high) and that the $\overline{R D}$ input be driven low. When these conditions are
met the address logic overrides the address inputs (AO, A1) and forces a read of the RBR. Similarly, a DMA write to the TBR requires that the TBRE bit in the USR register is set (high) and that TXDACK and $\overline{W R}$ are asserted by the DMA controller. Once again the address logic overrides the address inputs and forces a write to the TBR register.

The $\overline{C S O}$ and CS1 inputs would normally be in their inactive state during DMA accesses. The A0, A1, and ALE inputs are overridden during DMA operations and as such their logical state is a don't care.

## CRYSTAL OPERATIONS

The PACI crystal oscillator circuitry is designed to operate with a fundamental, parallel resonent crystal. This circuit is the same as used in the Harris 82C84A clock generator/ driver and as such the general applications information contained in Tech Brief TB-47 that applies to the oscillator operation will be pertinent to the PACl . To summarize Table 3 and Figure 10 show the required crystal parameters and crystal circuit configuration respectively.

When using an external clock source the Ix input is driven and the Ox output is left open. Power consumption when using an external clock is typically 2 times lower than when using a crystal. This is due to the sinusoidal nature of the drive circuitry when using a crystal.

| PARAMETER | TYPICAL CRYSTAL SPECIFICATION |
| :---: | :---: |
| Frequency <br> Type of Operation Load Capacitance (CL) $\mathrm{R}_{\text {series }}($ Max. $)$ | 1.0 to 16 MHz <br> Parallel resonent, Fund. mode 20 or 32 pf. (typ.) <br> 100 ohms ( $f=16 \mathrm{MHz}, \mathrm{CL}=32 \mathrm{pf}$.) <br> 200 ohms ( $\mathrm{f}=16 \mathrm{MHz}, \mathrm{CL}=20 \mathrm{pf}$.) |

TABLE 3


* C1 $=\mathbf{C 2} \approx 20$ pf for $C L=20 p f$. $C 1=C 2 \approx 47 \mathrm{pf}$ for $\mathrm{CL}=32 \mathrm{pf}$.

FIGURE 10

REGISTER BIT ASSIGNMENT SUMMARY

| REGISTER NAME | MNEMONIC | BIT ASSIGNMENT |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LSB 0 | 1 | 2 | 3 | 4 | 5 | 6 | MSB 7 |
| Receiver Buffer | RBR | Bit 0 | Bit 1 | Bit 2 | Bit 3 | Bit 4 | Bit 5 | Bit 6 | Bit 7 |
| Transmitter Buffer | TBR | Bit 0 | Bit 1 | Bit 2 | Bit 3 | Bit 4 | Bit 5 | Bit 6 | Bit 7 |
| UART Status | USR | Parity Error (PE) | Framing Error (FE) | Overrun Error (OE) | Received Break (RBRK) | Modem Status (MS) | Transmission Complete (TC) | Transmitter Buffer Reg. empty (TBRE) | Data Ready (DR) |
| UART Control | UCR | Stop Bit Select | Parity Control 0 | Parity Control 1 | Parity Control 2 | Word Length 0 | Word Length 1 | Reserved* | Reserved * |
| Modem Control | MCR | Request To Send (RTS) | Data Terminal Ready (DTR) | Interrupt Enable (INTEN) | Mode Select 0 | Mode Select 1 | Receiver Enable (REN) | Modem Interrupt enable (MIEN) | 0 |
| Modem Status | MSR | Clear to Send (CTS) | Data Set Ready (DSR) | Received Line Signal Detect (RLSD) | Ring Indicator (RI) | Not Used | Not Used | Not Used | Not Used |
| Bit Rate Select | BRSR | Prescaler <br> Select 0 | Prescaler <br> Select 1 | Divisor <br> Select 0 | Divisor <br> Select 1 | Divisor Select 2 | Divisor <br> Select 3 | Divisor <br> Select 4 | Co Select |

[^14]
## Specifications

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 Volts |
| :--- | ---: |
| Operating Voltage Range | +4 V to +7 V |
| Input Voltage Applied | GND -2.0 V to +6.5 V |
| Output Voltage Applied | GND -0.5 V to $\mathrm{VCC}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | -650 C to $+150{ }^{\circ} \mathrm{C}$ |


| Operating Temperature Range |  |
| :--- | ---: |
| Industrial | -400 C to +850 C |
| Military | -550 C to +1250 C |
| Maximum Power Dissipation | 1 Watt |

CAUTION: Stresses above those listed in the "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D. C. CHARACTERISTICS
$V C C=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=-400 \mathrm{C}$ to $+850 \mathrm{C}(-9) ; T_{A}=-550 \mathrm{C}$ to $+1250 \mathrm{C}(-2,-8)$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | 2.0 |  | V |  |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| VTH | Schmidt Trigger Logical One Input Voltage | VCC -0.5 |  | V | Reset Input |
| VTL | Schmidt Trigger Logical One Input Voltage |  | GND +0.5 | V | Reset Input |
| VIH (CLK) | Logical One Clock Voltage | VCC -0.5 |  | V | External Clock |
| VIL (CLK) | Logical Zero Clock Voltage |  | GND +0.5 | V | External Clock |
| VOH | Output High Voltage | $\begin{gathered} 3.0 \\ \text { VCC }-0.4 \end{gathered}$ |  | $\begin{aligned} & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-2.5 \mathrm{~mA} \\ & \mathrm{IOH}=-400 \mu \mathrm{~A} \end{aligned}$ |
| VOL | Output Low Voltage |  | 0.4 | V | $1 \mathrm{OL}=+2.5 \mathrm{~mA}$ |
| IIL | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{VCC}$ |
| IOL | Output Leakage Current | -10.0 | +10.0 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leq \mathrm{VO} \leq \mathrm{VCC}$ |
| ICCOP* | Operating Power Supply Current |  | 3 | ma | External Clock $\begin{aligned} & \mathrm{F}=2.4576 \mathrm{MHz} \\ & \mathrm{VCC}=5.5 \mathrm{~V} \\ & \mathrm{VIN}=\mathrm{VCC} \text { or GND } \\ & \text { Outputs Open } \end{aligned}$ |

* Guaranteed and sampled, but not $100 \%$ tested. ICCOP is typically $\leq 1 \mathrm{~mA} / \mathrm{MHz}$


## CAPACITANCE

$T A=25^{\circ} \mathrm{C} ; \mathrm{VCC}=\mathrm{GND}=0 \mathrm{~V} ; \mathrm{VIN}=+5 \mathrm{~V}$ or GND

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :---: |
| CIN* | Input Capacitance |  | 10 | pf | FREQ $=1 \mathrm{MHz}$ <br>  <br>  <br> COUT* Output Capacitance |
| CI/O* | I/O Capacitance |  |  |  | Uneasured pins <br> returned to GND |

*Guaranteed and sampled, but not $100 \%$ tested
A. C. CHARACTERISTICS

$$
\begin{aligned}
V C C=+5 \mathrm{~V} \pm 10 \%, G N D=0 V: T A & =-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(-9) \\
T A & =-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(-2,-8)
\end{aligned}
$$

TIMING REQUIREMENTS

| SYMBOL. | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TLHLL | ALE Pulse Width | 50 |  | ns |  |
| TAVLL | Address Setup | 20 |  | ns |  |
| TlLAX | Address Hold | 20 |  | ns |  |
| TSVCTL | Select Setup to Control leading edge | 30 |  | ns |  |
| TCTHSX | Select Hold from Control Trailing Edge | 50 |  | ns |  |
| TCTLCTH | Control Puise Width | 150 |  | ns | Control Consists of $\overline{R D}$ or $\overline{W R}$ |
| TCTHCTL | Control Disable to Control Enable | 100 |  | ns |  |
| TRLDV | Read low to Data Valid |  | 120 | ns | 1 |
| TRHDZ | Read Disable | 0 | 60 | ns | 2 |
| TCTHLH | Control Inactive to ALE High | 20 |  | ns |  |
| TDVWH | Data Setup Time | 50 |  | ns |  |
| TWHDX | Data Hold Time | 20 |  | ns |  |
| FC | Clock Frequency | 0 | 16 | MHz | TCHCL + TCLCH must be $\geq 62.5 \mathrm{~ns}$ |
| TCHCL | Clock High Time | 25 |  | ns |  |
| TCLCH | Clock Low Time | 25 |  | ns |  |
| TR/TF | IX Input <br> Rise/Fall Time ( $10 \%$ - $90 \%$ ) (External Clock) |  | tx | ns | $\mathrm{tx} \leq 1 /(6 \mathrm{FC})$ or 50 ns whichever is smaller |
| TFCO | Clock Output Fall Time |  | 15 | ns | $\mathrm{CL}=50 \mathrm{pf}$ |
| TRCO | Clock Output Rise Time |  | 15 | ns | $\mathrm{CL}=50 \mathrm{pf}$ |

## A.C. Test Circuits



| TEST CONDITION | V1 | R1 | R2 | CL |
| :--- | :---: | :---: | :---: | :---: |
| 1 Propagation Delay | 1.7 V | 520 | $\infty$ | 100 pF |
| 2 Disable Delay | VCC | 5 K | 5 K | 50 pF |

## A. C. Testing Input, Output Waveform

PROPAGATION DELAY


ENABLE/DISABLE DELAY

OUTPUT $\qquad$
A. C. Testing: All input signals must switch between VIL -0.4 V and $\mathrm{VIH}+0.4 \mathrm{~V}$. TR and TF must be less than or equal to 15 ns .

## Timing Diagrams

## MULTIPLEXED BUS OPERATION



DEMULTIPLEXED BUS OPERATION (ALE HIGH)


## Preview

## Features

- SINGLE CHIP UART/BRG
- DC TO 16 MHz OPERATION
- CRYSTAL OR EXTERNAL CLOCK INPUT
- ON CHIP BAUD RATE GENERATOR . . 72 SELECTABLE BAUD RATES
- INTERRUPT MODE WITH MASK CAPABILITY
- microprocessor bus oriented interface
- $80 C 86$ COMPATIBLE
- SCALED SAJI IV CMOS PROCESS
- SINGLE 5V POWER SUPPLY
- LOW POWER - $1 \mathrm{~mA} / \mathrm{MHz}$ TYPICAL
- modem interface
- LINE bREAK GENERATION AND DETECTION
- LOOPBACK AND ECHO MODES


## Description

Pinout

Top View

| $\overline{\text { RD }}$ | 28 | Cso |
| :---: | :---: | :---: |
| $\overline{W R}{ }^{2}$ | 27 | VCc |
| DO | 26 | DR |
| D1 4 | 25 | $\square$ SDI |
| D2 5 | 24 | $\square$ IntR |
| D3 $\square^{6}$ | 23 | $\square \mathrm{RST}$ |
| D4 5 | 22 | $\square$ TBRE |
| D5 당 | 21 | $\square \mathrm{CO}$ |
| 06 단 | 20 | $\square \mathrm{RTS}$ |
| D7 10 | 19 | DTR |
| AO 11 | 18 | $\square \overline{\text { DSR }}$ |
| A1 12 | 17 | ] CTS |
| 1x ${ }^{13}$ | 16 | $\square \mathrm{GND}$ |
| 0x ㄷ 14 | 15 | SDO |

The 82C52 is a high performance programmable Universal Asynchronous Receiver/Transmitter (UART) and Baud Rate Generator (BRG) on a single chip. Utilizing the Harris advanced Scaled SAJI IV CMOS process, the 82C52 will support data rates from D.C. to 1M baud asynchronously with a 16 X clock ( $0-16 \mathrm{MHz}$ clock frequency).

The on-chip Baud Rate Generator can be programmed for any one of 72 different baud rates using a single industry standard crystal or external frequency source. A unique pre-scale divide circuit has been designed to provide standard RS-232-C baud rates when using any one of three industry standard baud rate crystals ( $1.8432 \mathrm{MHz}, 2.4576 \mathrm{MHz}$, or 3.072 MHz ).

A programmable buffered clock output (CO) is available and can be programmed to provide either a buffered oscillator or 16X baud rate clock for general purpose system usage.

Inputs and outputs have been designed with full TTL/CMOS compatibility in order to facilitate mixed TTL/NMOS/CMOS system design.


CAUTION: These devices are sensitive to electrostatic discharge. Users should follow standard IC Handling Procedures.

## CMOS/LSI Universal Asynchronous Receiver Transmitter (UART)

## Features

- OPERATION FROM D.C TO 2.0 MHz © 5.0 VOLTS
- LOW POWER-TYP. 10 mW © 2.0MHz AND 5.0 VOLTS
- PROGRAMMABLE WORD LENGTH, STOP BITS AND PARITY
- AUTOMATIC DATA FORMATTING AND STATUS GENERATION
- COMPATIBLE WITH INDUSTRY STANDARD UART'S
- SINGLE POWER SUPPLY


## Description

The HD-6402 is a CMOS/LSI subsystem for interfacing computers or microprocessors to an asynchronous serial data channel. The receiver converts serial start, data, parity and stop bits to parallel data verifying proper code transmission, parity, and stop bits. The transmitter converts parallel data into serial form and automatically adds start, parity, and stop bits. The data word length can be 5, 6,7 or 8 bits. Parity may be odd or even. Parity checking and generation can be inhibited. The stop bits may be one or two or one and one-half when transmitting 5 bit code.

The HD-6402 can be used in a wide range of applications including modems, printers, peripherals and remote data aquisition systems. CMOS/LSI technology permits operation clock frequencies up to 2.0 MHz (125K Baud) an improvement of 10 to 1 over previous PMOS UART designs. Power requirements, by comparison, are reduced from 300 mW to 10 mW . Status logic increases flexibility and simplifies the user interface.

## Functional Diagram



Pinout
TOP VIEW


## Control Definition

CONTROL WORD
CHARACTER FORMAT

| $C$ | $C$ |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $L$ | $L$ | $P$ | $E$ | $S$ |  |  |  |  |
| $S$ | $S$ | $I$ | $P$ | $B$ | START | DATA | PARITY | STOP |
| 2 | 1 |  | $E$ | $S$ | BIT | BITS | BIT | BITS |
| 0 | 0 | 0 | 0 | 0 | 1 | 5 | ODD | 1 |
| 0 | 0 | 0 | 0 | 1 | 1 | 5 | ODD | 1.5 |
| 0 | 0 | 0 | 1 | 0 | 1 | 5 | EVEN | 1 |
| 0 | 0 | 0 | 1 | 1 | 1 | 5 | EVEN | 1.5 |
| 0 | 0 | 1 | $X$ | 0 | 1 | 5 | NONE | 1 |
| 0 | 0 | 1 | $X$ | 1 | 1 | 5 | NONE | 1.5 |
| 0 | 1 | 0 | 0 | 0 | 1 | 6 | ODD | 1 |
| 0 | 1 | 0 | 0 | 1 | 1 | 6 | ODD | 2 |
| 0 | 1 | 0 | 1 | 0 | 1 | 6 | EVEN | 1 |
| 0 | 1 | 0 | 1 | 1 | 1 | 6 | EVEN | 2 |
| 0 | 1 | 1 | $X$ | 0 | 1 | 6 | NONE | 1 |
| 0 | 1 | 1 | $X$ | 1 | 1 | 6 | NONE | 2 |
| 1 | 0 | 0 | 0 | 0 | 1 | 7 | ODD | 1 |
| 1 | 0 | 0 | 0 | 1 | 1 | 7 | ODD | 2 |
| 1 | 0 | 0 | 1 | 0 | 1 | 7 | EVEN | 1 |
| 1 | 0 | 0 | 1 | 1 | 1 | 7 | EVEN | 2 |
| 1 | 0 | 1 | $X$ | 0 | 1 | 7 | NONE | 1 |
| 1 | 0 | 1 | $X$ | 1 | 1 | 7 | NONE | 2 |
| 1 | 1 | 0 | 0 | 0 | 1 | 8 | ODD | 1 |
| 1 | 1 | 0 | 0 | 1 | 1 | 8 | ODD | 2 |
| 1 | 1 | 0 | 1 | 0 | 1 | 8 | EVEN | 1 |
| 1 | 1 | 0 | 1 | 1 | 1 | 8 | EVEN | 2 |
| 1 | 1 | 1 | $\times$ | 0 | 1 | 8 | NONE | 1 |
| 1 | 1 | 1 | $X$ | 1 | 1 | 8 | NONE | 2 |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage <br> Input or Output Voltage Applied | +8.0 V |
| :--- | ---: |
| Storage Temperature Range |  |
| Operating Temperature Range |  |
| Industrial HD-6402-9 |  |
| Military HD-6402-2/8 | GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |

## ELECTRICAL CHARACTERISTICS

$\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \% . \mathrm{TA}=$ Industrial or Military
D.C.

| SYMBOL | PARAMETER | MINIMUM | TYPICAL | MAXIMUM | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical "1" Input Voltage | 70\% Vcc |  |  | V |  |
| VIL | Logical " 0 " Input Voltage |  |  | 20\% VCC | V |  |
| IIL | Input Leakage | -1.0 |  | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VIN} \leq \mathrm{VCC}$ |
| VOH | Logical "1" Output Voltage | 2.4 |  |  | $v$ | $1 \mathrm{OH}=-0.2 \mathrm{~mA}$ |
| VOL | Logical " 0 " Output Voltage |  |  | 0.45 | $v$ | $1 \mathrm{OL}=2.0 \mathrm{~mA}$ |
| 10 | Output Leakage | -1.0 |  | 1.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VO} \leq \mathrm{VCC}$ |
| ICC | Supply Current |  | 1.0 | 100 | $\mu \mathrm{A}$ | VIN = GND or VCC; <br> VCC $=5.5 \mathrm{~V}$, Output |
| CIN | Input Capacitance* |  | 7.0 | 8.0 | pF | Open |
| Co | Output Capacitance* |  | 8.0 | 10.0 | pF |  |

*Guaranteed but not $100 \%$ tested
A.C.

|  |  | $\begin{aligned} V C C & =5.0 \mathrm{~V} \\ T_{A} & =25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{TA}_{\mathrm{A}}=\text { Indust. or Mil. } \end{aligned}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | TYP | MAX | MIN | TYP | MAX | UNITS | CONDITIONS |
| felock <br> ${ }^{\text {tpw }}$ <br> $t_{M R}$ <br> tSET <br> thOLD <br> tEN | Clock Frequency <br> Pulse Widths CRL, DRR, TBRL <br> Pulse Width MR <br> Input Data Setup Time <br> Input Data Hold Time <br> Output Enable Time | $\begin{gathered} \text { D.C. } \\ 150 \\ 350 \\ 50 \\ 60 \end{gathered}$ |  | $3.0$ $125$ | $\begin{array}{\|c} \hline \text { D.C. } \\ 150 \\ 400 \\ 50 \\ 60 \end{array}$ |  | $2.0$ $160$ | MHz <br> ns <br> ns <br> ns <br> ns <br> ns | $C_{L}=50 \mathrm{pF}$ <br> See Switching Time Waveforms 1, 2, 3 |

NOTE (1) All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information-not guaranteed.

## Transmitter Operation

The transmitter section accepts parallel data, formats it and transmits it in serial form on the TROutput terminal.
(A) Data is loaded into the transmitter buffer register from the inputs TR1 through TR8 by a logic low on the TBRLoad input. Valid data must be present at least tSET prior to and tHOLD following the rising edge of TBRL. If words less than 8 bits are used, only the least significant bits are used. The character is right justified into the least significant bit, TR1. (B) The rising edge of TBRL clears TBREmpty. 0 to 1 clock cycles later, data is transferred
to the transmitter register, TREmpty is cleared, TBREmpty is set high, and serial data transmission is started. Output data is clocked by TRClock. The clock rate is 16 times the data rate. (C) A second pulse on TBRLoad loads data into the transmitter buffer register. Data transfer to the transmitter register is delayed until transmission of the current character is complete. (D) Data is automatically transferred to the transmitter register and transmission of that character begins one clock cycle later.


## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0 V |
| :--- | ---: |
| Input or Output Voltage Applied | GND -0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$ |
| Storage Temperature Range | $-650^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range (Industrial -9) | $-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ |

ELECTRICAL CHARACTERISTICS VCC $=5.0 \mathrm{~V} \pm 10 \% . T_{A}=$ Industrial

| D.C. | SYMBOL | PARAMETER | MINIMUM | TYPICAL | MAXIMUM | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | VIH | Logical "1" Input Voltage | 70\% V ${ }_{\text {CC }}$ |  |  | V |  |
|  | VIL | Logical "0" Input Voltage |  |  | 20\% V ${ }_{\text {c }}$ | V |  |
|  | IIL | Input Leakage | -10.0 |  | +10.0 | $\mu \mathrm{A}$ | $O V \leq V_{I N} \leq V C C$ |
|  | VOH | Logical "1" Output Voltage | 2.4 |  |  | v | $1 \mathrm{OH}=-0.2 \mathrm{~mA}$ |
|  | VOL | Logical "0' Output Voltage |  |  | 0.45 | $v$ | $1 \mathrm{OL}=2.0 \mathrm{~mA}$ |
|  | 10 | Output Leakage | -10.0 |  | +10.0 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{VO} \leq \mathrm{VCC}$ |
|  | ICC | Supply Current |  | 1.0 | 800 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN }=G N D \text { or } V C C \\ & V C C=5.5 \mathrm{~V} \end{aligned}$ |
|  | CIN | Input Capacitance* |  | 7.0 | 8.0 | pF | Output Open |
|  | Co | Output Capacitance* |  | 8.0 | 10.0 | pF |  |


|  |  |  | $\begin{aligned} V C C & =5.0 \mathrm{~V} \\ T_{A} & =25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{aligned} \text { VCC } & =5.0 \mathrm{~V} \pm 10 \% \\ \mathrm{TA}^{2} & =\text { Industrial } \end{aligned}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SYMBOL | PARAMETER | MIN | TYP | MIAX | MIN | TYP | MAX | UNITS | CONDITIONS |
| A.C. | $f_{\text {clock }}$ <br> ${ }^{t}$ pw <br> ${ }^{t}$ MR <br> tSET <br> thOLD <br> ten | Clock Frequency <br> Pulse Widths CRL, DRR, TBRL <br> Pulse Width MR <br> Input Data Setup Time <br> Input Data Hold Time <br> Output Enable Time | $\begin{gathered} \text { D.C. } \\ 200 \\ 500 \\ 60 \\ 75 \end{gathered}$ |  | $2.0$ $150$ | $\begin{gathered} \text { D.C. } \\ 225 \\ 600 \\ 75 \\ 90 \end{gathered}$ |  | $1.0$ $190$ | $\begin{gathered} \mathrm{MHz} \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \mathrm{~ns} \end{gathered}$ | $C_{L}=50 \mathrm{pF}$ <br> See Switching Time Waveforms 1, 2, 3 |

NOTE (1.) All devices guaranteed at worst case limits. Room temperature, 5 V data provided for information-not guaranteed.

## Receiver Operation

Data is received in serial form at the RInput. When no data is being received, RInput must remain high. The data is clocked through the RRClock. The clock rate is 16 times the data rate. (A) A low level on DRReset clears the DReady line. (B) During the first stop bit data is transferred from the receiver register to the RBRegister. If the word is less than 8 bits, the unused most significant bits will be a logic low. The output character is right justified to the
least significant bit RBR1. A logic high on OError indicates overruns. An overrun occurs when DReady has not been cleared before the present character was transferred to the RBRegister. (C) 1 clock cycle later DReady is reset to a logic high, and FError is evaluated. A logic high on FError indicates an invalid stop bit was received, a framing error. A logic high on PError indicates a parity error.


## Start Bit Detection

The receiver uses a 16 X clock for timing. (A) The start bit could have occurred as much as one clock cycle before it was detected, as indicated by the shaded portion. The center of the start bit is defined as clock count $7 \frac{1}{2}$. If the receiver clock is a symet-
rical square wave, the center of the start bit will be located within $\pm 1 / 2$ clock cycle, $\pm \frac{1}{32}$ bit or $3.125 \%$ giving a receiver margin of $46.875 \%$. The receiver begins searching for the next start bit at the center of the first stop bit.


## Pin Assignment And Functions

| PIN | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: |
| 1 | VCC | Positive Voltage Supply |
| 2 | NC | No Connection |
| 3 | GND | Ground |
| 4 | RRD | A high level on RECEIVER REGISTER DISABLE |
|  |  | forces the receiver holding outputs RBR1-RBR8 to a high impedance state. |
| 5 | RBR8 | The contents of the RECEIVER BUFFER REGISTER |
|  |  | appear on these three-state outputs. Word formats less than 8 characters are right justified to RBR1. |
| 6 | RBR7 | See Pin 5 - RBR8 |
| 7 | RBR6 | See Pin 5 - RBR8 |
| 8 | RBR5 | See Pin 5-RBR8 |
| 9 | RBR4 | See Pin 5 -RBR8 |
| 10 | RBR3 | See Pin 5 -RBR8 |
| 11 | RBR2 | See Pin 5 - Rbr8 |
| 12 | RBR1 | See Pin 5 - RBR8 |
| 13 | PE | A high level on PARITY ERROR indicates received parity does not match parity programmed by control bits. When parity is inhibited this output is low. |


| PIN | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: |
| 14 | FE | A high level on FRAMING ERROR indicates the first <br> stop bit was invalid. <br> A high level on OVRRUN ERROR indicates the data <br> received flag was not cleared before the last character <br> was transferred to the received buffer register. <br> A high level on STATUS FLAGS DISABLE forces the <br> outputs PE, FE, OE, DR, TBRE to a high impedance <br> state. <br> The RECEIVER REGISTER CLOCK is 16X the re- <br> ceiver data rate. <br> A low level on DATA RECEIVED RESET clears the <br> data received output DR to a low level. <br> A high level on DATA RECEIVED indicates a char- <br> acter has been received and transferred to the receiver <br> buffer register. <br> Serial data on RECEIVER REGISTER INPUT is <br> clocked into the receiver register. <br> A high level on MASTER RESET clears PE, FE, OE, <br> and DR to a low level and sest the transmitter output <br> to a high level after 18 clock cycles. MR does not <br> clear the receiver buffer register. This input must be <br> pulsed at least once after power up. |
| 20 | OE | RRC |
| 19 | DRR |  |



| PIN | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: |
| 22 | TBRE | A high level on TRANMITTER BUFFER REGISTER EMPTY indicates the transmitter buffer register has transferred its data to the transmitter register and is ready for new data. |
| 23 | TBRL | A low level on TRANSMITTER BUFFER REGISTER LOAD transfers data from inputs TBR1-TBR8 into the transmitter buffer register. A low to high transition on TBRL indicates data transfer to the transmitter register is busy, transfer is automatically delayed so that the two characters are transmitted end to end. |
| 24 | TRE | A high level on TRANSMITTER REGISTER EMPTY indicates completed transmission of a character including stop bits. |
| 25 | TRO | Character data, start data and stop bits appear serially at the TRANSMITTER REGISTER OUTPUT. |
| 26 | TBR1 | Character data is loaded into the TRANSMITTER BUFFER REGISTER via inputs TBR1-TBR8. For character formats less than 8 bits the TBR8, 7, and 6 inputs are ignored corresponding to the programmed word length. |
| 27 28 | TBR2 TBR3 | See Pin 26 - TBR1 <br> See Pin 26 - TBR1 |


| PIN | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: |
| 29 | TBR4 | See Pin 26 - TBR1 |
| 30 | TBR5 | See Pin 26 - TBR1 |
| 31 | TBR6 | See Pin 26 - TBR1 |
| 32 | TBR7 | See Pin 26 - TBR1 |
| 33 | TBR8 | See Pin 26 - TBR1 |
| 34 | CRL | A high level on CONTROL REGISTER LOAD loads the control register. |
| 35 | PI | A high level on PARITY INHIBIT inhibits parity generation. Parity checking and forces PE output low. |
| 36 | SBS | A high level on STOP BIT SELECT selects 1.5 stop bits for 5 character format and 2 stop bits for other lengths. |
| 37 | CLS2 | These inputs program the CHARACTER LENGTH SELECTED (CLS1 low CLS2 low 5 bits) (CLS1 high CLS2 low 6 bits) (CLS1 low CLS2 high 7 bits) (CLS1 high CLS2 high 8 bits) |
| 38 | CLS1 | See Pin $37-\mathrm{CLS} 2$ |
| 39 | EPE | When PI is low, a high level on EVEN PARITY ENABLE generates and checks even parity. A low level selects odd parity. |
| 40 | TRC | The TRANSMITTER REGISTER CLOCK is 16 X the transmit data rate. |



The bit rate generator is shown supplying the transmit and receive clocks for the UART.


Switching Waveforms

figure 1
Data Input Cycle


FIGURE 2
Control Register Load Cycle


FIGURE 3
Status Flag Output Enable Time or Data Output Enable Time

## Features

－HD－4702－PROVIDES 13 COMMONLY USED BIT RATES
－USES A 2.4576 MHz CRYSTAL／INPUT FOR STANDARD FREQUENCY OUTPUT（ 16 TIMES BIT RATE）
－TTL COMPATIBLE－OUTPUT WILL SINK 1.6 mA
－LOW POWER DISSIPATION 4.5 mW TYP．＠ 2.4576 MHz
－CONFORMS TO EIA RS－404
－ONE HD－4702 CONTROLS UP TO EIGHT TRANSMISSION CHANNELS
－initialization circuit facilitates diagnostic fault ISOLATION
－ON－CHIP INPUT PULL－UP CIRCUIT

## Description

The HD－4702 Bit Rate Generator provides the necessary clock signals for digital data transmission systems，such as a UART．It generates 13 commonly used bit rates using an on－chip crystal oscillator or an external input．For conventional operation generating 16 output clock pulses per bit period，the input clock frequency must be 2.4576 MHz （i．e． 9600 Baud $\times 16 \times 16$ ，since there is an internal $\div 16$ prescaler）．A lower input frequency will result in a proportionally lower output frequency．

The HD－4702 can provide multi－channel operation with a minimum of external logic by having the clock frequency CO and the $\div 8$ prescaler outputs $\mathrm{O}_{0}, \mathrm{O}_{1}, \mathrm{O}_{2}$ available externally．All signals have a $50 \%$ duty cycle except 1800 Baud，which has less than $0.39 \%$ distortion and 3600 Baud，which has less than $0.78 \%$ distortion．

The four rate select inputs（ $\mathrm{S}_{0}-\mathrm{S}_{3}$ ）select which bit rate is at the output $(Z)$ ．The table lists select code and output bit rate．Two of the 16 for the HD－4702 do not select an internally generated frequency，but select an input into which the user can feed either a different frequency，or a static level（High or Low）to generate＂ZERO BAUD＂．

The bit rate most commonly used in modern data terminals（110，150， $300,1200,2400$ Baud）require that no more than one input be grounded for the HD－4702，which is easily achieved with a single 5－position switch．

The HD－4702 has an initialization circuit which generates a common master reset for all flip－flops．This signal is derived from a digital differentiator that senses the first high level on the CP input after the $\bar{E}_{\mathrm{CP}}$ input goes low．When $\bar{E}_{C P}$ is high，selecting the crystal input，$C P$ must be low．A high level on CP would apply a continuous reset．

For the HD－4702，all inputs except IX have on－chip pull－up circuits which provide TTL compatibility and eliminate the need to tie a perm－ anently high input to $\mathrm{V}_{\mathrm{CC}}$ ．

Pinout
top view

| Q \％ 1 | $16 \mathrm{P} \mathrm{V}_{\mathrm{cc}}$ |
| :---: | :---: |
| $\mathrm{Q}_{1} 42$ | 1519 |
| $\mathrm{O}_{2}=3$ | 14 So |
| $\overline{E S P P}^{51} 4$ | 13 S1 |
| CP 515 | 12 ${ }^{\text {S2 }}$ |
| $0 \times 5$ | 11 Tr 3 |
| $1 \times$－1］ 7 | 10 \％ |
| GND 48 | 9 HCO |

PIN NAMES
CP External Clock Input
ECP External Clock Enable Input（Active Low）
$\begin{array}{ll}\text { IX } & \text { Crystal Input } \\ \text { IM } & \text { Multiplexed Input }\end{array}$
$\mathrm{SO}_{0}-\mathrm{S}_{3} \quad$ Rate Select Inputs Clock Output
OX Crystal Drive Output
$\mathrm{Qo}_{0}-\mathrm{Q}_{2} \quad$ Scan Counter Outputs Bit Rate Output

## Truth Tables

TABLE 1
CLOCK MODES AND INITIALIZATION

| Ix | $E_{\text {CP }}$ | CP | OPERATION |
| :---: | :---: | :---: | :---: |
| 以T | H | L | Clocked from IX |
| $x$ | L | 凹几 | Clocked from CP |
| X | H | H | Continuous Reset |
| $\times$ | L | J | Reset During $1^{\text {st }} \mathrm{CP}=$ HIGH Time |

NOTE：Actual output frequency is 16 times the indicated Output Rate，assuming a clock frequency of 2.4576 MHz ．


NOTE：
（1） 19200 BAUD by connecting $\mathrm{Q}_{2}$ to $\mathrm{I}_{\mathrm{M}}$ ．

## ABSOLUTE MAXIMUM RATINGS

| Supply Voltage | +8.0V |
| :---: | :---: |
| Input or Output Voltage Applied | (GND -0.3V) to ( $\mathrm{VCC}+0.3 \mathrm{~V}$ ) |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Temperature Range |  |
| Industrial HD-4702-9 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Military HD-4702-2/8 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Operating Voltage Range | +4 to +7 V |

ELECTRICAL CHARACTERISTICS
D.C.: $V_{C C}=5 \mathrm{~V} \pm 10 \% ; T_{A}=$ Industrial or Military.
A.C.: $V_{C C}=5 V ; T_{A}=25^{\circ} \mathrm{C}$.
D.C.


| $\begin{aligned} & \text { tPLH } \\ & \text { tPHL } \end{aligned}$ | Propagation Delay, IX to CO |  | $\begin{aligned} & 300 \\ & 250 \end{aligned}$ |  | $\begin{aligned} & 300 \\ & 250 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & C_{L} \leq 7 p F \text { on } O_{x} \\ & C_{L}=15 p F, \text { Input } \\ & \text { Transition Times } \leq 20 \mathrm{~ns} \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { TPLH } \\ & \text { tPHL } \end{aligned}$ | Propagation Delay, CP to CO |  | $\begin{aligned} & 215 \\ & 195 \end{aligned}$ |  | $\begin{aligned} & 215 \\ & 195 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |  |
| $\begin{aligned} & \text { tPLH } \\ & \text { tPHL } \end{aligned}$ | Propagation Delay, CO to $Q_{n}$ |  | (5) |  | (5) | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |  |
| tPLH tPHL | Propagation Delay, CO to Z |  | $\begin{aligned} & 75 \\ & 65 \end{aligned}$ |  | $\begin{aligned} & 75 \\ & 65 \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |  |
| $\begin{aligned} & \text { tTLH } \\ & \text { tTHL } \end{aligned}$ | Output Transition Time (except OX) |  | $\begin{aligned} & 80 \\ & 40 \end{aligned}$ |  | $\begin{aligned} & 80 \\ & 40 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |  |
| $\begin{aligned} & \text { tPLH } \\ & \text { tPHL } \end{aligned}$ | Propagation Delay, IX to CO |  | $\begin{aligned} & 350 \\ & 275 \end{aligned}$ |  | $\begin{aligned} & 350 \\ & 275 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & C_{L} \leq 7 \mathrm{pF} \text { on } \mathrm{OX} \\ & \mathrm{CL}_{\mathrm{L}}=50 \mathrm{pF}, \text { Input } \\ & \text { Transition Times } \leq 20 \mathrm{~ns} \end{aligned}$ |  |
| $\begin{aligned} & \text { tPLH } \\ & \text { TPHL } \end{aligned}$ | Propagation Delay, CP to CO |  | $\begin{aligned} & 260 \\ & 220 \end{aligned}$ |  | $\begin{aligned} & 260 \\ & 220 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |  |
| $\begin{aligned} & \text { tPLH } \\ & \text { tPHL } \end{aligned}$ | Propagation Delay, CO to $Q_{n}$ |  | (5) |  | (5) | $\begin{array}{r} { }^{\circ} \mathrm{ns} \\ \mathrm{~ns} \end{array}$ |  |  |
| $\begin{aligned} & \text { tPLH } \\ & \text { tPHL } \end{aligned}$ | Propagation Delay, CO to Z |  | $\begin{aligned} & 85 \\ & 75 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 85 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |  |  |
| $\begin{aligned} & \text { tTLH } \\ & \text { tTHL } \end{aligned}$ | Output Transition Time (except OX) |  | $\begin{gathered} 160 \\ 75 \end{gathered}$ |  | $\begin{gathered} 160 \\ 75 \end{gathered}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |  |
| $\begin{aligned} & \mathrm{ts}^{2} \\ & \text { th } \end{aligned}$ | Set-Up Time, Select to CO Hold Time, Select to CO | $\begin{gathered} 350 \\ 0 \end{gathered}$ |  | $\begin{gathered} 350 \\ 0 \end{gathered}$ |  | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & C_{L} \leq 7 p F \text { on } O x \\ & C_{L}=15 p F, \text { Input } \\ & \text { Transition Times } \leq 20 \mathrm{~ns} \end{aligned}$ |  |
| $\begin{aligned} & \mathrm{ts}^{2} \\ & \text { th } \end{aligned}$ | Set-Up Time, IM to CO Hold Time, IM to CO | $\begin{gathered} 350 \\ 0 \end{gathered}$ |  | $\begin{gathered} 350 \\ 0 \end{gathered}$ |  | $\begin{aligned} & \hline \text { ns } \\ & \text { ns } \end{aligned}$ |  |  |  |
| twCP(L) <br> $t_{w}$ CP(H) | Minimum Clock Pulse-Width Low and High (3) (4) | $\begin{aligned} & 120 \\ & 120 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 120 \\ & 120 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |  |  |
| $\begin{aligned} & t_{w} C P(L) \\ & t_{w} C P(H) \end{aligned}$ | Minimum IX Pulse Width, Low and High (4) | $\begin{aligned} & 160 \\ & 160 \end{aligned}$ |  | $\begin{aligned} & 160 \\ & 160 \end{aligned}$ |  | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |  |  |

A.C.

NOTES:
(1) Input Current and Quiescent Power Supply Current are relatively higher for this device because of active pull-up circuits on all inputs except $\mid X$. This is done for TTL compatibility.
(2) Propagation Delays (tPLH and tPHL) and Output Transistion Times ( t TLH and t THL) will change with Output Load Capacitance (CL). Set-Up Times ( $t_{s}$ ), Hold Times ( th ), and Mininum Pulse Widths ( $t_{W}$ ) do not vary with load capacitance.
(3) The first High Level Clock Pulse after ECP goes Low and must be at least 350 ns long to guarantee reset of all Counters.
4. It is recommended that input rise and fall times to the Clock Inputs (CP, IX) be less than $15 \mu \mathrm{~s}$.
(5. For multichannel operation, Propagation Delay ( $C O$ to $Q_{n}$ ) plus Set-Up Time, Select to CO, is guaranteed to be $\leq 367 \mathrm{~ns}$.

## Switching Waveforms



NOTE: Set-Up and Hold Times are shown as positive values but may be specified as negative values.

Block Diagram


## Applications

## SINGLE CHANNEL BIT RATE GENERATOR

Figure 1 shows the simplest application of the HD-4702. This circuit generates one of five possible bit rates as determined by the setting of a single pole, 5-position switch. The Bit Rate Output ( $\mathbf{Z}$ ) drives one standard TTL load or four low power Schottky loads over the full temperature range. The possible output frequencies correspond to $110,150,300,1200$, and 2400 or 3600 Baud. For many low cost terminals, these five bit rates are adequate.

## SIMULTANEOUS GENERATION OF SEVERAL BIT RATES

Figure 2 shows a simple scheme that generates eight bit rates on eight output lines, using one HD-4702 and one 93L34 Bit Addressable Latch. This and the following applications take advantage of the built-in scan counter (prescaler) outputs, As shown in the block diagram, these outputs ( $Q_{0}$ to $Q_{2}$ ) go through a complete sequence of eight states for every half-period of the highest output frequency ( 9600 Baud). Feeding these Scan Counter Outputs back to the Select Inputs of the multiplexer causes the HD-4702 to interrogate sequentially the state of


FIGURE 1
Switch selectable bit rate generator configuration providing five bit rates.


FIGURE 3
19200 Baud Operation
eight different frequency signals. The 93L34 8 Bit Addressable Latch, addressed by the same Scan Counter Outputs, re-converts the multiplexed single Output $(Z)$ of the HD-4702 into eight parallel output frequency signals. In the simple scheme of Figure 2, input $\mathrm{S}_{3}$ is left open (HIGH) and the following bit rates are generated:

| $Q_{0}: 110$ Baud | $Q_{1}: 9600$ Baud | $Q_{2}:$ | 4800 Baud |
| :--- | :--- | :--- | :--- |
| $Q_{3}: 1800$ Baud | $Q_{4}: 1200$ Baud | $Q_{5}: 2400$ Baud |  |
| $Q_{6}: 300$ Baud | $Q_{7}: 150$ Baud |  |  |

Other bit rate combinations can be generated by changing the Scan Counter to Selector interconnection or by inserting logic gates into this path.

## 19200 BAUD OPERATION

Though a 19200 Baud signal is not internally routed to the multiplexer, the HD-4702 can be used to generate this bit rate by connecting the $\mathrm{O}_{2}$ output to the $\mathrm{I}_{\mathrm{M}}$ input and applying select code. An additional 2 -input NOR gate can be used to retain the "Zero Baud" feature on select code 1 for the HD-4702 (See Figure 3).


TABLE 3
CRYSTAL SPECIFICATIONS

| PARAMETERS | TYPICAL CRYSTAL SPEC |
| :--- | :---: |
| Frequency | 2.4576 MHz "AT" Cut |
| Series Resistance (Max) | 250 |
| Unwanted Modes | -6.0 dB (Min) |
| Type of Operation | Parallel |
| Load Capacitance | $32 \mathrm{pF}+0.5$ |

Harris Reliability and Quality
Introduction ..... 6-2
Quality Control ..... 6-2
Quality Assurance ..... 6-4
Reliability ..... 6-4
Harris SAJI Process Overview ..... 6-8
CMOS Design Considerations ..... 6-10

## Harris Reliability \& Quality

## Introduction

The Product Assurance Department at Harris Semiconductor Products Group is responsible for assuring that the quality and reliability of all products shipped to customers meet their requirements. During all phases of product fabrication, there are many independent visual and electrical checks performed by Product Assurance personnel.

Prior to shipment, a final inspection is performed at Quality Assurance Plant Clearance to insure that all requirements of the purchase order and customer specifications are met.

The following military documents provide the foundation for HARRIS Product Assurance Program.

```
MIL-M-38510D
MIL-Q-9858A
MIL-STD-883B
NASA Publication 200-3
MIL-C-45662A
MIL-I-4508A
```

"General Specification of Microcircuits" "Quality Program Requirements"
"Test Methods and Procedures for Microelectronics" "Inspection System Provisions" "Calibration System Requirements"
"Inspection System Requirements"
The Harris Semiconductor Reliability and Quality Manual, which is available upon request, describes the total function and policies of the organization to assure product reliability and quality. All customers are encouraged to visit the Harris Semiconductor facilities and survey the deployment of the Product Assurance function.

## Quality Control

The Quality Control Department consists of Process Control with Chemical Mix as an available supporting service.

Process Quality Control is responsible for quality engineering and controls in the wafer processing modules, assembly, mask and materials production areas, and electrical wafer probe.

The primary responsibilities of Process Quality Control are:
a. To establish and maintain effective controls for monitoring manufacturing processes and equipment
b. to provide rapid feedback of information concerning the state of control
c. to initiate, design, and develop statistically controlled experiments to further improve product reliability and quality levels.

Statistical control charts on processes and operating procedures are used in the manufacturing areas and in the evaluation of process and product parameters utilized to qualify new processes.

When necessary, fixed gate inspections are permanently employed to assure specified quality levels.

On a regular basis, process audits are performed to verify conformance to operating procedures.

Statistical control charts are maintained on processes and workmanship for all phases of assembly and environmental testing.

PROCESS CONTROL
WAFER FABRICATION - GENERAL PROCESS FLOW

INCOMING MATERIALS (SILICON, CHEMICALS, GASES,
 DOPANTS, PIECE PARTS)

## RUN SETUP/MATERIALS PREP.

OXIDATION DIFFUSION, IMPLANT


## PHOTORESIST/ETCH



THIN FILM (RESISTORS, INTERCONNECTS)


PASSIVATION/GLASSIVATION (SILOX, DOPED SILICON, SILICON NITRIDE)


WAFER/DIE FINALINSPECTION


PROBE


WAFER SAW/BREAK


PRRODUCTION
(P) PRODUCTION INSPECTION

0 QUALITY CONTROL LOT ACCEPTANCE
Q QUALITY CONTROL MONITOR/AUDIT

## Quality Assurance

The primary responsibility of the Quality Assurance Department is to assure that all delivered products meet the rigid standard of reliability and quality of Harris Semiconductor Products Group. The Quality Assurance department is responsible for process control and product quality from product test to shipment. Random sampling of products at specified points and intervals is used to ensure quality. This includes performance and analysis of sample electrical testing (Group A) and environmental and life testing (Groups B, C and D). In addition, mechanical and visual inspections specified by the Quality Assurance Test Plans, as well as customer and military specifications are performed. The random selection and distribution of samples, the routing of devices through specified testing and adherence to inspection programs are controlled and implemented by Quality Assurance.

All packaged microcircuits are marked by a code indicating the date the lot was sealed. This code provides product traceability and meets customer date coding requirements. Traceability is maintained through lot acceptance, testing and shipment to the customer.

## Reliability

## RELIABILITY PROCEDURES

Harris Semiconductor Products Group employs a comprehensive approach to reliability evaluation to ensure that reliability is designed and built into all products. This approach is referred to as the Reliability Evaluation Procedures and outlines the basic guidelines for evaluation of the total inherent reliability capability of all products types. The Reliability Evaluation Procedures are applied as an overlay during the early product development phase, subsequent prove-in via preproduction and final maturity in the manufacturing of all new product types. They also provide guidelines for evaluation of new process technologies deployed in all applicable products. The Reliability Evaluation Procedures also encompass a package qualification procedure, and the "Add-on" program which is a quarterly reliability monitor of all process groups. These documents are available upon request. The following test matrix (Table 1) outlines the minimum requirements necessary for product qualification.

TABLE 1. TEST MATRIX

| Design Package Process | New <br> New <br> New | New <br> New <br> Est. | New <br> Exist <br> New | New <br> Exist Est. | Exist <br> New <br> New | Exist <br> New <br> Est. | Exist <br> Exist <br> New | Exist <br> Exist <br> Est. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Abuse Tests 20 Units | X | X | X | X | X |  | X | X |
| Max. Ratings 20 Units: No Failures | X |  | X | X | X |  | X | X |
| 86/86 or Autoclave <br> 50 Units: No Failures | X | X | X |  | X | X | X |  |
| Constr. Analysis <br> 5 Units: No Failures | X | X | X | X | X | X | X | X |
| Centrifuge 50 Units: No Failures | X | X |  |  | X | X |  |  |
| Ele. Charac. <br> 20 Units: No Failures | X | X | X | X | X |  | X | X |
| ESD Immunity <br> 20 Units: No Failures | X | X | X | X | X |  | X | X |
| Fig. Test 20 Units: No Failures | X | X | X | X | X |  | X |  |
| HTOL Sample Groups | $\begin{aligned} & 200 \\ & (\min ) \end{aligned}$ | $\begin{aligned} & 200 \\ & (\min ) \end{aligned}$ | $\begin{aligned} & 200 \\ & (\min ) \end{aligned}$ | $\begin{gathered} 200 \\ (\mathrm{~min}) \end{gathered}$ | $\begin{aligned} & 200 \\ & (\min ) \end{aligned}$ | $\begin{aligned} & 200 \\ & (\min ) \end{aligned}$ | $\begin{gathered} 200 \\ (\min ) \end{gathered}$ | $\begin{gathered} 200 \\ (\mathrm{~min}) \end{gathered}$ |
| Latch-up <br> 20 Units: No Failures | X | X | X | X | X |  |  |  |
| Lead Integrity 20 Units: No Failures | X | X |  |  | X | X | X | X |
| Mech. Charac. 20 Units: No Failures | X | X |  |  | X | X |  |  |
| Mech. Schock <br> 50 Units: No Failures | X | X |  |  | X | X |  |  |
| Moisture Resist <br> 50 Units: No Failures | X | X |  |  | X | X |  |  |
| Oja/Ojc 20 Units | X | X |  |  | X | X |  |  |
| Solvent Resistance <br> 4 Units: No Failures | X | X |  |  | X | X |  |  |
| Solderability <br> 20 Units: No Failures | X | X |  |  | X | X |  |  |
| Temperature Cycling 50 Units: No Failures | X | X |  |  | X | X |  |  |
| Thermal Shock 50 Units: No Failures | X | X |  |  | X | X |  |  |
| Vibration <br> 50 Units: No Failures | X | X |  |  | X | X |  |  |

The HARRIS CMOS product line has had a continual evolution of new and enhanced processes. From SAJI I (Self Aligned Junction Isolated) to the most recent SAJI V process. There has been an ongoing effort to increase performance, density and reliability. The current RAM products ( 4 K and up) along with the microprocessors and peripheral families utilize the SAJI IV, scaled SAJI IV, and SAJI V processes. Table II is a summary of recent reliability data taken on the various SAJI processes. Table III lists the activation energies of the most common defects associated with the CMOS products. Table IV gives a breakdown of field returns by failure mechanism.

At Harris, accelerated life Tests are utilized to estimate the field failure rate of our product. A typical life test consists of 200 devices tested at +1250 C to +1500 C ambient, dynamic operation, 5.5 V to 6.5 V , for 1000 hours. All failures are carefully analyzed to determine the failure mechanism and associated activation energy (EA) utilizing the arrehnius equation derating factors back to +550 C ambient, 5.5 volts operation are determined.

$$
\begin{aligned}
& \text { Derating factor }=D . F_{1}=e-\left(\frac{E_{A}}{K}\right) \quad\left(\frac{1}{T_{2}}-\frac{1}{T_{1}}\right) \text { where } \quad E_{A}=\text { Activation Energy } \\
& K=\text { Boltzman's Constant } \\
& \text { T2 }=\text { Life Test Junction Temp. } \\
& \mathrm{T}_{1}=\text { Junction Temp. at }+550 \mathrm{C} \\
& \text { Ambient }
\end{aligned}
$$

Projected field failure rates are calculated at $60 \%$ and $95 \%$ confidence levels. This means that either $60 \%$ or $95 \%$ of the product will meet or exceed the reliability demonstrated in the test. We also ensure that the failure rate is decreasing with time to prevent any wearout mechanism from reaching our customers.

TABLE II. SUMMARY OF RELIABILITY DATA

| SAJI <br> Process <br> Type | No. of Devices | $\begin{aligned} & \text { Device } \\ & \text { Hours } \\ & \left(+125{ }^{\circ} \mathrm{C}\right) \end{aligned}$ | No. of Failures | $\begin{aligned} & \text { EA } \\ & \text { (ev) } \end{aligned}$ | Failure Rate (\%/K Hours) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | @ $\mathrm{T}_{\mathrm{A}}=+55^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  |  | Observed | 60\% Confidence | 95\% Confidence |
| 1 | 2,046 | 4,019,046 | 1 4 6 | 1.0 ev <br> . 6 ev <br> . 5 ev |  |  |  |
|  |  |  |  |  | . 0007 | . 001 | . 002 |
| 11 | 1,515 | 1,791,668 | 2 1 2 2 | 1.0 ev <br> .7ev <br> . 6 ev <br> .5ev |  |  |  |
|  |  |  |  |  | . 004 | . 013 | . 028 |
| III | 440 | 938,844 | 0 | - | . 002 | . 005 | . 015 |
| IV | 687 | 740,464 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | . 6 ev . 5 ev |  |  |  |
|  |  |  |  |  | . 020 | . 025 | . 044 |
| Scaled IV | 1740 | 3,387,860 | 21 2 3 6 | $\begin{gathered} 1.0 \mathrm{ev} \\ .7 \mathrm{ev} \\ .6 \mathrm{ev} \\ .5 \mathrm{ev} \end{gathered}$ |  |  |  |
|  |  |  |  |  | . 012 | . 015 | . 025 |

TABLE III CMOS PRODUCTS ACTIVATION ENERGY

| Failure Mechanism | Activation <br> Energy (EA) |
| :--- | :---: |
| Oxide Defects | 0.5 ev |
| Defective Apertures | 0.6 ev |
| Photoresist Flaws | 0.7 ev |
| Assembly Defects | 0.8 ev |
| Ionic Contamination | 1.0 ev |

TABLE IV. FIELD RETURNS BY FAILURE MECHANISM


NOTE: Returned units are approximately $1 \%$ of the total shipped.

## Harris SAJI Process Overview

SAJI I - Self Aligned Junction Isolation


In 1972 Harris Semiconductor began development of a SAJI CMOS process that would become the basis for all Harris CMOS devices. In 1973, Harris perfected the SAJI I process and proved its potential for high speed, low power and high packing density. By 1975, the SAJI I process had proved to be successful in volume production of high density CMOS components as evidenced by the reliability of the 1 K CMOS RAMs. SAJI I utilizes a single level of polysilicon and a single level of metal interconnect.

SAJI II


GOLD BACK

To achieve higher packing density, SAJI II was implemented in the 4K CMOSRAMs in 1978. SAJI II represents the evolution of SAJI processes into a second generation, incorporating smaller (scaled) devices and a second level of polysilicon interconnect, labeled N + POLY 2. Buried contacts allow the interface of multiple interconnect levels. This process relies upon the thick oxide for device isolation and guardbanding.


GOLD BACK

In 1980, SAJI III was introduced with the redesigned (2nd generation) 4K CMOS RAMs. SAJI III advances include device scaling for increased packing density and die size reductions, and selective oxidation processing, which exhibits more planar device surface structures improving step coverage and device reliability. The selective oxidation process involves the deposition of a nitride layer in the gate region of each device. This nitride layer prohibits the growth of oxide in the gate region. As a result, thick oxide is not grown across the entire face of the die but only in areas not inhibited by the nitride layer. Thick oxide growth now occurs between devices and below the surface of the die. The lower inherent capacitance in the gate area due to a thinner gate oxide results in increased device speed. Previous SAJI processes are easily retrofitted to this process.


The next generation process was SAJI IV. SAJI IV features the selection oxidation and planar surface characteristics of SAJI III while adding further device scaling with the option of high resistivity substrates which reduces internal junction capacitances and increases speed. Self-aligned implanted $\mathrm{P}+$ and $\mathrm{N}+$ guardbands were also added, which increased the isolation between devices and reduced adjacent device interaction and increased packing density.

## CMOS Design Considerations

## ESD (ELECTROSTATIC DISCHARGE)

Since the introduction of MOS, manufacturers have searched for effective and safe ways of handling this voltage sensitive device. High input impedance of CMOS, coupled with gate-oxide breakdown characteristics, result in susceptibility to electrostatic charge damage.

Figure 2 shows a cross-section of a silicon gate MOS structure. Note the very thin oxide layer ( $\approx 500-1000 \AA$ ) present under the gate material. Actual breakdown voltage for this insulating layer ranges from 70 V to 100 V .
Handling equipment and personnel, by simply moving, can generate in excess of 10 kV of static potential in a low humidity environment. Thus, static voltages, in magnitudes sufficient to damage delicate MOS input gate structures, are generated in most handling environments.

A failure occurs when a voltage of sufficient magnitude is applied across the gate oxide causing it to breakdown and destruct. Molten material then flows into the void creating a short from the gate to the underlying silicon. Such shorts occur either at a discontinuity in doping concentration, or at a defect site in the thin oxide. If no problems appear in the oxide, breakdown would most likely occur at gate/source, or gate/drain intersection coincidence due to the doping concentration gradient.

Noncatastrophic degradation may result due to overstressing a CMOS input. Sometimes an input may be damaged, but not shorted. Most of these failures relate to damage of the protection network, not the gate, and show up as increased input leakage.


Figure 2 - Silicon-gate PFET structure cross-section shows the heavily doped source and drain region. They are separated by a narrow gap over which lies a thin-gate oxide and gate material.
*NOTE: $1 \AA$ (Angstrom $=10-8 \mathrm{~cm}$ )

## Voltage Limiting Input Protection

During the evolution of monolithic MOS, manufacturers developed various protection mechanisms that are an integral part of the circuit. However, several of these earlier techniques have been replaced by improved methods now in use. The object of most of these schemes is to prevent damage to input-gate structures by limiting applied voltages.

Recent CMOS designs employ a dual-diode concept in their input protection networks. Figure 3 illustrates such a protection circuit.

One characteristic of junction-isolated CMOS protection circuits is the $\approx 200 \Omega$ current limiting resistor. Cross sectional area of the metallization leading to the resistor, and the area of the resistor are, therefore, designed to absorb discharge energy without sustaining permanent damage. This dual-diode protection has proved very effective and is the most commonly used method in production today.

## HARRIS INPUT GATE PROTECTION

To protect input device gates against destructive overstress by static electricity accumulating during handling and insertion of CMOS products, Harris provides a protection circuit on all inputs. The general configuration of this protection circuit is shown in Figure 3.


Figure 3 - Junction isolated dual-diode protection networks are most commonly used in today's CMOS circuits.

Both diodes to the VDD and VSS lines have breakdown voltages averaging between 35 and 40 volts. Excessive static charge accumulated on the input pin is thus effectively discharged through these diodes which limit the voltage applied from gate to drain and source. The 200 ohm resistor provides current limiting during discharge. Depending on the polarity of the input static charge and on which of the supply pins aregrounded, the protective diodes may either conduct in the forward direction or breakdown in the reverse direction.

In order to test this concept, step stress tests have been performed at Harris using an approximate equivalent circuit to simulate the static charge encountered in handling operations. The equivalent circuit consists of a 100 pF capacitor in series with a 1.5 K ohm resistor and is considered the rough equivalent of a human body. Step stressing takes the form of charging the capacitor to a given voltage and then discharging it into an input pin of the CMOS device under test according to the sequence given in MIL-M-38510.

Stress Voltage
500
700
1000 - 0
1400
1600
1
$1800 \quad 4$

These results indicate that the input protection used for Harris CMOS products provides adequate protection against static electricity based on the limits specified in MIL-M38510.

There are two trade-offs to consider when fabricating an input protection scheme, namely effectiveness of the overvoltage protection and performance of the overall circuit. It is obvious that increasing the series resistance and capacitance at an input limits current and this, in turn, increases the input protection's ability to absorb the shock of a static discharge. However, such an approach to protection can have a significant effect on circuit speed and input leakage. The input protection selected must therefore provide a useful performance level and adequate static-charge protection.
Commonly used MOS-input protection circuits all have basic characteristics that limit their effectiveness. The zener diodes, or forward-biased pn-junctions, employed have finite turn-on times too long to be effective for fast rise-time conditions. A static discharge of 1.5 kV into a MOS input may bring the gate past its breakdown level before the protection diodes or zener becomes conductive.

Actual turn-on times of zeners and pn-diodes are difficult to determine. It is estimated that they are a few nanoseconds and a few tens of picoseconds, respectively. A low-impedance static source can easily produce rise times equal to or faster than these turn-on times. Obviously the input time constant required to delay buildup of voltage at the gate must be much higher for zener diodes or other schemes having longer turn-on times.

Consider an example. Figure 4 shows a test circuit that simulates the discharge of a 1.5 kV static charge into a CMOS input. Body capacitance and resistance of the average person is represented by a 100 pF capacitor through $1.5 \mathrm{k} \Omega$. Switch A is initially closed, charging 100 pF to 1.5 kV with switch B open. Switch $A$ is opened, then $B$ is closed, starting the discharge. With the $1.5 \mathrm{~K} \Omega \times 5 \mathrm{pF}$ time constant to limit the charge rate at the DUT input, it would take approximately 350 psec to charge to 70 V above VDD. Diode turn-on time is much shorter than 350 psec, hence the gate node would be clamped before any damage could be sustained.


Figure 4 - Input protection network test setup illustrates how diode clamping prevents excessive voltages from damaging the CMOS device.

## HANDLING RULES

There is no completely foolproof system of chip-input protection presently in production. If static discharge is of high enough magnitude, or of sufficiently short rise-time, some damage or degradation may occur. It is evident, therefore, that proper handling procedures should be adopted at all times.

Elimination or reduction of static charge can be accomplished as follows:

- Use conductive work stations. Metallic or conductive plastic tops on work benches connected to ground help eliminate static build-up.
- Ground all handling equipment.
- Ground all handling personnel with a conductive bracelet through $1 \mathrm{M} \Omega$ to ground.
- The $1 \mathrm{M} \Omega$ resistor will prevent injury.
- Smocks, clothing, and especially shoes of certain insulating materials (notably nylon) should not be worn in areas where devices are handled. These materials, highly dielectric in nature, will hold or aid in the generation of a static charge.
- Control relative humidity to as high a level as practical. A higher level of humidity helps bleed away any static charge as it collects.
- Ionized air blowers reduce charge build-up in areas where grounding is not possible or desirable.
- Devices should be in antistatic conductive carriers during all phases of transport. If antistatic carriers are used the devices and carriers should be in a static shielding bag.
- In automated handling equipment, the belts, chutes or other surfaces the leads contact should be of a conducting nature. If this is not possible, ionized air blowers may be a good alternative.

Harris currently ships all CMOS products in Benstat TM tubes placed inside static shielding bags. Packing materials are all antistatic.

## THE FORWARD-BIAS PHENOMENON

Monolithic CMOS integrated circuits employ a single-crystal silicon wafer into which FET sources and drains are implanted. For complex functions many thousands of transistors may be required and each must be electrically isolated for proper operation.

Junction techniques are commonly used to provide the required isolation - each switching node operating reverse-biased to its respective substrate material. Additionally, as previously mentioned, protection diodes are provided to prevent static-charge related damage where inputs interface to package pins. Forward-biasing any of these junctions with or without power applied may result in malfunction, parametric degradation, or damage to the circuit.

High currents resulting from an excessive forward-bias can cause severe overheating localized to the area of a junction. Damage to the silicon, overlying oxide and metallization can result.

## BIPOLAR PARASITICS

Care must always be exercised not to forward-bias junctions from input or output pads.
A complex and potential defect phenomenon is the interaction of a npn/pnp combination a la SCR (Figure 5). Forward-biasing the base-emitter junction of either bipolar component can cause the pair to latch up if $\beta \mathrm{npn} \times \beta \mathrm{pnp} \geq 1$. The resultant low impedance between supply pins can cause fusing of metallization or over-dissipation of the chip.

Figure 5 shows how an SCR might be formed. The $p+$ diffusion labeled INPUT is connected to aluminum metallization and bonded to a package pin. Biasing this point positive with respect to $V_{D D}$ supplies base drive to the pnp through R2. Although gain of these lateral devices is normally very low, sufficient collector current may be generated to forwardbias and supply substantial base current to the vertical npn parasitic. Once the pair has been activated, each member provides the base current required to sustain the other. A latched condition will be maintained until power is removed or circuit damage disables further operation.


Figure 5 - Improper biasing can latch-up this SCR configuration. A p+ guard ring is commonly used to kill lateral pnp action. This ring is diffused into the surface at the junction of $p$ - and $n$-silicon.

## DESIGN RULES EQUALLY IMPORTANT AS HANDLING RULES

A system using CMOS devices must have reliability designed in. No amount of testing can guarantee long term reliability when poor design practices are evident.

- Never apply signals which exceed maximum ratings to a CMOS circuit before or after power has been turned on (to prevent latch-up)
- Supply filter capacitance should be distributed such that some filtering is in close proximity to the supply pins of each package. Testing has shown $0.01 \mu \mathrm{~F} /$ package to be effective in filtering noise generated by most CMOS functions.
- CMOS signal lines are terminated at the driving end by a relatively high impedance when operating at the low end of the supply voltage range. This high-impedance termination results in vulnerability to high-energy or high-frequency noise generated by bipolar or other non-CMOS components. Such noise must be held down to manageable levels on both CMOS power and signal lines.
- Where CMOS must interface between logic frames or between different equipments, ground differences must be controlled in order to maintain operation within absolute maximum ratings.
- Capacitance on a CMOS input or output will result in a forward-bias condition when power is turned off. This capacitance must discharge through forward-biased input or output to substrate junctions as the bus voltage collapses. Excessive capacitance (thousands of pF ) should be avoided as discharging the stored energy may generate excessive current densities during power-down.
- Where forward-biasing is inevitable, current limiting should be provided. Current should not be permitted to exceed 1 mA on any package pin excluding supply pins.

All CMOS is susceptible to damage due to electrical overstress. It is the user's responsibility to follow a few simple rules in order to minimize device losses.
First, select a source for the CMOS device that employs an effective input protection scheme. This will allow a greater margin of safety at all levels of device handling since the devices will not be quite so prone to static charge damage. Next, he should apply a sound set of handling and design rules. At minimum, this will eliminate electrical stresing or hold it to manageable levels.

With an effective on-chip protection scheme, good handling procedures and sound design, users should not lose any CMOS devices to electrical overstress.

Introduction ..... 7-3
Advantages of Standard Flows ..... 7-3
Standard Manufacturing Flows ..... 7-3
CMOS Military Product Description ..... 7-4

## Harris Hi-Rel and Military Products

## Introduction

High reliability, the Military and Harris Semiconductor have enjoyed a cooperative relationship for more than a decade. Over ten years ago, Harris was the first to manufacture and, subsequently, JAN-qualify bipolar PROMS. Harris currently has government certified manufacturing lines producing a variety of high-rel products.

Early commitment to CMOS technology has made Harris the premier manufacturer of high performance CMOS VLSI devices. HARRIS fast, low power components are designed to offer significant power reduction, lower operating temperatures, improved reliability, reduced packaging costs and improved performance for extended temperature range applications. For the military/hi-rel market, Harris also has standard CMOS hi-rel grades which accommodate the requirements of virtually all applications.

## Advantages of Standard Flows

Wherever feasible, and in accordance with good value engineering practice, it is beneficial to the IC user to specify Hi-Rel device grades based on one of the five standard Harris manufacturing flows. These generally meet or exceed the requirements of the majority of applications.

Advantages gained by basing designs on the standard data book or slash sheet (as applicable) electrical limits and calling out standard as opposed to custom flows include:

- LOWER COST than the same or an equivalent flow executed on a custom basis. This results from the higher efficiency achieved with a constant product flow and the elimination of such extra cost items as special fixturing, test programs, additional handling, and added documentation.
- FASTER DELIVERY since the manufacturer often can supply many items from inventory and, in any case, can establish and maintain a better product flow when there is no need to restructure process and/or test procedures.
- INCREASED CONFIDENCE in the Hi-Rel devices, as a continuing flow of a given Hi-Rel product permits the manufacturer to monitor trends which may influence endproduct performance or reliability and to effect necessary corrective action.


## Standard Manufacturing Flows

Harris has developed standard flows which should satisfy most requirements. Produced in accordance with established manufacturing flows, the standard Harris Hi-Rel grades and their indicated areas of application are as follows:

- DASH-9+ [PLUS] products are processed to Harris high reliability test conditions and are designed for industrial use. Performance is guaranteed over a temperature range of -400 C to $+85^{\circ} \mathrm{C}$. For added reliability, devices packaged in ceramic (CERDIP) are burned-in for 160 hours at +1250 C , while the burn-in requirement for epoxy packaged parts is 96 hours at +1250 C .
- DASH-8 products are designed for general use in the military environment, with performance guaranteed over a temperature range of -550 C to +1250 C . Included in Harris DASH-8 processing is 160 hours of burn-in at 1250 C.
- DESC drawing parts are manufactured in accordance with drawings provided by the Defense Electronic Supply Center which call out full military screening and lot acceptance testing requirements.


## CMOS MICROPROCESSOR AND SUPPORT CIRCUITS

| MILITARY PART NUMBER | FUNCTION | $\begin{aligned} & \text { PIN } \\ & \text { COUNT } \end{aligned}$ | PAGE REF |
| :---: | :---: | :---: | :---: |
| 8/16-BIT MICROPROCESSORS |  |  |  |
| MD80C86/B | 16 BIT CMOS MICROPROCESSOR ( 5 MHz ) | 40 | 3-4 |
| MD80C86-2/B | 16 BIT CMOS MICROPROCESSOR ( 8 MHz ) | 40 | 3-4 |
| MD80C88/B | 8 BIT CMOS MICROPROCESSOR ( 5 MHz ) | 40 | 3-96 |
| MD80C88-2/B | 8 BIT CMOS MICROPROCESSOR ( 8 MHz ) | 40 | 3-96 |
| 80C86/88 PERIPHERAL CIRCUITS |  |  |  |
| MD82C52/B | CMOS SERIAL COMMUNICATION INTERFACE | 28 | 3-27 |
| MD82C54/B | CMOS PROGRAMMABLE INTERVAL TIMER | 24 | 3-28 |
| MD82C55A/B | CMOS PROGRAMMABLE PERIPHERAL INTERFACE | 40 | 3-43 |
| MD82C59A/B | CMOS PRIORITY INTERRUPT CONTROLLER | 28 | 3-62 |
| MD82C37A/B | CMOS DMA CONTROLLER | 40 | 3-97 |
| 80C86/88 BUS SUPPORT CIRCUITS |  |  |  |
| MD82C82/B | CMOS OCTAL LATCHING BUS DRIVER | 20 | 3-77 |
| MD82C83/B | CMOS OCTAL LATCHING INVERTING BUS DRIVER | 20 | 3-98 |
| MD82C84A/B | CMOS CLOCK GENERATOR/DRIVER | 18 | 3-82 |
| MD82C86/B | CMOS OCTAL BUS TRANSCEIVER | 20 | 3-100 |
| MD82C87/B | CMOS OCTAL INVERTING BUS TRANSCEIVER | 20 | 3-101 |
| MD82C88/B | CMOS BUS CONTROLLER | 20 | 3-89 |
| MD82C89/B | CMOS BUS ARBITER | 20 | 3-102 |
| 12-BIT MICROPROCESSORS |  |  |  |
| HM-6100-8 | CMOS 12 BIT MICROPROCESSOR | 40 | 4-30 |
| HD-6120-8 | CMOS HIGH PERFORMANCE 12 BIT MICRO | 40 | 4-3 |
| 12-BIT PERIPHERAL CONTROLLERS |  |  |  |
| HD-6101-8 | CMOS PARALLEL INTERFACE ELEMENT (PIE) | 40 | 4-51 |
| HD-6121-8 | CMOS I/O CONTROLLER (IOC) | 40 | 4-22 |
| BUS SUPPORT CIRCUITS |  |  |  |
| HD-6431-8 | CMOS HEX LATCHING BUS DRIVER | 16 | 4-59 |
| HD-6432-8 | CMOS HEX BIDIRECTIONAL BUS DRIVER | 18 | 4-62 |
| HD-6433-8 | CMOS QUAD BUS SEPARATOR/DRIVER | 16 | 4-65 |
| HD-6434-8 | CMOS OCTAL LATCH BUS DRIVER W/RESET | 24 | 4-68 |
| HD-6436-8 | CMOS OCTAL BUS BUFFER/DRIVER | 20 | 4-71 |
| HD-6440-8 | CMOS LATCHED 3 TO 8 LINE DECODER/DRIVER | 18 | 4-74 |
| HD-6495-8 | CMOS HEX BUS DRIVER | 16 | 4-78 |
| SERIAL COMMUNICATION CIRCUITS |  |  |  |
| HD-4702-8 | CMOS BIT RATE GENERATOR | 16 | 5-56 |
| HD-6402-8 | CMOS UART | 40 | 5-51 |
| HD-6406-8 | CMOS PROG. ASYNC. COMMUNICATION INTERFACE | 40 | 5-39 |
| HD-6409-8 | CMOS MANCHESTER ENCODER-DECODER | 20 | 5-30 |
| HD-15530-8 | CMOS MANCHESTER ENCODER-DECODER | 24 | 5-3 |
| HS-15530RH | CMOS MANCHESTER ENCODER-DECODER (RADIATION | 24 | 9-17 |
| HD-15531-8 | CMOS MANCHESTER ENCODER-DECODER | 40 | 5-10 |
| HD-15531B-8 | CMOS MANCHESTER ENCODER-DECODER | 40 | 5-10 |
| HS-3182 | CMOS ARINC 429 BUS INTERFACE LINE DRIVER CIRCUIT | 16 | 9-28 |
| HS-3282 | CMOS ARINC 429 BUS INTERFACE CIRCUIT | 40 | 9-29 |

## CMOS STATIC RAMS

| MILITARY PART NUMBER | CONFIGURATION | PIN COUNT | ACCESS TIME | STANDBY CURRENTICCSB | DATA RET. CURRENTICCDR | OPERATING CURRENTICCOP | PAGE REF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1K - SYNCHRONOUS |  |  |  |  |  |  |  |
| HM-6508-8 | $1 \mathrm{~K} \times 1$ | 16 | 250ns | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ | $4 \mathrm{~mA} / \mathrm{MHz}$ | 2-5 |
| HM-6508B-8 | $1 \mathrm{~K} \times 1$ | 16 | 180ns | $10 \mu \mathrm{~A}$ | $5 \mu \mathrm{~A}$ | $4 \mathrm{~mA} / \mathrm{MHz}$ | 2-5 |
| HM-6518-8 | $1 \mathrm{~K} \times 1$ | 18 | 250ns | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ | $4 \mathrm{~mA} / \mathrm{MHz}$ | 2-11 |
| HM-6518B-8 | $1 \mathrm{~K} \times 1$ | 18 | 180ns | $10 \mu \mathrm{~A}$ | $5 \mu \mathrm{~A}$ | $4 \mathrm{~mA} / \mathrm{MHz}$ | 2-11 |
| HM-6551-8 | $256 \times 4$ | 22 | 300ns | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ | $4 \mathrm{~mA} / \mathrm{MHz}$ | 2-17 |
| HM-6551B-8 | $256 \times 4$ | 22 | 220ns | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ | $4 \mathrm{~mA} / \mathrm{MHz}$ | 2-17 |
| HM-6561-8 | $256 \times 4$ | 18 | 300ns | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ | $4 \mathrm{~mA} / \mathrm{MHz}$ | 2-25 |
| HM-6561B-8 | $256 \times 4$ | 18 | 220ns | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ | $4 \mathrm{~mA} / \mathrm{MHz}$ | 2-25 |
| 4K - SYNCHRONOUS |  |  |  |  |  |  |  |
| HM-6504-8 | $4 \mathrm{~K} \times 1$ | 18 | 300 ns | $50 \mu \mathrm{~A}$ | $25 \mu \mathrm{~A}$ | $7 \mathrm{~mA} / \mathrm{MHz}$ | 2-29 |
| HM-6504B-8 | $4 \mathrm{~K} \times 1$ | 18 | 200ns | $50 \mu \mathrm{~A}$ | $25 \mu \mathrm{~A}$ | $7 \mathrm{~mA} / \mathrm{MHz}$ | 2-29 |
| HM-6504S-8 | $4 \mathrm{~K} \times 1$ | 18 | 120ns | $50 \mu \mathrm{~A}$ | $25 \mu \mathrm{~A}$ | $7 \mathrm{~mA} / \mathrm{MHz}$ | 2-29 |
| HM-6514-8 | $1 \mathrm{~K} \times 4$ | 18 | 300ns | $50 \mu \mathrm{~A}$ | $25 \mu \mathrm{~A}$ | $7 \mathrm{~mA} / \mathrm{MHz}$ | 2-40 |
| HM-6514B-8 | $1 \mathrm{~K} \times 4$ | 18 | 200ns | $50 \mu \mathrm{~A}$ | $25 \mu \mathrm{~A}$ | $7 \mathrm{~mA} / \mathrm{MHz}$ | 2-40 |
| HM-6514S-8 | $1 \mathrm{~K} \times 4$ | 18 | 120ns | $50 \mu \mathrm{~A}$ | $25 \mu \mathrm{~A}$ | $7 \mathrm{~mA} / \mathrm{MHz}$ | 2-40 |
| 16K - SYNCHRONOUS |  |  |  |  |  |  |  |
| HM-6516-8 | $2 \mathrm{~K} \times 8$ | 24 | 200ns | $100 \mu \mathrm{~A}$ | $50 \mu \mathrm{~A}$ | $10 \mathrm{~mA} / \mathrm{MHz}$ | 2-51 |
| HM-6516B-8 | $2 \mathrm{~K} \times 8$ | 24 | 120ns | $50 \mu \mathrm{~A}$ | $25 \mu \mathrm{~A}$ | $10 \mathrm{~mA} / \mathrm{MHz}$ | 2-51 |
| 16K - ASYNCHRONOUS |  |  |  |  |  |  |  |
| HM-65162-8 | $2 \mathrm{~K} \times 8$ | 24 | 90ns | $100 \mu \mathrm{~A}$ | $40 \mu \mathrm{~A}$ | 70 mA | 2-57 |
| HM-65162B-8 | $2 \mathrm{~K} \times 8$ | 24 | 70ns | $50 \mu \mathrm{~A}$ | $20 \mu \mathrm{~A}$ | 70 mA | 2-57 |
| HM-65172-8 | $2 \mathrm{~K} \times 8$ | 24 | 90 ns | $100 \mu \mathrm{~A}$ | $40 \mu \mathrm{~A}$ | 70 mA | 2-70 |
| HM-65172B-8 | $2 \mathrm{~K} \times 8$ | 24 | 70ns | $50 \mu \mathrm{~A}$ | $20 \mu \mathrm{~A}$ | 70 mA | 2-70 |
| CMOS RAM MODULES |  |  |  |  |  |  |  |
| HM-6564-8 | 64K | 40 | 350ns | $800 \mu \mathrm{~A}$ | $400 \mu \mathrm{~A}$ | 28/56mA/MHz | 2-85 |
| HM-92560-8 | 256K | 48 | 150ns | $500 \mu \mathrm{~A}$ | $350 \mu \mathrm{~A}$ | $15 / 30 \mathrm{~mA} / \mathrm{MHz}$ | 2-96 |
| HM-92570-8 | BUFFERED 256K | 48 | 250ns | $600 \mu \mathrm{~A}$ | $450 \mu \mathrm{~A}$ | $15 / 30 \mathrm{~mA} / \mathrm{MHz}$ | 2-104 |

## CMOS RADIATION HARDENED RAMS

| PART <br> NUMBER | CONFIG- <br> URATION | PIN <br> COUNT | ACCESS <br> TIME | STANDBY <br> CURRENT- <br> ICCSB | DATA RET. <br> CURRENT- <br> ICCDR | OPERATING <br> CURRENT- <br> ICCOP | PAGE <br> REF |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| HS-6504RH | $4 \mathrm{~K} \times 1$ | 18 | 300 ns | $100 \mu \mathrm{~A}$ | $50 \mu \mathrm{~A}$ | $7 \mathrm{~mA} / \mathrm{MHz}$ | $9-18$ |
| HS-6508RH | $1 \mathrm{~K} \times 1$ | 16 | 300 ss | $100 \mu \mathrm{~A}$ | - | $4 \mathrm{~mA} / \mathrm{MHz}$ | $9-19$ |
| HS-6514RH | $1 \mathrm{~K} \times 4$ | 18 | 200 ss | $250 \mu \mathrm{~A}$ | $50 \mu \mathrm{~A}$ | $7 \mathrm{~mA} / \mathrm{MHZ}$ | $9-20$ |
| HS-6551RH | $256 \times 4$ | 22 | 300 ns | $100 \mu \mathrm{~A}$ | - | $4 \mathrm{~mA} / \mathrm{MHz}$ | $9-21$ |
| HS-6564RH | $16 \mathrm{~K} \times 4$ | 40 | 350 ns | $800 \mu \mathrm{~A}$ | - | $32 \mathrm{~mA} / \mathrm{MHz}$ | $9-22$ |
| RAM MODULE | $0 \mathrm{~K} \times 8$ |  |  |  |  |  |  |

## CMOS FUSE LINK PROMS

| PART <br> NUMBER | CONFIG- <br> URATION | PIN <br> COUNT | ACCESS <br> TIME | STANDBY <br> CURRENT- <br> ICCSB | DATA RET. <br> CURRENT- <br> ICCDR | OPERATING <br> CURRENT- <br> ICCOP | PAGE <br> REF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HM $-6641-8$ <br> HM $-6616-8 ~$ | $512 \times 8$ <br> $2 K \times 8$ | 24 | 250 n | $100 \mu \mathrm{~A}$ | - | $10 \mathrm{~mA} / \mathrm{MHz}$ | $2-113$ |
| 24 | 120 ns | $100 \mu \mathrm{~A}$ | - | $13 \mathrm{~mA} / \mathrm{MHz}$ | $2-118$ |  |  |


Article Reprints Table of Contents ..... 8-2
Article Reprints ..... 8-3

## Article Reprints Table of Contents

Page
Defense Electronics
Part 1 Microprocessor Family Turns to Low Power ..... 8-3
Part 2 High Density LCC Packages ..... 8-10
Computer Design
Providing CMOS Benefits to Peripheral Chips ..... 8-17
Electronics
Custom Microprocessor Powers Portable Workstation ..... 8-23
Electronic Design
For Data Communication, Manchester Chip Could be the Best ..... 8-27
Electronic Design
Industrial Controller Joins MIL-STD-1553 Bus ..... 8-37
EDN
Take a Total System Approach with CMOS Memories ..... 8-44
EDN
LCC Implementation Procedures Enhance a Valuable Technology ..... 8-51

# Microprocessor Family Turns to Low-Power CMOS 

## The 80C86 microprocessor adds a proven design and low power to high performance defense systems.

onth. Part I/ in this mo-part series on microprocessors will examine the transition of the low-penser 8()C 86 famill to indusiry standard leadless chip carrier packages.

Walter Nienserski is a techmical markering engineer with Harris Corporation's Semicon(luctor (jroup), (:MOS Digital Proctucts Division, P.(). Bo.x 88.3, MS 54-130, Melhourne. Fl.32901.

CMOS equivalents of existing high performance circuits offer obvious advantages to the military system de-signer-allowing immediate reductions in critical system operating power, reduced power supply requirements, sealable enclosures, and lighter, higher density packaging. System reliability is improved due to lower ambient and junction temperatures and the high radiation tolerance of the cmos process. In the past, however, this power reduction usually came at the expense of lower system performance.

The new 80C86 products from Harris Semiconductor have been designed especially for high performance military systems. Initial device specifications for the product line include 5 MH z operation over the full $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range, with selected products available in 8 MHz . versions. Upgrades of all circuits to 8 MHz compatibility are planned. Mil.-STID-883B processing allows full implementation of CMOS products in military designs.

## 80C86 Functional Compatibility

Full functional compatibility with existing 8086 NMOS/bipolar equivalents is provided in the 80 C 86 family. Programs that test original source

devices are being used to verify functionality and compatibility. In-system testing has been done by both the Harris Semiconductor (MOS Applications Group and selected external customer sites to verify functionality in a real system, real time environment providing an additional level of compatibility assurance.

Product compatibility with existing industry standard devices and development systems can immediately improve system performance with respect to power and reliability. Life spans of existing hardware and software designs can be extended by providing direct low-power, high performance upgrades for existing 8086based systems.

The unit's hardware interface and instruction set are compatible with proven design and development tools. Soft ware developed for projects using the 8086 can be used directly with the 80 C 86 family, reducing the manpower investment and resulting in decreased development time and cost. With standard software (Ada, Jovial, ete.) for military, defense, and aerospace applications, this software compatibility can result in significant savings in new and existing projects.

## Worst Case Design for <br> Defense Applications

As with all system components, CMOS devices best perform within their specified operating conditions. The problem facing the designer is one of insuring these system operating conditions will not degrade device performance beyond the limits imposed by the design. Devices guaranteed to operate to specifications over "worst case ranges" make this task easier (for example, parameter limits guaranteed over the full temperature range and propagation delays guaranteed at realistic 100 to 300 pF capacitive loads as opposed to 15 to 45 pr ). All AC parameters are tested and guaranteed with worst case specified loads on the appropriate outputs.

The 80C86 product line has been designed for military applications; specific operation goals over the military temperature range were established and maintained throughout the design process. Performance is also guaranteed at worst case conditions, including operation over the power

supply voltage range and at the maximum rated loads. These worst case specifications insure reliable operation under adverse conditions such as extreme temperature variations, fluctuating power supply level, and heavy output load.

Limits specified for the 80C86 family $A C$ and $D C$ parameters reflect maximums and minimums over the entire military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ temperature range. Capacitive loads are 100 to 150 pF for standard peripherals and 300 pF for the 82 C 82 and $82 C 88$ bus interface devices, which interface directly with the system bus. These guarantees insure a system is designed to worst case specifications; no performance degradation calculations for guaranteed parameters will be needed during initial design; and, the system will operate properly over the full specified operating ranges.

## Low-Power System Application

The 80C86 CPU, operating in the maximum mode, is the focal point in the control module for flight navigation. Non-inverting octal latches (82C82) and transceivers (82C86) provide the address/data latching and buffering for the local bus. The 82C88 cMOS bus controller provides the con-
trol signals for the on-board memory. both (MOS RAM and non-volatile CMOS PROM, and for the peripheral circuits.

## CMOS Memory Options

CMOS memory circuits offer the designer several options. The HM6516 , a $2 \mathrm{~K} \times 8$ CMOS static RAM, offers a low operating power of 10 $\mathrm{mA} / \mathrm{MHz}$, maximum, for military applications. Access times as low as 120 ns make this device compatible with many high-speed applications. Where increased performance is necessary, the HM-65162 asynchronous 16 K CMOS RAM can be used with an access time of 70 ns , maximum.

CMOS fuse link PROMS are used in this application because of the high reliability requirements of military systems. The long-term data retention characteristics of polysilicon fuses insure reliable operation in extreme environments. The low power ( 13 mA / MHz for the 16 K density (MOS PROM) and 150 ns access time provide the performance needed for this generation of CMOS systems.

## Multiple CPUs

Expanding system capabilities beyond the level available with a single


A typical flight control computer configuration based on the 80 C 86 microprocessor family is a full 5 MHz design. The device can also operate at lower speeds to provide even greater power savings. The 80C86 can directly replace the NMOS 8086 in existing designs.
processor can be accomplished in several ways. The addition of another CPU subsystem. along with the appropriate interface to allow common access to data, significantly improves system throughput. To accommodate this multiprocessing scheme, the 82 C 88 bus controller and the 82 C 89 bus arbiter provide the control and arbitration for the system bus. Inverting latches ( $82(83$ ) and transceivers (82C87) meet the necessary functional compatibility for existing industry standard multiprocessor bus systems.
If there is no need to expand beyond a single board or enlarge to a multiprocessor system, the 80C86 can run in the Minimum mode, where decoded memory and I o signals are
avalable from the processor. This type of configuration eliminates the need for the 82 C 88 bus controllers and the additional multiprocessor interface circuitry.

## Mixing Technologies

Another way to increase system throughput, especially in cases where arithmetic functions and numeric data manipulation are critical, is to add an 8087 numeric coprocessor to the system. Although not available in ( MOS the device can be used in a cmos 80 C86 system, providing the increase in power dissipation is acceptable.

The addition of the $1 M(O) 8087$ to the otherwise all-(MOS 80) C 86 sistem and the subsequent mixing of technol-
ogies is possible with the full 111 compatibility present on the 80C86 products. This compatibility on both inputs and outputs eases interfacing to 1 MOS and bipolar circuits. CMOS output drivers, along with the dual V OH specification, guarantee operation at (MOS and III logic levels.

## Mil-Std Bus

When data communication between subsystems is desired, but not necessarily at parallel bus speeds, a MII.-STID-1553 or alternate protocol Man-chester-based serial bus can be used. The addition of an HD-6406 programmable asynchronous communication interface (PACI) and an HD15530 Manchester encoder-decoder
(MED) form a high-speed serial link between several remote systems. Standard eight-bit data transfers can be accomplished in the non-1553 bus applications by using the military version of the HD-6409 Manchester en-coder-decoder - which allows more freedom than the MIL-SID-1553 bus for formatting the serial data.

The HD-6406 provides the UARI parallel-to-serial/serial-to-parallel conversion function and bit rate generator in a single 40 -pin package. A 28 -pin version (82C52) will also be available for higher packing density applications. The HD-6406 functions are fully programmable through a micro-processor-compatible bidirectional bus, which has a maximum serial data rate of one megabaud (asynchronous transmission with a 16 X clock). The HD-15530 ( 1.25 M -bit/sec) and the HD-6409's (1 M-bit/sec) maximum data rates can fully support a one M-bit serial bus interface for military applications.


## Peripheral Monitor and Control Functions

Several peripheral functions monitor system $1 / 0$ and timing control. The 82C55A programmable peripheral interface can be used for display control or for information passing between subsystems, using the bidirectional handshaking mode. Upon RESET, the 82C55A port pins become defined as inputs. If these inputs are not used or will eventually become outputs, they have no driving source and are in an undefined, or "float," condition.


Both the 80C86 and the 82C55A use this on-chip "bus-hold" circuitry to provide valid input voltages to specific inputs without using external resistors.

Undefined input voltage levels are forbidden in CMOS system design. Undefined input states allow the input circuitry to "float" within the devices" active regions. Unfortunately, floating CMOS inputs tend to migrate toward the threshold voltage and increase ICC substantially. All CMOS inputs, if unused, must be tied to VCC or (iND to avoid oscillation and high ICC conditions.

Pull-up pull-down resistors are the most common method for defining cMOS inputs when no driving source is present. But, this technique has several disadvantages. Additional components (resistors) are necessary, which increase production costs and reduce overall reliability. Higher power operation can actually occur when using pull-up/down resistors. Since the driving circuit must supply the current needed when switched to the opposite state of the pull-up/down resistor, the result can be a significant increase over normal cMOS input leakage current levels of $1 \mu \mathrm{~A}$.

## Bus-Hold Circuitry

To avoid the need for external resistors and eliminate the high power effects of floating inputs, the 82 C 55 A , along with the 80 C 86 CPU , uses onchip "bus-hold" circuitry to provide valid input voltages to specific inputs; this is important when there is no driving source (i.e., a no-connect or a driving input that goes to a high impedance state). The bus-hold cir-
cuits maintain these pins at a Logic One level internally and externally until they are defined as outputs or are overdriven by an external source.

An external driver must be capable of supplying $300 \mu \mathrm{~A}$ minimum sink or source current at valid input voltage levels in order to overdrive the bus-hold circuits. Since this circuitry is active and not a passive pull-up resistive-type element, the 82 C 55 A . stand by current is kept to $10 \mu \mathrm{~A}$, maximum.
System needs and overall compatibility dictated the placing of bus-hold circuits on specific devices. The 80C86 (PU has bus-hold devices on selected pins (ADO ADIS, etc.), which are common to the local bus …This eliminates the compounding of the overdrive current necessary if all 80 C 86 family members had bus-hold circuitry, and keeps all current requirements within TTI. LSTTI capabilities.

## Gated Inputs

The 82C82 octal latch also has specialized input circuitry to minimize power dissipation and help eliminate the need for external resistors. Gated inputs minimize the effects on the ICC from switching and undefined inputs. This gating function, initiated by the falling edge of the strobe ( STB) input, disconnects the input inverter from the VCC by turning off the upper P channel (Q1) and lower N -channel (Q2). Thus, there is no current path, other than leakage, between VCC and


Gated inputs on the 82C82 octal latch eliminate extraneous current spikes due to input conditions unrelated to latch operation. While data is latched, floating inputs can be directly connected to the 82C82 inpuits without using pull-up resistors.


For power critical applications where power is reduced to the point that even tull-tıme operation at reduced frequency is not desirable, the 80C86's static circuitry allows the clock to be stopped.
(iNI) during input transitions when data is latehed in the 82C82. Internally, logic states are held valid by the feedback logic signal in the circuit's latch section.

Input gating also isolates the driving source from the internal circuitry. Invalid logic states from floating inputs cannot be transmitted to succeeding stages when the inputs are turned off, eliminating the need for
pull-up resistors when data is latched. In an 80C86 system, the sil input is driven by an Al.E (address latch enable). At 5 MHz , the high pulse width of the AIEE is 98 ns or approximately 15 to 20 percent of the bus cycle period. Therefore, 82 C 82 inputs are disabled 80 percent of the time. During this time, ICC transients from input switching are eliminated, resulting in a lower operating current.

Polled or On-Demand Data Sensing
The 82C59A priority interrupt controller and the 82C54 programmable interval timer manage system interrupt and polling control functions. Two methods, used either separately or concurrently, are available for controlling the system sequencing of data acquisition. Polled acquisition or in-terrupt-driven data taking can be accomplished with the circuit described.

The 82C54 timer can be programmed, using single or multiple 16-bit timers (three per package), to provide an input to the 82C59A interrupt controller and cause execution of a data acquisition software routine: This procedure can be repeated by using the 82C54 in the rate generator mode (Mode 2), inverting the signal. and inputting it to the 82C59A programmed for edge-triggered inputs.

If certain functions must be executed only every vth cycle, the 82C54 Timer 0 output (ovi 0) can be fed into the clock of Timer I (clk ). Timer I can be programmed to operate as an event counter (Mode 0 interrupt on terminal count) and interrupt the 82C59A every vith count.

The 82C59A is also used for control of other external interrupts such as emergency conditions like engine over-temperature, pressure high low. and other on-demand situations. If desirable, the repeated interrupt for polling purposes can be disabled by using the 82C59A's interrupt masking ability, which only allows generation of critical situation interrupts.

The 82C59A interrupt inputs can be prioriticed. When bothepolled and on-demand sequences are used concurrently, the on-demand emergency situations would be considered highest priority.

## Tailoring Low-Power System Operation

Several circuit design techniques can be valuable in examining lowpower operation at the system level. CMOS is only a first step. Significant reductions in system-level power consumption can be realized if proper design approaches are taken.

In an aircraft situation, power is not normally a problem. If, however, the microsystem power fails independent of the main aircraft power, full
navigation controls can remain intact and operational with the 80 C 86 CMOS control system. With a backup battery power supply, the power sensing unit can transter the system from main power operation to battery supply. With system power levels approximately 10 percent of equivalent NMOS bipolar circuits, full $5 \mathrm{MH} /$ operation can be maintained.

As primary power is diminished (battery discharging) or removed (power interruption battery backup operation) in portable or remote bat-tery-powered applications, running at a lower frequency to eonserve power becomes important. Operating power is critical in low-power applications, and cMos operating power is directly related to frequency.

With the 80C86 family's static design, power requirements can be user controlled: lowering the frequency reduces power. Static design (i.e., no internal dynamic registers needing constant clocking or refresh) allows operation from 1 ( ${ }^{\prime}$ to the individual
device's maximum rated frequencies.
The (mos 80C86 static design allows the system clock to drop to a lower frequency ( 100 kHz , for example), making full computational and data manipulation powers available while significantly reducing system power consumption. This low frequency operation is not available with most NMOS processors. including the NMOS 8086 where 2 MH \% is the minimum allowed clock frequency. Dynamic register designs in the Nmos (Pls need to be refreshed at a minimum rate and do not allow low operating frequencies.

Typical operating power for the 80C8G cPl: at $5 \mathrm{MH} /$ is 40 mA . derated linearly as frequency drops (approximately 2 ma at $100 \mathrm{kH} /$ ). Similar deratings are also valid for the power dissipations of the peripheral. support, and memory circuits.

Finally, given a power eritical situation where power is diminished to the point that even low frequency, fulltime operation is undesirable, the

80C'86's static internal circuitry allows clocks to be stopped. This capability eliminates the power dissipation associated with switching, and reduces device currents to standby levels. With static ID operation, individual peripheral device standby currents are guaranteed to be less than $10 \mu \mathrm{~N}$. with the 80C86 cPl typically less than $500 \mu \mathrm{~A}$.

Static design can also stop and single-step the system clock during system prototyping. This debug method allows the designer to inspect the system bus and examine specific operations. The real time complications of 5 MHz bus transfers are eliminated and system debug is simplified.

## Stopped Clock Power Savings

Although the 82C84A clock generator's 40 mA ICC limit is significantly lower than the bipolar 8284A's 162 ma limit, it is still the largest. single power user in a cmos 80C86 system; this is due to the high frequency of

| CMOS/NMOS/Bipolar Parametric Comparison |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { СмоS } \\ & 80 \mathrm{C} 86 \end{aligned}$ | NMOS 8086 | $\begin{aligned} & \text { CMOS } \\ & 82 C 54 \end{aligned}$ | $\begin{gathered} \text { NMOS } \\ 8254 \end{gathered}$ | $\begin{gathered} \text { CMOS } \\ 82 C 55 A \end{gathered}$ | $\begin{aligned} & \text { NMOS } \\ & 8255 A \end{aligned}$ | $\begin{gathered} \text { CMOS } \\ \text { 82C59A } \end{gathered}$ | $\begin{gathered} \text { NMOS } \\ 8259 A \end{gathered}$ | $\begin{aligned} & \text { CMOS } \\ & 82 C 82 \end{aligned}$ | $\begin{gathered} \text { Bipolar } \\ 8282 \end{gathered}$ | $\begin{gathered} \text { CMOS } \\ \text { 82C84A } \end{gathered}$ | Bipolar <br> 8284A | $\begin{aligned} & \text { СMOS } \\ & 82 \mathrm{C} 88 \end{aligned}$ | $\begin{gathered} \text { Bipolar } \\ 8288 \end{gathered}$ |
| ViH | 2.2 V | 2.0 V | 2.2 V | 2.0 V | 2.2 V | 2.0 V | 2.2 V | 2.0 V | 2.2 V | 2.0 V | 2.2 V | 2.0 V | 22 V | 20 V |
| VIL | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V | 0.8 V |
| VOH | $\begin{aligned} & 3.0 \mathrm{~V} / \\ & \mathrm{VCC} \\ & 0.4 \mathrm{~V} \end{aligned}$ | 2.4 V | $\begin{aligned} & 3.0 \mathrm{~V} / \\ & \mathrm{VCC} \\ & 0.4 \mathrm{~V} \end{aligned}$ | 2.4 V | $\begin{aligned} & 3.0 \mathrm{~V} / \\ & \mathrm{VCC} \\ & 0.4 \mathrm{~V} \end{aligned}$ | 2.4 V | 3.0 V <br> VCC <br> 0.4 V | 2.4 V | 2.9 V | 2.4V | $\begin{aligned} & \text { VCC } \\ & 0.4 \mathrm{~V} \end{aligned}$ | 2.4 V | 3.0 V <br> VCC 0.4 V | 24 V |
| IOH | $\begin{aligned} & -2.5 \mathrm{~mA} / \\ & -100 \mu \mathrm{~A} \end{aligned}$ | $-400 \mu \mathrm{~A}$ | $\begin{aligned} & -2.5 \mathrm{MA} / \\ & -100 \mu \mathrm{~A} \end{aligned}$ | $-400 \mu \mathrm{~A}$ | $\begin{aligned} & -2.5 \mathrm{~mA} / \\ & -100 \mu \mathrm{~A} \end{aligned}$ | -400 $\mu \mathrm{A}$ | $\begin{array}{\|l} -2.5 \mathrm{~mA} / \\ -100 \mu \mathrm{~A} \end{array}$ | $-400 \mu \mathrm{~A}$ | -8mA | -5mA | -2.5mA | -1mA | $\begin{array}{\|l\|l\|} \hline-8 \mathrm{~mA} / \\ -2.5 \mathrm{~mA} \end{array}$ | -5mA |
| VOL | 0.4V | 0.45 V | 0.4 V | 0.45V | 0.4 V | 0.45 V | 0.4V | 0.45 V | 0.4 V | 0.45 V | 0.4V | 0.45 V | $\frac{0.5 \mathrm{~V} /}{0.4 \mathrm{~V}}$ | 0.5 V |
| IOL | $+2.5 \mathrm{~mA}$ | $+2.5 \mathrm{~mA}$ | $+2.5 \mathrm{~mA}$ | +2mA | $+2.5 \mathrm{~mA}$ | $+2.5 \mathrm{~mA}$ | $+2.5 \mathrm{~mA}$ | $+2.2 \mathrm{~mA}$ | $+8 \mathrm{~mA}$ | +32mA | $+2.5 \mathrm{~mA}$ | +5mA | $\left\lvert\, \begin{gathered} +20 \mathrm{~mA} / \\ +8 \mathrm{~mA} \end{gathered}\right.$ | $\begin{gathered} +32 \mathrm{~mA} / \\ +16 \mathrm{~mA} \end{gathered}$ |
| ICCsB | $500 \mu \mathrm{~A}$ Typical | Not Applicable | $10 \mu \mathrm{~A}$ | 140mA | $10 \mu \mathrm{~A}$ | 120mA | $10 \mu \mathrm{~A}$ | 85mA | $10 \mu \mathrm{~A}$ | 160 mA | $\begin{gathered} 10 \mu \mathrm{~A} \\ \text { Typical } \end{gathered}$ | 162 mA | $10 \mu \mathrm{~A}$ | 230 mA |
| ICCOP | $\begin{aligned} & 40 \mathrm{~mA} \\ & @ 5 \mathrm{MHz} \\ & \text { Typical } \end{aligned}$ | 340 mA | $\begin{array}{\|c} 1 \mathrm{~mA} / \\ \mathrm{MHz} \\ \text { Typical } \end{array}$ | 140mA |  | 120 mA | $\begin{gathered} 1 \mathrm{~mA} / \\ \mathrm{MHz} \\ \text { Typical } \end{gathered}$ | 85mA | $1 \mathrm{~mA} /$ <br> MHz <br> Typical | 160 mA | $\begin{gathered} 40 \mathrm{~mA} \\ \stackrel{@}{\mathrm{M}} \mathrm{~Hz} \end{gathered}$ | $\begin{gathered} 162 \mathrm{~mA} \\ @ \\ 25 \mathrm{M} \mathrm{~Hz} \end{gathered}$ | $\begin{aligned} & 1 \mathrm{~mA} / \\ & \mathrm{MHz} \end{aligned}$ | 230 mA |
| $C_{L}$ | 100 pF | 100 pF | 150 pF | 150 pF | 150 pF . | 150 pF | 100 pF | 100 pF | 300 pF | 300 pF | $\begin{gathered} 100 \mathrm{pF} / \\ 30 \mathrm{pF} \end{gathered}$ | $\begin{gathered} 100 \mathrm{pF} / \\ 30 \mathrm{pF} \end{gathered}$ | $\begin{gathered} 300 \mathrm{pF} / \\ 80 \mathrm{pF} \end{gathered}$ | $\begin{gathered} 300 \mathrm{pF} / \\ 80 \mathrm{pF} \end{gathered}$ |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



Power curves for the 82C84A show the effects of both frequency and voltage decreases on the ICC.
operation (15 24 MH erystal frequency for $\%$ MH/ system frequency) and the non-ideal waveform of the crystal signal.

When using the 82C84A in a stopclock application, the external frequency input (EFI) mode of operation must be used. The 82C84A clock generator has a minimum crystal frequency of 2.4 MHz (corresponding to $800 \mathrm{kH} /$ system frequency) for internal oscillator operation. The EFI input allows use of an external clock to provide the main timing. This external clock is processed through the same internal $82 C 84 A$ circuitry as the crystal oscillator input, so timing within the system remains the same.

An additional benefit, critical to the successful design of a stop-clock circuit, is the 82C84A's reduced operating power when using an external frequency source to drive the EFI input.

With XI and X 2 crystal operation. the input transistors spend a greater percentage of time in the active region due to the sinusoidal nature of the erystal circuit. Driving the EFI input
to lec and (ixi) levels with an external source more effectively turns internal circuitry on and off. resulting in decreased operating power.

The clock frequency reduction must be properly timed to meet minimum 80C86 clock high- and low-time requirements. Therefore, along with the appropriate divide-down circuitry needed to provide the proper lower frequency, synchronization between the low frequency signal line and the control circuitry is necessary. Care must be taken to avoid cases of asynchronous timing errors caused by irregular clocks that are outside the (P) specification limits.

The 82C55A plp provides the parallel cPu interface to the control circuitry. An interrupt from the 82C59A priority interrupt controller can provide the start-up signal for the system clock control circuitry. The 82C59A allows prioritizing and masking of interrupting sources so that: during the time the system is stopped, only the most critical signals may restart the processor.

# High Density Leadless Chip Carrier Packages Increase Reliability, Save Weight 

## A military CMOS 16-bit microprocessor packaged in LCCs reduces operating temperatures, size, and weight, adding to that family's low-power advantages.

By Walter J. Niewierski and Jeffrey M. Wilkinson

Last month, DE looked at the 80C86 family, which adds low-power CMOS to a proven design for high performance defense systems. This month, Part II in this two-part series on microprocessors will examine that family's transition to industry standard leadless chip carrier packages.

Just as critical as power consumption is packaging technique. The low-power operation of the CMOS 80C86 family, along with memory and support chips, allows for design of sealed, portable system enclosures. In turn, this type of packaging reduces operating temperatures and minimizes hostile external environment effects, increasing system reliability.

## System Level Reductions

Replacing higher power devices with their CMOS equivalents can reduce system "hot spots" caused by localized high dissipation circuits. A direct replacement with low-power CMOS components will significantly reduce system ambient temperatures. Using the power supply current requirements of the CMOS 82C88 and bipolar 8288 bus controller, along with a typical 0 jA (junction to ambient temperature rise with respect to power dissipation) of $50^{\circ} \mathrm{C} / \mathrm{W}$, the following device temperature comparison can be made:

$$
\begin{aligned}
& \mathrm{T}=6 \mathrm{j} \mathrm{~A} \times \text { power dissipation }+\mathrm{T}_{\mathrm{A}} \\
& \begin{aligned}
& \text { For } \\
& \text { bipolar }= \\
& \quad \times 50^{\circ} \mathrm{C} / \mathrm{W} \times(230 \mathrm{VA}) \\
&=55^{\circ} \mathrm{C} / \mathrm{W} \times 1.265 \mathrm{~W} \\
&+125^{\circ} \mathrm{C}
\end{aligned}
\end{aligned}
$$



Leadless chip carriers attached to a ceramic dual-in-line substrate allow Harris Semiconductor to package the complete 16-bit CMOS microprocessor as a single unit. Harris has already used this packaging concept to produce 64 K - and 256 K -bit RAM arrays based on $16 K$ and $64 K$ chips. All these LCC packaged products are military qualified.

| $=$ | $63.25^{\circ} \mathrm{C}+125^{\circ} \mathrm{C}$ |
| ---: | :--- |
| $=$ | $188.25^{\circ} \mathrm{C}$, typical |
| For $=$ | $50^{\circ} \mathrm{C} / \mathrm{W} \times(5 \mathrm{~mA})$ |
| $\mathrm{CMOS} \quad$ | $\times 5.5 \mathrm{~V}+125^{\circ} \mathrm{C}$ |
| $=$ | $50^{\circ} \mathrm{C} / \mathrm{W} \times .0275 \mathrm{~mW}$ |
|  | $+125^{\circ} \mathrm{C}$ |
| $=$ | $1.375^{\circ} \mathrm{C}+125^{\circ} \mathrm{C}$ |
| $=$ | $126.375^{\circ} \mathrm{C}$, typical |

The rise in the die surface temperature of CMOS is approximately two percent of the increase seen in NMOS products. This lower CMOS die temperature results in a significant in-


Package welghts and area for LCCS are compared to equivalent ceramic dual-in-line packages.
crease in the mean time between failure (MTBF). The MTBF equation shows the direct relationship of the failure rate and temperature:
$\mathrm{MTBF}_{\mathrm{T}}=\mathrm{e}^{\mathrm{EA} / \mathrm{KT}}$
where $\mathrm{MTBF}_{\mathrm{T}}=\mathrm{MTBF}$ at temperature T

$$
\begin{aligned}
\mathrm{EA} & =\text { activation energy }(\mathrm{ev}) \\
\mathrm{K} & =\text { Boltzman's constant } \\
\mathrm{T} & =\text { absolute temperature }\left({ }^{\circ} \mathrm{K}\right)
\end{aligned}
$$

Similar increased MTBF numbers can be estimated for system operation when system ambient temperatures are reduced by CMOS circuits.

With decreased system temperatures, the need for special cooling equipment and enclosure openings can be eliminated or reduced. The use of cooling techniques such as heat pipes, liquid coolants, heat sinks, and louver assemblies can add weight and volume to systems. Besides these physical disadvantages, the lower reliability of electromechanical operation and the system's exposure to hostile environments adds an additional risk factor to system reliability. CMOS systems can keep the system operating temperature
to lower levels, enabling the use of sealed enclosures with a minimum of cooling.

Temperature also affects circuit and system performance. CMOS leakage currents and, therefore, standby power dissipation increase at the high end of the temperature range. Performance also degrades because of increased channel resistances on the P - and N channel transistors. Keeping the system ambient temperature low results in an improved overall performance.

Replacing existing circuits with lowpower CMOS offers many benefits. However, the system environment remains constant-that is, compatible with NMOS/bipolar operation. Power supplies, cooling equipment, and enclosure size and weight all remain the same.

In order to optimize the reductions possible in weight and cost and increase reliability, the system must be designed with low power in mind. Smaller system power supply requirements and lower temperatures eliminate the need for cooling components.

## Device Level Miniaturization

Decreasing an individual device's package can lead to miniaturization and portability. Flatpacks and DIPs are the main packages used in military system designs. However, leadless chip
carriers (LCC) have recently become popular because of their small size and light weight.

The trend toward using dual-in-line packages has proven sufficient in most applications. But, where very light and small, complex electrical functions are required, LCCs offer space and flexibility. DIPs occupy approximately three times the space an LCC package uses for the same pin count. And unlike an LCC package, the DIP has leads that can bend or break, adding a parasitic resistance and capacitance.

The introduction of flatpacks to military applications proved an alternative to the DIP package in reducing board space requirements. But, flatpack costs are high because of the large amounts of gold used in the package plating. Long lead length and narrow spacing also require special carriers for handling. And, when soldering to printed circuit boards, the long lead length permits package vibration, which could affect the reliability of the leads or their solder connections.

Leadless chip carriers offer small package sizes, no leads to bend or break, and premium electrical performance due to full parametric testing allowed at the package level. For critical military applications, MIL-STD-883B, group A, B, C, and D can be applied to leadless chip carriers in a method
similar to those applied to dice packaged in a size-brazed DIP.

Many devices cannot be manufactured in LCCs or must be placed in larger pad count carriers because of bipolar and NMOS technologies' excessive power dissipations. But with CMOS, power dissipation is reduced optimizing package size and pin count.

The leadless chip carrier pinout definitions for the CMOS 80C86 family follows, for the most part, predefined pinout and package assignments as established by the original NMOS source. With certain device types, specifically the original source products, larger than necessary packages were used. For example, the 8282 octal latch, 8284A clock generator, and 8288 bus controller are packaged in 28 -pad LCCs, while 20 -pad LCC packages are standard for the 82 CXX CMOS equivalents. One of the main reasons for using this enlarged package for bipolar devices is its higher-than-CMOS power dissipation. With CMOS' lower power characteristics, however, minimum package sizes can be achieved. Using 20 -pad LCCs for the CMOS versions of the above devices allows for maximum system packing density.

Leadless chip carriers for high density packaging and minimized pad counts further reduce board space and weight in high density systems. In addition, LCC packages' reduced package lead lengths and interconnect lower the parasitic inductance of the circuitry. Parasitic inductance is a major contributing factor to noise in high-speed CMOS system designs (See sidebar, "System Noise Reduction in High-Speed CMOS Design").

## LCC Assembly Techniques

The relatively recent revival of the LCC package, along with the advantages of implementing these packages on printed circuit boards and substrates, allows designers a high-density packaging option. To ease the transition from conventional DIP/PCB assemblies to the LCC/PCB packaging option, the designer must understand the differences between the two packaging technologies.

## Substrate Material Selection

The basic concern for selection of the substrate material is matching the


Pinouts for the 80C86 CMOS microprocessor family are similar to the more familiar pinouts used for conventional flatpacks.

# CMOS vs NMOS Power Requirements 

| Part <br> Type | Description | CMOS Operating <br> Power Supply Current | NMOS/Bipolar Equiv. <br> Power Supply Current |
| :--- | :--- | ---: | ---: |
| 80C86 | CMOS 16-Bit CPU | 40 mA | 340 mA |
| 82C54 | CMOS Interval Timer | 5 mA |  |
| 82C55A | CMOS Parallel Interface | 1 mA | 140 mA |
| 82C59A | CMOS Interrupt Controller | 1 mA | 120 mA |
| HD-6406 | CMOS UART/BRG | 3 mA | 85 mA |
| 82C82 | CMOS Octal Latch | 1 mA | 100 mA |
| 82C83 | CMOS Octal Latch (Inv) | 1 mA | 160 mA |
| 82C84A | CMOS Clock Generator | 25 mA | 160 mA |
| 82C86 | CMOS Bus Transceiver | 1 mA | 162 mA |
| 82C87 | CMOS Bus Transceiver (Inv) | 1 mA | 160 mA |
| 82C88 | CMOS Bus Controller | 5 mA | 130 mA |
| 82C89 | CMOS Bus Arbiter | 5 mA | 230 mA |
| Approx. System Power Supply Current | 89 mA | 165 mA |  |

80C86 Family Package Comparisons

| Part <br> Type | $\begin{gathered} \text { DIP } \\ \text { Pin Count } \end{gathered}$ | $\begin{gathered} \text { LCC } \\ \text { Pad Count } \end{gathered}$ | DIP Area (Sq. In.) | LCC Area (Sq. In.) | DIP Weight (Gr.) | LCC Weight (Gr.) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 80 C 86 | 40 | 44 | 1.2 | 0.423 | 10.92 | 1.18 |
| 82C54 | 24 | 28 | 0.75 | 0.198 | 6.48 | 0.55 |
| 82C55A | 40 | 44 | 1.2 | 0.423 | 10.92 | 1.18 |
| 82C59A | 28 | 28 | 0.997 | 0.198 | 7.56 | 0.55 |
| HD-6406 | 40 | 44 | 1.2 | 0.423 | 10.92 | 1.18 |
| 82C82 | 20 | 20 | 0.3 | 0.123 | 2.9 | 0.34 |
| 82C83 | 20 | 20 | 0.3 | 0.123 | 2.9 | 0.34 |
| 82C84A | 18 | 20 | 0.283 | 0.123 | 2.48 | 0.34 |
| 82C86 | 20 | 20 | 0.3 | 0.123 | 2.9 | 0.34 |
| 82C87 | 20 | 20 | 0.3 | 0.123 | 2.9 | 0.34 |
| 82C88 | 20 | 20 | 0.3 | 0.123 | 2.9 | 0.34 |
| 82C89 | 20 | 20 | 0.3 | 0.123 | 2.9 | 0.34 |

## Material Thermal Properties

| Substrate Material | TCE <br> (in./lin. ${ }^{\circ} \mathbf{C ~} \times 1 \mathbf{1 0}^{-6}$ ) |
| :--- | :---: |
| Alloy 42 | 5.3 |
| 96\% Alumina | 6.3 |
| 94\% Alumina | 6.4 |
| 92\% Alumina | 6.4 |
| Copper Clad Invar | 6.4 |
| 99.5\% Be0 | 6.4 |
| Low Carbon Steel | 12.0 |
| Polyimide G30 | 14.3 |
| Epoxy/Glass G10 | 15.8 |
| Triazine G40 | 16.0 |
| CDA 101 Copper | 17.3 |
| 6061 Aluminum | 23.6 |

## Comments

42\% Ni, Balance Fe Industry Standard Industry Standard

## Expensive

Porcelanized Industry Standard Industry Standard Industry Standard Very High TCE Very High TCE
linear thermal coefficient of expansion (TCE). Matching the TCEs is critical to attaching an LCC to a substrate when the assembly must be able to survive the number of thermal cycles typical of military applications and testing. When the LCC is soldered on a board, the solder interface is not only the electrical contact but the mechanical connection as well.

When the TCEs of both the package and mounting substrate are not properly matched, thermostatic deflection (warp) can occur during temperature cycles. When these two materials warp, torque is directed to the solder joints, which results in a fatigued mechanical/ electrical connection. This problem becomes even more apparent as the LCC pin count increases. Larger package and substrate sizes result in higher stress levels. The selection and use of board material should follow this general rule: The larger the difference between the TCEs of the two materials used (the LCC and the substrate material), the smaller the substrate surface area should be. Available materials range widely in cost and TCE characteristics.

## Printed Circuit Considerations

After selecting the substrate material, the printed circuit trace geometries should be investigated. The circuit traces for LCC foot pads should be the same size as the metallization on the bottom of the LCC and slightly longer to the outer edge of the package. This metallization allows the solder, when heated to the reflow temperature, to wet both the base contacts and the LCC package's castellations.

The outer surface of the solder deposit forms a fillet where it extends over the metallization pad on the substrate's surface, strengthening the mechanical bond. This type of bond raises the LCC away from the board's mounting surface to facilitate cleaning the residual flux and debris under the package.

To optimize packaging density, relatively tight geometries in layout are of concern. Leadless package layouts often require $.010-\mathrm{in}$. lines, $010-\mathrm{in}$. spaces between lines, and $.020-\mathrm{in}$. or smaller feed-through holes. The pads that connect to the LCCs are typically $.020-\mathrm{in}$. wide, and are .050 -in. center to


Printed circult board metallization should extend beyond the LCCs outer edge. This extension permits molten solder to flow up the castellated regions, and to form a fillet of solder to complete the electrical connection while strengthening the mechanical bond.
center. This spacing allows one $.010-\mathrm{in}$. line at $.010-\mathrm{in}$. spacing to be run between the LCC mounting pads.

If lines are run close to other metallization, a solder mask should be used on the board to prevent solder bridging during the reflow process. When using multilayer boards or substrates, a clean layout can be made by allocating the surface layer metallization exclusively to LCC mounting padseliminating the need for a solder mask and reducing the concern for solder bridging. Electrical noise problems can be diminished by power gridding the supply buses on a unique layer while routing signal lines on other layers of the substrate.

## LCC Mounting Techniques

Socketing and soldering directly to the board are the two methods possible for mounting LCCs on circuit boards. In military applications, socketing becomes a disappointing compromise for LCC mounting because of the socket's bulky size. An LCC socket has its place in less critical applications, but can severely sacrifice packing density, and falls short of the stringent environmental testing required by most military applications. Direct LCC to substrate
mounting is the most reliable method for assembly.

The basic principle for attaching LCCS to boards and substrates is reflow soldering. Both the leadless package I/O metallization and the interconnecting substrate metallization are pretinned with solder; the two are then mated and heated by one of a number of means. Surface tension and the cohesive properties of the molten solder align the package over the substrate metallization. The assembly is then cooled, making complete the electrical/mechanical bond.

The best results are usually obtained from reflow soldering, and when both the LCC and the metallization on the substrate it is to be attached to are pre-tinned. The LCC package pads can be pre-tinned by fluxing and dipping. The substrate pads are usually tinned by wave soldering or screening on a solder paste.

When using a wave solder tinning approach, and after the substrate has been tinned, an adhesive must be applied temporarily to hold the LCC in place over the substrate metallization during the reflow process.

In implementing the screened on solder paste technique, the paste is


## System Noise Reduction in High-Speed CMOS

The majority of current flow in an all CMOS system is transient by nature, occurring on the waveform edges or transitions where instantaneous demand for current occurs. These current transients result from:

- charging and discharging of output load capacitance
- simultaneous P-channel and N -channel switching

The currents generated by these switching conditions can be large and cause noise on the power supply lines. However, the current's magnitude is not the only factor in determining the size of VCC/GND variations-The time period over which this current is switched is also critical. If this time period is relatively long, the current can be categorized as steady or bulk current, and the transient effect on the power supply voltage is minimal.
However, as the time period decreases, these inductance effects begin to play a more important role. The relationship of time and inductance are given by:

$$
\mathrm{V}=\mathrm{Ldi} / \mathrm{dt}
$$

Switching the same amount of current more quickly will have as great an effect on the VCC as an increase in the magnitude of the current change in the same time period. As propagation delays and output rise/fall times decrease, the effect of the related inductance becomes more significant.
The parasitic inductance is a result of system interconnect, socket, decoupling capacitor, and device package contributions. The inductance must be minimized to reduce this transient effect. The main sources of inductance are lead lengths (both IC and decoupling capacitor), PC board interconnect (VCC to capacitor to GND), and the capacitor, itself.
Although the designer can do little about standard IC packaging and lead length, manufacturers can employ several techniques for controlling the IC's parasitic inductance. Matching device size to package cavity area allows minimum bond wire lengths in assembly. Doubling the VCC and GND bond wire interconnect also reduces parasitic inductance effects within the package.
Printed circuit board runs should be kept to minimum lengths with VCC and GND lines $3 / 16-\mathrm{in}$. to $5 / 16-\mathrm{in}$. wide to reduce power line inductance. In prototype circuits, extra care should be taken in limiting wire length and including sufficient decoupling since the wire and socket lead length add inductance beyond that normally found in PC boards. Low inductance capacitors and socket elimination will help control system related inductance.
-W.J.N. \& J.M.W.
applied to the substrate contacts using a screen printing technique. Normally, a layer of "wet" paste, eight to nine mils thick, is deposited on the substrate contacts. Then the contact area, covered with paste, is air dried until tacky before the LCC is attached. The LCC is then mounted to the corresponding contacts manually or by automatic placement.

One important step in the LCC assembly process is baking the populated substrates dry before soldering, which allows the air and flux pockets in the paste to evacuate, minimizing the volatility effects in a vapor phase soldering operation. This process is vital because unevacuated flux pockets will cause the package to float during the reflow operation. Floating affects the package's positioning properties, and an unacceptable package alignment can occur. Also, the liquid vehicle of the solder paste is evaporated and the LCC is temporarily held to the substrate by the paste, which is now dry.

LCC placement on the substrate is not as critical as it might appear. During the reflow process, the dried solder paste holds the LCC in place while the paste reaches the reflow temperature. During this process, the surface tension of the solder will pull the LCC into alignment over the substrate contacts. The placement must be accurate enough to insure the LCC solder pads do not overlap the adjacent interconnect on the metallization below.

Heat must be applied to melt the solder and connect the LCC and the substrate. Methods such as belt furnaces, heated air chambers, and infrared radiated heat techniques can be used, but are not finding widespread acceptance. The most popular heating method for high-volume production is the vapor phase reflow technique.

In vapor phase reflow, the populated substrate to be soldered is lowered into a saturated vapor above a pool of high boiling point, flourinated hydrocarbons. Usually, vapor phase soldering systems have two operation zones. The primary zone is used for heating; the secondary zone is used as an intermediate cooling and cleansing zone before the assembly is removed from the soldering operation.

As the board is lowered into the primary zone, the solder joints are reflowed uniformly by the vapor, condensing over the surface of the substrate, which gives up its latent heat from vaporization. This thermal exchange heats the board quickly and evenly. When the substrate is raised into the secondary zone, the now condensed fluid from the primary zone drips off the board into the boiling liquid below. The substrate assembly exits from the process, uniformly oldered, dry, and relatively clean.
Cleaning the soldered assembly should be performed immediately after the vapor phase reflow process while the boards are still hot. Uncongealed residue can be easily removed at this time, resulting in thorough cleaning.

Another reflow technique employs hot solder oil. The substrate with positioned LCCS are fully immersed in a hot oil bath to bring the solder and parts up to the reflow temperature quickly. The assembly is then removed from the oil and allowed to cool. Rinsing the assembly afterwards removes residual oil and excess flux. This technique is useful for experimentation and low-volume production because of its relatively small capital investment.

## LCC Assembly Rework

The repair and replacement of a failed device packaged in an LCC is important in chip carrier assembly processes. The advantages in rework stem from the ease of reflow soldering. Since there are no leads on LCCs and usually no holes in the substrate to deform, many rework cycles are allowed. Of course, rework is dependent on the reflow technique, type of solder, reflow temperature, and the thickness of the metallization used in a particular application. During a rework situation, LCC removal can be accomplished using several techniques.

One method is to use the same hot solder oil immersion technique for applying the LCCs to a board. After the immersion and subsequent reflow of the solder, a pair of tweezers, or a similar tool, can be used to remove the defective LCC from the board.

Other removal methods are possible, such as using a soldering iron with a specially shaped tip to heat the contacts or by heating the defective package and its surrounding area with a forced hot air gun.

The heat gun method is usually the most convenient, inexpensive, and practical for rework. When the LCC is heated by the gun, the package should be removed with tweezers-the now exposed substrate contacts can be tinned, if necessary, as could the LCC contacts on the replacement device. The LCC is manually replaced in close proximity to its final position. The repair area or entire board is then heated to the solder reflow temperature to complete the operation.

## System on a Substrate Concept

When the appropriate LCC system components are assembled on a ceramic substrate with dual-in-line pins, the space, weight, and reliability advantages of LCCs are made more accessible. This "system on a substrate" technique allows LCCs to be used in more traditional system configurations such as those using standard DIP packaging.

One of the first movements in this concept direction has been the development of memory arrays on ceramic substrates. The HM-6564, a 64 K CMOS RAM module, was first introduced in 1979, and uses sixteen $4 \mathrm{~K} \times 1$ CMOS RAMs mounted on both the substrate's top and bottom. This packaging technique further increases an LCC's functional density on the RAM module. Other products available in module form include the Texas Instruments TMS4164, a 64 K dynamic RAM assembly, and a 64 K EEPROM assembly from National Semiconductor, the NMH2864.

With the introduction of the 16 K CMOS RAM, a step-up in module density is also seen. The HM-92560 uses sixteen HM-6516 RAMs, and has a total capacity of 256 K bits of static CMOS memory. The HM-92560 can be configured as a $16 \mathrm{~K} \times 16$ or $32 \mathrm{~K} \times 8$ static RAM array.

The HM-6564 and HM-92560, along with the other such modules, provide
only the memory circuitry-This approach increases the system packing density when large amounts of memory are necessary. Maximum reduction, however, is not accomplished because bus drivers and decoders must be added externally to the module assembly. To achieve a greater reduction in size, as many functions as possible must be placed on high density assemblies.
The Harris HM-92570 is a beginning to the "system on a substrate" development. By providing LCC-packaged cMOs bus drivers and decoders on the substrate, all the functions of a 256 K -bit memory board are contained in one high density assembly. The HM-92570 address inputs are buffered and have an input current leakage limit of $10 \mu \mathrm{~A}$ so direct connection to the CPU address bus is possible without additional buffering. The HD-6440 CMOS decoders on the substrate meet the memory array decoding needs.
The Digital Equipment Corporation Micro/J-11, a CMOS module assembly, which is a two-chip set equivalent of the PDP-11 minicomputer, has adapted this concept to the microprocessor area. Two CMOS devices manufactured by Harris, the control chip and the data chip, are packaged in $64-$ pad lCCs and are mounted on a 60-pin ceramic DIP substrate, compatible with the PDP-11's full instruction set. Compared to the original PDP-11 assembly, which consisted of several boards, this transition to a 60 -pin substrate offers significant size and power reduction advantages.

The next step will be the combination of CPU, $\mathrm{I} / \mathrm{O}$, and a significant amount of memory onto a single substrate assembly. The development of more highly integrated processor, such as the 80 C 186 , that include $\mathrm{I} / \mathrm{O}$ and control functions on-chip will make the logistics of providing all capabilities in a single high-density unit easier to handle. With all functions available in one unit, systems can be implemented with one assembly connected to the outside world, or additional assemblies added to provide greater amounts of memory or high-density multiprocessing capabilities.

## by Walter J. Niewierski

Ioday's complementary metal oxide semiconductor microprocessors have evolved in differing wayssome through direct hardware/software emulation of existing N -channel metal oxide semiconductor microprocessors, others by the merging of several architectures and instruction sets. In both cases, performance improvement and low power operation result.

In order to take advantage of these microprocessor advancements, logic and memory also had to improve. For example, an entire second generation of high speed small scale integration/medium scale integration (SSI/MSI) logic appeared in the $74 \mathrm{HCXX} / 74 \mathrm{SCXX}$ products. These logic devices offered low power Schottky transistor-transistor logic (LS/TTL) equivalent propagation delays at complementary metal oxide semiconductor (CMOS) operating power levels and provided the necessary high speed "glue" for advanced CMOS microprocessor systems.

Similarly, higher density CMOS memories are now available at much greater speeds. Functional options include both synchronous and asynchronous memory

[^15]
operation to meet specific system requirements. Synchronous 16 k CMOS random access memories (RAMS), for example, have a guaranteed operating current of $10 \mathrm{~mA} / \mathrm{MHz}$ maximum for low power or battery operated systems. In addition, asynchronous 16 k CMOS RAMS, with the same configuration, have access times as low as 70 ns .

CMOS nonvolatile memory support is available with both erasable programmable read only memory (EPROM) and fuse link programmable read only memories (PROMS). CMOS PROMs offer the greatest benefits in nonvolatile applications where low power and reliable data retention are critical. Present CMOS fuse link PROMs store data in programmed polysilicon fuses. Fuse link technology yields permanent, stable storage characteristics for the life of the device. Polysilicon fuses, combined with the low power of CMOS, provide an excellent alternative to EPROMS or bipolar PROMs for battery operated and other low power systems.

For high performance, low power 2716-type memory applications, 16 k CMOS synchronous fuse link PROMs

| TABLE 1 |  |  |
| :---: | :---: | :---: |
| CMOS 80C86 Family Peripheral Support Chips |  |  |
| Part | CMOS device type/function | Comments |
| 82 C 82 | octal latch | $\mathrm{T}_{\mathrm{PD}}=35 \mathrm{~ns}$ max at $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pf}$ |
| 82C84A | clock generator/driver | $8-\mathrm{MHz}$ system clock frequency |
| 82 C 88 | bus controller | Status decode function |
| 82 C 54 | programmable interval timer | $10-\mathrm{MHz}$ count frequency |
| 82C55A | programmable peripheral interface | Control word read capability |
| 82C59A | priority interrupt controller | 8 user defined priority interrupt requests |

method for data movement, using read (RD) and write (WR) lines, allows interface to almost any recent generation microprocessor.

In addition, consistent family specifications make system design easier. All peripheral product ac and dc specifications are guaranteed over the industrial ( $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ ) or military ( $-55^{\circ} \mathrm{C}$ to $125{ }^{\circ} \mathrm{C}$ ) temperature range and $5-\mathrm{V} \pm 10 \%$ voltage range. Timing specifications for peripheral circuits allow full speed operation with a CMOS 80 C 86 central processing unit (CPU) at 5 MHz , with no wait states.
provide a low $13-\mathrm{mA} / \mathrm{MHz}$ operating current with 175 -ns access times. Moreover, performance upgrades to $125-\mathrm{ns}$ access times will soon be possible. In nonvolatile memory, CMOS has a significant speed advantage over N-channel MOS (NMOS), while showing a large power reduction.

## Improving peripheral support

Although sophisticated CMOS microprocessors have brought high performance to low power designs, they cannot reach their full potential without equally high performance, low power consumption support chips. For the most part, CMOS peripheral circuit design efforts have lagged. This has limited the development of systems attempting to use CMOS devices exclusively. A new family of microprocessor peripheral circuits fills this void by providing increased performance and functionality without sacrificing low power consumption.

Because the Harris 80 C 86 peripheral product line (see Table 1) has a wide functional range, complex, high performance systems for low power applications can be designed. The peripherals are TTL compatible CMOS versions of industry standard NMOS devices. In addition, they incorporate improvements that eliminate traditional problems in hardware, software, and power consumption. With the peripheral circuit family, costeffective, low power designs can be implemented at superior performance levels.

Drop-in replacements for their NMOS equivalents (see Table 2), the $80 \mathrm{C86}$ peripheral family offers equal or greater performance. The peripheral family's architecture is fully compatible with 80 C 85 - and 80 C 86 -type microprocessors. However, the popular 2-line control

Dual specifications for the logical 1 output voltage $(\mathrm{VOH})$ ensure interface compatibility of the peripherals with both CMOS and TTL devices. Even in an all-CMOS design, there may be the need for circuit functions available only in NMOS or bipolar. In this case, the peripherals allow direct interface without pullup resistors or additional buffers. For future system enhancements with circuits of other technologies, the retrofit problems that occur with non-TTL compatible devices are eliminated.
Several techniques used to design the peripherals improve CMOS's natural low power operation. During normal system operation, bus signals at the latch inputs can exhibit high impedance or make transitions unrelated to latch operation. These voltage transitions cause an increase in power dissipation due to the low resistance path between $\mathrm{V}_{\mathrm{CC}}$ and ground created when the input circuitry switches.
In Harris' 82 C 82 octal latching bus driver, gated inputs eliminate input switching current transients by turning off the inputs when data are latched (strobe pin = low). See Fig 1. The strobe pin (STB) disconnects the input inverter from the power supply by turning off the upper P-channel (Q1) and lower N-channel (Q2). No current flow from $V_{C C}$ to ground occurs during input transitions. Invalid logic states from floating inputs are not transmitted to succeeding circuitry, thereby eliminating the need for pullup resistors.

## Steering clear of high current conditions

Bus-hold circuitry used on specific pins avoids high current conditions caused by floating inputs to CMOS devices. These circuits maintain a valid logic state when

TABLE 2
Peripheral Interface Compatibility

|  | Logical 1 Input voltage (VIH) | Logical 0 Input voltage (VIL) | Logical 1 Output voltage (VOH) | $\begin{gathered} \text { Logical } 1 \\ \text { Output current } \\ (1 O H) \end{gathered}$ | Logical 0 Output voltage (VOL) | Logical 0 Output current (IOL) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $80 \mathrm{C86}$ <br> Peripherals | $\begin{aligned} & 2.0 \mathrm{~V} / 2.2 \mathrm{~V} \\ & \text { Ind/Mil } \end{aligned}$ | 0.8 V | $\begin{aligned} & 3.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{cc}}-0.4 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -2.5 \mathrm{~mA} \\ & -100 \mu \mathrm{~A} \end{aligned}$ | 0.4 V | 2.5 mA |
| NMOS 8086 Family | 2.0 V | 0.8 V | 2.4 V | -400 $\mu \mathrm{A}$ | 0.45 V | 2.5 mA |
| CMOS | 70\% V ${ }_{\text {cc }}$ | $30 \% \mathrm{~V}_{\text {c }}$ | $\mathrm{V}_{C C}-0.5 \mathrm{~V}$ | $-10 \mu \mathrm{~A}$ | 0.4 V | 2.0 mA |
| LS/TTL | 2.0 V | 0.8 V . | $\begin{aligned} & 2.5 \mathrm{~V} \\ & 2.7 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -400 \mu \mathrm{~A} \\ & -400 \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & 0.4 \mathrm{~V} \\ & 0.5 \mathrm{~V} \end{aligned}$ | 4.0 mA - Military <br> 8.0 mA - Commercia |



Fig 1 Gated inputs of $\mathbf{8 2 C 8 2}$ octal latching bus drivers. Such internal circuitry eliminates need for external pullup resistors.
no driving source is present (ie, an unconnected pin or a driving input that goes to a high impedance state). In the 82C55A programmable peripheral interface (PPI), all port pins have bus-hold circuitry (Fig 2). Port pins are defined as inputs at reset. If they are either open or will eventually become outputs, they have no driving source and are floating. With normal CMOS input circuitry, this could cause a high current situation. On the PPI port pins, however, bus-hold circuits maintain a logic 1 level internally and externally until the ports are either defined as outputs or overdriven by an external source.

To overdrive the bus-hold circuits, an external driver must supply $300-\mu \mathrm{A}$ minimum sink or source current at valid input voltage levels. Since this bus-hold circuitry is active and not a resistive-type element, the associated power supply current is negligible. The PPI standby current specification is $10 \mu \mathrm{~A}$ maximum.

All 80C86 peripheral family devices are designed with fully static circuitry. This allows the devices to be operated from dc to their individual maximum rated frequencies. Since operating power is critical in low power applications, the user can control this parameter,


Fig 2 Bus-hold circuitry used on the 82C55A programmable peripheral interface CMOS peripheral. Logic 1 level is maintained internally on undefined port pins to keep power consumption to a minimum.
based on system operating frequencies. CMOS operating power is directly related to frequency; the lower the frequency, the lower the operating power dissipation. At a dc frequency, device standby currents are typically less than $10 \mu \mathrm{~A}$.

Where voltage is concerned, the peripheral family maximum input voltage limit (ground $-2.0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }}$ $\leq 6.5 \mathrm{~V}$ ) essentially eliminates the problem of device latch-up. Latch-up results from an overvoltage condition on the inputs or outputs that causes a parasitic silicon controlled rectifier on the die to become active. This creates a high power supply current (ICC) condition. The increased input/output (1/0) voltage range on the peripherals offers greater protection from systeminduced noise, as well as increased noise immunity.

## Expanding parallel ports

Adding parallel $1 / \mathrm{O}$ ports to an 80 C 48 family microcomputer using a PPI is well documented. However, designing this system in CMOS (see Fig 3) requires additional attention to the port reset condition and the state of unused port inputs. The CMOS PPI eliminates these concerns and, in conjunction with a unique feature of the 82 C 82 octal latch, keeps power dissipation low enough for battery operation. An extremely low standby power supply current of $10 \mu \mathrm{~A}$ maximum is guaranteed over the full operating temperature range for both the PPI and the octal latch. This is especially desirable in idle or low power modes of operation. Since these devices see mostly static operation, the standby current level is the dominant factor in overall power dissipation.

With the use of bus-hold devices on all port inputs, the PPI eliminates the need for pullup resistors to prevent undefined signal states. Upon being reset, all port (A, B, and C) pins are pulled high by internal bus-hold devices instead of the standard NMOS PPI procedure of putting all port pins into the high impedance state. The bus-hold devices also provide valid logic levels to CMOS inputs connected to the port pins prior to port initialization. Shaded areas in Fig 3 indicate where pullup resistors, normally needed for CMOS systems, are eliminated.

A low level external drive input ( $\mathrm{I}_{\mathrm{O}}=300 \mu \mathrm{~A}$ ) can overcome the bus-hold function. If the port input is unused, the bus-hold device maintains a high logic level and provides a valid logic input to the port pin. Since the bus-hold device is an active component on the chip and the PPI standby current is specified as $10 \mu \mathrm{~A}$ maximum, dc standby current is decreased by a factor of 1000 from the levels seen with pullup resistors.
Functional update is simplified by a readable control word on the PPI. Status of this device can be obtained by a control-word read operation. Data are transferred from the PPI control register, eliminating the need to store port configurations in system memory or internal registers.

Used in this application for address/data bus demultiplexing, the octal latch keeps power at a minimum with a specialized input circuit design. Gated inputs on the octal latch prohibit the passing of invalid input states to octal latch internal circuitry during the time data are latched. This prevents undefined logic states and high current transients due to input switching.

Fig 3 Parallel i/o port expansion with cmos peripheral low power consumption and elimination of external pullup resistors (shaded areas) are benefits of cmos techniques.


## Waking up the processor

One of the most appealing features in many CMOS microprocessors is the interrupt wake-up from powerdown mode. In this operation, the CPU is brought back from a low power idle mode by an external interrupt. Typically, simple interrupt schemes must be implemented since only a single external interrupt is available at the processor itself. With the 82C59A CMOS priority interrupt controller (PIC), eight separate interrupting sources can wake up the processor on a priority basis. For complex systems, 64 interrupts can be serviced via the cascaded connection of up to eight PICs.

Fig 4 shows how the PIC accommodates several interrupts in a single-chip CMOS microcomputer system.

Addressing for the 82C59A PIC takes a 2-level approachstandard read/write operations and interrupt vector transfer. Since there is no interrupt acknowledge (INTA) signal available from the processor (this line is needed to transfer the interrupt vector information from the PIC), the necessary decoding for these two sets of operations must be handled elsewhere. A single HD-6440 CMOS line decoder and one 74 HC 00 quad 2 -input NAND gate will do the job. A single bit from port $\mathrm{B}(\mathrm{PBI})$ is used to gate the microcomputer RD signal to the 82C59A PIC RD input for standard data transfers ( $\mathrm{PB} 1=\operatorname{logic} 0$ ), or to the INTA input for vector information ( $\mathrm{PB} 1=\operatorname{logic} 1$ ).

Fig 4 Multiple interrupt handiling in priority interrupt controller CMOs chip. Up to eight levels of interrupts are possible, with a single 82C59A priority interrupt controller.


| TABLE 3 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Priority Interrupt Controller Chip Interrupts |  |  |  |  |  |  |  |  |
| Interrupt Bit Assignments |  |  |  |  |  |  |  |  |
| Interrupt Request Inputs | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO |
| IR7 | T7 | T6 | T5 | T4 | T3 | 1 | 1 | 1 |
| IR6 | T7 | T6 | T5 | T4 | T3 | 1 | 1 | 0 |
| IR5 | T7 | T6 | T5 | T4 | T3 | 1 | 0 | 1 |
| IR4 | T7 | T6 | T5 | T4 | T3 | 1 | 0 | 0 |
| IR3 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 1 |
| IR2 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 0 |
| IR1 | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 1 |
| IRO | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 0 |

A PIC response can occur in either of two user programmable modes. The first mode is the classic 8080/85 format where a call opcode is transmitted with two bytes of additional vector information. For the most efficient interrupt response in this system, however, the 8086 compatible mode should be used. This mode needs only two INTA pulses instead of the three required for mode 1 operation. During the initial INTA cycle in the 8086 compatible mode, the PIC freezes the state of the interrupts, resolves priority, and issues the master interrupt codes on the cascade lines. No data are transmitted on the data bus during the first cycle. On the second INTA cycle, a byte of interrupt code is sent to the CPU. This acknowledgment byte is defined in Table 3. The host CPU programs the upper five bits (D3 through D7) at initialization. They provide the base address for interrupt
vectoring. The lower three bits (D0 through D2) provide the offset based on the interrupting source.

INTA signals are generated by decoding specific addresses' output during load accumulator (LDA) instructions. The vector information transferred during the last INTA cycle can be used in an interrupt service routine using an indexed jump to locate the specific service program.
The timing diagram in Fig 5 shows a 146805 microcomputer's response to a wake-up interrupt, along with the necessary INTA generation and vector information retrieval from the PIC. The ability to wake up an idle CMOS microcomputer with any of several interrupting sources greatly increases single-chip system flexibility.

## High resolution timing

Although the increased speeds of CMOS microprocessors meet the timing requirements of many applications, some demand a more precise reflection of time. In these situations, the 82 C 54 CMOS programmable interval timer (PIT) provides high frequency count capability while the 82C84A CMOS clock generator/driver (CGD) delivers, from a single input frequency, both a high frequency timer input and a lower frequency CPU clock. High resolution timing is thus accomplished with relatively low system clock frequencies.

In the system depicted in Fig 6, an $8-\mathrm{MHz}$ timer frequency is used with a $4-\mathrm{MHz}$ CPU clock. The CGD generates three output signals: OSC is the crystal frequency; CLK is the crystal frequency divided by three; and PCLK is the clock frequency divided by two. A $24-\mathrm{MHz}$ parallel resonant, fundamental mode, AT cut crystal on the CGD results in a $24-\mathrm{MHz}$ OSC frequency, $8-\mathrm{MHz}$ CLK


Fig 5 Timing diagram of microprocessor response to a wake-up interrupt. Any of several interrupts can initiate the wake-up response.

Fig 6 CMOS programmable interval timer and clock generator. Such a system provides high timing resolution from low system clock frequencies.

frequency, and $4-\mathrm{MHz}$ PCLK frequency. The system thus has an $8-\mathrm{MHz}$ count frequency and $2-\mathrm{MHz}$ NSC800 operation. If an upgrade to $4-\mathrm{MHz}$ operation is desired, the $8-\mathrm{MHz}$ CLK output from the PIT can clock both the processor and the PIT. The guaranteed maximum count frequency for the PIT is 10 MHz minimum. The $8-\mathrm{MHz}$ output from the CGD meets the minimum pulse width requirements for the PIT clock input. This high count frequency allows resolution of time increments down to 125 ns , even with processor T-state periods of 500 ns .

Two software features-a readable status word and realtime count indication-allow full 82C54 PIT control in high frequency applications. The status-word read capability enables the processor to get an accurate indication of device status and reconfigures the counter when necessary. For accurate realtime count readings, the PIT can be read while still incrementing. When a
read count operation is initiated, the current count is held in a count register until the read is completed. The count register is then updated to the new elapsed count status. If lower system operating power is desired, or if a slower CPU speed is needed, the 82 C 84 A CGD base frequency can be reduced. Since CMOS operating power is directly related to frequency, both CGD and PIT operating power will be lower at these reduced frequencies.

The advent of a diverse group of CMOS peripheral chips heralds a new era in system design. Applications demanding low power consumption, high performance, and portability can now be served by an entirely CMOS oriented approach. Broadening CMOS applications into areas hitherto restricted to the realm of other technologies will allow designers more flexibility in creating tomorrow's systems.

# CUSTOM MICROPROCESSOR POWERS OFFICE WORK STATION 

by Carl P. Gerstle and Donald A. White, Digital Equipment Corp., Small Systems Engineering Group, Maynard, Mass.
$\square$ Generous use of complementary-MOS semiconductor technology in a new processor chip and in many other circuit components imparts high performance and outstanding reliability to a combined small-business computer and office-automation work station. Beneficiary of the C-MOS magic is the DECmate Work Processor, the newest member of the fully compatible family of wordand data-processing systems based on the 12 -bit PDP- 8 architecture. Its new integrated-circuit processor, called the 6120, runs an extended PDP-8/A instruction set, including memory-address expansion on chip.

For both the 6120 processor and the 6121 input/output controller, C-MOS was deemed superior to less-power-efficient static n-channel mos technology and also to more complex dynamic $n$-MOS technology. Although dynamic $n$-MOS could have reduced the amount of power required, as compared with static parts, a dynamic design would not have been as clean to work with for the logic functions needed.

In the asynchronous environment of static logic, chip designers need not be as precise in planning timing tolerances as is necessary to maintain two-phase clock synchronization in dynamic logic. Moreover, single-step design debugging in static logic allows the designer to see individual problems as they happen at slow clock speeds. The system clock may be brought down to dc if desired, there being no minimum cycling rate required.

## C-MOS is superior

The 6120 chip (Fig. 1) was a joint development project between DEC's Small Systems Engineering group and the Harris Semiconductor division of Harris Corp., Melbourne, Fla. It is about three times faster than the predecessor 6100 C -MOS processor used in the earlier WS78 computer.

The speed improvement was measured executing a representative mix of instructions. In fact, the 6120 is even a little faster than a PDP-8/A minicomputer running the software of the WS200 multiterminal wordprocessing system.
Two differences between the 6100 and 6120 are chiefly responsible for the speed hike. First, the 6120 was designed to perform some operations in parallel, but the 6100 processes all functions serially. For example, the page addresses in memory are calculated at the I/O pins while data is being computed in the arithmetic and logic unit. Secondly, the shrink from 6-micrometer geometry in the 6100 to $4-\mu \mathrm{m}$ features in the 6120 reduced on-chip capacitance, boosting transfer speeds with little increase in power dissipation.

A significant jump in transistor density on the 6120 owes much to the move to $4-\mu \mathrm{m}$ technology, but it is also due in part to enhanced on-chip interconnection techniques. The die size of the 6120 is 230 mils by 210 mils-only a $20 \%$ increase in die area for a $175 \%$ increase in transistor count as compared with the 6100.

## Old reliable

The high reliability experienced with the 6100 C-MOS chip in more than four years in the field, as well as the low power consumption and other design benefits of this technology, made it an easy decision to use such logic in the 6120 processor chip. Furthermore, there were many good reasons to extend the use of C-MOS in preference to n -MOS and TTL logic wherever possible among support functions surrounding the central processor.

C-MOS was also chosen for the 6121 custom I/O controller chips designed for this product - two of them on the processor board and one on the optional communica-tions-controller board. C-mOS is used, as well, for the read-only and random-access memories in the control store of the processor board and for the universal asynchronous receiver-transmitters in the serial printer and keyboard control circuitry, also on board. The control memory is used for such functions as self-testing, terminal t/O emulation, floppy-disk control, and a buffer memory and control registers for the video display.

Altogether, there are 27 static C-MOS ICs on the microcomputer board and 14 more on the communica-tions-controller board. However, dynamic n-mOS was chosen for main memory to achieve the maximum storage capacity per dollar. These RAMS are the only dynamic circuitry on the processor board.

## Memory control

On-chip memory-extension control in the 6120 boosts its addressing capability over previous family members from $4-\mathrm{K} 12$-bit words to $32-\mathrm{K}$ words in each of two separate memory spaces. In addition, the new chip executes the memory-extension instructions faster. It also contains 12 special-purpose registers and control logic, along with the arithmetic and logic unit.

Extensions to the PDP-8/A instruction set include stack-command macroinstructions that permit more efficient encoding of the ROM-based firmware. Another benefit from the expanded instruction set is the addition of power-up self-test diagnostics. The 6120 costs about the same as the 6100, but by taking over memoryextension control, it reduces total system cost.

The mostly C-MOS, cool-running single-board micro-


1. Chip off the old block. The 6120 C-MOS processor chip implements the much-used PDP-8 architecture, executing an extended PDP-8/A instructions set. The design uses two system buses - the data and address I/O bus and the C-bus-and 12 special-purpose registers (tinted):

2. Energy-efficient worker. The C-MOS-intensive DECmate desktop system packs a lot of function onto a small number of low-power boards. The processor board alone handles eight functions. The building blocks implemented totally or partly in C-MOS are shaded.
computer (Fig. 2), requiring a mere 15 watts, is the controller of all functions in the computer. The 11.1-by-10.5-inch DEC-standard extended quad board contains eight major functional units: the processor, the 32-K 12 -bit-word main memory, address space for as much as $32-\mathrm{K}$ words of control memory, a real-time clock, and four control circuits.

## Smaller package

The new chips allow the microprocessor and its main memory to fit on a single board. The equivalent ICs including the 6100 processor in the older WS78 occupy three larger boards and one slightly smaller one. The number of 14 -pin-chip equivalents was reduced from 375 in the WS78 to 200 in the DECmate. The $80 \%$ net reduction in board area stems in part from the use of large-scale integrated circuits, the other factors being the combining of the terminal and central processors that were separate in the WS78 and the tighter board layout possible with improved printed-circuit boards.
The almost $50 \%$ reduction in chip population increases long-term reliability because it reduces the total number
of gold-wire bonds subject to temperature cycling and possible failure. Equally important is the massive switch to cool-running, low-power C-mOS. The temperature rise on such a die is only about $25 \%$ above the ambient temperature, while the rise on a similarly sized TTL or n -mos die is roughly $100 \%$. In the latter case, then, a much greater temperature strain is imposed on wire bonds and metal lines, as well as on the IC devices themselves.

Like any MOS part, a C-MOS IC is self-limitingcircuit currents drop as temperature rises. In TTL parts, higher temperatures result in increased currents - which can ultimately lead to cyclic degeneration or thermal runaway. Since C-mOS runs cooler than other mOS technologies, the resultant parts offer a more generous temperature safety margin.

Through the use of static C-mCs logic in the 6121 I/o controller, board space and power were saved again. Because the 6121 spends much of real time in an inactive state, dynamic logic would have required a good deal of refresh circuitry either on the chip or in discrete logic. The three 40 -pin 6121 s perform $\mathrm{I} / \mathrm{O}$ control for five

3. C-MOS to the rescue. When the DP278 communications controller for the DECmate was using too much power, consumption was cut from 6 to 4 watts by using the C-MOS 6121 I/O controller chip and replacing 16 TTL chips with 14 C-MOS chips (tinted).
channels each. They are programmable, so the board designer has more flexibility in establishing channel characteristics.

C-MOS logic also offers reduced ringing and overshoot - a cleaner signal that is especially valuable on a bus. There tend to be fewer difficulties with electromagnetic and radio-frequency interference-a point that has increased importance today in view of the new Government emissions regulations on office equipment. The noise margins offered by C-MOS are superior to those of TTL, there being a wider tolerance for noise introduced between the maximum input and output low voltages: 1.4 v versus 0.4 v . Similarly, a C-MOS receiver has a high-voltage margin of 1.4 V versus 0.4 V .

## Little watts

Low power consumption, chiefly as a means of optimizing reliability, was, from the beginning of the design effort, a principal reason for specifying C-MOS in both custom and off-the-shelf parts. Whenever off-the-shelf C-MOS chips were available, they were used in preference to their TTL counterparts for bus buffering, special hard-
ware registers, and dedicated address decoding. In general, this reduced system bus noise and power requirements.
The system power requirements were set at a low enough level so as to ensure reliability within a convec-tion-cooled terminal housing. An important design goal was as small a power supply as possible, while maintaining the ability of adding options. A $60-\mathrm{w}$ supply is used, requiring 75 w from a wall outlet. As a comparison, the WS78 used somewhat over 200 w .
Well into the design effort, the small power supply, coupled with a fixed power allotment for the processor board and any further options, necessitated a very limited power allotment for the DP278 communicationscontrol optional board. The DP278 was originally designed in n -MOS (four ICs) and 7400 -series TTL parts to minimize cost. The TTL, however, caused the module's power requirement to be $50 \%$ over its allotment. So in the 10 functions shaded in Fig. 3, C-MOS parts were used to cut the projected power to 4 W at 5 v dc. Replacing 16 TTL chips were 14 C -MOS equivalents about $19 \%$ of the module.

For many data-communication tasks, commercial or military, a programmable Manchester encoder-decoder circuit has the edge over UARTs or protocol controllers.

# For data-comm links, Manchester chip could be best 

Although there are many LSI chips for interfacing computers, terminals, and other subsystems with serial datacommunication links, in many applications the programmable Manchester encoder-decoder offers significant advantages over the other chips. These advantages become apparent when comparisons are made at the system level.

The list of competing circuits includes universal asynchronous re-ceiver-transmitters (UARTs), multiprotocol controllers (such as those for various levels of data-link control), and several types of encoders and decoders. But it is often difficult to compare capabilities at the chip level because of the chips' different natures. Performance must therefore be compared at the system level, taking into account the required throughput, accuracy, and communication protocols.

In many situations, such analysis shows that programmable Manchester
 encoder-decoder circuits have higher
data rates, overhead efficiency, and accuracy. Unlike other controller chips, however, these devices do not perform serial-to-parallel or parallel-to-serial data conversion. Also, additional circuitry is needed to implement some standard data protocols, thereby making them less cost-effective in those applications.

The Harris HD-15531 aptly illustrates the capabilities of systems built with a Manchester encoder-decoder chip. Originally aimed at military applications (see "Interfacing with a Military DataComm Bus"), the 15531 is sufficiently versatile,
Lester Sanders, Member of the Technical Staff
Harris Corp., Semiconductor Digital Products Division
P.O. Box 883, Melbourne, Fla. 32901
thanks to its programmability, to compete with UARTs and multiprotocol controllers in a wide range of commercial applications as well.
It is built with CMOS technology and comes in a 40 -pin package. Capable of data rates up to 2.5 $\mathrm{Mbits} / \mathrm{s}$, the 15531 has power dissipation of only 50 mW . As a transmitter, it encodes nonreturn-to-zero code into Manchester code; as a receiver, it decodes the Manchester back into NRZ. The data word length is programmable from 2 to 28 bits.
Other programmable characteristics include parity polarity and synchronous/asynchronous clock operation. Independent encoder and decoder sections on the chip allow full-duplex data communication.

Also available are lower-cost preprogrammed versions (the HD-15530 and HD-6408) in 24 -pin packages.

## Speed without sacrificing accuracy

The goal in data-communication systems is maximum throughput combined with maximum accuracy. But there are several conflicting tradeoffs. First, a need for extreme accuracy tends to restrict the throughput. Then, too, throughput depends on both the data rate and the overhead efficiency. Finally, overhead efficiency relates directly to the communication protocol employed.
Therefore protocol and data rate are used to measure the effectiveness of data-communication ICs. The most popular LSI circuits for data communications are UARTs and data-link control chips. Some UARTs operate at up to $500 \mathrm{kbits} / \mathrm{s}$, but most work in the 40 -to- 50 -kbaud range. Similarly, some data-link controllers operate at up to $2 \mathrm{Mbits} / \mathrm{s}$, but $1 \mathrm{Mbit} / \mathrm{s}$ is more typical. With a maximum data rate of $2.5 \mathrm{Mbits} / \mathrm{s}$, the 15531 clearly outpaces both


1. The data formats of UARTS (a), protocol controllers (b), and Manchester encoder-decoders (c and d) differ vastly, each offering advantages for different applications. The HD-6408 and HD-15530 (c) have a fixed, 16-bit word length, whereas the HD-15531 (d) has a programmable word length.

UARTs and data-link controllers on the basis of data rate alone. However, the questions of communication protocol and overhead efficiency remain to be resolved. In many cases the 15531 will offer further advantages in those areas.

Since accuracy should not be sacrificed to achieve throughput, the synchronization schemes used by the various data-communication circuits must be considered. Synchronization is the key to accurate reception of incoming data. Because they transmit data in Manchester code rather than NRZ, Manchester circuits are better at synchronization than UARTs and DLCs. Also, the 15531 establishes synchronization by recognizing a 5 -bit sequence, and its relatively powerful error detection circuitry further enhances accuracy.

Manchester code offers other useful advantages in addition to reliable synchronization (see "Manchester Code Gaining on NRZ"). For one, it is selfclocking, so that a wire for the clock signal is not needed, thus reducing transmission-line costs. In addition the Manchester code has no de or lowfrequency components in the waveform; therefore signals can be ac-coupled with transformers or capacitors, thereby lowering system costs, and in some applications avoiding errors or failure caused by interference.

## Protocols and data formats

Usually, system designers select data-communication ICs primarily on the basis of the data structure used in a particular application. For example, UARTs and programmable Manchester circuits transmit data asynchronously (though synchronous operation is possible with the 15531), whereas datalink controllers send data synchronously.

A data-communication protocol is the implied set of rules that establishes communication between a transmitting and receiving station. The information structure in any serial data-communication scheme includes both control information and data. The control information performs such functions as delineating data, defining the amount of data to be transmitted, providing the addresses of the transmitting and receiving stations, and error handling. Figure 1 compares the data formats of UARTs, the DLC circuits and the 15531.

UARTs have programmable data formats. They frame from 5 to 8 data bits with 2 to 4 frame bits, using start and stop frame bits to define the beginning and end of a character. A programmed parity bit can provide error detection.

In data transmission, those bits that are not data are considered to be overhead, and overhead efficiency is a measure of the amount of data contained in a message. To calculate the typical overhead efficien-
cy of a UART, assume that a 7 -bit ASCII character is transmitted and that the UART is programmed for a parity bit and one stop bit. Thus, including the start bit, 3 control bits are used in a 10 -bit frame, for an overhead efficiency of $70 \%$.

With the 15531 , the length of the transmitted character is also programmable-in this case, from 2 to 28 data bits. A 3 -bit synchronization pulse and a parity bit frame the data word. The 3 -bit sync pulse is an invalid Manchester pattern generated by the encoder and recognized by the decoder. The sync pattern consists of $11 / 2$ bits in one state followed by $11 / 2$ bits in the opposite state. (As will be shown later, this particular pattern has definite advantages for synchronization.) The use of 3 bits plus parity means that 4 overhead bits are required to send as many as 28 data bits-yielding an overhead efficiency of
87.5\%.

Data-link, or multiprotocol, controllers typically generate such bit-oriented protocols as Synchronous Data Link Control (SDLC), High-level Data Link Control (HDLC), and Advanced Data Communications Control Procedure (ADCCP). These protocols frame blocks of data with byte-wide or multibytewide fields like preframe sync, address, control, cyclic redundancy check (two bytes), and post-frame sync so that six control bytes are required to send a data field of 0 to 256 bytes (extended with HDLC and ADCCP). Therefore the overhead efficiency of multiprotocol controllers ranges from zero to nearly $98 \%$. Table 1 compares the overhead efficiencies and other important characteristics of all three types of data-communication circuits.
Arbitrarily sized gaps between characters occur

## Manchester code gaining on NRZ

Although nonreturn-to-zero (NRZ) code is still the most widely used in data-communication systems, Manchester code is gaining ground rapidly. Already it is extremely common in magnetic tape recording and fiber-optic communication systems. More recently, it has gained support for serial data communications. The Ethernet office network-supported by Xerox, Digital Equipment Corp., Intel, Hewlett-Packard, and others-specifies Manchester phase encoding. Also, MIL-STD-1553 specifies Manchester code for an avionics data bus (see "Interfacing with a Military DataComm Bus").
Strictly speaking, the coding scheme referred to as "Manchester" should be called "Manchester II," as it differs from the original Manchester code, which is almost never used today. Also known as biphase-L, Manchester code is distinguished from NRZ and others by a transition at the center of each data cell.

The diagram compares NRZ and Manchester codes for the binary expression 01100. Note that the NRZ version represents the binary value with a static level throughout a bit period-where a binary 0 is a low logic level and a binary 1 is a logic high. Manchester code, on the other hand, has a logic

transition at the middle of each bit period. The binary value of data is represented by the direction of the transition: a high-to-low midbit transition represents a logic 1 , and a low-to-high represents logic 0 . The midbit transition represents both the data and the clock. Because the clock and data are included in a single serial data stream, Manchester is known as a self-clocking code.

Note that with NRZ code, only one symbol ( 1 or 0 ) is required to represent a data cell. Therefore the data transfer rate is the same as the information rate. With Manchester, however, two symbols are needed for each cell. That means that a modulation rate twice that of NRZ is needed to transmit the same amount of data -a possible drawback in band-width-limited communication channels.

The advantages of Manchester code include self-clocking, inherent error detection, and the absence of a dc component-which allows ac coupling. NRZ, however, requires no additional encoding or decoding, and it makes the most efficient use of a communication channel's bandwidth. Another advantage of NRZ is that it is supported by a wide range of ICs. However, the introduction of Manchester LSI chips, such as the HD-15531, signals increasing support of Manchester code by semiconductor companies.
with asynchronous data transfer. Typically such transfer occurs when a human-operated peripheral, such as a keyboard, interfaces with a computer; the interval between characters is arbitrary. In contrast, with synchonous data transfer the characters are transmitted contiguously. Synchronous data transfer occurs typically in computer-to-computer interfaces. Although there are exceptions, UARTs are traditionally used for asynchronous data transfers, and protocol controllers for synchronous data. Usual-ly-but not necessarily-synchonous data transfer is faster than asynchronous.

In many situations, however, both UARTs and data-link chips are limited in speed, overhead efficiency, or both. UARTs, especially, lack the throughput needed for the more demanding data networks. Data-link controllers, on the other hand, have excessive overhead when single characters are transmitted, because, as explained, each frame has an overhead of six bytes, even if the frame length is only one or a few bytes.

As an example of the limitations of protocol controllers, consider systems for process control or data acquisition. Typically, such systems have many remote stations sending data to a primary computer. At the remote stations, input or output devices (such as temperature sensors) communicate a single 8 -, 10 -, or 12 -bit word through analog-to-digital or digital-to-analog converters. With a protocol controller, however, the fixed-format frame would require the opening and closing flags and the address,
control, and CRC fields-clearly inefficient for transmission of a single character.

A programmable Manchester circuit like the 15531 is much better suited to process-control applications. In addition to providing high data rates, it has a programmable data format, which can be useful for interfacing with a-d and d-a converters. For example, the programmable character length makes it easy to upgrade an 8 -bit conversion system to, say, 10 or 12-bit resolution. In contrast, UARTs are limited to 8 -bit characters and are therefore difficult to operate with 10 - or 12 -bit converters.

Protocol requirements are satisfied with various degrees of completeness by available data-communication circuits. UARTs merely provide a frame for the character, plus bits for framing and parity error checking. Protocol controllers provide somewhat more, using established fields to facilitate data communication. For example, the address field defines the address of the remote station for which the data is intended, and the control field defines the nature of the transfer. Both types, UARTs and protocol controllers, perform the parallel-to-serial and serial-to-parallel conversions needed for computer interfacing. In addition, most protocol controllers provide address recognition.

Several of the 15531's functions prove useful in generating a protocol. The Sync Select input, for instance, allows the polarity of the synchronization pulse to be selected at the encoder. Since this polarity is subsequently recognized by the decoder, it provides

2. Two sections of the 15531 decoder circuitry play a role in synchronization. The synchronizer detects signal edges and operates at 12 times the data rate, and the synchronization-pulse recognizer detects specific patterns.

## Interfacing with a military data-comm bus

The HD-15531 Manchester en-coder-decoder was developed originally for military applications. Specifically, it was designed to meet MIL-STD-1553A, a time-division-multiplexed bus for military aircraft.

Manchester code brings several important benefits to military avionics. For example, because it is self-clocking, it allows serial data transmission over a single twisted-wire pair, thus minimizing weight and space requirements. Also, accurate synchronization and simplified error detection enhance system reliability, so that the technique can safely be used for aircraft instrumentation and control signals. In addition, unlike signals resulting from other coding schemes, Manchester
signals can be ac-coupled, allowing the use of transformers and simplifying the design of fiberoptic transmission systems. In turn, the isolation provided by transformers or fiber-optic cables minimizes interference from other electrical systems.
Of course, the 15531 and other ICs designed for MIL-STD-1553B meet the temperature and other environmental requirements of military systems. The military standard provides a $1-\mathrm{MHz}$ datacommunication channel, so that real-time control is achieved even when many signals are multiplexed.
Companion ICs for the 15531 are available from Standard Microsystems Corp., Circuit Technology Inc., and ILC Data Device Corp.

The figure shows the connections when the 15531 is used with a UART from Standard Microsystems. The COM-1553A SMART (synchronous-mode avionics re-ceiver-transmitter) converts parallel data into serial form and vice versa, recognizes addresses, and counts words for error detection. Also, it provides a convenient interface with a microcomputer or other controller via an 8-bit data bus. As can be seen, in the figure, the two chips are extremely compatible.

To read or transmit the control and data words, two read or write pulses must be generated to the Read Data Enable or the Write Data Enable pin respectively. Connections to the data-communication bus are from $\overline{\mathrm{BZO}}$ and $\overline{\mathrm{BOO}}$.

a way to distinguish between two types of words in the communication between the transmitting and receiving stations. Then, for example, the transmitter can generate a command sync pulse to indicate to the receiver that a particular word contains address and control information. Similarly, a data sync denotes a data word.
Techniques for synchronization
To compare the accuracy of a UART and the 15531, it is necessary to understand how the two circuits synchronize with data. Typically, a UART employs a clock rate of 16 times the data frequency to synchronize with incoming data. The stop bit from the transmitter has a high logic level, and the gap between words (known as the idle state of the line) also is high. The start bit is a low level for one bit cell. To detect this bit, the receiver recognizes a high-to-low-level transition of the input (from the stop bit or idle state). The receiver then verifies the start bit in two steps: by counting eight cycles of the $16 \times$ clock to reach the center of the start bit and by checking to make certan that the start bit is still low. If the sample yields a high logic level, the receiver knows that the start bit is false. It then continues to look for a high-to-low transition. Thus synchronization with a character is initiated on the basis of two states.
Two sections of the 15531's decoder are involved in the synchronization: the synchronizer and the sync-pulse recognizer (Fig. 2). The former includes edge-detection circuitry, and its clock frequency is 12 times the data rate. The latter can detect a particular type of data pattern that is 5 bits wide. The pattern consists of $11 / 2$ data cells at one logic level, followed by $1 \frac{1}{2}$ data cells at the opposite level, followed by two valid Manchester bits (Fig. 3). A valid Manchester bit is defined as one with a midbit transition, and it is detected by the Exclusive-OR gates shown in Fig. 2.

Although the synchronization scheme of the 15531 requires three bits of preframe sync, as opposed to a UART's single bit, it checks a total of 10 states for synchronization. Therefore synchronization is much more reliable with the 15531 than with a UART.

Manchester code has a transition in the center of a data cell, and depending upon the data pattern, it also may have a transition at the beginning of the data cell. Transitions not only determine whether the data is a logic 0 or a logic 1, they also provide references to which the decoder can synchronize. Unlike UARTs, which synchronize only at the beginning of each character, the 15531 synchronizes with each transition. After it has been reset, the decoder needs to know when to sample the logic state of the
data. The optimum time to do that is midway between the data transitions, because this allows time for the signal waveform to settle from the rise and fall times.

Since transitions in Manchester code occur at the beginning and center of the data cells, the sample points should be one-quarter and three-quarters of the way through the data cell. A transition detector, a counter, and logic circuitry team up to locate the required sampling points. With a clock of 12 times the data rate, the decoder counts to 3 to find the onequarter data-cell point and to 9 for the three-quarters data-cell point. For resynchronization, the algorithm is reset at each transition-which occurs once or twice in each data cell. Thus synchronization of the 15531 is far superior to that of a UART, which synchronizes only once per character. With the 15531, sampling error does not accumulate over adjacent data-bit cells, whereas it does with UARTs.

## Interfacing with a serial data bus

The 15531 performs word framing, error checking, and Manchester encoding and decoding for a serial interface. It interfaces with a serial bus in either a single-ended or a differential format. Because the circuit receives and sends NRZ serial data, parallel-to-serial and serial-to-parallel shift registers are needed to communicate with computers, which operate on parallel data.
To interface with a 16 -bit parallel data bus, two
Table 1. Comparing data-comm circuits

|  | UART | Protocol <br> controller | Manchester <br> encoder- <br> decoder |
| :---: | :---: | :---: | :---: |
| Maximum <br> data rate <br> Overhead <br> efficiency <br> Error <br> detection | 50 kbaud | $1-2$ Mbaud | 2.5 Mbaud |
| Parity, framing | Code <br> Cyclical <br> redundancy <br> check | Bit count, <br> parity, valid <br> Manchester |  |
| Disad- <br> vantages | PRZ <br> throughput <br> for large <br> blocks of data | NRZ, NRZ-1 <br> Inefficient <br> overhead for <br> character <br> transmission | Manchester <br> Requires <br> shift registers |

74C165 shift registers can be used (Fig. 4). The 15531 strobes the CLK inputs of the shift registers with the NAND product of the Send Data and Encoder Shift Clock outputs. The parallel inputs are loaded just before Send Data goes high, which happens after the sync pulse has been shifted out of the encoder (it returns low before the parity bit is generated). When Send Data is high, NRZ data is shifted into the chip.

To transmit a word, the controller or microcomputer must apply a high logic level to the Encoder Enable input of the 15531. If this line stays high, so that contiguous words are transmitted out of the encoder, the only gap in the NRZ data is the 3 -bit sync pulse and the parity bit. As noted, the type of word transmitted (control or data) is selected with the Sync Select input.

3. For synchronization, the decoder section of the 15531 samples at 10 points to recognize a pattern that has a total length of 5 bits. The pattern has $11 / 2$ blts at one logic level, followed by $11 / 2$ blts at the opposite level, and culminates with two valld Manchester bits.

An example of how the 15531 interfaces with a controller for use as a transmitter, with the help of an Intel 8255A programmable peripheral interface (PPI) chip, is shown in Fig. 4. A general-purpose I/O device, the 8255 A has $24 \mathrm{I} / 0$ pins that can be configured for any of three modes of operation. An 8 -bit data bus allows it to be connected directly to a microcomputer. The microcomputer selects the operating mode and defines the port directions with commands via the data bus.
In Mode 1, used in this example, the 24 I/O pins of the 8255 A are configured as two 8 -bit data ports and one 8 -bit control and status port for handshaking operations. The data ports, Port A and Port B, interface directly with the two parallel-to-serial shift registers.

## Operation as a transmilter

To transmit, the microcomputer generates a write signal to the 8255 A , which then sends an Output Buffer Full (OBF) signal to the Encoder Enable input of the 15531. One of the two programmable I/O pins ( $\mathrm{PC} \mathrm{C}_{4}$ in this case) controls the polarity of the sync pulse to define the type of word transmitted. If desired, the Send Data output of the 15531 can be used to acknowledge the transmission of a word. When Send Data returns low, the microcomputer can generate another word. The 15531 transmits Manchester code onto the serial bus as logical complements at the Bipolar Zero Out (BZO) and Bipolar

4. The transmitter section of a terminal based on the 15531 includes 74 C165 shift registers to convert paraliel signals from the controller Into serlal data for the Manchester encoder. An 8255A programmable peripheral interface buffers the processor to minimize system overhead.

## Millitary Electronics: Manchester chip

One Out ( $\overline{\mathrm{BOO}}$ ) outputs.
To provide a 16 -bit parallel word when the 15531 is operated as a receiver, the Serial Data Out (SDO) pin of the 15531 is connected to a pair of cascaded 74C164 serial-to-parallel shift registers (Fig. 5). The Take Data (TD) and Decoder Shift Clock (DSC) outputs of the 15531 are ANDed and used to strobe the shift registers. The Valid Word (VW) signal goes high approximately half a clock cycle after the final bit in a word is shifted out, and the latter action is indicated when TD returns low. The parallel data from the 74 C 164 s must be latched to define the beginning and end of the word.
To operate the 15531 as a receiver, a second 8255 A is used; as shown in Fig. 5. As with the transmitter subsystem, the 8255 A is configured in Mode $1_{A}$ Once again, Port A and Port B serve as the interface with the data bus, and Port C provides the necessary handshaking signals between the 15531 and the microcomputer. A signal into the STB pin latches the data word into the 8255A. The 8255A subsequently outputs an Input Buffer Full (IBF) signal and follows with an Interrupt (INT) signal.
Depending on the required functions, the receiver interface has a variety of possible forms. Many of the functions can be provided by either hardware or
software. One hardware/software tradeoff concerns address recognition. If no external address-recognition circuitry is provided, the 15531 must interrupt the 8255 A with the reception of every control and data word on the data bus. That will require that the microcomputer read each control word to find the terminal for which the message is intended. Of course, regardless of the address-recognition scheme used, the data words following another station's message should be ignored.
The system shown in Fig. 5 includes hardware that provides address recognition for one of 16 terminals. The VW output of the 15531 latches data into the 82 C 82 CMOS octal latching bus drivers. Hard-wired inputs, $b_{0}-b_{3}$, of a 7485 magnitude comparator define the station's address. The receiving terminal's corresponding address on the data bus is input $a_{0}-a_{3}$. If these inputs match the hardwired inputs, the signal $\mathrm{a}=\mathrm{b}$ goes high.
The 7485 has no way of distinguishing between control and data words. Therefore, since a data word may contain a pattern that arbitrarily reproduces a terminal's address, the $\mathrm{a}=\mathrm{b}$ output is NANDed with the VW and CMD SYNC outputs from the 15531. The CMD SYNC output must be latched, because it returns low before VW goes high. For a serial bus

| Table 2. Control codes for a network protocol |  |  |  |
| :---: | :---: | :---: | :---: |
| Contro field | From | To | Control command |
| 000 | Primary | Remote terminal | Transmit a character to the primary; message poll |
| 001 | Remote terminal | Primary | Transmit character feedback; remote terminal has message to transmit |
| 001 | $\begin{aligned} & \text { Primary } \\ & \text { or remote } \\ & \text { terminal } \\ & \hline \end{aligned}$ | Remote terminal or primary | Receive the following message |
| 100 | $\begin{aligned} & \text { Primary } \\ & \text { or remote } \\ & \text { terminal } \end{aligned}$ | $\begin{gathered} \text { Remote } \\ \text { terminal } \\ \text { or primary } \\ \hline \end{gathered}$ | End of message-from originating to receiving remote terminal |
| 101 | $\begin{aligned} & \text { Primary } \\ & \text { or remote } \\ & \text { terminal } \end{aligned}$ | Remote terminal or primary | Message error; retransmit-from originating to receiving remote terminal |
| 110 | $\begin{aligned} & \text { Primary } \\ & \text { or remote } \\ & \text { terminal } \end{aligned}$ | Remote terminal or primary | Acknowledge valid message-from receiving to originating remote terminal |
| 111 | $\begin{gathered} \text { Originating } \\ \text { remote } \\ \text { terminal } \end{gathered}$ | Primary | Message transfer is complete; bus is free |

with more than 16 terminals, 7485s can be cascaded to provide the expanded address recognition.

Some functions, however, are usually better served by software than by hardware. One such function is the word count of the message length. The transmitting station generates a word that contains the message length-that is, number of words in the message. To ensure that the message is transmitted and received accurately, the receiving station counts the Data Sync outputs and matches the total with the transmitted word count. (If the 24-pin Manchester chip, the HD-6408, is used, the Data Sync output is multiplexed with the Command Sync output. Therefore Take Data can be ExclusiveORed with the Command/Data Sync output to provide the word count.)

For interfacing with a microcomputer or controller with a 16 -bit data bus, a different design is appropriate. This scheme, too, uses two 8255As in Mode 1. But instead of dedicating one 8255 A to transmission and the other to reception, it uses the A ports of both 8255 As to transmit and the B ports
to receive. As before, the C ports provide the control and status functions for handshaking between devices. The modified bus structure allows reading or writing of the 16 data bits in a single operation.

## Distinguishing control information

As shown earlier, the 15531 generates and detects programmable sync pulses that can be used to tag different types of information. Thus the chip generates and recognizes two types of words: control and data. To communicate control information between transmitting and receiving stations, specific meanings must be preassigned to various bit combinations. That, of course, must be done as part of the system design.
To illustrate the design procedure, consider a multidrop serial data communication network. The system will handle both asynchronous character transfers (such as instrumentation data) and block messages. Basically, the system consists of a single primary station and a user-definable number of remote terminals. For simplicity, just one primary

5. A receiver circuit built around the 15531 uses 74 C 164 shift registers for serlal-to-parallel conversion. The 82C82 latching bus drivers and the 7485 magnitude comparator provide hard-wired address recognition. As with the receiver, an 8255A acts as the interface to the controller.
and two remote stations will be used as a design example. In an actual system, of course, the programmable word length of the 15531 specifies the number of stations addressed and the control messages. For the initial design, the length of a control word will be fixed at 16 bits.
Assume now that the control word is divided into three fields, each of which plays a role in the protocol of the data-communication network. For this example, the first six bits of the control word give the address of the station transmitting the control word, the next four bits form the control field, and the last six bits provide the address of the intended receiving station. With such an arrangement, the number of possible stations that can be addressed is $2^{6}$, or 64 , and the number of control commands that can be issued is $2^{4}$, or 16 .
The system uses a primary terminal to poll remote terminals for a character feedback-such as a temperature reading for an energy control system. At the same time, it provides for block data transfers, such as messages. Actually blocks are not transferred synchronously, as with a protocol controller. However, the higher data rate and overhead efficiency of the 15531-based system yield higher overall throughput than is possible with systems with conventional block transfers.
The system has the following protocol: First, the primary station polls the first remote terminal, requesting a character feedback. The control field contains a control code that indicates the type of data transfer. Then the remote terminal responds with a control word, which verifies its address, and a control field, which indicates whether or not it has a message to transmit. In either case, the terminal subsequently transmits a data word-which is the single-character feedback. The primary terminal receives this character and stores it in memory. Depending upon the response of the remote terminal to the message poll, the primary performs one of two options. If the remote terminal did not have a message, the primary proceeds to poll the next station, for the character feedback and message flag. If, on the other hand, the remote terminal indicates in its control-word response that it has a message to transmit, the primary idles and relinquishes control of the bus.

## Control codes give commands

The primary terminal's receiver remains active because it, as well as remote stations, can receive messages. Message transfer can take place from any terminal, primary or remote to any other terminal. The message need not go through the primary. To transfer a message, the first remote terminal generates a control word with the same format as
a primary's control word.
The control code in the control field instructs the receiving station to "receive the following message." A list of control code commands is given in Table 2.

The receiving station identifies the source of a message by reading the address field of the control word. The originating remote terminal then transmits a special data word (the only data word that is used as a control word). Since in all other instances data words contain only data, this exception must be recognized by the controller software of the receiving terminal. This data word gives the number of words in the message. Were a control word used here instead of a data word, the arbitrary data pattern indicating the message length could trigger the address-recognition circuitry of another terminal on the bus. The address and control fields could be repeated, but this would mean that the message length, as defined by the word, would be limited to $2^{6}$ characters-which is too short.
If there is a message, the first remote terminal transmits the message continuously. After completing the message, it transmits a control word in which the control code indicates "end of message." Upon receiving this word, the receiving terminal checks to see if the correct number of data words were received. Then it responds to the originating remote terminal with a control word indicating one of two responses.
If the receiving terminal did not receive the message properly (the number of data words does not equal the number indicated by the sending terminal), the receiving terminal indicates this with a "message error, retransmit" control code. When the originating remote terminal receives this code, it can go back several steps and begin retransmitting the message with the original control word. The number of retries should be limited by the sender's controller software.
If the message was received properly, the receiving terminal indicates that fact to the sender with the appropriate control code. When the latter receives the indication, it transmits a control word to the primary with a control code signifying that the message transfer is complete and the bus is free. Even if there is repeated failure to acknowledge the message, the originating terminal must indicate after the retries that the bus is free. The primary can then poll the next remote terminal.

## LOCAL NETWORKS

Based onlow-cost, low-power CMOS circultry, an industrialgrade local-area network controller brings high-speed data communications to the 1553data bus.

David G. Williams, Member of the Technical Staff Harris Corp., Semiconductor Group P.O. Box 883, Melbourne, Fla. 32901

Protecting the integrity of information is the most important function of a data-communications system. One way to ensure secure data communications is to design the system's local-area network similar to the specifications defined in MIL-STD-1553. Originally intended for the high-noise environment of military aircraft, 1553's provisions are applicable to a variety of industrial and commercial systems that must provide high performance under adverse conditions (see "Riding the 1553 Bus").

To bring 1553's data integrity to nonmilitary applications, the network design must cost-effectively meet space, power consumption, and data-rate requirements. With these factors in mind, a CMOS network controller can be designed with the following features:

- A 1-Mbit/s data rate, upgradable to $2.5 \mathrm{Mbits} / \mathrm{s}$
- An extremely low bit-error rate
- An operating power consumption of just 150 mW , including line drivers and receivers
- A bus length of 1000 ft (expandable)
- The use of low-cost, shielded-twisted-pair cable
( $15 ¢ /$ ft per pair)
- A component cost of $\$ 60$ per controller
- The use of multidrop topology
- Low chip count, using LSI technology

The block diagram of the controller is shown in Fig. 1. Its principal component is Harris Semiconductor CMOS HD-6408 Manchester encoder-decoder chip, which operates at data rates of up to 1 Mbit/s (Electronic Design, Aug. 5, p.201). To obtain higher data rates-up to $1.25 \mathrm{Mbits} / \mathrm{s}$-and
operation over the full military temperature range, the HD-6408 can be replaced by the pin-compatible HD-15530-8, which conforms to MIL-STD-883 specifications. If the application warrents the highest data rates-up to $2.5 \mathrm{Mbits} / \mathrm{s}$-the HD-15531B can be substituted for the HD-15530-8.
To interface the controller with virtually any 8or 16 -bit microprocessor, the design uses two 82 C 55 A programmable peripheral interface chips. A CMOS functional equivalent of an original Intel part, it operates at much lower power levels and with far greater speed, thanks to circuit and technology improvements.

Selecting a suitable clock generator was one of the more difficult tasks in designing the controller. The HD-6408 requires a $12-\mathrm{MHz}$ clock input which switches within 0.5 V of the power supply rails, and has both rise and fall times of 8 ns or less. An 82 C 84 A CMOS clock generator-driver was chosen because it supplies a buffered clock output of up to 30 MHz when running from a fundamental, parallel-mode crystal and two capacitors. This device is another
functional equivalent of an original Intel bipolar device, but being CMOS, it operates at a much lower power-supply current-about $1 \mathrm{~mA} / \mathrm{MHz}$.
Components that interface with the serial data bus play an extremely important role in the overall design. No matter how well the controller itself performs, the line driver-receiver and cable combination can create a bottleneck through which all data must flow. Consequently, deficiencies in interface design become a limiting factor in the controller's data throughput and integrity.
High data rates, long cable lengths, and low power consumption present a designer with conflicting requirements. Most conventional line drivers and receivers handle larger amounts of power than CMOS. To accommodate CMOS technology, the controller uses a so-called current-mode transmission system (see "Why Current-Mode Transmission").
Current-mode transmission was developed for space satellites, in which low-power drains and very low levels of radiated and conducted electromagnetic interference are mandatory. Basically, the technique


1. A self-contained local-area network controller for driving a data bus similar to the MIL-STD-1553 data bus with Manchester II data, this system runs at data rates of up to $2.5 \mathrm{Mbit} / \mathrm{s}$ and interfaces with most 8 - and 16-bit microprocessors.
switches a constant current between each of two conductors in a twisted-pair transmission line. The total current in the pair remains constant and flows in the same direction for any transmission. Current flows through line-termination resistors and returns to the transmitter as a steady dc current on the transmission-line shield. The net effect is near-zero current through the complete shielded twisted pair, resulting in very low levels of EMI.
The major advantages of current-mode transmission are very low system power levels: typical dissipation is 25 mW when the system is active and 100 $\mu \mathrm{W}$ on standby, for a transmitter operating at a 1 $\mathrm{Mbit} / \mathrm{s}$ data rate over a transmission line of 1000 feet or longer. Moreover, using multiple twisted pairs within the same shield is possible, since there are no high crosstalk levels like those common to differential-voltage switching systems.
As for CMOS, besides all the obvious advantages,
there is another reason for its use. Because of CMOS's low power consumption, a sealed enclosure often becomes feasible. With strict FCC regulations governing allowable RFI emissions, sealing the box becomes important. Moreover, sealed enclosures are more suitable for the extremely hostile environments encountered in most military and some industrial applications.

## Getting down to details

Figure 2 shows a complete schematic of the controller. The system interfaces with an 8 -bit microprocessor by tying together the $\mathrm{D}_{0}-\mathrm{D}_{7}$ inputs of the 82 C 55 As to form an 8 -bit bus. These devices must be programmed individually to their mode 1 , strobed I/O, configuration. A double-buffered inter-rupt-driven interface can then be achieved.
Port A of each 82 C 55 A is programmed as an output port to supply data to the HD-6408 for subsequent

2. The complete schematic of the network controller shows a data-communications system designed around the HD-6408 Manchester encoder-decoder chip ( $\mathrm{U}_{11}$ ) and a pair of 82C55A programmable peripheral interface devices ( $U_{1}$ and $U_{2}$ ). The system operates as both transmitter and receiver, and because the two functions are independent, it can be configured for either half- or full-duplex operation.

## Local Networks: 1553 controller

transmission. A pair of 74C165s (8-bit parallelloading, serial-output shift registers) convert 16 -bit transmission data from parallel into serial form. Bits 3, 6 , and 7 of port $C$ provide the handshaking signals for port A data.

When data is written by the microprocessor to port A, bit 7 of port $\mathrm{C}\left(\mathrm{C}_{7}\right)$ goes low, producing an Output Buffer Full ( $\overline{0 B F}$ ) signal. Although this signal appears at the output of each 82C55A when data is written to them, only the $\overline{\mathrm{OBF}}$ signal from the device containing the most significant byte of data is used -in this case, $\mathrm{U}_{2}$. The reason is that all 16 bits of transmitted data must be available to the network controller before transmission starts. When data is written to the 82 C 55 As , the least significant byte is written first, followed by the most significant byte.

3. Oscilloscope photos of the network controller's recelver output show waveforms taken at data rates of $1 \mathrm{Mbit} / \mathrm{s}$ (a) and 2.5 Mbits/s (b). Although distortion is slightly greater at the higher data rate, the difference is virtually Insignificant.

The OBF signal controls the Encoder Enable (EE) input on the 6408. This signal prompts the 6408 to start transmission. Once transmission begins, the 6408 responds with a Send Data (SD) signal, which forms an acknowledgment (ACK) to $\mathrm{C}_{6}$. The response resets $\overline{0 B F}$ and prompts the 82 C 55 A to issue a Transmit Interrupt signal from line $\mathrm{C}_{3}$ to the processor's CPU. This signal informs the CPU that the transmitter is ready to receive another word for transmission. A double-buffered transmitter results that permits continuous data transmissions without interword gaps or idle time.
At a 1-Mbyte/s data rate, the CPU has about 16 $\mu \mathrm{s}$ in which to send a new data word without having any idle time. This is a relatively short response time for an 8 -bit processor. An upgraded version of the controller would use a faster 16 -bit microprocessor such as an Intel 8086 or a Harris CMOS 80C86. Under this condition, the $\mathrm{D}_{0}-\mathrm{D}_{7}$ inputs must be connected as a 16 -bit bus ( $\mathrm{D}_{0}-\mathrm{D}_{15}$ ) and simultaneous chipselection signals $\left(\mathrm{CS}_{0}-\mathrm{CS}_{1}\right)$ must be applied to both 82C55As.
The system can be upgraded further with a DMA controller, which lets the CPU spend more time on other processing tasks. But this addition is necessary only for high data-rate systems-lower data-rate systems operate satisfactorily without DMA or interrupt-driven schemes. In slower controllers, the interrupt outputs ( $\mathrm{C}_{0}$ and $\mathrm{C}_{3}$ ) are unused, and the CPU can poll the status word of port C by reading the port.
The receiver operates much as does the transmitter and is likewise double-buffered. Since the receiver and transmitter are independent, the controller can be set up for either half- or full-duplex operation. The receiver circuitry ignores spurious data on the bus and begins its response sequence only on receipt of a valid sync character, followed by two valid Manchester II bits. This procedure is implemented with circuitry internal to the 6408.
After a validation sequence has occurred, the 6408 generates a Take Data (TD) signal, enabling the 74C164-based shift register to accept the Serial Data Output (SDO) of the 6408. The trailing edge of TD indicates that all 16 data bits have been transferred to the shift register and also serves to generate a strobe signal ( $\overline{\mathrm{STB}}$ ) for the 82 C 55 As . STB, $\mathrm{C}_{2}$ causes the devices to load the received data into their port B inputs. Then the 82 C 55 A responds with an Input Buffer Full (IBF) signal, which resets the STB line. The shift register is available immediately to receive the next 16 -bit word. Since there is always a minimum time of four bit periods between data words-because of the parity bit and sync character -the design guarantees successful reception of socalled back-to-back data words.

STB also causes the 82C55A to generate a Receive Interrupt on the $\mathrm{C}_{0}$ output. As in the transmitter, this interrupt can be either used directly or polled under software control.

The 6408 indicates acceptance of an error-free word by generating a Valid Word (VW) signal. VW is latched and presented to a spare input at $\mathrm{C}_{5}$, and the microprocessor reads the bit to validate correct data. With a slight hardware modification, VW can be used to enable STB, thereby reducing the required software and its overhead.

The 6408's error-detection circuitry checks every data bit for correct Manchester II encoding and also verifies correct parity. As a result of its composite error-detection algorithm, the chip detects $100 \%$ of three or fewer sampling errors in any data word. When more than three errors occur, the 6408 will correctly detect-on a statistical basis-better than
$99.99 \%$ of all possible errors. Thus, at a system level, undetected errors occur five or six orders of magnitude less frequently than detected errors.
Two types of synchronization characters can be supplied by the 6408 to differentiate between command and data words. The Command/Data Sync (CDS) output reflects the reception of a command or data word based on the sync character. The signal is latched and presented to the spare input at $\mathrm{C}_{4}$ of U 1 and can be read under software control. Since the use of CDS depends on the application, it is employed at the designer's option.

The 6408's transmitter section has two control signal inputs which connect to the spare port C outputs on $U_{2}$. Sync Select (SS) determines whether a command or data sync character is to be transmitted, and Output Inhibit $(\overline{\mathrm{OI}})$ is a low-true signal used to put the $\overline{\mathrm{BOO}}$ and $\overline{\mathrm{BZO}}$ transmit-data

## Riding the 1553 bus

MIL-STD-1553 defines a time-division-multiplexed data bus for use in military aircraft. The bus carries bipolar signals and uses a single twisted-pair shielded cable. Data going out on the bus is encoded in the Manchester II format. Under this system, no dc signal components appear on the bus. Thus transformer coupling is permitted, resulting in excellent isolation between data-handling systems and their environment.

The signaling format of 1553 is specified assuming that 32 or fewer terminals are managed by a central control unit that uses command words. Provision is made for dynamic reassignment of the control unit using the tokenpassing technique. Each word transmitted is preceded by a synchronizing pulse and followed by a parity bit, resulting in a total word time of $20 \mu \mathrm{~s}$. The character and word formats of the MIL-STD 1553 bus are shown in Figs. A and B , respectively.
The HD-6408 Manchester encod-er-decoder, which is the key component of the network controller, is designed to meet the require-
ments of 1553. At the same time, the CMOS device is flexible enough to implement other signaling protocols. The 16 data bits in both the 1553 's command and data words are defined by the user and can be generated by the hardware-software combination in the network controller. For example, expanding the system to any number of terminals is possible by redefining the meaning of bit assignments within command words. Additionally, error codes can be deleted or expanded. By substituting the HD-15531 Manchester encoder-decoder for the HD-6408, additional user-defined features can be incorporated, such as expanding the word length of the bus to 28 data bits, if desired.


## Local Networks: 1553controller

outputs in their inactive states (high). These signals are also application-dependent, and are therefore optional.

## Evaluating controller performance

To check the controller's design, breadboards can be connected using Belden Corp. 9855 Twinaxial cable. This inexpensive high-performance cable con-
tains two twisted pairs inside a common shield. The shield has both braided and foil conductors to ensure $100 \%$ coverage.

Tying the ends of two twisted pairs together at the end of a $500-\mathrm{ft}$ length of cable produces an effective cable length of 1000 ft . This configuration is useful for observing the effects of possible crosstalk between adjacent pairs inside a common

voltage switching have three drawbacks: they are high power consumers, generate crosstalk between adjacent lines, and produce noise in the form of conducted and radiated RFI. The relatively unknown technique called current-mode transmission can eliminate these drawbacks and works well over long lines.

A current-mode transmitter (left half) alternately applies current to each of two conductors ( $\phi_{1}$, $\phi_{2}$ ) in a twisted pair. The total current is constant and always flows in the same direction.

A logic 1 is produced by line $\phi_{1}$ conducting a certain current. This current travels down the transmission line, through a $50-\Omega$ terminating resistor $\mathrm{R}_{\mathrm{T}}$ (right half), and returns through the shield to the common point of the transmitter's power supply, A logic 0 results when the current is prevented from flowing in $\phi_{1}$, and flows in $\phi_{2}$. The shield carries the same dc current constantly, since lines $\phi_{1}$ and $\phi_{2}$ always conduct alternately.
Small variations in transmis-sion-line current can occur if there is overlap between the turn-on and turn-off times of $\phi_{1}$ and $\phi_{2}$. However, the complementary outputs of the HD-6408 are designed for near-zero overlap.

With signal swings typically 20 times smaller than in differentialvoltage systems, and with its nonsaturating current-switching transmitter producing smooth ramps without overshoot or ringing, current-mode transmission is far superior to differential voltage systems in limiting conducted and radiated RFI. The three types of externally generated noise that affect digital signal-line transmission are: magnetic and capacitive pickup from nearby electrical conductors, magnetic and capacitive crosstalk between transmission lines sharing a common shield, and ground-line noise between transmitter and receiver. Currentmode transmission combats the first two types of noise as well as or better than the other systems. The ground-noise problem is usually eliminated by avoiding ground loops as dictated by standard design practices.
shield. Current-mode transmission systems exhibit very low levels of crosstalk, thereby permitting multiple twisted-pairs within a single shield. Voltage-mode transmission schemes, on the other hand, may require separately shielded cables for long runs, resulting in much higher cable costs than in current-mode systems.
In an actual system, the additional twisted pair may be used as a secondary bus for higher system throughput or as a redundant bus to increase system reliability. Another option is to provide a full-duplex point-to-point data link.

A standard five-pin DIN shielded audio connector is an ideal low-cost method of connecting the breadboards to the 9855 cable. Its shielded shell provides adequate integrity for all but the most stringent requirements.

A complete $1000-\mathrm{ft}$ cable running at a $1-\mathrm{Mbit} / \mathrm{s}$ data rate serves as a reliable data link and when tested produced no detectable transmission errors or crosstalk. The typical power consumption is 150 mW . By inserting a $30-\mathrm{MHz}$ crystal at the 82 C 84 A 's input, the data rate can be increased to $2.5 \mathrm{Mbits} / \mathrm{s}$. At this
rate, some pulse distortion results because of inadequate gain of the simple low-power receiver used. Figure 3 shows oscilliscope photos taken at the receiver's outputs-note the slightly higher distortion in Fig. 3b compared with Fig. 3a. The problem can be solved by substituting premium transistors in place of the 2 N 4124 s ordinarily used. An alternative solution to that is to replace the discrete line receiver with an industry-standard 75107 line receiver.

In a worst-case design, which accounts for temperature and voltage variations, the CMOS shift registers may be too slow at a $2.5-\mathrm{Mbit} / \mathrm{s}$ data rate. However, they can be replaced with fast new devices offered by several manufacturers without compromising the low-power aspects of the design.

Because of the design's low power dissipation, the components can be incorporated into a single module using leadless chip carriers, with a ceramic substrate providing the connections between components. Another option is to house the components in a chip-and-wire hybrid, which results in even greater packaging density.

# Take a total-system approach, with advanced CMOS memories 

## CMOS memories are undergoing continual refinement, and new devices are increasingly competitive with those in other technologies. For these devices, though, specs such as standby and operating current are system parameters, not merely device descriptors.

## Walter J Niewierski and Russell M Pate, Harris Semiconductor

Memory manufacturers have improved CMOS so much that it now competes favorably with NMOS in speed while retaining its edge in power consumption. New CMOS devices, though, present design considerations somewhat different from those of older CMOS memories; you must take a systems approach to designing with them.

CMOS-memory choices have definitely expanded. CMOS RAMs, for example, now store as much as 64 k bits and achieve access time as short as 55 nsec, operating current of $7 \mathrm{~mA} / \mathrm{MHz}$ and standby current of $10 \mu \mathrm{~A}$.

Additionally, CMOS fuse-link PROMs hold 16k bits and spec access time of $200 \mathrm{nsec}, 10-\mathrm{mA} / \mathrm{MHz}$ opera-ting-current consumption and $100-\mu \mathrm{A}$ standby-current consumption. The short access time, along with an $\mathrm{I}_{\mathrm{CC}}$ requirement lower than for NMOS or bipolar devices, gives CMOS the best PROM speed-power product.

CMOS EPROMs also compete well with their NMOS counterparts; devices store as much as 64 k , and access time reaches 300 nsec with $\mathrm{I}_{\mathrm{CC}}$ of $25 \mathrm{~mA} / \mathrm{MHz}$ vs 100 mA for NMOS. At a 350 -nsec access time, CMOS improves NMOS operating current by 4:1 and standby current by $250: 1$. Finally, in EEPROMs, you'll find $1 \mathrm{k} \times 8$ block-erasable CMOS devices. However, NMOS, because of higher densities and byte-erase capability, still holds a slight edge here, although future CMOS units will also offer these features.

These performance levels exemplify a trend in MOS memories: the narrowing time span between the appearance of an NMOS device and its CMOS counterpart. For instance, CMOS EEPROMs followed their NMOS equivalents after less than 1 yr . Indeed, 16 k

[^16]

Fig 1-CMOS-memory operating current varies widely over device operating-voltage range. Standby current is at a minimum when $V_{\mathbb{I N}}$ is at either power-supply rail. Note the difference in operating current associated with the VOH (highest output-voltage level) for TTL and CMOS.

CMOS static RAMs even preceded NMOS units by approximately 6 months.

What about price? Lower density (4k) CMOS RAMs are competitive with NMOS devices, but other CMOS memory types still sell at a premium. However, because NMOS is a mature process in all device types and CMOS isn't yet fully mature in all areas, the price gap should decrease.

CMOS memories provide another plus: You have a choice unavailable in most other technologiessynchronous or asynchronous operation. Roughly equal in price, both types have design advantages.

Synchronous memories provide on-chip address latches; thus, the address on the bus must be valid for only a short time, during which it's latched with the Chip Enable signal. This feature allows minimum-

## CMOS memories compete favorably with NMOS in speed

parts-count interfaces for systems with multiplexed address/data buses. Synchronous devices also spec lower average operating power.

Asynchronous memories, on the other hand, achieve shorter cycle times, even at the same access time as a synchronous unit. Why? Synchronous units require a minimum TEHEL (enable-pulse HIGH time) to precharge the matrix-column lines that speed up transitions of the column lines to the proper logic states.

Previously, 4k CMOS RAMs, like most memories, were strictly asynchronous-a feature that gave rise to availability problems. A circuit that accepts both types, however, provides the flexibility of dealing with more device suppliers, especially for 4 k and 16 k RAMs. The trick to designing such circuits is to devise a Chip Enable signal that undergoes a transition of the proper


Fig 2-Bidirectional level shifters (CD40116s) interface standard $5 \mathrm{~V} \pm 10 \%$ CMOS memory and peripheral chips to the NSC800, which requires 3 to 11 V power.
polarity when a stable bus address is present (Refs 1, 2 and 3). This signal causes the selected memories to latch the address, freeing up the system bus.

Despite CMOS memories' increasing speed and other advantages, though, designers generally favor them primarily for their low power consumption in both Operating and Standby mode. The operating current arises mainly when device-enable inputs get switched; additional current arises when input circuits enter their linear operating regions. The low-Z path that occurs when an input voltage crosses through the switchingthreshold region increases power-supply current ( $\mathrm{I}_{\mathrm{CC}}$ ), which varies directly with the enable and switching frequencies.

Input-switching frequency also affects another major contributor to CMOS operating power-the charging of output loads. Increased load capacitance increases the current needed to charge and discharge such a load. Thus, $\mathrm{I}_{\mathrm{CC}}$ increases with output-drive requirements.

CMOS memories consume microwatts in Standby mode with input levels stable at $\mathrm{V}_{\mathrm{cc}}$ or ground; the corresponding current consists of surface, junction and channel-leakage contributions. When using batterybacked CMOS RAMs, you can minimize standby current by idling the devices when not in use and by deselecting all inputs, which you should hold at either power-supply rail.

Given this state of the art in CMOS memories, some designer reorientation might be required to use the newest devices. Users sometimes dispute standbycurrent specs, for example, because they observe above-spec values in memory devices that are disabled but that remain connected to active address and data buses. This phenomenon arises because of CMOS $\mathrm{I}_{\mathrm{CC}}-\mathrm{vs}-\mathrm{V}_{\mathrm{IN}}$ transfer characteristics (Fig 1), and it reinforces the need to examine device operation within the context of the system.

Note that the current for a CMOS input increases significantly near the threshold or switching voltage. At that point, both enhancement-mode input transistors that implement the input's inverter are ON to some degree (typically 1.3 to 2.2 V at room temperature), introducing a dc path between the power-supply rails. When this transient current is time-averaged (accounting for the rise and fall times of bus transitions) and then multiplied by the number of disabled device inputs connected to an active bus, the disabled device's current can increase by a factor of 60 to 100 .

You can observe a similar effect when driving CMOS inputs with devices that have valid logic levels within or near threshold regions. To maintain minimum standby current, you might need pull-up resistors to keep $\mathrm{V}_{\mathrm{OH}}$ from these devices above the thresholds.

You might also need pull-up or -down resistors on some CMOS RAMs in battery-backed applications to


Fig 3-To decode the lower 16k bytes of memory in Fig 2's multiplexed output into $2 k$-byte blocks suited for CMOS RAMs, this circuit uses an HM-6440 decoder driver. For data-bus interfacing, it incorporates an 82C86 bus transceiver.
keep inputs from floating through and around the threshold region when power is lost to other system devices. Input voltages in reduced-power-supply applications should be no more than 0.1 V from $\mathrm{V}_{\mathrm{cc}}$ or ground. Otherwise, the battery-discharge rate increases considerably because of the higher $\mathrm{I}_{\mathrm{CC}}$ caused by floating inputs. But these resistors can affect the transition times of driver outputs: In Operating mode, pull-down resistors might slow the rise time of TTL drivers by as much as $20 \%$, and puli-up resistors increase their fall times by the same fraction.

CMOS-memory manufacturers have removed some of these design obstacles by adding two MOSFETs to standard 2 -transistor input-inverter circuits. Such gated or disabled-input configurations prohibit the circuit's inverter from reacting to input transitions or floating inputs while the device is disabled. This feature simplifies battery-backup designs, reduces standby and operating current and cuts system parts count by eliminating the need for pull-up resistors.

When interfacing to CMOS memories not equipped with this input gating, you might overwhelm the operating power of bus drivers with the memory array's operating current. Avoid this problem by using CMOS bus drivers, which can reduce array power consumption as much as $70 \%$ compared with LSTTL buffers, mainly because of the differences in permissible output-voltage ranges between CMOS and LSTTL.

Fig 1 clearly illustrates this advantage. Note the memories' higher power consumption as $\mathrm{V}_{\text {IN }}$ moves
away from $\mathrm{V}_{\mathrm{CC}}$ and ground toward operating levels, then note the $\mathrm{I}_{\mathrm{CC}}$ associated with the output-voltage levels of bipolar and CMOS bus drivers. For example, a 16 k -byte CMOS static-RAM array running at 5 V and $25^{\circ} \mathrm{C}$ and cycling at 1 MHz dissipates 1.35 W with 74LS365 LSTTL bus drivers but only 475 mW with a CMOS bus driver.
Bus-interface considerations also help answer perhaps the most often asked question in memory-system design: Can memory be accessed rapidly enough to be speed compatible with the $\mu \mathrm{P}$-system operating frequency? Many designers often overlook the effect of bus-interface-device speed-bus-buffer delays can restrict memory speed. But a tradeoff arises: Increasing bus-driver propagation delay by just 1 nsec, for example, might call for buying faster, more expensive memory devices.

Other system conditions can affect CMOS-memory operation. For instance, CMOS parameters generally improve as ambient temperature decreases-outputdrive capability increases, providing greater current to charge and discharge load capacitances and thus increasing device speed. Standby power dissipation also decreases as the temperature drops.

Voltage levels of supplies and inputs also affect device performance. Raising the supply level increases device speed and power consumption; input levels above spec can greatly increase current and even damage devices.
Device ac characteristics depend greatly on the capacitive loading arising from interconnect and input

## Icc increases significantly near input-threshold values

capacitances of devices attached to the memory outputs. Loads greater than spec can increase memory propagation delay.

Other capacitive effects become more important in the newer high-speed CMOS memories. For instance, the large current transients associated with fast rise/fall times call for installing a decoupling capacitor ( $0.01 \mu \mathrm{~F} \mathrm{~min}$ ) between the power-supply rails of every device in CMOS memory arrays. You should also install a large electrolytic capacitor where power enters the array. This provision proves especially important in large arrays of synchronous devices, where the largest transients occur on the $\mathrm{V}_{\mathrm{CC}}$ and ground lines during chip-enable transitions.

## CMOS RAMs in data-retention systems

When using CMOS RAMs in battery-power or battery-backup applications, be aware of several additional design precautions. For instance, input and output voltages can create prohlems. Thus, be sure to establish safe power-up and -down sequences because junction-isolated CMOS devices' inputs contain a parasitic SCR that remains inactive during normal operation but becomes active when input or output voltages exceed spec'd values. To avoid problems, raise and lower supplies in an order that prevents inputs and outputs from existing at potentials higher than $\mathrm{V}_{\mathrm{CC}}$ or lower than ground.

Note also that you don't always need batteries in CMOS data-retention systems: Capacitor manufacturers now supply high-value, low-voltage units that can substitute for batteries. For instance, a 1F, 5V capacitor measuring 44 mm in diameter and 18.5 mm high requires less maintenance than a battery, exhibits a longer useful lifetime and permits an unlimited
number of charge cycles. (However, it has a faster discharge rate and doesn't suit applications requiring data retention for extended periods-a $1 F$ capacitor holds a $1 \mathrm{k} \times 8$ synchronous-RAM array for 2 to 3 hrs .)

If you take the aforementioned CMOS-memory design factors into account and your battery-backed array is still losing data, use a checklist to troubleshoot most cases:

- Is $\mathrm{V}_{\mathrm{cc}}$ dropping to less than 2V? If so, the problem probably arises during transitions into or out of Backup mode.
- Is the Write (W) line being pulled up with the Chip Enable (E) line as an added precaution?
- Are $V_{c c}, E$ and $W$ transitions glitch free, and do they ramp up and down smoothly?
- Are all other inputs held at $\mathrm{V}_{\mathrm{CC}}$ or ground during the backup period? Floating inputs increase $I_{\text {CC }}$ and shorten battery life.
- If you drive RAM inputs with LS drivers, are their outputs pulled up? They needn't be in most cases, because LS outputs tend to go to a low-Z-to-ground state when $\mathrm{V}_{\mathrm{CC}}$ fails. (Some 3 -state Schottky drivers don't exhibit this characteristic.)
- Are CMOS bus drivers being powered from the CMOS V ${ }_{\text {CC }}$ supply and not the system supply? This should be the case, and you should hold driver inputs HIGH or LOW with resistors. The outputs of CMOS drivers, however, should never be pulled up with resistors.
- For synchronous memories, is E held HIGH for at least one TEHEL period after $\mathrm{V}_{\mathrm{CC}}$ has risen to normal operating level?
The following design examples, besides showing how to account for such system considerations, illustrate


Fig 4-lnterfacing CMOS memory to CMOS $\mu \mathrm{Ps}$ such as the 12-bit HM-6100 proves simple. With this all-CMOS design, you can easily create a small data-acquisition system that accommodates 10-or 12-bit A/D or D/A transfers in one byte.


Fig 5-Memory expansion for single-chip $\mu \mathrm{Cs}$ doesn't necessarily introduce a large power penalty. This design applies to systems using the CMOS or NMOS versions of the 8048 as well as other 8048 -family members.
how to implement all-CMOS $\mu \mathrm{C}$-memory systems and how to adapt CMOS memories to NMOS-processor systems.

The first example uses an NSC800 8-bit CMOS $\mu$ P. While most CMOS devices require $5 \mathrm{~V} \pm 10 \%$, this $\mu \mathrm{P}$ and a family of support devices accommodate a 3 to 11 V operating range. You might, however, need some CMOS devices of the standard $5 \mathrm{~V} \pm 10 \%$ type, and using a system supply voltage outside this range for both types can present interfacing problems.

To implement such interfacing, the system must be able to shift voltage levels quickly; for this task, the circuit shown in Fig 2 uses the CD40116 octal bidirectional level shifter. This device exhibits a 15-nsec propagation delay when shifting from 12 to 5 V and 30 nsec when going from 5 to 12 V .

Fig 2's $10 \mathrm{~V} / 5 \mathrm{~V}$ translation interface uses two CD40116 control signals to determine the direction of data flow and voltage translation. CMOS inputs $\mathrm{A}_{1.8}$ can withstand levels as high as $\mathrm{V}_{\mathrm{DD}}(10 \mathrm{~V}$ in this case), while inputs $B_{1.8}$ are TTL compatible only.

The control signals are generated separately (via three level shifters) for address- and data-bus and control-line buffering. Of these, the control-line interface is the simplest: Its level shifter is constantly enabled for CMOS/TTL conversion. And because these NSC800 control signals and upper addresses are unidirectional outputs, controlling them involves only a shift between CMOS/TTL conversion and the high-
impedance state, achieved with the $\mu$ P's Bus Acknowledge ( BACK ) line. When the $\mu \mathrm{P}$ gives up control of the bus to another processor or peripheral, these lines have a high impedance. Finally, the multiplexed low-address/ data bus is controlled by the $\mu$ P's RD signal, which gets inverted and applied to that CD40116's Disable input. You can translate remaining control signals (such as WAIT, INTA or BACK) with additional CD40116s or with 74C90X translators as shown.
To decode the lower 16k bytes of memory provided in the multiplexed output into 2 k -byte blocks, use the circuit shown in Fig 3. Its HD-6440 decoder/driver, with three device enables, allows the circuit to decode addresses directly. You need only a NOR gate to combine ALE (Address Latch Enable) and $10 / \bar{M}$ (Input-Output/Memory). The 6440 also provides eight 2 k -block enables for the CMOS memories shown. Moreover, because the circuit uses synchronous memory devices with on-chip address latches, it needs no external latches.
The NSC800 controls memory operation with RD and WR lines, which connect to the all-output enable (OE) controls and the Write line on each RAM. The decoder/driver generates each RAM's enable (E) signal. If you need additional data-bus buffering, or if you choose not to use a CD40116 for voltage translation, consider the 82C86 CMOS bidirectional bus transceiver for the data-bus interface. This device remains enabled unless the $\mu \mathrm{P}$ gives up bus control (BACK
controls the bus transceiver's enable); RD determines data direction.

You can apply this CMOS-based circuit to the NMOS 8085. Using CMOS memories in an NMOS system can improve reliability and system operation by decreasing power requirements and providing higher noise immunity than NMOS devices. Furthermore, by using CMOS bus drivers with CMOS memories, you can further reduce circuit operating-power requirements.
The second all-CMOS microsystem example uses the HM-6100, which suits applications such as remote data acquisition. Fig 4 shows a minimum memory configuration for this $\mu$ P. A $1 \mathrm{k} \times 12$ CMOS ROM (an HM-6322) holds the main program and also provides decoding for the system's $64 \times 12$ CMOS RAMs. The ROM's XS (External Select) output places the RAM in the memory map as determined by its decoding logic, which you program. This output enables system RAM whenever the RAM area gets addressed. Both ROM and RAM devices provide on-chip address latches and latch this data on the falling edge of the LXMAR (Latch External Memory Address Register) signal from the $\mu \mathrm{P}$. To add memory to the system, you can adapt nearly any standard device.

The final design example, which uses the CMOS 80 C 48 single-chip $\mu \mathrm{C}$, destroys the myth that singlechip systems should have as few devices as possible for lowest power consumption-the capabilities of new CMOS devices can compensate for this factor in system expansion. This circuit (Fig 5) expands both data and program memory via CMOS devices. This expansion concept, though, is applicable to systems with CMOS or NMOS versions of the 8048 or other family members with few modifications. When using an NMOS 8048 with $\mathrm{V}_{\mathrm{OH}}$ spec'd at 2.4 V , you might need to add a few pull-up resistors in the worst case. Timing, though, presents no problems.

Within the CMOS $\mu \mathrm{C}$, data and program memory reside in separate areas, each with its own control signals. For data-memory expansion, this design uses

HM-6561 synchronous RAMs. It needs two such $256 \times 4$ devices to fill the 80C48's 256 -byte data memory.

The RAMs have two select pins ( $\mathrm{S}_{1,2}$ ) and one enable $(E)$; this latter line latches the address bits onto the chip and is active LOW. Address latching occurs on E's HIGH-to-LOW transition. The $\mu \mathrm{C}$ 's ALE (Address Latch Enable) connects to the E line, and this signal has the proper polarity and its HIGH-to-LOW transition occurs when addresses are stable on the processor bus. The ALE signal serves for the $E$ function on all devices in the memory array. Chip Select lines ( $\mathrm{S}_{1,2}$ ) select the appropriate RAM; $\mathrm{S}_{1}$ is derived from the 80 C 48 's RD and WR signals while the $\mathrm{S}_{2}$ pins get tied to ground. The two memory signals occur whenever a data-memory read or write is in progress; you need no further decoding because these signals are active only during data-memory transfers.

For program-memory expansion, this circuit uses an HM-6616 $2 \mathrm{k} \times 8$ CMOS PROM; this high-density device eliminates extensive decoding, reducing parts count for both the decoding scheme and the memory devices. Individual output enables from the HD-6440 decoder are available for each PROM along with an EEPROM enable. If you use no other devices for program memory, you can eliminate the decoder; in that case use the processor's PSEN signal for enabling PROM because it's active only for external program-memory fetches.

EDM

## References

1. Niewierski, W J and Pate, R M, "Total CMOS memory system design," paper presented at Midcon/81.
2. Patstone, W, "Trio of $2 k \times 8$ CMOS RAMs poses design tradeoffs," EDN, November 20, 1980, pgs 45-49.
3. Hochstedler, C M, "Synchronous static CMOS RAMs increase system performance," EDN, April 5, 1979, pgs 93-94.

# LCC implementation procedures enhance a valuable technology 

## Meeting tight military and commercial packaging requirements, standard leadless chip carriers offer weight, space and density benefits. To take advantage of these fortes, though, you must pay close attention to assembly techniques.

## Jeffrey M Wilkinson, Harris Semiconductor

Despite their much-touted benefits-primarily increased packaging density, higher reliability and lower cost compared with other types of IC packagesleadless chip carriers (LCCs) haven't made the expected inroads with system designers. Why? Largely because published information has focused on design concepts and techniques rather than on practical implementation procedures. Consequently, this article describes LCC mounting, soldering, heating and reworking guidelines to help you overcome the constraints posed by the need for compact packaging (see box, "LCCs shine in high-density packaging").

## Match, don't mix, mating materials

After having chosen LCC-packaged ICs for your application (EDN, May 27, 1981, pg 49), you must determine the means of attaching these packages to a pe board or substrate material. To accomplish this chore, evaluate LCC mounting materials (table).
Selecting a board or substrate material involves matching its linear thermal coefficient of expansion (TCE) to the LCC's. When the TCEs don't match, thermostatic deflection (twisting or warping) results during the wide temperature changes characteristic of military applications. During twisting, for example, torque effects bear on the solder joints, causing electrical and mechanical connection fatigue.
This thermal problem gets worse with larger LCC pinouts because of increased package size and stress levels. Accordingly, follow a general rule when selecting a substrate material: The larger the TCE difference between LCC and substrate materials, the smaller the substrate's surface area must be. Alumina substrates, for instance, work best when they don't exceed 24 in. ${ }^{2}$ Ideally, therefore, choose the same material for both the substrate and the LCC: a $92 \%$-alumina ceramic LCC attached to a $92 \%$-alumina substrate (Fig 1), for example.

| MATERIAL THERMAL PROPERTIES |  |  |
| :---: | :---: | :---: |
| SUBSTRATE MATERIAL | $\text { IN }_{\left(I N I^{\prime} I^{\text {TCE }} \times 10-6\right)}$ | comments |
| Alloy 42 | 5.3 | $42 \%$ Ni, $58 \% \mathrm{Fe}$ |
| 96\% ALUMINA | 6.3 | Industry standard |
| 94\% ALUMINA | 6.4 | Industry standard |
| 92\% ALUMINA | 6.4 | industry standard |
| COPPER CLAD INVAR | 6.4 | industry standard |
| 99.5\% BeO | 6.4 | EXPENSIVE |
| low Carbon steel | 12.0 | porcelainized |
| POLYIMIDE G30 | 14.3 | industry standard |
| EPOXY/GLASS G10 | 15.8 | industry standard |
| TRIAZINE G40 | 16.0 | industry standard |
| CDA 101 COPPER | 17.3 | VERY High tce |
| 6061 ALUMINUM | 23.6 | VERY High tce |
| -TCE = THERMAL COEFFICIENT OF EXPANSION |  |  |

 with the equivalent DIP configuration, this multilayer 92\%-alumina ceramic substrate holds $92 \%$-alumina LCCs. The materials matching prevents parts from undergoing thermostatic deflections (twisting or warping) during the temperature changes typical of military applications. Note that the LCCs, carrying 256k static-RAM-module prototypes from Harris, mount on both sides of the substrate.

## Military circuits benefit from LCC size, weight, density assets

In picking pc-board materials, military specifications play a dominant role. One MIL spec, MIL-STD-883B, Method 5004.4, Class B, for instance, outlines pertinent test and qualification methods. It requires Method 1010.2, Condition $C$ thermal cycling (ie, over -64 to $+150^{\circ} \mathrm{C}$ with $10-\mathrm{min}$ durations at each extreme) for at least 10 cycles. This standard covers microelectronic devices, such as those with an LCC as a component, but doesn't apply to printed-wiring-board assemblies.

Another military spec, MIL-P-55110C for printedwiring boards, calls for 100 thermal-shock cycles, spanning -65 to $+125^{\circ} \mathrm{C}$ for expoxy boards and -65 to $+204^{\circ} \mathrm{C}$ for polyimide boards. Yet another, MIL-P-

28809 for printed-wiring assemblies, mandates thermal shocks in accordance with MIL-STD-202, Test Methods for Electronics and Electronic Component Parts, Method 107. This method's applicable worst-case test specifies 100 temperature cycles, ranging over -65 to $+150^{\circ} \mathrm{C}$ with 5 -min maximum intermediate hold periods at $25^{\circ} \mathrm{C}$, and with soak times at temperature extremes determined by the assembly's weight. (In most cases, soak times run 0.5 or 1 hr .)

Not everyone agrees completely with these tempera-ture-cycle requirements. Martin Marietta (Orlando, FL), for instance, has been mounting LCCs on printed-wiring boards for more than 6 yrs . And based

## LCCs shine in high-density packaging

Leadless-chip-carrier (LCC) product designs appear to be becoming the industry-preferred package for high-density, high-pinout ICs. In fact, they should supplant flatpacks and hybrids in the short term and surpass DIPs in the long term. They meet the need for very small, dense and lightweight circuit packaging, especially in military applications, which stress highly reliable electrical and mechanical performance.

In the past, DIPs have proved sufficient for these applications. But as military-circuit specifications continue to demand smaller size and less weight for more complex electrical functions, another packaging method-the flat-pack-has evolved.

Flatpacks have proved a worthy alternative to DIPs for reducing board space. However, they also exhibit shortcomings. For one, package cost is high because of extensive gold plating. Moreover, long lead lengths and narrow spacings mandate special handling carriers. Further, during soldering to pc boards, the long lead lengths allow package vibration, jeopardizing lead connection and solder-joint reliability.

Because ICs packaged in DIPs and flatpacks have proved defi-
cient in meeting strict space-vsfunction requirements, chip-andwire hybrids have become popular. Extremely compact, these hybrids provide multiple functions within a small area. Typically, though, they cost more than DIPs and pc boards because of high assembly and test costs, low rework yields and the expensive manufacturing equipment required. In military applications, however, small size and lightweight design generally take priority over cost.

Manufacturers commonly assemble hybrids from dice. This procedure, however, results in limited device performance because of IC-manufacturing constraints on wafer-level testing. Less-than-stringent testing thus passes less-than-perfect devices for hybrid assembly. Nevertheless, subsequent hybrid-level testing assures quality products, although low device yields prove expensive.

An LCC-packaged device attached to a board or substrate material achieves higher performance at a lower price than a hybrid device. Furthermore, LCC packages permit full parametric testing plus burn-in, yielding higher reliability units.

When similarly contrasted with DIPs, LCCs offer much smaller size and weight. For example, an 18-pin DIP occupies 0.276 in. $^{2}$; an 18 -pin LCC, only $0.100 \mathrm{in}^{2}{ }^{2}$ The space-saving ratio with LCCs therefore approaches 3:1. Likewise, comparing weights, an 18-pin DIP weighs 2.48 g ; an 18 -pin LCC, 0.32 g . The LCC thus proves 7.75 times lighter.

LCCs' electrical benefits are outstanding as well. Their small sizes and leads on four edges permit the use of very short conductor lengths from the external leads to the internal chipcavity bond pads. This layout results in lower parasitic resistances, capacitances and inductances than those demonstrated by corresponding DIPs.

What's more, you can use clock rates as high as 4 GHz with LCCs; DIPs' parasitic deficiencies restrict their speed to about 500 MHz . And besides their small sizeoften only slightly larger than the installed die-and lack of leads to break or bend, LCCs withstand the rigors of MIL-STD-883B testing at the package level, including Groups A, B, C and D.

To ensure industry-wide acceptance, the Joint Electron Device Engineering Council (JEDEC) and
on its experience and test data, it concludes that 100 temperature cycles are excessive. The packaging industry, on the other hand, favors increased cycling but over a narrower temperature range- 300 cycles at -55 to $+125^{\circ} \mathrm{C}$.

## Take care with pc-trace layouts

After board- or substrate-material selection, investigate pc-trace geometries. In accordance with industryproven practices, make the LCC foot pads' circuit traces the same size as the metallization on the LCC's bottom surface and slightly longer at the package's outer edge (Fig 2a). Lengthening the pc board's
metallization allows the solder, when heated to reflow temperature, to wet both the base contacts and the grooved region on the LCC package's sides.
The solder deposit's outer surface thus forms a fillet that extends over the metallization pad on the board or substrate surface (Fig 2b). This extension aids in strengthening the mechanical bond. Additionally, this type of bond elevates the LCC above the board's mounting surface, facilitating the cleaning of residual flux and debris from under the package.
To take advantage of LCCs' high packaging density, maintain relatively tight geometries in boardmetallization layout and manufacturing. Successful
the Dept of Defense (DoD) have sought to develop chip-carrier packaging concepts and standards for military applications. These efforts have resulted in a standard line of LCCs with two packaging styles-one with 50-mil-center terminal spacing and another with $40-\mathrm{mil}$ centers. Within these package styles, a variety of pin counts is available-16 through 156 in 16 common sizes.

The USAF Materials Lab (AFML) has directed and supervised DoD LCC development efforts, funded through the Manufacturing Technology (MANTECH) portion of the DoD's R\&D budget. This group has also financed Hughes Aircraft's development and manufacturing of a line of 50-mil LCCs and RCA's development of 40-mil types.

JEDEC's endeavors have centered on coordinating industry projects with the MANTECH program to minimize duplicating tasks. Coordinated investigations have produced eight standard LCC packages, with two more versions expected soon.

Many system designers, however, can't justify the time and expense required to buy manufacturing equipment and develop new assembly procedures for in-
stalling LCCs on pc boards. To overcome these problems, consider an alternative packaging method-cofired ceramic substrates with attached LCCs. These substrate mother boards or modules provide interesting design tradeoffs compared with chip-and-wire hybrids and pc-boardmounted LCCs.

As one benefit, you don't need LCC-handling and reflowsoldering equipment. As another, you can mount LCCs on both sides of the module, achieving a parts density twice that of a single-sided pc-board assembly. (Note that you can build 2 -sided LCC-based pc-board assemblies, but they are difficult for a firstdesign effort.) As yet another benefit, you can choose among a variety of LCC packages and quickly configure a system.

On the debit side, though, manufacturers charge more for finished module products than the sum of the parts costs: They typically add the expenses of additional assembly and test time as well as the substrate cost.

To make a worthwhile pc-board-vs-module comparison, therefore, you must make the traditional build-or-buy decision. If your application calls for high density, the
module approach usually is more cost effective. Furthermore, major semiconductor manufacturers offer off-the-shelf ceramic mother boards.

For example, Mostek makes a 4332D 32k dynamic-RAM package using two 4116E 18-pin LCC devices. It also plans to combine two 64k 4164E dynamic-RAM LCCs on a mother board to yield a $128 k \times 1$ dynamic RAM.

Texas Instruments employs a similar approach in its SMJ444164 256k dynamic RAM, which contains four TMS4164 64k dynamic RAMs mounted in 28-pin LCCs. And Harris Semiconductor furnishes the HM5-6564 64k CMOS static RAM. Double-side mounted on a ceramic mother board along with four decoupling capacitors, this RAM contains an array of 16 HM-6504 4k RAM chips in LCC packages.

Finally, an analog signal processor from Harris, the HI5-5900, comes assembled with five LCC packages and eight $0.1-\mu \mathrm{F}$ decoupling capacitors. The LCCs include an input multiplexer, dual buffers, a programmable-gain instrumentation amplifier, a reference buffer and a track/hold.

## Mismatched thermal parameters cause stress on solder joints

guidelines dictate chip-carrier package layouts with $0.010-\mathrm{in}$.-wide trace lines, $0.010-\mathrm{in}$. spaces between lines and 0.020 -in.-diameter (or smaller) feedthrough holes. Pads that connect to the LCCs typically run 0.020 in . wide on $0.050-\mathrm{in}$. center spacings. This center-spacing dimension permits one 0.010 -in.-wide line and $0.010-\mathrm{in}$. line spacing between LCC mounting pads (Fig 3). If you must run trace lines between (or very near) pads, apply a solder mask to the pc board to prevent solder bridging during the reflow process.

Using multilayer boards or substrates calls for added layout awareness. For example, use the surface-layer metallization exclusively to implement LCC mounting pads. This allocation eliminates the need for a solder mask and minimizes solder bridging. Furthermore, to reduce electrical noise, arrange the power-supply buses in a gridded array within a single layer and route signal lines on other substrate layers. Moreover, if you employ the services of a board manufacturer, make sure that the vendor can reproduce the product accurately and reliably with the required line widths, hole diameters, solder masks and multilayer construction before initiating LCC layout.

## Mounting LCCs can be difficult

Now that the finished boards are on hand, you must populate them. Attaching LCCs to conventional pc boards entails bonding problems that defy straightforward solutions. Currently, you can choose between two methods-soldering or socketing.

In military applications, socketing falls short: Available sockets are bulky and have unwieldy construction, and although adequate for routine uses, they're deficient for critical ones that demand high packing density and undergo severe environmental stresses. As a result, reflow soldering, although far from ideal for attaching LCCs to boards or substrates, works best.
To aid the reflow-soldering process, pretin both the LCC's package I/O metallization and the interconnecting substrate's metallization. Fluxing and dipping methods serve well for pretinning the LCC's package pads; use wave soldering or screen on a solder paste for the substrate's pads.
For wave soldering, after tinning the substrate, use an adhesive or glue to secure the LCC on top of the substrate's metallization during reflow soldering. Implementing the solder-paste option calls for applying the paste to the substrate's contacts with a screenprinting technique. This process involves depositing an 8- to 9 -mil-thick layer of wet paste on the contacts and then air drying the board until the paste becomes tacky. You then mount the LCC, either manually or by machine insertion, onto the corresponding contacts.
Another presoldering process producing favorable results involves bake drying the populated substrate. It allows air- and flux-pocket evacuation within the paste, minimizing volatility effects in a vapor-phase soldering operation. Otherwise, unevacuated flux pockets would float the LCC package during reflow soldering and result in misaligned positioning. Bake drying also


Fig 2-For proper installation on a substrate or board material, make an LCC's foot-pad metallization the same size as the associated pc traces, but slightly larger at the chip carrier's outer edge (a). Elongating the pc metallization permits the heated solder to wet the base contacts and the grooves located on the chip carrier's sides. Forming a fillet, the solder deposit's outer surface extends over the metallization pad on the substrate's surface (b). This arrangement completes the LCC-to-substrate electrical connection, strengthens the mechanical bond and slightly lifts the LCC from the substrate for cleaning purposes.


Fig 3-High LCC packaging density calls for tight geometries in board metallization, layout and manufacturing. Typical chip-carrier layouts mandate 0.010 -in.-wide pc traces, 0.050 -in. LCC center spacings and 0.010-in. spaces between traces and LCC mounting-pad metallization.


Fig 4-To meet high-volume production needs, vaporphase reflow soldering bonds LCCs to a substrate through the use of dried solder paste. Within the soldering chamber, the populated substrate absorbs heat in the primary saturated-vapor region and reflows the solder joints. Lifting the substrate into the secondary-vapor region cools, dries and cleans the soldered assembly.
reduces the solder paste's liquidity, temporarily holding the LCC to the substrate.

Locating the LCC on the substrate, however, doesn't require critical placement. During reflow soldering, the dried solder paste bonds the LCC in position while heating to reflow temperature: The solder's surface tension pulls the LCC into alignment over the substrate contacts. Placement thus needs only enough accuracy to ensure that the LCC's solder pads don't overlap other pads on the metallization below.
Whatever soldering procedure you choose, though, you must apply sufficient, controlled heat to melt the solder. Widely used methods include belt furnaces, heated air chambers and infrared radiation; however, they haven't received widespread industry acceptance. The vapor-phase reflow-soldering technique, on the other hand, proves efficient for high-volume LCC production (Fig 4). It typically involves a chamber containing a primary heating zone, a secondary intermediate cooling and cleansing zone and a pool of high-boiling-point fluorinated hydrocarbons.

During vapor-phase reflow soldering, a populated substrate gets lowered into the primary zone. Here, the saturated vapor causes uniform solder-joint reflow: It condenses over the substrate's surface, dispensing its latent heat through vaporization. This thermal exchange quickly and evenly heats the substrate.

Next, the substrate gets lifted into the secondary zone. In this vaporized region, the condensed fluid accumulated within the primary zone drips off the
substrate and drops into the boiling liquid. Then the substrate leaves the chamber soldered, dry and relatively clean. A final cleaning process ensues immediately after substrate removal before any residue congeals.

Yet another reflow-soldering technique-cost effective for experimental and low-volume production needs -employs hot solder oil. In this method, the populated substrate is immersed into a hot oil bath, quickly heating the solder and parts to reflow temperature. After removal from the bath, the substrate undergoes a cooling interval. Finally, a rinsing operation removes residual oil and excess flux.

## Reflow soldering simplifies reworking

In addition to the board-assembly techniques just discussed, you must pay an equal amount of attention to removing LCCs for repair or replacement. Because LCCs contain no leads and board substrates possess no holes to deform, rework proves straightforward. Of course, soldering factors such as reflow technique and temperature, solder type and metallization thickness greatly affect the degree of rework difficulty.

One LCC-package-removal method merely reverses the hot-solder-oil immersion technique for installing LCCs. In this approach, after substrate immersion and solder reflow, you remove the LCC from the board using tweezers or a similar tool.

Another removal method involves the use of a soldering iron containing a specially shaped tip for heating LCC contacts. You can also use a forced-hot-air

## Vapor-phase reflow soldering dominates bonding techniques

gun to heat the LCC package and surrounding area. This heat-gun method is widely used because it's convenient, inexpensive and practical. After heating, you lift the package off the board using tweezers.

Before soldering a replacement LCC, though, make sure you tin its contacts and the substrate's exposed contacts. Then manually position the new LCC close to its designated location. Finally, heat the surrounding area or the entire board to the solder-reflow temperature, bonding the LCC to the board and completing the rework cycle.

## References

1. Caswell, Greg, and Isaacson, Dale, "Hermetic chip carrier assembly process and materials evaluation," Electronic Packaging and Production, January 1982.
2. Dance, Francis J, and Wallace, John L, "Clad metal circuit board substrates for direct mounting of ceramic chip carriers," Electronic Packaging and Production, January 1982.
3. Fennimore, John E, "Hermetic ceramic chip carrier implementation," Electronic Packaging and Production, May 1981.
4. Hochstedler, Charles $M$, and Wilkinson, Jeffrey $M$, "Leadless carriers and CMOS technology yield highdensity low-power memory systems," Wescon Proceedings, Session 24, 1980.
5. Jonas, A W, and Garner, L E, Leadless chip carriers: The packaging technique of the 1980s, Harris Semiconductor publication.
6. Tsantes, John, "Leadless chip carriers revolutionize IC packaging," EDN, May 27, 1981, pgs 49-74.

Custom Integrated Circuits Division
Introduction ..... 9-2
Custom Capabilities ..... 9-3
Semicustom Capabilities ..... 9-7
Radiation Hardened Products ..... 9-15
Specialized Products ..... 9-27
Product Assurance ..... 9-31
CICD Sales Office Locations ..... 9-33

## Custom Integrated Circuits Division

Harris. A reputation in hi-rel custom circuits no one else can match. An emerging force in gate arrays and standard cells. A leader with all the options.

Fifteen years of pace-setting experience from programs like Trident and Peacekeeper to commercial satellites and heart pacemakers make Harris your logical choice for quality, speed and performance in custom/semicustom ICs. From commercial screening all the way to Class $S$ equivalents. And beyond.

If fast turnaround to market introduction or system prove-out in low volumes is your need, look to Harris gate arrays. Minimum initial investment and development time make them the logical choice. And upgrading to standard cell or full custom is easy.

Quick turnaround combined with ease of design and medium-to-large volume cost efficiencies make Harris standard cells your best buy.

However, for highest performance, lowest unit price, maximum reliability and smallest silicon area in high-volume requirements, Harris full custom ICs are the preferred option.

Your choices don't stop there.
Choose the technology. Analog or Digital. Bipolar or CMOS. Separately, or combined onto a single chip. Let us apply our vast experience to provide you with the right product, in the right package, at the right price.

You can even choose your level of design and layout participation to make best use of your in-house capabilities. Use our engineers or use your own. Full capability or silicon foundry, we offer all the support you need.

And if you have radiation hardeness requirements look no further. Harris is the leading supplier of radiation hardened circuits in the military marketplace.

No matter which option you take, opt for the experts at Harris. The logical choice.


For more information or data sheets, mail your request to: Harris Custom Integrated Circuits Division, P. O. Box 883, Mail Stop 53/107, Melbourne, Florida 32902.


## CUSTOM CAPABILITIES

- VLSI Development Alternatives
- Custom VLSI Services
- General Custom Capabilities
- Process Alternatives for MOS Design


## Custom Capabilities

## VLSI DEVELOPMENT ALTERNATIVES

| DEVELOPMENT | ADVANTAGES |
| :---: | :--- |
| Full Custom | Highest speed, highest density (smaller die), lowest recurring cost, <br> lowest power consumption. |
| Custom/Semicustom <br>  <br> standard cells) <br> Semicustom <br> (standard cell) <br> Gastom blocks have the advantages of the "full custom" development <br> with high speed, density and power in the standard cell section. <br> High speed, density and low power, low recurring and nonrecurring <br> cost. Proven cells give high probability of success. <br> Lowest nonrecurring cost. Proven cells and macros. |  |

## CUSTOM VLSI SERVICES

| TYPE | SERVICES SUPPLIED | CUSTOMER INPUTS |
| :---: | :---: | :---: |
| System/Chip Partitioning | Development of device specification | System specification |
| Logic Simulation | Verify logic using CAD equipment | Logic diagram |
| Test Word Generation | Generate the test vectors, add parametrics and produce a test program | Logic diagram and specification |
| Fault Analysis | Analyze test program for detection of failed states | Logic diagram and test word |
| Circuit Design | $A C$ simulations, chip plan device design | Specification |
| Circuit Layout | Generate data base for circuit fabrication | Design package |
| Mask Fabrication | Generate optical or MEBES masks | PG, Calma or MEBES data base |
| Wafer fabrication | Produce wafers and if required probe, assemble, test and burn-in | Masks |
| Device Characterization | Analyze units for compliance with specifications and map working zone | Test program and units |
| "Built to Print" Production | Run wafers and if required probe, assemble, test and burn-in | Masks, test program and specification |

These options are available as stand-alone services or as parts of an integrated development program.

## Custom Capabilities GENERAL CUSTOM CAPABILITIES

| High Performance Digital Si-Gate CMOS | Basic process for custom developments, $100+\mathrm{MHz}$ operation of clocks, high density and low power. |
| :---: | :---: |
| Radiation Hardened Option | Available for military and spacecraft use. |
| Analog Option | Useful in increasing the level of integration. Utilizes mixed high performance Si-Gate CMOS and analog elements. |
| Class B and Class S Equivalent Screens | Full high reliability screening capabilities (i.e., Burn-in, SEM, Failure Analysis, Wafer lot identity, etc.). |
| Classified Programs | All CICD design personnel have appropriate clearances to participate in classified developments. Manufacturing and test areas are cleared to process classified material. |

## PROCESS ALTERNATIVES FOR CUSTOM MOS DESIGN

| PROCESS | CHARACTERISTICS | fMAX | GATE $\mathrm{t}_{\text {pd }}$ | RADHARD OPTION | APPLICATIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CMOS Self-Aligned Silicon Gate SAJI I SAJI IV | $\begin{gathered} V_{T} \approx 0.6 \text { to } 1.1 \mathrm{~V} \\ B V_{D S S}>7 \mathrm{~V} \\ V_{D D}=-1.8 \text { to } 7 \mathrm{~V} \end{gathered}$ | $\begin{gathered} \leq 50 \mathrm{MHz} @ 4.5 \mathrm{~V}, \\ 125^{\circ} \mathrm{C} \\ \leq 100 \mathrm{MHz} @ 4.5 \mathrm{~V}, \\ 125^{\circ} \mathrm{C} \end{gathered}$ | $\sim 5 \mathrm{~ms}$ Custom $\sim 10 \mathrm{~ns} \mathrm{HL}$ Cell Library <br> ~2ns Custom $\sim 4$ ns HD Cell Library | Yes | Custom \& semicustom cell library for computers, industrial controls, interface circuits, memories, heart pacemakers, Telecomm, Datacomm, nuclear reactor controls. |
| CMOS <br> Metal Gate | $\begin{aligned} & \mathrm{V}_{\mathrm{T}}=0.5 \text { to } 1.5 \mathrm{~V} \\ & \mathrm{BV}_{\mathrm{DSS}}>15 \mathrm{~V} \end{aligned}$ | $5 \mathrm{MHz} @ 10 \mathrm{~V}$ | 50ns @ 10V | Yes | Digital communications, interface circuits, logic. |
| PMOS Silicon Gate | $\begin{gathered} V_{T} \approx 1.5 \mathrm{~V} \\ B V_{D S S}>15 \mathrm{~V} \\ V_{D D}=-7 \mathrm{~V} \\ V_{G G}=15 \mathrm{~V} \end{gathered}$ | 1 MHz | 125ns Average | No | Digital communications, dynamic shift register |
| PMOS <br> Metal Gate | $\begin{aligned} & V_{T}=-3 V \text { to }-4 V \\ & B V_{D S S} \geq 30 V \\ & V_{D D}=-15 V \\ & V_{G G}=-27 V \end{aligned}$ | $\leq 1 \mathrm{MHz}$ | ~125ns Average | No | Digital communications, dynamic shift register |
| Analog CMOS | SAJI IV with added high value resistors \& voltage inciependent capacitors | $\sim 2 \mathrm{MHz}$ | - | Yes | Mix analog \& digital on same chip for op amps, comparators, oscillators, analog switches, switched capacitor filter, voltage mulitpliers. |
| High Voltage CMOS | SAJI I with 40V Capability | $\begin{gathered} \leq 50 \mathrm{MHz} @ 4.5 \mathrm{~V} \\ 125^{\circ} \mathrm{C} \end{gathered}$ | ```~5ns Custom 10ns Cell Library``` | Yes | Interface circuits, industrial control, automotive. |



## SEMICUSTOM CAPABILITIES

- Design Automation Support
- Standard Cell
- Gate Array
- SSI/MSI Library for Semicustom Design


# 10 HARRIS <br> FEBRUARY, 1983 <br> DIAL-A-CHIP ${ }^{\text {sm }}$ CODING \& LOGIC SIMULATION 

## Features

- DIAL-UP CAPABILITY
- TEGAS SIMULATION
- AUTOMATIC TEST PROGRAM GENERATION



## Description

In this phase the designer converts the discrete logic schematic to an equivalent schematic using Harris SSI/MSI library functions from the cell library.
The designer enters the logic description code at the terminal. The code is written in the form of a from-to connection list similar to the component wiring list of a PC board. The overall procedure is to code each software block in a hierarchical manner beginning with the lowest level and progressing to the highest. Software macros may be defined by the designer on repetitive circuitry to make logic coding simpler. After each block is coded, an error-checking program is run to check for coding errors. Errors are corrected using a basic line editor before proceeding to the next block.
Once all software blocks are coded, a logic description file is created which represents the input database for the complete circuit design. It is used as input to several programs which perform logic simulation (TEGAS), initial layout (MERLYN or MP2D) and network checking (NETCHK).
The next step is to generate a test description file which will be used for simulation and test program generation. By having the test vector in this TDF language, a Sentry test program can be made quickly and easily.
Design verification is next conducted using the TEGAS
logic simulation program. During this phase, the system designer simulates the functional operation of the logic design, evaluates circuit speed and determines how effective his input test patterns are in detecting circuit faults.

## Customer Input

A design may contain SSI/MSI functions which are required by the design and are not found in the Harris macro library. If it is decided to have Harris design these macros a design cost will be incurred. This additional design charge may be avoided by the customer by breaking down the circuit into primitive logic before defining the logic in the Harris LDF code.

- Customer is to provide a set of test words in TDF truth table format to be used to develop a test program
- Fault simulation of the device must exceed $90 \%$ on supplied test word.
- Customer is responsible for identifying critical paths and associated worst case delays.
- The customer is expected to provide logic simulation and fault simulation until TEGAS is approved in the Teledesign ${ }^{\text {TM }}$ software package.
- Customer supplies conventional logic diagram in 7400 or 4000 logic.

Task Performed


## 8 HARRIS

## Features

- 3 MICRON CMOS TECHNOLOGY
- VARIABLE DIE SIZE
- 3ns TYPICAL GATE DELAY
- 50 MHz TOGGLE FREQUENCY
- 74LS-SSI, MSI LIBRARY IMPLEMENTED
- ADVANCED CAD TELEDESIGNTM* SOFTWARE SUPPORT
- VARIABLE DIE SIZE
- INDIVIDUALLY PROGRAMMABLE I/O BUFFERS
- COMPATIBLE WITH DIAL-A-CHIPSM** DESIGN AUTOMATION SYSTEM
- BI-DIRECTIONAL AND THREE STATE I/O
- TTL AND CMOS COMPATIBILITY
- COMMERCIAL TEMPERATURE RANGE
- MILITARY TEMPERATURE RANGE
- MULTIPLE PACKAGE OPTIONS


## Description

Harris Custom Integrated Circuits Division offers a complete family of custom and semicustom products. The HARRIS Standard Cell product is a very cost effective alternative to gate arrays or full custom. The standard cell circuit is manufactured using the HARRIS state-of-the-art SAJI IV local oxidation process. The process offers $3 \mu \mathrm{~m}$ channel lengths with typical gate delays of 3 ns and toggle frequencies of 50 MHz . Each input-output buffer can be individually programmed as input, output, three-state or bi-directional. CMOS and TTL compatibility can be specified. The same SSI MSI 74LS functions used to design the gate array are used for the standard cell circuits.

The logic description and simulator functions are identical for both standard cell circuits and gate arrays. However, the standard cell circuit dimensions can change dynamically for each individual circuit. Where the gate array is a fixed number of gates and fixed chip size, the standard cell uses only enough silicon to fully implement the desired logic function. Typically a standard cell chip is $30 \%$ smaller than a fully utilized gate array offering a cost savings benefit to those customers with medium to high volumes.

The standard cell chip does require a complete set of masks rather than the three required by the gate array. The standard cell circuit is fully supported by the HARRIS TeledesignTM software and the HARRIS Dial-A-ChipSM timeshare service. This allows the customer to perform as much of the design and development as he desires from his own office with a data terminal.

[^17]

## Features

- 3 MICRON CMOS TECHNOLOGY
- 600, 1200, AND 2500 GATE ARRAYS
- 3ns TYPICAL GATE DELAY
- 50 MHz TOGGLE FREQUENCY
- 74LS-SSI, MSI LIBRARY IMPLEMENTED
- ADVANCED CAD TELEDESIGNTM SOFTWARE SUPPORT
- COMPATIBLE WITH DIAL-A-CHIPSM DESIGN AUTOMATION SYSTEM
- INDIVIDUALLY PROGRAMMABLE I/O BUFFERS
- BI-DIRECTIONAL AND THREE STATE I/O
- TTL AND CMOS COMPATIBILITY
- commercial temperature range
- Military temperature range
- MULTIPLE PACKAGE OPTIONS


## CMOS Gate Array Family

| PART <br> NO. | TRAN- <br> SISTOR | GATE <br> EQUIV. | DIE <br> SIZE <br> (MILS) | I/O <br> PINS | ROWS/ <br> CELLS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| HGA-C00600 | 2592 | 648 | $198 \times 165$ | 54 | $6 \times 36$ |
| HGA-C01200 | 5184 | 1296 | $257 \times 198$ | 78 | $12 \times 36$ |
| HGA-C02500 | 10,080 | 2520 | $272 \times 287$ | 100 | $14 \times 60$ |

* One gate equivalent is equal to one 2 -input nand.



## Description

Harris Custom Integrated Circuits Division offers a complete family of custom and semicustom logic. The HGA-C00600, HGA-C01200 and HGA-C02500 are three CMOS gate arrays manufactured using the HARRIS state-of-the-art SAJI IV process. This local oxidation process offers 3 m channel lengths and 2 minimum features. Typical propagation gate delay is 3 ns with 50 MHz toggle frequencies possible. Personalization is accomplished by patterning two levels of interconnection on three mask layers: polysilicon, contacts and metal.

The entire process is fully supported by advanced CAD Teledesign TM* software. With the HARRIS Dial-AChip SM** design automation system a customer chooses the amount of his participation in the design and development of his circuit. Using the HARRIS TeledesignTM timeshare system, logic description, simulation, and artwork editing can all be performed by the customer in his own office via a digital data communications link or if he so chooses, he may use the Customer Design Center in Melbourne.

The HARRIS system minimizes the amount of design and logic coding by offering a library of 74LS equivalent SSI and MSI function designs. There is no need to implement large MSI functions with primative gates. Each function has a complete data sheet specifying propagation delays and A.C. parameters. A final software program verifies that the original logic description matches the finished artwork.

Each input-output buffer can be individually specified to be input, output, three-state, or bi-directional. CMOS or TTL compatiblity can also be specified. The large number of I/O buffers keeps the input/output to gate ratio high insuring that the design is not pin limited.

Transition from gate arrays to standard cell circuits is very simple. The same logic description files are used as input to the Dial-A-ChipSM software. Both utilize the same SSI, MSI 74LS library.
*Trademark of Harris Corporation
**Servicemark of Harris Corporation

# Semicustom Capabilities HCA SSI/MSI LIBRARY 

For use with HARRIS CMOS Gate Array and Standard Cell Family

HCA000XB
HCA0001B HCA002XB HCA0021B HCA004XB HCA007XB HCA008XB HCA010XB HCA011XB HCA020XB HCA021XB HCA027XB HCA029XB HCA030XB HCA032XB HCA051XB HCA073XB HCA074RB HCA074SB HCA074XB HCAN74RB HCAN74SB HCAN74XB

HCA075XB
HCA083SB
HCA085XB
HCA086XB
HCA138XB
HCA139XB
HCA152XB
HCA157XB
HCA161XB
HCA163XB
HCA164XB HCA165XB HCA173XB HCA175XB HCA180XB HCA192XB HCA193XB HCA194XB HCA225XB HCA240XB HCA244XB HCA257XB HCA273XB HCA283XB HCA352XB
HCA377XB
HCA393XB
HCA645XB
HCA1000B
DUAL 2 INPUT NANDDUAL 2 INPUT NAND WITH INVERTERDUAL 2 INPUT NOR
DUAL 2 INPUT NOR WITH INVERTER
TRIPLE INVERTER
HIGH FANOUT BUFFER (5 pF DRIVE)
2 INPUT AND
3 INPUT NAND
3 INPUT AND
4 INPUT NAND
4 INPUT AND
3 INPUT NOR
6 INPUT NAND
8 INPUT NAND
2 INPUT OR
4 INPUT AND-OR-INVERT GATE
JK FLIP FLOP WITH RESET
D FLIP FLOP WITH RESET
D FLIP FLOP WITH SET
D FLIP FLOP WITH SET AND RESET
D FLIP FLOP WITH RESET-NEGATIVE EDGE TRIGGERED
D FLIP FLOP WITH SET-NEGATIVE EDGE TRIGGEREDD FLIP FLOP WITH SET AND RESET-NEGATIVE EDGETRIGGEREDQUAD D TYPE LATCH WITH INDIVIDUAL RESETS
BCD FULL ADDER
4-BIT MAGNITUDE COMPARATOR
2 INPUT EXCLUSIVE OR
3 TO 8 LINE DECODER
2 TO 4 LINE DECODER
8 TO 1 DATA SELECTOR
QUAD 2 TO 1 DATA SELECTOR
4-BIT SYNCHRONOUS BINARY COUNTER WITH ASYNCHRONOUSRESET
4-BIT SYNCHRONOUS BINARY COUNTER WITH SYNCHRONOUS
RESET
8-BIT PARALLEL OUTPUT SHIFT REGISTER
8-BIT PARALLEL LOAD SHIFT REGISTER
4-BIT D REGISTER WITH THREE STATE OUTPUTS
QUAD D FLIP FLOP WITH RESET
9-BIT PARITY GENERATOR
4-BIT SYNCHRONOUS UP DOWN DECADE COUNTER
4-BIT SYNCHRONOUS UP DOWN BINARY COUNTER4-BIT SYNCHRONOUS LOAD BI-DIRECTIONAL SHIFT REGISTEREXPANDABLE 4 WORD BY 1 BIT FIFOOCTAL INVERTING THREE STATE BUFFEROCTAL NON-INVERTING THREE STATE BUFFERQUAD 2 TO 1 LINE DATA SELECTOR
OCTAL D FLIP FLOP WITH COMMON CLOCK
4-BIT BINARY FULL ADDER WITH FAST CARRY
DUAL 4 TO 1 LINE DATA SELECTOR
OCTAL D FLIP FLOP WITH ENABLE
4-BIT BINARY RIPPLE COUNTER
OCTAL BUS TRANSCEIVER
15:1 RATIO PULL UP RESISTOR WITH ENABLE

# Semicustom Capabilities <br> HCA SSI/MSI LIBRARY 

For use with HARRIS CMOS Gate Array and Standard Cell Family

GATE ARRAY I/O BUFFERS

HCA900XB HCA901XB HCA910XB HCA911XB HCA950XB HCA951XB HCA952XB HCA960XB HCA970XB HCA971XB HCA980XB HCA981XB

HCAVSSXB HCAVIA

CMOS INPUT BUFFER
CMOS INPUT BUFFER WITH 18K PULL UP RESISTOR TTL INPUT BUFFER
TTL INPUT BUFFER WITH 18K PULL UP RESISTOR
3.2 MA OUTPUT BUFFER
3.2 MA OUTPUT BUFFER-OPEN DRAIN P-CHANNEL
3.2 MA OUTPUT BUFFER-OPEN DRAIN N-CHANNEL
3.2 MA OUTPUT BUFFER-THREE STATE
3.2 MA BI-DIRECTIONAL BUFFER-CMOS INPUT
3.2 MA BI-DIRECTIONAL BUFFER-CMOS INPUT WITH 18K PULL UP
3.2 MA BI-DIRECTIONAL BUFFER-TTL INPUT
3.2 MA BI-DIRECTIONAL BUFFER-TTL INPUT WITH 18K PULL UP RESISTOR
PLACEABLE VSS I/O PAD
VIA CELL

## STANDARD CELL I/O BUFFERS

HCC900XB
HCC901XB HCC905XB HCC906XB HCC908XB HCC910XB HCC911XB HCC915XB HCC950XB HCC951XB HCC952XB HCC955XB HCC960XB HCC965XB HCC970XB HCC971XB HCC975XB HCC976XB HCC980XB HCC981XB HCC985XB HCC986XB HCC990XB HCCVDDYB HCCVSSYB

CMOS INPUT BUFFER
CMOS INPUT BUFFER WITH 18K PULL UP
CMOS INPUT BUFFER—INVERTING
CMOS INPUT BUFFER-INVERTING WITH PULL UP SCHMITT TRIGGER INPUT BUFFER
TTL INPUT BUFFER
TTL INPUT BUFFER WITH 18K PULL UP
TTL INPUT BUFFER WITH 18K PULL UP INVERTING 3.2 MA OUTPUT BUFFER
3.2 MA OUTPUT BUFFER WITH OPEN DRAIN P-CHANNEL 3.2 MA OUTPUT BUFFER WITH OPEN DRAIN N-CHANNEL 8.0 MA OUTPUT BUFFER
3.2 MA OUTPUT BUFFER THREE STATE
8.0 MA OUTPUT BUFFER THREE STATE
3.2 MA BI-DIRECTIONAL WITH CMOS INPUT
3.2 MA BI-DIRECTIONAL CMOS INPUT AND 18K PULL UP
8.0 MA BI-DIRECTIONAL WITH CMOS INPUT 8.0 MA BI-DIRECTIONAL CMOS INPUT AND 18K PULL UP 3.2 MA BI-DIRECTIONAL TTL INPUT
3.2 MA BI-DIRECTIONAL TLL INPUT AND 18K PULL UP 8.0 MA BI-DIRECTIONAL TTL INPUT 8.0 MA BI-DIRECTIONAL TTL INPUT AND 18K PULL UP UNBUFFERED INPUT WITH STATIC PROTECTION VDD SUPPLY PAD VSS SUPPLY PAD

| HIGH DENSITY HD CELL LIBRARY (PRIMITIVE FUNCTIONS) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| CELL | FUNCTIONAL DESCRIPTION | SIZE | DELAY | TRANS |
| HD1100 | LOGIC I/O CONNECTION | $132 \times 20 \mu \mathrm{~m}$ | N/A | N/A |
| HD1110 | INVERTER | $132 \times 30 \mu \mathrm{~m}$ | 3.0 ns | 4.7 ns |
| HD1130 | 3X inverter | $132 \times 40 \mu \mathrm{~m}$ | 2.7 ns | 4.5 ns |
| HD1150 | 5X INVERTER | $132 \times 50 \mu \mathrm{~m}$ | 3.1 ns | 5.0 ns |
| HD1160 | CMOS BUFFER | $132 \times 50 \mu \mathrm{~m}$ | 2.7 ns | 1.5 ns |
| HD1180 | TTL TO CMOS BUFFER | $132 \times 50 \mu \mathrm{~m}$ | 4.0 ns | 2.5 ns |
| HD1210A | 2 INPUT NAND | $132 \times 40 \mu \mathrm{~m}$ | 3.0 ns | 5.0 ns |
| HD1220 | 2 INPUT AND | $132 \times 50 \mu \mathrm{~m}$ | 3.5 ns | 2.7 ns |
| HD1230 | 2 INPUT NOR | $132 \times 40 \mu \mathrm{~m}$ | 3.0 ns | 5.3 ns |
| HD1240 | 2 INPUT OR | $132 \times 50 \mu \mathrm{~m}$ | 3.5 ns | 3.0 ns |
| HD1310 | 3 INPUT NAND | $132 \times 50 \mu \mathrm{~m}$ | 3.1 ns | 4.9 ns |
| HD1320A | 3 INPUT AND | $132 \times 60 \mu \mathrm{~m}$ | 3.3 ns | 2.8 ns |
| HD1330A | 3 INPUT NOR | $132 \times 50 \mu \mathrm{~m}$ | 3.3 ns | 5.6 ns |
| HD1340 | 3 INPUT OR | $132 \times 70 \mu \mathrm{~m}$ | 3.8 ns | 2.8 ns |
| HD1410 | 4 INPUT NAND | $132 \times 60 \mu \mathrm{~m}$ | 3.3 ns | 5.0 ns |
| HD1420 | 4 INPUT AND | $132 \times 70 \mu \mathrm{~m}$ | 3.5 ns | 2.5 ns |
| HD1430 | 4 INPUT NOR | $132 \times 90 \mu \mathrm{~m}$ | 4.8 ns | 3.0 ns |
| HD1440 | 4 INPUT OR | $132 \times 80 \mu \mathrm{~m}$ | 3.5 ns | 2.6 ns |
| HD2120 | EXCLUSIVE-OR | $132 \times 80 \mu \mathrm{~m}$ | 4.7 ns | 3.5 ns |
| HD2130 | EXCLUSIVE-NOR | $132 \times 70 \mu \mathrm{~m}$ | 5.4 ns | 3.4 ns |
| HD2140 | TRANSMISSION GATE | $132 \times 40 \mu \mathrm{~m}$ | 1.2 ns | 7.3 ns |
| HD2150 | TRI-STATE | $132 \times 50 \mu \mathrm{~m}$ | 2.0 ns | 4.4 ns |
| HD2210 | 4 TO 1 MUX | $132 \times 240 \mu \mathrm{~m}$ | 5.0 ns | 5.0 ns |
| HD2220 | 2 TO 1 MUX | $132 \times 100 \mu \mathrm{~m}$ | 3.9 ns | 2.5 ns |
| HD2230 | 2, 2-AND, 2-NOR | $132 \times 60 \mu \mathrm{~m}$ | 4.1 ns | 6.6 ns |
| HD2240 | 2, 3-AND, 2-NOR | $132 \times 80 \mu \mathrm{~m}$ | 4.4 ns | 6.9 ns |
| HD2250 | 3, 2-AND, 3-NOR | $132 \times 80 \mu \mathrm{~m}$ | 4.8 ns | 7.8 ns |
| HD3100 | D FF | $132 \times 120 \mu \mathrm{~m}$ | 2.5 ns | 3.2 ns |
| HD3110 | D FF W/RESET | $132 \times 150 \mu \mathrm{~m}$ | 3.4 ns | 3.2 ns |
| HD3120 | D FF W/RESET, QBR | $132 \times 170 \mu \mathrm{~m}$ | 4.3 ns | 4.0 ns |
| HD3130 | D FF W/SET, RESET | $132 \times 180 \mu \mathrm{~m}$ | 5.0 ns | 3.8 ns |
| HD3140 | D FF W/SET, QBAR | $132 \times 170 \mu \mathrm{~m}$ | 4.2 ns | 4.2 ns |
| HD3150 | D FF W/QbAR | $132 \times 140 \mu \mathrm{~m}$ | 4.5 ns | 3.5 ns |
| HD3200A | JK FF | $132 \times 160 \mu \mathrm{~m}$ | 4.5 ns | 5.0 ns |
| HD3210 | JK FF W/RESET | $132 \times 180 \mu \mathrm{~m}$ | 4.8 ns | 4.8 ns |
| HD3220A | JK FF W/RESET, QBR | $132 \times 210 \mu \mathrm{~m}$ | 5.4 ns | 3.5 ns |
| HD3230 | JK FF W/SET, RESET | $132 \times 250 \mu \mathrm{~m}$ | 5.4 ns | 4.3 ns |
| HD3240 | JK FF W/SET | $132 \times 210 \mu \mathrm{~m}$ | 5.0 ns | 5.4 ns |
| HD3250 | JK FF W/abar | $132 \times 210 \mu \mathrm{~m}$ | 6.7 ns | 7.0 ns |
| HD3260A | JK FF W/R, QBAR (POS) | $132 \times 210 \mu \mathrm{~m}$ | 5.5 ns | 3.6 ns |
| HD5040A | 4-BIT SHIFT REGISTER | $132 \times 340 \mu \mathrm{~m}$ | 4.6 ns | 4.6 ns |
| HD5060A | 6-BIT SHIFT REGISTER | $132 \times 500 \mu \mathrm{~m}$ | 4.6 ns | 4.6 ns |

NOTE: DESIGN AND DEVELOPMENT SUPPORT FOR THIS LIBRARY IS PROVIDED BY CUSTOM INTEGRATED CIRCUITS DIVISION ENGINEERING.

## Semicustom Capabilities

| CELL | FUNCTIONAL DESCRIPTION | SIZE | DELAY | TRANS |
| :---: | :---: | :---: | :---: | :---: |
| HD5080A | 8-BIT SHIFT REGISTER | $132 \times 660 \mu \mathrm{~m}$ | 4.6 ns | 4.6 ns |
| HD6210 | 2 INPUT NAND (INV) | $132 \times 50 \mu \mathrm{~m}$ | 3.4 ns | 4.9 ns |
| HD6220 | 2 INPUT AND (INV) | $132 \times 70 \mu \mathrm{~m}$ | 4.0 ns | 3.0 ns |
| HD6230 | 2 INPUT NOR (INV) | $132 \times 60 \mu \mathrm{~m}$ | 4.0 ns | 5.3 ns |
| HD6240 | 2 INPUT OR (INV) | $132 \times 50 \mu \mathrm{~m}$ | 3.4 ns | 5.0 ns |
| HD6310 | 3 INPUT NAND (INV) | $132 \times 70 \mu \mathrm{~m}$ | 3.7 ns | 4.9 ns |
| HD6320 | 3 INPUT AND (INV) | $132 \times 80 \mu \mathrm{~m}$ | 4.5 ns | 3.0 ns |
| HD6330 | 3 INPUT NOR (INV) | $132 \times 70 \mu \mathrm{~m}$ | 4.2 ns | 5.6 ns |
| HD6340 | 3 INPUT OR (INV) | $132 \times 80 \mu \mathrm{~m}$ | 4.5 ns | 3.1 ns |
| HD6410 | 4 INPUT NAND (INV) | $132 \times 80 \mu \mathrm{~m}$ | 4.0 ns | 5.1 ns |
| HD6420A | 4 INPUT AND (INV) | $132 \times 80 \mu \mathrm{~m}$ | 5.3 ns | 2.6 ns |
| HD6430 | 4 INPUT NOR (INV) | $132 \times 110 \mu \mathrm{~m}$ | 5.0 ns | 2.6 ns |
| HD6440 | 4 INPUT OR (INV) | $132 \times 100 \mu \mathrm{~m}$ | 4.7 ns | 3.1 ns |
| HD8120A | P CHAN TEST DEVICES | $239 \times 269 \mu \mathrm{~m}$ | N/A | N/A |
| HD8220A | N CHAN TEST DEVICES | $239 \times 269 \mu \mathrm{~m}$ | N/A | N/A |
| HD8310AQ | N- TEST CAPACITOR | $174 \times 397 \mu \mathrm{~m}$ | N/A | N/A |
| HD8320 | P- TEST CAPACITOR | $186 \times 358 \mu \mathrm{~m}$ | N/A | N/A |
| HD8420A | TEST RESISTORS | $185 \times 251 \mu \mathrm{~m}$ | N/A | N/A |
| HD8510 | ALIGNMENT MARKS | $66 \times 302 \mu \mathrm{~m}$ | N/A | N/A |
| HD8520 | MASK REVISION ID | $64 \times 272 \mu \mathrm{~m}$ | N/A | N/A |
| HD8530 | CRITICAL DIMENSION | $86 \times 174 \mu \mathrm{~m}$ | N/A | N/A |
| HD8610 | CORNER ROT. MARK 1 | $28 \times 78 \mu \mathrm{~m}$ | N/A | N/A |
| HD8620 | CORNER ROT. MARK 2 | $28 \times 78 \mu \mathrm{~m}$ | N/A | N/A |
| HD8710 | COPYRIGHT SYMBOL | $82 \times 87 \mu \mathrm{~m}$ | N/A | N/A |
| HD8720 | "HARRIS" | $34 \times 239 \mu \mathrm{~m}$ | N/A | N/A |
| HD8730 | HARRIS LOGO | $146 \times 146 \mu \mathrm{~m}$ | N/A | N/A |
| HD8750 | CICD | $40 \times 154 \mu \mathrm{~m}$ | N/A | N/A |
| HD8810 | \#1 PAD ID (1 SIDE) | $21 \times 105 \mu \mathrm{~m}$ | N/A | N/A |
| HD8820 | \#2 PAD ID (2 SIDES) | $126 \times 126 \mu \mathrm{~m}$ | N/A | N/A |
| HD8910 | VIA | $6 \mathrm{x} \quad 6 \mu \mathrm{~m}$ | N/A | N/A |
| HD8920 | FEED THROUGH CELL | $132 \times 10 \mu \mathrm{~m}$ | N/A | N/A |
| HD9100 | VDD TYPE A | $314 \times 170 \mu \mathrm{~m}$ | N/A | N/A |
| HD9130 | VSS TYPE B | $314 \times 170 \mu \mathrm{~m}$ | N/A | N/A |
| HD9210 | INPUT W/PROTECT | $314 \times 240 \mu \mathrm{~m}$ | N/A | N/A |
| HD9220 | INPUT W/PULLUP | $314 \times 250 \mu \mathrm{~m}$ | N/A | N/A |
| HD9230 | INPUT W/PULLDOWN | $314 \times 280 \mu \mathrm{~m}$ | N/A | N/A |
| HD9240 | BUFFERED OUTPUT | $314 \times 320 \mu \mathrm{~m}$ | 6.1 ns | 4.1 ns |
| HD9250 | BI-DIRECTIONAL | $314 \times 390 \mu \mathrm{~m}$ | 6.8 ns | 5.0 ns |
| HD9310 | INPUT W/PROTECT | $314 \times 240 \mu \mathrm{~m}$ | N/A | N/A |
| HD9320 | INPUT W/PULLUP | $314 \times 260 \mu \mathrm{~m}$ | N/A | N/A |
| HD9330 | INPUT W/PULLDOWN | $314 \times 280 \mu \mathrm{~m}$ | N/A | N/A |
| HD9340 | BUFFERED OUTPUT | $314 \times 320 \mu \mathrm{~m}$ | 6.1 ns | 4.1 ns |
| HD9350 | BI-DIRECTIONAL | $314 \times 390 \mu \mathrm{~m}$ | 6.8 ns | 5.0 ns |

NOTE: DESIGN AND DEVELOPMENT SUPPORT FOR THIS LIBRARY IS PROVIDED BY CUSTOM INTEGRATED CIRCUITS DIVISION ENGINEERING.


# RADIATION HARDENED CMOS PRODUCTS 

## - Current Products

- Future Products


## CURRENT RADIATION HARDENED CMOS PRODUCTS

BUS INTERFACE CIRCUITSHS-15530RH Rad Hard Mil. Std. 1553 Encoder/Decoder (24 Pins)
RAD HARD MEMORIESHS-6504RH Rad Hard 4K $\times 1$ CMOS RAMHS-6508RH Rad Hard $1 \mathrm{~K} \times 1$ CMOS RAMHS-6514RM Rad Hard $1 \mathrm{~K} \times 4$ CMOS RAMHS-6551RH Rad Hard $256 \times 4$ CMOS RAMHS-6564RH Rad Hard 64K Memory Module ( $8 \mathrm{~K} \times 8$ or $16 \mathrm{~K} \times 4$ )HS-6532RH Rad Hard 32K Memory Module ( $8 \mathrm{~K} \times 4$ or $16 \mathrm{~K} \times 2$ )
ANALOG SWITCHES/MULTIPLEXERS
HS-508ARM Rad Hard 8 Channel MultiplexerHS-1840RH Rad Hard 16 Channel Multiplexer

## (7) Harras

 HS-15530RH Radiation ResistantCMOS Manchester Encoder-Decoder

- SUPPORT OF MIL-STD-1553
- 1.0 MEGABIT/SEC DATA RATE
- SYNC IDENTIFICATION AND LOCK-IN
- CLOCK RECOVERY
- MANCHESTER II ENCODE, DECODE
- SEPARATE ENCODE AND DECODE
- LOW OPERATING POWER: 50mW AT 5 VOLTS
- FULL MILITARY TEMPERATURE RANGE
- FUNCTIONAL TOTAL DOSE . . $1 \times 104$ RAD(Si)
- LATCH-UP FREE TO . . . . . . . . . $5 \times 1011$ RAD (Si)/sec


## Features

## Pinout

| VALID WORD 1 | $24 \square \mathrm{VCC}$ |
| :---: | :---: |
| encoder shift clock 2 | 23 encoder clock |
| take data 3 | 22 send clock in |
| serial data out 4 | 21.1 send data |
| decoder clock 5 | 20.7 sync select |
| bipolar zeroin 6 | 19 encoder enable |
| bipolar one in 7 | 18 serial datain |
| unipolar data in 8 | 17 P BIPOLAR ONE OUT |
| decoder shift clock ${ }^{\text {a }}$ | 16 OUTPUT INHIBIT |
| COMMAND/ $\overline{\text { DATA }}$ SYNC 10 | 15 BIPOLAR ZERO OUT |
| decoder reset 11 | $14 \div 60 \cup T$ |
| GND 12 | 13 master reset |

## Description

The Harris HS-15530RH is a high performance, radiation resistant, CMOS device intended to service the requirements of MIL-STD-1553 and similar Manchester 11 encoded, time division multiplexed serial data protocals. This LSI chip is divided into two sections, an Encoder and a Decoder. These sections operate completely independent of each other, except for the Master Reset function.

This circuit provides many of the requirements of MIL-STD-1553. The Encoder produces the sync
pulse and the parity bit as well as the encoding of the data bits. The Decoder recognizes the sync pulse and identifies it as well as decoding the data bits and checking parity.

This integrated circuit is fully guaranteed to support the 1 MHz data rate of MIL- STD-1553 over both temperature and voltage while residing in a radiation environment. It interfaces with CMOS, TTL or N channel support circuitry, and uses a standard 5 volt supply.

## Block Diagrams

## ENCODER

DECODER


## 8 HARRIS <br> Preliminary

## HS-6504RH $4096 \times 1$ CMOS RAM

Features

- LOW POWER STANDBY
- LOW POWER OPERATION
- EXTREMELY LOW SPEED POWER PRODUCT
- FUNCTIONAL TOTAL DOSE
- DATA UPSET
- latch - up freeto
- TTL COMPATIBLE INPUT/OUTPUT
- THREE-STATE OUTPUT
- STANDARD JEDEC PINOUT
- FAST ACCESS TIME

200nsec TYP.

- MILITARY TEMPERATURE RANGE
- 18 PIN PACKAGE FOR HIGH DENSITY
- ON CHIP ADDRESS REGISTER


## Description

The HS-6504RH is a $4096 \times 1$ static CMOS RAM fabricated using the Harris Custom Integrated Circuits Division radiation hardened self-aligned silicon gate technology. The device utilizes synchronous circuitry to achieve high performance and low power operation.
On-chip latches are provided for addresses, data input and data output allowing efficient interfacing with microprocessor systems. The data output can be forced to a high impedance for use in expanded memory arrays.
The HS-6504RH is a fully static RAM and may be maintained in any state for an indefinite period of time.

## Pinout

| TOP VIEW |  |
| :---: | :---: |
| AO 1 | 18 |
| A1 2 | 17 |
| A2 3 | 16 |
| A 34 | 15 |
| A4 5 | 14 |
| A5 6 | 13 |
| $0 \square$ | 12 |
| W-8 | 11 |
| GNO- 9 | 10 |

Logic Symbol


## Functional Diagram



Information on this device is preliminary. Data is subject to change unless otherwise specifically agreed. No obligations are assumed for notice of change or future manufacture of this device.
CAUTION: These devices are sensitive to electrostatic discharge.

## 7. HARRIS

HS-6508RH
$1024 \times 1$ CMOS RAM

## Features

```
- FUNCTIONAL TOTAL DOSE
```


$\qquad$
$\qquad$

```
- LATCH-UP FREE TO . . . . . . . . . . . . . . . . . . . 5.0 x 1011 RAD Si/sec
- LOW STANDBY POWER . . . . . . . . . . . . . . . . . . . . . . . }550\muW\mathrm{ MAX
- LOW OPERATING POWER . . . . . . . . . . . . . . . . . . . 25mW/MHz MAX
- FAST ACCESS TIME . . . . . . . . . . . . . . . . . . . . . . . . 300nsec MAX
- TTL COMPATIBLE IN/OUT
- HIGH OUTPUT DRIVE - 2TTL LOADS
- HIGH NOISE IMMUNITY
- ON-CHIP ADDRESS REGISTER
- MILITARY TEMPERATURE RANGE
- THREE-STATE OUTPUTS
- 16 PIN PACKAGE FOR HIGH DENSITY
```


## Description

The HS-6508RH is a 1024 by 1 static CMOS RAM fabricated using the HARRIS Programs Division radiation hardened self-aligned silicon gate technology. Synchronous circuit design techniques are employed to achieve high performance and low power operation.

On-chip latches are provided for addresses allowing efficient interfacing with microprocessor systems. The data output buffers can be forced to a high impedance state for use in expanded memory arrays.

The HS-6508RH is a fully static RAM and may be maintained in any state for an indefinite period of time.

## Pinout

TOP VIEW


A - Address Input $D$ - Data Input $\bar{E}$ - Chip Enable Q-- Data Output $\bar{W}$ - Write Enable

Logic Symbol


Functional Diagram


## (T) HARRIS Preliminary

HS-6514RH $1024 \times 4$ CMOS RAM

## Features

- LOW POWER STANDBY
- LOW POWER OPERATION
- functional total dose
- DATA UPSET
- latch - upfreeto
$25 \mu \mathrm{~W}$ TYP.
25mW/MHz TYP.
$1 \times 10^{5}$ RAD Si
$>10^{8} \mathrm{RADS} \mathrm{Si} / \mathrm{s}$
$>5 \times 10^{11} \mathrm{RAD} \mathrm{Si} / \mathrm{s}$
- TTL COMPATIBLE INPUT/OUTPUT
- COMMON DATA IN/OUT
- THREE-STATE OUTPUTS
- STANDARD JEDEC PINOUT
- FAST ACCESS time

200ns TYP.

- MILITARY TEMPERATURE RANGE
- 18 PIN PACKAGE FOR HIGH DENSITY
- ON - CHIP ADDRESS REGISTER


## Description

The HS-6514RH is a $1024 \times 4$ static CMOS RAM fabricated using the Harris Custom Integrated Circuits Division radiation hardened self-aligned silicon gate technology. The device utilizes synchronous circuitry to achieve high performance and low power operation.
On-chip latches are provided for the addresses allowing efficient interfacing with microprocessor systems. The data output can be forced to a high impedance state for use in expanded memory systems.
The HS-6514RH is a fully static RAM and may be maintained in any state for an indefinite period of time.

Pinout
top view
A5

## Logic Symbol



## Functional Diagram


information on this device is preliminary. Data is subject to change unless otherwise specifically agreed. No obligations are assumed for notice of change or future manufacture of this device.
CAUTION: These devices are sensitive to electrostatic discharge.

# HARRIS <br> <br> HS-6551RH <br> <br> HS-6551RH $256 \times 4$ CMOS RAM 

 $256 \times 4$ CMOS RAM}

## Features

- functional total dose
- Latch-up freeto
- LOW STANDBY POWER
- Low operating power
- fast access time
- tTL COMPATIBLE in/out
- high output drive - 1ttl load
- high NOISE IMMUNITY
- ON CHIP ADDRESS REGISTER
- military temperature range
- THREE-STATE OUTPUTS
- 22 PIN PACKAGE FOR HIGH DENSITY


## Description

The HS-6551RH is a 256 by 4 static CMOS RAM fabricated using the Harris Programs Division radiation hardened self-aligned silicon gate technology. Synchronous circuit design techniques are employed to achieve high performance and low power operation.

On-chip latches are provided for addresses, allowing efficient interfacing with microprocessor systems. The data output buffers can be forced to a high impedance state for use in expanded memory arrays.

The HS-6551RH is a fully static RAM and may be maintained in any state for an indefinite period of time.

## Pinout

TOP VIEW

|  | ${ }_{22} \mathrm{plvc}$ |
| :---: | :---: |
| $\mathrm{A}_{2} \mathrm{Cl}_{2}$ | ${ }_{21} \mathrm{D}^{\text {A4 }}$ |
| $\mathrm{AlO}^{3}$ | 20 w |
| ${ }^{\text {a }}$ [ ${ }^{4}$ | 19 - ${ }^{11}$ |
| ${ }_{45}{ }^{4}$ | 18. |
| $\left.{ }^{46}\right]^{6}$ | ${ }_{17}{ }^{1}$ |
| A) ${ }^{\text {a }}$ | ${ }_{16} \mathrm{O} 04$ |
| Ono 8 | ${ }_{15}{ }^{04}$ |
| $00^{0}$ | 14 O |
| 0 | 13 D03 |
| 02 Cl | ${ }_{12}{ }^{\circ} \mathrm{O}$ |

$$
\begin{array}{ll}
\text { A - Address Input } & \bar{W} \text { - Write Enable } \\
\overline{\bar{E}} \text { - Chip Enable } & \text { D - Data Input } \\
\bar{S} \text { - Chip Select } & \text { Q - Data Output }
\end{array}
$$

## Logic Symbol



## Functional Diagram



## 0 HARRIS <br> Preliminary

## Features

- LOW POWER STANDBY
- Low power operation
- data retention
- ttl compatible in/out
- THREE STATE OUTPUTS
- FAST ACCESS time
- MILITARY TEMPERATURE RANGE
- ON CHIP ADDRESS REGISTERS
- ORGANIZABLE $8 K \times 8$ OR $\mathbf{1 6 K} \times 4$
- 40 PIN DIP PINOUT $2.000^{\prime \prime} \times \mathbf{0 . 9 0 0 ^ { \prime \prime }}$
- functional total dose
- DATA UPSET
- Latch-up free to


## Description

The HS-6564RH is a radiation resistant 64 K bit, synchronous CMOS RAM. It consists of $16 \mathrm{HS}-6504 \mathrm{RH} 4 \mathrm{~K} \times 1$ radiation resistant CMOS RAMs, in leadless carriers, mounted on a ceramic substrate. The HS-6564RH is configured as an extra wide, standard length 40 pin DIP. The memory appears to the system as an array of $164 \mathrm{~K} \times 1$ static RAMs. The array is organized as two 8 K by 4 blocks of RAM sharing only the address bus. The data inputs, data outputs, chip enables and write enables are separate for each block of RAM. This allows the user to organize the HS-6564RH RAM as either an 8 K by 8 or a 16 K by 4 array.
This 64K memory provides a unique blend of low power CMOS semiconductor technology and advanced packaging techniques. The HS-6564RH is intended for use in radiation environments where a large amount of RAM is needed, and where power consumption and board space are prime concerns. On-chip latches are provided for addresses, data input and data output allowing efficient interfacing with microprocessor systems. The data output can be forced to a high impedance for use in expanded memory arrays. The guaranteed low voltage data retention characteristics allow easy implementation of non-volatile read/write memory by using very small batteries mounted directly on the memory circuit board.
$1 \times 10^{5}$ RAD Si
$500 \mu \mathbf{W}$ MAX $180 \mathrm{~mW} / \mathrm{MHz}$ MAX
3.0 V MIN

250 nsec TYP.
$-55^{\circ} \mathrm{C}$ TO $+125^{\circ} \mathrm{C}$
$>10^{4}$ RAD Si/SEC
$>5 \times 10^{11} \mathrm{RAD} \mathrm{Si} /$ SEC

Functional Diagram


Information on this device is preliminary. Data is subject to change unless otherwise specifically agreed. No obligations are assumed for notice of change or future manufacture of this device.
CAUTION. These devices are sensitive to electronic discharge.



## FUTURE RADIATION HARDENED PRODUCTS

| FUTURE RADIATION HARDENED $80 C 85$ FAMILY |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| DEVICE | SANDIA P/N | INDUSTRY EQUIVALENT | HCICD P/N | AVAILABILITY |
| 8 Bit CPU | SA3000 | 8085 | HS-80C85RH | 20'84 |
| $256 \times 8$ CMOS RAM <br> with I/O Ports and Timer | SA3001 | 8155/56 | HS-8155/56RH | 20'84 |
| $2 \mathrm{~K} \times 8$ CMOS RAM | SA3002 | 8355 | HS-8355RH | 20 84 |
| 3 to 8 Line Decoder | SA2995 | 74138 | - | 20 84 |
| Bi-directional CMOS/TTL Level Converter | SA2996 | 40116 | - | 20 84 |
| Bus Transceiver | SA2997 | 8208 | - | 20 84 |
| Input/Output Port | SA3026 | 8212 | - | 20 84 |


| FUTURE RADIATION HARDENED PROMs |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DEVICE | ORGANI- <br> ZATION | INDUSTRY <br> EQUIVALENT | COMMENTS | AVAIL- <br> ABILITY |  |
| 4 K CMOS PROM | $512 \times 8$ | HM-6641 | $\bullet$ Latch-up Free <br> $\bullet$ Total Dose Goal <br> $\geq 1 \times 10^{5}$ RADS (Si) | 20 ‘84 |  |


| FUTURE RADIATION HARDENED STATIC RAMs |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| DEVICE | ORGANI- <br> ZATION | COMMENTS | AVAIL- <br> ABILITY |  |
| 16K CMOS STATIC <br> Asynchronous RAM | $16 K \times 1$ | $\bullet$ Immune to single event upset <br> $\bullet$ Total Dose Tolerant to $\geq 5 \times 105$ <br> RADs (Si) <br> $\bullet$ Latch-up Free | 20 ‘84 |  |



## SPECIALIZED PRODUCTS

Bus Interface Circuits<br>- HS-3182 ARINC 429 Line Driver<br>- HS-3282 ARINC 429<br>Line Receiver/Transmitter<br>\section*{Other<br><br>- HS-3819 Video Character Generator}

## Hid HARRIS

 HS-3182
## ARINC 429 Bus Interface Line Driver Circuit

## Features

- inputs t²L and cmos compatible
- ADJUSTABLE RISE AND FALL TIMES VIA 2 EXTERNAL CAPACITORS
- PROGRAMMABLE OUTPUT DIFFERENTIAL RANGE VIA VOLTAGE REFERENCE INPUT (VREF)
- power strobe input permits low quiescent POWER OF < 20 mW
- OUTPUTS ARE INHIBITED (O VOLTS) IF DATA (A) AND DATA (B) INPUTS ARE BOTH IN THE "LOGIC ONE" STATE
- CAN OPERATE UP TO A 100 KILOBITS data rate
- OUTPUT SHORT CIRCUIT PROOF AND CONTAINS OVERVOLTAGE PROTECTION
- DATA "A" AND DATA "B" SIGNALS ARE "AND'D" WITH CLOCK AND SYNC SIGNALS
- full military temperature range


$$
\frac{\text { MIN. }}{\text { MAX. }} \quad \text { NOTE: DIMENSIONS IN INCHES }
$$

## Description

The HS-3182 ARINC 429 bus interface driver circuit is a monolithic dielectrically isolated bipolar differential line driver designed to meet the specifications of ARINC 429. This device is intended to be used with a companion chip, HS-3282 CMOS ARINC bus interface circuit, which provides the data formatting and processor interface function.
All logic inputs are $\mathrm{T}^{2} \mathrm{~L}$ and CMOS compatible. In addition to the DATA $(A)$ and DATA $(B)$ inputs there are also inputs for a CLOCK and SYNC signal which are AND'D with the DATA inputs. This feature was added to enhance system performance and to allow the HS-3182 to be used with devices other than the HS-3282. Also adding to system performance is the STROBE input. To minimize power consumption the STROBE input can be asserted to place the chip in the power-down mode where it draws substantially less current. Four power supplies are required; $+\mathrm{V}=+15 \mathrm{~V} \pm 10 \%$, $-\mathrm{V}=-15 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{1}=5 \mathrm{~V} \pm 5 \%$ and $\mathrm{V}_{\text {REF }} \mathrm{V}_{\text {REF }}$ is used to program the output voltage swing, such that $\mathrm{V}_{\text {OUT }}($ DIFF $)= \pm 2 \mathrm{~V}_{\text {REF }}$ Typically, $V_{\text {REF }}=V_{1}=5 \mathrm{~V} \pm 5 \%$.

The driver output impedance is $75 \Omega \pm 20 \%$ at $25^{\circ} \mathrm{C}$. Output rise and fall times are programmed through the use of two external capacitors, $\mathrm{C}_{A}$ and $\mathrm{C}_{B}$. To meet the requirements for rise and fall times as specified in ARINC 429, $C_{A}=C_{B}=75 \mathrm{pF}$ for the high speed operation ( 100 KBPS ) and 500 pF for the low speed operation ( $12-14.5 \mathrm{KBPS}$ ). The outputs are protected against overvoltage and short circuit as shown in the Block Diagram. This device is designed to operate with a case temperature range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$.

## Truth Table

| $\overline{\text { STROBE }}$ | SYNC | CLOCK | DATA <br> (A) | DATA (B) | A OUT | $B_{\text {OUT }}$ | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | $x$ | $x$ | $x$ | x | HI-Z | H/-Z | Power-Down State |
| L | $x$ | L | $x$ | $x$ | OV | OV | NULL |
| L | L | X | X | $x$ | OV | OV | NULL |
| L | H | H | L | L | OV | OV | NULL |
| L. | H | H | L | H | $-V_{\text {REF }}$ | $+V_{\text {REF }}$ | LOW |
| L | H | H | H | L | $+V_{\text {REF }}$ | $-V_{\text {REF }}$ | HIGH |
| L | H | H | H | H | OV | OV | NULL |

## Block Diagram

Pinout top view

| $V_{\text {REF }}{ }^{1}$ | ${ }^{16} \mathrm{~V}_{1}$ |
| :---: | :---: |
| STROBE ${ }_{2}$ | 15 NC |
| SYNC [3 | 14 ClOCK |
| DATA (A) 4 | 13 DATA (B) |
| $\mathrm{c}_{\mathrm{A}} \mathrm{S}_{5}$ | ${ }_{12} \mathrm{C}_{\mathrm{B}}$ |
| Aout 6 | $1{ }^{1} \mathrm{~B}$ OUt |
| - $\mathrm{v}_{0}$ | $10 ¢ \mathrm{NC}$ |
| GND 8 | - + |

## 6) HARRIS /

## Description

The Harris HS-3282 is a high performance CMOS bus interface circuit that is intended to meet the requirements of ARINC Specification 429, and similar encoded, time multiplexed serial data protocols. The ARINC 429 bus interface circuit consists of two (2) receivers and a transmitter operating independently as shown in Figure 1. The two receivers operate at a frequency that is ten (10) times the receiver data rate, which can be the same or different from the transmitter data rate. Although the two receivers operate at the same frequency, they are functionally independent and each receives serial data asynchronously. The transmitter section of the ARINC bus interface circuit consists mainly of a First-In First-Out (FIFO) memory and timing circuit. The FIFO memory is used to hold eight (8) ARINC data words for transmission serially. The timing circuit is used to correctly separate each ARINC word as required by ARINC Specification 429.

Even though ARINC Specification 429 specifies a 32-bit word, including parity, the HS-3282 can be programmed to also operate with a word length of 25 bits. The incoming receiver data word parity is checked, and a parity status is stored in the receiver latch and is outputted on Pin BD08 during the 1st word. [A logic " 0 " indicates that an odd number of logic " 1 "s were received and stored; a logic " 1 " indicates that an even number of logic " 1 "s were received and stored]. In the transmitter the parity generator will generate either odd or even parity depending upon the status of PARCK control signal. A logic " 0 " on BD12 will cause odd parity to be generated and inputted to the output data stream. Conversely, a logic " 1 " on BD12 will result in the generation of even parity that will be inputted to the output data stream.

More versatility is provided in both the transmitter and receiver by the addition of an external TTL clock input allowing the bus interface circuit to operate at data rates from 0 to 1 megabits. The TTL external clock must be ten (10) times the data rate to insure no data ambiguity.

The ARINC bus interface circuit is fully guaranteed to support the data rates of ARINC specification 429 over both the voltage ( $\pm 10 \%$ ) and full military temperature range. It interfaces with TTL, CMOS or NMOS support circuitry, and uses the standard 5 -volt VCC supply.

## Features

- ARINC SPECIFICATION 429 COMPATIBLE
- DATA RATES OF 100 KILOBITS OR 12.5 KILOBITS
- SEPARATE RECEIVER AND TRANSMITTER SECTION
- DUAL AND INDEPENDENT RECEIVERS, CONNECTING DIRECTLY TO ARINC BUS
- SERIAL TO PARALLEL RECEIVER DATA CONVERSION
- PARALLEL TO SERIAL TRANSMITTER DATA CONVERSION
- WORD LENGTHS OF 25 OR 32 BITS
- PARITY STATUS OF RECEIVED DATA
- GENERATE PARITY OF TRANSMITTER DATA
- AUTOMATIC WORD GAP TIMER
- SINGLE 5-VOLT SUPPLY
- LOW POWER DISSIPATION
- FULL MILITARY TEMPERATURE RANGE


## Pinout

| TOP VIEW |  |  |
| :---: | :---: | :---: |
| $\mathrm{vcc}_{1}$ | 40 | ]/C |
| 429D11(A) 2 | 39 | MR |
| 429DI1(B) 3 | 38 | TX CLK |
| 429DI2(A) 4 | 37 | jttl Clk |
| 429DI2(B) 5 | 36 | $]^{\mathrm{FC}}$ |
| $\overline{\mathrm{D} / \mathrm{R} 1} 6$ | 35 | ] F |
| $\overline{\mathrm{D} / \mathrm{R} 2} 7$ | 34 | CWSTR |
| SEL 8 | 33 | ENTX |
| EN1 9 | 32 | $\underline{42900}$ |
| EN2 10 | 31 | 42900 |
| BD 1511 | 30 | ] TX/R |
| BD 1412 | 29 | $\overline{\text { PL2 }}$ |
| BD13 13 | 28 | PL1 |
| BD 1214 | 27 | BD00 |
| BD11 15 | 26 | BD01 |
| BD10 16 | 25 | bD02 |
| BD09 17 | 24 | ]803 |
| BD08 18 | 23 | BD04 |
| BD07 19 | 22 | bD05 |
| BD06 20 | 21 | Jand |

## HARRIS <br> Preliminary <br> Video Character Generator

## Features

- OPERATION (DOT CLOCK) FROM 1.0 TO 27 MHz
- DESIGNED TO INTERFACE WITH INTEL 8275 PROGRAMMABLE CRT CONTROLLER
- DIRECTLY DECODES (FROM ON-CHIP ROM);
- ASCII 96 CHARACTER SET
- 32 PSEUDO-GRAPHIC CHARACTERS
- 10 OVERLAY PATTERNS
- EXPANDABLE CHARACTER TABLE
- $9 \times 12$ DOT MATRIX WITH DESCENDER CAPABILITY
- HANDLES VIDEO MODIFIERS;
- BLANK
- VIDEO SUPPRESS
- REVERSE VIDEO
- LIGHT ENABLE


## Description

The HS-3819 is a CMOS/LSI Video Character Generator designed to help interface an Intel 8275 Programmable CRT Controller to a video monitor. The character generator must be supplied with a clock frequency of between 1 and 27 MHz which will be used as the dot clock. This signal is then divided by nine to form the character clock output needed by the CRT Controller. The HS-3819 then converts character data into a video output signal, through use of an internal (ROM) character table. Stored in this ROM are the standard 96 ASCII characters, 32 pseudo-graphic characters and 10 overlay patterns used to modify characters. Additional characters, if needed, can easily be decoded from an external memory field.

Pinout

| $\overline{W R}$ | 1 | 40 | $V_{\text {cc }}$ |
| :---: | :---: | :---: | :---: |
| CS | 2 | 39 | GRAPHE |
| AO | 3 | 38 | E8 |
| S1 | 4 | 37 | E7 |
| S2 | 5 | 36 | $\overline{E 6}$ |
| S3 | 6 | 35 | E5 |
| LC3 | - | 34 | E4 |
| LC2 | 8 | 33 | $\overline{E 3}$ |
| LC1 | 9 | 32 | E2 |
| LCO | 10 | 31 | E1 |
| EXEN | 11 | 30 | E0 |
| ROMDIS | 12 | 29 | DOTCLK |
| CC6 | 13 | 28 | RESET |
| CC5 | 14 | 27 | CCLK |
| CC4 | -15 | 26 | VSP |
| Cc3 | 16 | 25 | LTEN |
| CC2 | 17 | 24 | RVV |
| CC1 | 18 | 23 | $\overline{\text { BLK }}$ |
| CCO | 19 | 22 | VID2 |
| GND | $\underline{20}$ | 21 | vID1 |

LCO-3 - LINE COUNT CC0.6 - CHARACTER CODE ROMDIS - ROM DISABLE LTEN - LIGHT ENABLE RVV - REVERSE VIDEO VSP - VIDEO SUPPRESS BLK - BLANK S1-3 - SPECIAL FUNCTION EXEN - EXPANSION ENABLE $\overline{E 0.8}$ - EXPANSION INPUTS GRAPHE - GRAPHICS ENABLE WR - WRITE
$\overline{\overline{C S}}$ - CHIP SELECT A0 - ADDRESS 0 VIDT-2 - VIDEO OUTPUTS RESET - RESET DOTCLK - DOT CLOCK CCLK - CHARACTER CLOCK

## Standard Character Set

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NuIL | $\mathcal{L}$ | SP | 0 | (2) | P | - | p |
| 1 | $\frac{6 M}{1}$ | $\stackrel{\text { OUP }}{*}$ | $!$ | 1 | A | Q | a | q |
| 2 | ! | $\neg$ | 11 | 2 | B | R | b | r |
| 3 | - | (! | \# | 3 | C | S | $c$ | , |
| 4 | $\square$ | $\cdots$ | \$ | 4 | D | T | d | $t$ |
| 5 | ? | -- | \% | 5 | E | U | e | u |
| 6 |  | 7 | \& | 6 | F | V | 1 | $\checkmark$ |
| 7 | - | $\square$ | , | 7 | G | W | 9 | w |
| 8 | © |  | ( | 8 | H | X | h | x |
| 9 | - | $\checkmark$ | ) | 9 | 1 | $Y$ | i | $y$ |
| A | X | Z | * | : | J | Z | j | $z$ |
| B | へ |  | + | ; | K | [ | k | 1 |
| C | - | - | , | $<$ | L. | \} | 1 | 1 |
| D | $\rightarrow$ | 3 | - | $=$ | M | $]$ | m | \} |
| E | 웃 | $\stackrel{A}{\square}$ |  | $>$ | N | $\wedge$ | n | - |
|  | 웃 | 8 | 1 | ? | 0 | - | 0 | c |

## Overlay Patterns



Dot Matrix


NOTES

1. EACH ROW MAY HAVE DOTS IN SET A OR SET B ONLY.
2. EACH CHARACTER MAY HAVE DOTS IN NORMAL SET OR DESCENDER SET ONLY.

## PRODUCT ASSURANCE

For the custom, semicustom and rad hard products offered by CICD , any necessary screening or special product assurance testing is available. Class $S$ and Class $B$ military screening is routinely performed. Fabrication lot integrity is maintained, and product traceability to individual wafers is available.

CICD is a supplier to the most demanding high-reliability applications - specifically, for strategic missiles, satellites and heart pacers. If needed, customers may obtain a fully custom designed quality/reliability program to fit their unique requirements.

# Custom Integrated Circuits Division SALES OFFICE LOCATIONS 

Northeast Region 2600 Virginia AvenueSuite 800Washington, DC 20037202-342-3900
Telecopier: 202-338-3878
5 Old Concord Road
Burlington, MA 01803
617-273-1020
TWX: 710-332-1074
Quip: 617-272-7956
106 Seventh Street
Garden City, NY 11530
516-747-6776
TWX: 510-220-1527
Southeast Region Suite 1137040 Lake Ellenor Drive
Orlando, FL 32809
305-851-9450
Telex: 808819
Telecopier: 305-851-5141
Central Region Suite 704
2850 Metro Drive
Minneapolis, MN 55420
612-854-3224
TWX: 920-576-3418
Telecopier: 612-854-7359
Suite 110
17120 Dallas Parkway
Dallas TX 75248
214-248-3239
TWX: 910-860-5446
Western Region Suite 320
1503 South Coast Drive
Costa Mesa, CA 92626
714-957-6557
TWX: 910-595-1533
Telecopier: 714-957-6557
European Sales Office Harris Semiconductor
P. O. Box 27
145 Farnham Road
Slough SL1 4XD, England
011-447-5334666
Telex: 848174 Harris G

Ordering Information ..... 10-3
Package Availability ..... 10-4
Package Dimensions ..... 10-6

## Ordering Information

Harris products are designed by "Product Code". When ordering, please refer to products by the full code.

PRODUCT CODE


80CXX FAMILY PRODUCT CODE


## HARRIS DASH 8 PROGRAM

As a service to users of High Rel products, Harris makes readily available via the high reliability DASH 8 program many products from our product lines.

## SPECIAL ORDERS

For best availability and price, it is urged that standard "Product Code" devices be specified which are available worldwide from authorized distributors. Where enhanced reliability is needed, note standard "Dash 8" screening described in this Data Book. Harris application engineers may be consulted for advice about suitability of a part for a given application.

If additional electrical parameter guarantees or reliability screening are absolutely required, a Request for Quotation and Source Control Drawing should be submitted through the local Harris Sales Office or Sales Representative. Many electrical parameters cannot be economically tested, but can be assured through design analysis, characterization, or correlation with other parameters which have been tested to specification limits. These parameters are labeled "Sampled and guaranteed, but not $100 \%$ tested".

Harris reserves the right to decline to quote, or to request modification to special screening requirements.

## Package Availability

| PART NUMBER | CERDIP | $\begin{aligned} & \text { EPOXY* } \\ & \text { (Ag) } \end{aligned}$ | LEADLESS CARRIER | MODULE SUBSTRATE |
| :---: | :---: | :---: | :---: | :---: |
| CMOS 80C86 Family |  |  |  |  |
| $80 \mathrm{C86}$ | DE | FF | EA | - |
| $82 \mathrm{C82}$ | 52 | 7M | LS | - |
| 82C55A | 4 H | FD | EG | - |
| 82C84A | 4N | 7W | LS | - |
| $82 \mathrm{C88}$ | 52 | 7M | LS | - |
| 82C59A | 1M | FJ | LX | - |
| 82C54 | 5F | FG | EH | - |
| 82C52 ** | 1M | - | - | - |
| HD-6406 | 4 H | FD | EA | - |
| 80C88 | DE | FF | EA | - |
| 82C84B | 4 N | 7W | LS | - |
| 1K RAM |  |  |  |  |
| HM-6508 | 5 C | 71 | - | - |
| HM-6518 | 5 E | 7 D | LA | - |
| HM-6551 | 4M | 3E | - | - |
| HM-6561 | 4 N | 7D | LA | - |
| 4K RAM |  |  |  |  |
| HM-6504 | 5E | 7 D | LB | - |
| HM-6514 | 5E | 7 D | LB | - |
| CMOS Memory 16 RAM |  |  |  |  |
| HM-6516 | 5F | 72 | EC | - |
| HM-65162 | 5F | 72 | EC | - |
| HM-65172 | 5F | 72 | EC | - |
| RAM Modules |  |  |  |  |
| HM-6564 | - | - | - | MA |
| HM-92560 | - | - | - | MD |
| HM-92570 | - | - | - | MF |

[^18]Package Availability (continued)

| PART NUMBER | CERDIP | $\begin{aligned} & \text { EPOXY* } \\ & (\mathrm{Ag}) \end{aligned}$ | LEADLESS CARRIER | MODULE SUBSTRATE |
| :---: | :---: | :---: | :---: | :---: |
| Future Products |  |  |  |  |
| HM-65262 | 5M | 7F | - | - |
| HM-65642 | DD | - | ED | - |
| HM-92562 | - | - | - | MH |
| Programmable Memories |  |  |  |  |
| HM-6641 | DC, 5F | - | LZ | - |
| HM-6616 | DC, 5 F | - | EC | - |
| HM-6664 | DD | - | ED | - |
| $\mu$ Processors \& |  |  |  |  |
| Peripherals Microprocessors |  |  |  |  |
| HD-6120 | 5H | FE | - | - |
| HD-6121 | 5 H | FD | - | - |
| HM-6100 | 5 H | FE | - | - |
| HM-6101 | 5 H | FE | - | - |
| Peripherals |  |  |  |  |
| HD-6431 | 42 | 7H | LA | - |
| HD-6432 | 4 N | 7D | LA | - |
| HD-6433 | 42 | 7H | LA | - |
| HD-6434 | 4K | GB | - | - |
| HD-6436 | 52 | 7 J | - | - |
| HD-6440 | 4N | 7W | LA | - |
| HD-6495 | 42 | 7H | LA | - |
| Data Communications |  |  |  |  |
| HD-15530 | 4K | 7 C | LX | - |
| HD-15531/15531B | 5 H | FE | - | - |
| HD-6408 | 4K | 7 C | LX | - |
| HD-6409 | 52 | 7M | LS | - |
| HD-6406 | 4 H | FE | EA | - |
| HD-6402 | 5H | FD | - | - |
| HD-4702 | 42 | 7H | LA | - |

* Epoxy ( Ag ) is the type of leadframe that is recommended. The Epoxy $(\mathrm{Au})$ is an emergency back-up when the silver type ( Ag ) is not available.

4Z, 4N, 5E, 5Z, 5M, 4L, DC, 5C
CERDIP . 300


| PKG. <br> TYPE | LEAD COUNT | DIM. A | DIM. B | DIM. c | DIM. D | дім. E | дім. F | DIM. | DIM. <br> H | DIM. L | DIM. 0 | DIM. s | DIM. $\alpha$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 42 | $\begin{aligned} & 16 \\ & \text { MSI } \end{aligned}$ | $\frac{.140}{170}$ | $\frac{.016}{.018}$ | $\frac{.008}{.012}$ | . 760 | $\frac{.265}{285}$ | $\frac{.290}{310}$ | $\frac{.050}{.070}$ | $\frac{.090}{110}$ | $\frac{.125}{150}$ | $\frac{.020}{.040}$ | $\frac{.025}{.045}$ | $\frac{0}{150}$ |
| 5 C | $\begin{aligned} & 16 \\ & \text { LSI } \end{aligned}$ | $\frac{.140}{.170}$ | $\frac{.016}{.018}$ | $\frac{.008}{.012}$ | $\frac{.790}{760}$ | $\frac{.285}{305}$ | $\frac{.300}{320}$ | . 050 | $\frac{.090}{110}$ | $\frac{.125}{150}$ | $\frac{.020}{.040}$ | $\frac{.025}{.045}$ | $\frac{0}{150}$ |
| 4N | $\begin{aligned} & 18 \\ & \text { LSI } \end{aligned}$ | $\frac{.140}{.170}$ | $\frac{.016}{018}$ | $\frac{.008}{.012}$ | $\frac{.885}{915}$ | $\frac{.285}{305}$ | $\frac{.300}{320}$ | . 050 | $\frac{.090}{110}$ | $\frac{.125}{150}$ | $\frac{.020}{.040}$ | $\underline{.040}$ | $\frac{00}{150}$ |
| $\left\lvert\, \begin{aligned} & 5 Z, 5 \mathrm{M}, \\ & 4 \mathrm{~L} \end{aligned}\right.$ | $\begin{aligned} & 20 \\ & \text { LSI } \end{aligned}$ | $\frac{.140}{170}$ | $\frac{.016}{.018}$ | $\frac{.008}{012}$ | $\frac{.940}{970}$ | $\frac{285}{305}$ | $\frac{.300}{320}$ | $\frac{.050}{.070}$ | . 090 | $\frac{.125}{150}$ | $\frac{.020}{.040}$ | $\frac{.020}{.040}$ | $\frac{00}{150}$ |
| DC | 24 SLIM | $\frac{.150}{180}$ | $\frac{.016}{018}$ | $\frac{.008}{.012}$ | $\frac{1.240}{1.270}$ | $\frac{.285}{.305}$ | $\frac{.300}{320}$ | $\frac{.050}{070}$ | . 0900 | $\frac{.125}{150}$ | $\frac{.020}{.040}$ | $\underline{.060}$ | $\frac{00}{150}$ |

NOTE: 1 ) Dimensions are: $\frac{\text { MIN }}{\text { MAX }}$.
2) All Dimensions in inches

4M
CERDIP 400


| PKGG. <br> TYPE | LEAD <br> COUNT | DIM. <br> $\mathbf{A}$ | DIM. <br> $\mathbf{B}$ | DIM. <br> $\mathbf{C}$ | DIM. <br> $\mathbf{D}$ | DIM. <br> E | DIM. <br> F | DIM. <br> $\mathbf{G}$ | DIM. <br> $\mathbf{H}$ | DIM. <br> $\mathbf{L}$ | DIM. <br> $\mathbf{Q}$ | DIM. <br> $\mathbf{S}$ | DIM. <br> $\mathbf{\alpha}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $4 \mathrm{4M}$ | 22 | $\frac{.150}{.180}$ | $\frac{.016}{.018}$ | $\frac{.008}{.012}$ | $\frac{1.055}{1.085}$ | $\frac{.375}{395}$ | $\frac{.395}{.415}$ | $\frac{.050}{.070}$ | $\frac{.090}{.110}$ | $\frac{.125}{.150}$ | $\frac{.020}{.040}$ | $\frac{.030}{.050}$ | $\frac{00}{150}$ |

NOTE: 1) Dimensions are: $\frac{\text { MIN. }}{\text { MAX. }}$
2) All Dimensions in inches


5F, 4K, 1M, DD, 4H, 5H, DE

## CERDIP . 600



| PKG. <br> TYPE | LEAD COUNT | DIM. A | DIM. B | DIM. C | DIM. D | DIM. E | DIM. F | DIM. G | DIM. H | DIM. L | DIM. 0 | DIM. S | DIM. $\alpha$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 5 F \\ & 4 K \end{aligned}$ | $\begin{gathered} 24 \\ \text { MSI } \end{gathered}$ | $\frac{.150}{180}$ | . 016 | . 008 | $\frac{1.24}{1.27}$ | $\frac{.515}{.535}$ | $\frac{.595}{.615}$ | $\frac{.050}{.070}$ | $\frac{.090}{110}$ | $\frac{.125}{.150}$ | $\frac{.020}{.045}$ | $\frac{.060}{.090}$ | $\frac{0}{150}$ |
| $1 M$ DD | $\begin{gathered} 28 \\ \text { MSI } \end{gathered}$ | $\frac{.160}{.190}$ | $\frac{.016}{.018}$ | . 0008 | $\frac{1.44}{1.47}$ | $\frac{.515}{.535}$ | $\frac{.595}{.615}$ | $\frac{.050}{.070}$ | $\frac{.090}{.110}$ | $\frac{.125}{.150}$ | $\frac{.020}{.060}$ | $\frac{.060}{.090}$ | $\frac{00}{150}$ |
| $4 \mathrm{H}, 5 \mathrm{H} \text {, }$ DE | $\begin{aligned} & 40 \\ & \text { MSI } \end{aligned}$ | $\frac{.160}{200}$ | $\frac{.016}{.018}$ | $\frac{.008}{.012}$ | $\frac{2.035}{2.075}$ | $\frac{.515}{535}$ | $\frac{.595}{.615}$ | $\frac{.050}{.070}$ | $\frac{.090}{.110}$ | $\frac{.125}{150}$ | $\frac{.020}{.060}$ | $\frac{.065}{.095}$ | $\frac{00}{150}$ |

NOTE: 1) Dimensions are: $\frac{\mathrm{MIN}}{\mathrm{MAX}}$.
2) All Dimensions in inches

## Package Dimensions

## 7I, 3L, 7W, 7V, 7D, 7M, 7F, 7H, 7J



| $\begin{array}{\|l\|l\|} \hline \text { PKG. } \\ \hline \text { TYPE } \end{array}$ | LEAD COUNT | DIM. A | $\underset{\mathrm{B}}{\mathrm{DIM} .}$ | DIM. c | $\underset{\mathrm{D}}{\mathrm{DI}} .$ | DIM. E | дім. F | dIM. G | DIM. H | DIM. <br> L | DIM. <br> a | DIM. <br> s | DIM. $\alpha$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 71 \\ & 7 \mathrm{H} \end{aligned}$ | 16 | $\frac{.125}{140}$ | $\frac{.016}{.020}$ | $\frac{.008}{.012}$ | $\frac{.750}{.770}$ | $\frac{.245}{265}$ | $\frac{290}{310}$ | $\frac{.050}{.070}$ | $\frac{.090}{110}$ | $\frac{.150}{170}$ | $\frac{.020}{.040}$ | $\frac{.025}{035}$ | $\frac{00}{150}$ |
| $\begin{aligned} & 7 \mathrm{w}, 7 \mathrm{v} \\ & 70 \end{aligned}$ | 18 | $\frac{.125}{140}$ | $\frac{.016}{.020}$ | $\frac{.008}{.012}$ | $\frac{.900}{920}$ | $\frac{.245}{265}$ | $\frac{290}{310}$ | $\frac{.050}{070}$ | $\frac{.090}{110}$ | $\frac{.150}{170}$ | . 020 | $\frac{.040}{060}$ | $\frac{0}{150}$ |
| $\begin{array}{\|l\|} \hline 7 M, 7 F, \\ 7 J \end{array}$ | 20 | $\frac{.130}{145}$ | $\frac{.016}{.020}$ | $\frac{.008}{.012}$ | $\frac{1.030}{1.050}$ | $\frac{250}{270}$ | $\frac{.290}{310}$ | $\frac{.050}{070}$ | . 090 | $\frac{.150}{170}$ | $\frac{.020}{.040}$ | $\frac{.060}{080}$ | $\frac{00}{150}$ |

NOTE: 1) Dimensions are: $\frac{\mathrm{MIN} \text {. }}{\mathrm{MAX} \text {. }}$
2) All Dimensions in inches
$3 E$

## EPOXY . 400



FG, 7Z, FJ, FD, FF, 7C, FE
EPOXY . 600


## Package Dimensions

LB, LA, LS, LX, LZ, EC, ED, EA, EG, EH

## LEADLESS CHIP CARRIER



| $\begin{array}{\|l\|} \hline \text { PKQ. } \\ \text { TYPE } \end{array}$ | $\begin{aligned} & \text { LEAD } \\ & \text { COUNT } \end{aligned}$ | DIM. | $\begin{gathered} \text { DIM. } \\ \hline \end{gathered}$ | $\begin{gathered} \overline{\text { DIM. }} \\ \mathrm{c} . \end{gathered}$ | $\overline{\mathrm{DIM} .}$ | $\overline{\mathrm{DIM}} .$ | DIM. F | DIM. | $\underset{\mathrm{H}_{\mathrm{H}}}{ }$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { LB } \\ & \text { LA } \end{aligned}$ | 18 | $\frac{.050}{.078}$ | $\frac{.020}{0.30}$ | $\frac{.060}{.090}$ | $\frac{342}{358}$ | $\frac{.277}{293}$ | $\stackrel{080}{.086}$ | . 0.050 | $\frac{.040}{065}$ |
| LS | 20 | $\frac{.050}{.078}$ | $\frac{.020}{0.30}$ | $\frac{.080}{.090}$ | $\frac{.342}{358}$ | $\frac{342}{358}$ | $\frac{.080}{.086}$ | . 080 | $\frac{.040}{.065}$ |
| LX | $\begin{gathered} 28 \\ .400 \mathrm{iq} . \end{gathered}$ | $\begin{array}{r} .050 \\ .078 \end{array}$ | $\frac{.020}{0.30}$ | $\frac{.060}{.080}$ | $\frac{.390}{.418}$ | $\frac{.390}{.416}$ | $\frac{.060}{.095}$ | . 0.050 | $\frac{.040}{065}$ |
| Lz | $\begin{gathered} 28 \\ .450 \mathrm{sq} . \end{gathered}$ | $\frac{.050}{.078}$ | $\frac{.020}{0.30}$ | $\frac{.060}{.090}$ | $\frac{.442}{458}$ | $\frac{.442}{458}$ | $\frac{.080}{.096}$ | . 0.050 | $\frac{.040}{065}$ |
| $\left\lvert\, \begin{aligned} & \text { EC, ED, } \\ & E H \end{aligned}\right.$ | 32 | $\frac{.050}{.078}$ | $\frac{.020}{0.30}$ | $\frac{.080}{.090}$ | $\frac{545}{.380}$ | $\frac{.442}{.458}$ | $\frac{.060}{.085}$ | . 0.050 | . 040 |
| $\begin{aligned} & E A \\ & E G \end{aligned}$ | 44 | $\frac{.050}{.078}$ | $\frac{.020}{0.30}$ | $\frac{.080}{.090}$ | $\frac{.643}{662}$ | $\frac{.643}{862}$ | $\frac{.060}{095}$ | . 050 | $\frac{.040}{085}$ |

NOTE: 1) Dimensions are: $\frac{\text { MIN. }}{\text { MAX }}$
2) All Dimensions in inches


MD MODULE SUBSTRATE HM-92560, HM-92562


MF MODULE SUBSTRATE HM-92570


## GENERAL INFORMATION

Harris CMOS Products are available in chip form to the hybrid micro circuit designer. The standard chips are DC electrically tested at +1250 C to the data sheet limits for the commercial device and are $100 \%$ visually inspected. Packaging for shipment consists of waffle pack carriers plus an anti-static cushioning strip for extra protection.

The hybrid industry has rapidly become more diversified and stringent in its requirements for integrated circuits. To meet these demands Harris has several options additional to standard chip processing available upon request at extra cost. For more information consult the nearest Harris Sales Office.

## CHIP ORDERING INFORMATION

Standard and special chip sales are direct factory order only. The minimum order on all sales is $\$ 250.00$ per line item. Contact the local Harris Sales Office for pricing and delivery on special chip requirements.

## MECHANICAL INFORMATION

Dimensions: All chip dimensions nominal with a tolerance of $\pm .003^{\prime \prime}$. Maximum chip thickness is $.023^{\prime \prime}$.
Bonding Pads: Minimum bonding pad size is $.004^{\prime \prime} \times .004^{\prime \prime}$ unless otherwise specified.

## ELECTRICAL INFORMATION

CMOS: Die substrate must be electrically connected to VCC through conductive die attach, to assure proper electrical operating characteristics.

## DICE GEOMETRIES AND DIMENSIONS

May be obtained by contacting the factory of your local Harris Sales Office.

## PRODUCT CODE EXAMPLE

## or




Chip Form
*Contact Harris for availability of -2 ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ) dice.

Sector Alpha-Numeric Product Index ..... 12-3
Harris Sales Locations ..... 12-8
Action Request Cards ..... -

## Alpha-Numeric Product Index

## Analog

PRODUCT
HA-1608
HA-2400/04/05
HA-2420/25
HA-2420/02/05
HA-2500/02/05
HA-2510/12/15
HA-2520/22/25
HA-2539
HA-2540
HA-2600/02/05
HA-2620/22/25
HA-2630/35
HA-2640/45
HA-2650/55
HA-2720/25
HA-2730/35
HA-2740
HA-4156
HA-4600/02/05
HA-4620/22/25
HA-4741
HA-4900/0205
HA-5033
HA-5062
HA-5064
HA-5082
HA-5084
HA-5100/05
HA-5110/15
HA-5130/35
HA-5141/42/44
HA-5160/62
HA-5170
HA-5180/5180A
HA-5190/95
HA-5320
HC-5116A/5156A
HC-5502
HC-5504
HC-5510/5511
HC-5512/5512A
HC-5531
HC-55536
HC-55564

## DESCRIPTION

+10V Adjustable Voltage Reference
PRAM, Four Channel Operational Amplifiers
Fast Sample and Hold Operational Amplifiers
Precision High Slew Rate Operational Amplifiers
Precision High Slew Rate Operational Amplifiers
High Slew Rate Operational Amplifiers
Uncompensated High Slew Rate Operational Amplifiers
Super High Slew Rate Wideband Operational Amplifiers Ultra High Slew Rate Operational Amplifiers Wideband, High Impedance Operational Amplifiers Very Wideband, Uncompensated Operational Amplifiers High Performance Current Booster
High Voltage Operational Amplifiers
Dual High Performance Operational Amplifiers
Wide Range Programmable Operational Amplifiers
Wide Range Dual Programmable Operational Amplifiers
Quad Programmable Operational Amplifiers
High Performance Quad Operational Amplifiers
High Performance Quad Operational Amplifiers
Wideband, High Performance Quad Operational Amplifiers
Quad Operational Amplifier
Precision Quad Comparators
High-Speed Current Buffer
Dual Low Power, JFET Input Operational Amplifier
Low Power, JFET Input Quad Operational Amplifier
Dul JFET Input Operational Amplifer
JFET Input Quad Operational Amplifier
Wideband, JFET Input Operational Amplifiers
Wideband, JFET Input, Uncompensated Operational Amplifiers
Precision Operational Amplifiers
Power Operational Amplifier, Single, Dual \& Quad
Wideband, JFET Input, High Slew Rate, Uncompensated
Operational Amplifiers
Precision JFET Input Operational Amplifiers
Ultra Low IBIAS JFET Input Precision
Operational Amplifier
Wideband, Fast Settling Operational Amplifiers
High Speed Precision Monolithic Sample and Hold Amplifier Monolithic CODECS (Preliminary)
SLIC-LC Subscriber Line Interface Circuit (PBX)
SLIC-LC Subscriber Line Interface Circuit (PBX)
Monolithic CODECs (Preliminary)
PCM Monolithic Filter
Automatic Line Balance Network
Decode Digital Continuously Variable Slope Delta Modulator (CVSD)
Encode and Decode all Digtal Continuously
Variable Slope Delta Modulator (CVSD)

## Analog (Continued)

## PRODUCT

## DESCRIPTION

## HD-0165

HI-200
HI-201
HI-201HS
HI-300
HI-301
HI-302
HI-303
HI-304
HI-305
HI-306
HI-307
HI-381
HI-384
HI-387
HI-390
HI-506/507
HI-506A/507A
HI-506L/507L
HI-508/509
HI-508A/509A
HI-508L/509L
HI-516
HI-518
HI-524
HI-539
HI-562A
HI-565A
HI-574A
HI-674A
HI-1818A/1828A
HI-5040
HI-5041
HI-5042
HI-5043
HI-5044
HI-5045
HI-5046
HI-5046A
HI-5047
HI-5047A
HI-5048
HI-5049
HI-5050
HI-5051
HI-5610

Keyboard Encoder
Dual SPST CMOS Analog Switch
Quad SPST CMOS Analog Switch
High Speed Quad SPST CMOS Analog Switch
Dual SPST CMOS Analog Switch
SPDT CMOS Analog Switch
Dual DPST CMOS Analog Switch
Dual SPDT CMOS Analog Switch
Dual SPST CMOS Analog Switch
SPDT CMOS Analog Switch
Dual DPST CMOS Analog Switch
Dual SPDT CMOS Analog Switch
Dual SPST CMOS Analog Switch
Dual DPST CMOS Analog Switch
SPDT CMOS Analog Switch
Dual SPDT CMOS Analog Switch
Single 16/Differential 8 Channel CMOS Analog Multiplexers
16 Channel CMOS Analog Multiplexers with

## Overvoltage Protection

Latched, 16/8 Channel Analog Multiplexer
Single 8/Differential 4 Channel CMOS Analog Multiplexers
8 Channel CMOS Analog Multiplexers with
Overvoltage Protection
Latched, $8 / 4$ Channel Analog Multiplexer
16 Channel/Differential 8 Channel CMOS High Speed Analog Multiplexer
8 Channel/Differential 4 Channel CMOS High Speed Analog Multiplexer
4 Channel Video Multiplexer
Monolithic, Four Channel, Low Level, Differential Multiplexer
12 Bit High Speed Monolithic Digital-to-Analog Converter
High Speed Monolithic Digital-to-Analog Converter with Reference
Fast, Complete 12 Bit A-to-D Converter with $P$ Interface
High Speed, Complete 12-Bit A-to-D Converter
with PInterface
Low Resistance 8 Channel CMOS Analog Multiplexer
Low Resistance SPST Switch
Low Resistance Dual SPST Switch
Low Resistance SPDT Switch
Low Resistance Dual SPDT Switch
Low Resistance DPST Switch
Low Resistance Dual DPST Switch
Low Resistance DPDT Switch
Low Resistance DPDT Switch
Low Resistance 4PST Switch
Low Resistance 4PST Switch
Low Resistance Dual SPST Switch
Low Resistance Dual DPST Switch
Low Resistance SPDT Switch
Low Resistance Dual SPDT Switch
10 Bit High Speed Monolithic Digital-to-Analog Converter

## Analog (Continued)

## PRODUCT

HI-5618A/18B
HI-5660
HI-5680
HI-5685
HI-5687
HI-5712/12A
HI-5900
HI-5901
HI-7541
HI-DAC801
HI-DAC16B/C
HV-1000/1000A
LF347
LF353
LF355 Series
LF356 Series
LF357 Series
LM108/308
LM108A/308A
LM118/318
LM143/343
LM143A/343A
LM146/346
LM148/348
LM148A/348A
LM1558A/1458A
LM2908
LM4250/4250C

## DESCRIPTION

8 Bit High Speed Digital-to-Analog Converters High Speed Monolithic D-to-A Converter 12 Bit Low Cost Monolithic D-to-A Converter High Performance Monolithic 12 Bit D-to-A Converter Wide Temperature Range Monolithic 12 Bit D-to-A Converter
High Performance 12 Bit Analog-to-Digital Converters Analog Data Acquisition Signal Processor Analog Data Acquisition Signal Processor
12 Bit Multiplying Monolithic Digital-to-Analog Converter
12 Bit High Speed Monolithic Digital-to-Analog Converter 16 Bit D-to-A Converter
Single-Phase Induction Motor Energy Saver Wideband Quad JFET Input Operational Amplifiers
Wideband Dual JFET Input Operational Amplifier
Monolithic JFET Input Operational Amplifiers
Wideband Monolithic JFET Input OPerational Amplifiers
Decompensated Wideband Monolithic JFET Input
Operational Amplifiers
Operational Amplifiers
Operational Amplifiers
Operational Amplifiers
High Voltage Operational Amplifiers
High Voltage Operational Amplifiers
Programmable Quad Operational Amplifiers
Quad 741 Operational Amplifiers
Quad 741 Operational Amplifiers
Dual Operational Amplfiers
Quad Operational Amplifiers
Programmable Operational Amplifiers

## Bipolar

## PRODUCT

HD-6600
HM-0104
HM-0168
HM-0186
HM-0198
HM-0410
HM-7602/03
HPROM-0512
HM-7610/11
HM-7610A/11A
HM-7610B/11B
HM-7620/21
HM-7620A/21A
HM-7620B/21B
HM-7640/41
HM-7640A/41A
HM-7649
HM-7649A
HM-7642/43
HM-7642A/43A
HM-7642B/43B
HM-7681
HM-7681A
HM-7685
HM-7685A
HM-76161
HM-76161A
HM-76165
HM-76321
HM-76641
HPL-77153
HPL-77209
HPL-77215
HPL-77216
HPL-77317
HPL-77318
HPL-77319
HPL-77320
M38510/20701BEB
M38510/20702BEB M38510/20101BJB M38510/20301BEB M38510/20302BEB M38510/20401BEB M38510/20402BEB M38510/20801BJB M38510/20802BJB M38510/20602BVB M38510/20904BJB M38510/20902BVB M38510/21002BJB

## DESCRIPTION

Quad Power Strobe
$10 \times 4$ Diode Matrix
$6 \times 8$ Diode Matrix
$8 \times 6$ Diode Matrix
$9 \times 8$ Diode Matrix
$4 \times 10$ Diode Matix
$32 \times 8$ Bit Generic PROM
$64 \times 8$ HPROM
$256 \times 4$ Bit Generic PROM
$256 \times 4$ Bit High Speed Generic PROM
$256 \times 4$ Bit Ultra High Speed Generic PROM
$512 \times 4$ Bit Generic PROM
$512 \times 4$ Bit High Speed Generic PROM
$512 \times 4$ Bit Ultra High Speed Generic PROM
$512 \times 8$ Bit Generic PROM (24-Pin)
$512 \times 8$ Bit High Speed Generic PROM (24-Pin)
$512 \times 8$ Bit Generic PROM (20-Pin)
$512 \times 8$ Bit High Speed Generic PROM (20-Pin)
$1024 \times 4$ Bit Generic PROM
$1024 \times 4$ Bit High Speed Generic PROM
$1024 \times 4$ Bit Ultra High Speed Generic PROM
$1024 \times 8$ Bit Generic PROM
$1024 \times 8$ Bit High Speed Generic PROM
$2048 \times 4$ Bit Generic PROM
$2048 \times 4$ Bit High Speed Generic PROM
$2048 \times 8$ Bit Generic PROM
$2048 \times 8$ Bit High Speed Generic PROM
$4096 \times 4$ Bit Generic PROM
$4096 \times 8$ Bit Generic PROM
$8192 \times 8$ Bit Generic PROM
20-Pin Field Programmable Logic Array
20-Pin Field Programmable Array Logic (Active Low Outputs)
20-Pin Field Programmable Array Logic (Active Low Outputs)
20-Pin Field Programmable Array Logic (Programmable Output Polarity)
20-Pin Field Programmable Array Logic (Active Low Dedicated Outputs)
20-Pin Field Programmable Array Logic (Active High Dedicated Outputs)
20-Pin Field Programmable Array Logic (Enhanced HPL-77317)
20-Pin Field Programmable Array Logic (Enhanced
HPL-77318)
$32 \times 8$ Open Collector QPL1 PROM
$32 \times 8$ Three State QPL1 PROM
$64 \times 8$ Open Collector QPL1 PROM
$256 \times 4$ Open Collector QPL1 PROM
$256 \times 4$ Three State QPL1 PROM
$512 \times 4$ Open Collector QPL1 PROM
$512 \times 4$ Three State QPL1 PROM
$512 \times 8$ Open Collector QPL1 PROM
$512 \times 8$ Three State QPL1 PROM
$512 \times 8$ Three State QPL1 PROM
$1024 \times 8$ Three State QPL1 PROM
$2048 \times 4$ Three State QPL1 PROM
$2048 \times 8$ Three State QPL1 PROM

## CMOS

HD-15530
HD-15531
HD-4702
HD-6101
HD-6120
HD-6121
HD-6402
HD-6406
HD-6408
HD-6409
HD-6431
HD-6432
HD-6433
HD-6434
HD-6436
HD-6440
HD-6495
HM-6100
HM-6504
HM-6508
HM-6514
HM-6516
HM-65162
HM-65172
HM-6518
HM-65262
HM-6551
HM-6561
HM-6564
HM-6616
HM-6641
HM-6664
HM-92560
HM-92570
HPL- 16LC8
HPL-16RC4
HPL-16RC6
HPL-16RC8
$80 C 86$
80 C 88
82C37A
82 C 52
82 C 54
82C55A
82C59A
82 C 82
82 C 83
82C84A
82C84B
82 C 86
82 C 87
82C88
82C89

|  | Manchester Encoder-Decoder |
| :---: | :---: |
|  | Manchester Encoder-Decoder |
|  | Programmable Bit Rate Generator |
|  | Parallel Interface Element |
|  | 12 Bit High Performance Microprocessor |
|  | I/O Controller |
|  | LSI Universal Asynchronous Receiver Transmitter |
|  | Programmable Asynchronous Communication Interface |
|  | Asynchronous Manchester Adapter |
|  | Manchester Encoder-Decoder |
|  | Hex Latching Bus Driver |
|  | Hex Bi -directional Bus Driver |
|  | Quad Bus Separator/Driver |
|  | Octal Resettable Latch |
|  | Octal Bus Buffer/Driver |
|  | Latch Decoder/Driver |
|  | Hex Bus Driver |
|  | 12 Bit Static Microprocessor |
|  | 4K X 1 Synchronous RAM |
|  | $1 \mathrm{~K} \times 1$ Synchronous RAM |
|  | $1 \mathrm{~K} \times 4$ Synchronous RAM |
|  | 2K X 8 Synchronous RAM |
|  | 2K X 8 Asynchronous RAM |
|  | 2K X 8 Asynchronous RAM |
|  | 1K X 1 Synchronous RAM |
|  | 16K X 1 Asynchronous RAM |
|  | $256 \times 4$ Synchronous RAM |
|  | $256 \times 4$ Synchronous RAM |
|  | 64K Synchronous RAM Module |
|  | $2 \mathrm{~K} \times 8$ Fuse Link PROM |
|  | $512 \times 8$ PROM |
|  | 8K X 8 Fuse Link PROM |
|  | 256K Synchronous RAM Module |
|  | 256K Synchronous RAM Module |
|  | Programmable Logic |
|  | Programmable Logic |
|  | Programmable Logic |
|  | Programmable Logic |
|  | 16 Bit Microprocessor |
|  | 8 Bit Microprocessor |
|  | High Performance Programmable DMA Controller |
|  | Full Duplex UART |
|  | Programmable Interval Timer |
|  | Programmable Peripheral Interface |
|  | Priority Interrupt Controller |
|  | Octal Latch |
|  | Octal Latching Inverting Bus Driver |
|  | Clock Generator/Driver |
|  | Clock Generator Driver |
|  | Octal Bus Transceiver |
|  | Octal Bus Transceiver |
|  | Bus Controller |
|  | Bus Arbiter |

Manchester Encoder-Decoder Manchester Encoder-Decoder Programmable Bit Rate Generator Parallel Interface Element 12 Bit High Performance Microprocessor I/O Controller
LSI Universal Asynchronous Receiver Transmitter Programmable Asynchronous Communication Interface Asynchronous Manchester Adapter

Hex Latching Bus Driver
Hex Bi -directional Bus Driver
Quad Bus Separator/Driver
Octal Resettable Latch
Octal Bus Buffer/Driver
atch Decoder/Driver

12 Bit Static Microprocessor
4K X 1 Synchronous RAM
1K X 4 Synchronous RAM
2K X 8 Synchronous RAM
2K X 8 Asynchronous RAM
2K X 8 Asynchronous RAM
1K X 1 Synchronous RAM
16K X 1 Asynchronous RAM
X 4 Synchronous RAM

64K Synchronous RAM Module
2K X 8 Fuse Link PROM
X 8 PROM

256K Synchronous RAM Module
256K Synchronous RAM Module
Programmable Logic
Programmable Logic
Programmable Logic
16 Bit Microprocessor
8 Bit Microprocessor
High Performance Programmable DMA Controller
Full Duplex UART
Programmable Interval Timer
Priority Interrupt Controller
Octal Latch
Octal Latching Inverting Bus Driver
Clock Generator/Driver
Clock Generator Driver
Octal Bus Transceiver
Bus Controller
Bus Arbiter

## Harris Sales Locations

## OEM Sales

## EASTERN REGION

Suite 215
3890 West Commercial Blvd.
Ft. Lauderdale, FL 33309
(305) 739-0016

Suite 400
875 Johnson Ferry Road Atlanta, GA 30342
(404) 256-4000

Suite 308
1 Burlington Woods Drive
Burlington, MA 01803
(617) 273-5942
P. O. Box 31747

Raleigh, NC 27622
Suite 1101
996 Old Eagle School Road Wayne, PA 19087
(215) 687-6680

Suite 273
555 Broadhollow Road
Melville, L. I., NY 11747
(516) 249-4500

CENTRAL REGION
Suite 300
6400 Shafer Court Rosemont, IL 60018 (312) 692-4960

Suite 101
1717 East 116th Street
Carmel, IN 46032
(317) 844-8011

Suite 703
2850 Metro Drive
Minneapolis, MN 55420
(612) 854-3558

## Suite 110

17120 Dallas Parkway
Dallas, TX 75248
(214) 248-3237

## WESTERN REGION

Suite 250
1717 E Morten Avenue
Phoenix, AZ 85020
(602) 870-0080

Suite 320
1503 South Coast Drive Costa Mesa, CA 92626 (714) 540-2176

Suite B120
883 Stierlin Road
Mt. View, CA 94043
(415) 964-6443

Suite 205
6400 Canoga Avenue
Woodland Hills, CA 91367
(213) 992-0686

33919 9th Avenue South
Federal Way, WA 98003
(206) 838-4878

Suite 8
2005 Broadway
Vancouver, WA 98663
(206) 696-0043

International Sales
Europe

## HEADQUARTERS

Harris-MHS GMBH
Headquarters
Erfurterstrasse 29
8057 Eching
West Germany
TEL: 49-89-319-1035
TWX: 5-213-866
SALES OFFICES
ENGLAND
Harris Systems Ltd.
Harris Semiconductor Div.
153 Farnham Road
Slough SL1 4XD
Tel: 44-753-34666
TWX: 848174
ITALY
Harris Italiana, Inc.
20092 Cinisello Balsamo (Milano)
Via Fratelli Cracchi 48
Tel 39-2-6187249/6188282
TWX: 311164 Agerisi
WEST GERMANY
Harris-Matra Semiconductors
Deutschland GmbH
Erfurterstrasse 29
8057 Eching
Tel: 49-89-319-1035
TWX: 5-213-866

Harris-Matra-Harris GMBH
Walsroderstrasse 71
D-3012 Langenhagen 1
Tel: 49-511-737037
TWX: 9230474 HM HH D

## EUROPEAN DISTRIBUTORS

## AUSTRIA

Transistor Vetriebsgesellschaft
$\mathrm{mbH} \& \mathrm{Co} . \mathrm{KG}$.
Auhofstr. 41A
A-1130 Wien
Tel: 43-0222-82-94-01
TWX: 133738 TVGWN

## BELGIUM

Betea S.A
755 Chaussee de Louvain
B-1140 Brussels
Tel: 32-2-7368050
TWX 23188

## DENMARK

Ditz Schweitzer A. S.
Vallensbaekvej 41
DK-2600 Glostrup
Tel: 45-2-453044
TWX: 33257
FINLAND
Yleiselektronikka OY
Atomitie 5 B (P.O. Box 33)
SF-00370 Helsinki 37 Tel.: 358-0-90-562-1122

## FRANCE

Matra-Harris Semiconductor
Harris S. A
Harris Semi. Division
6 Av Charles de Gaulle
F-78150 Le Chesnay
Tel: 33-3-9548000
TWX: 696514
Matra Harris Semiconductor
B. P. 942

Nates Cedex
Tel: 33-40-490820
TWX: 711930

## WEST GERMANY

Alfred Neye-Enatechnik BmbH
Schillerstr. 14
Postfach 1240
D-2085 Quickborn
Tel: 49-4106-6121
TWX:213590

## Jermyn GmbH

Schulster. 84
Postfach 1180
D-6277 Camberg-Wuerges
Tel: 49-6434-231
TWX: 4884426
Kontrol Halbleiter GmbH
Breslauer Str. 2
Postfach 1251
D-8057 Eching bei Muenchen
Tel. 49-89-319011
TWX 522122

SASCO GmbH
Hermann-Oberth-Strasse 16
D-8011
Putzbrunn
Tel: 49-89-4611-1
Spoerle Electronic KG
Max-Planck-Str. 1-3
D-6072 Dreieich Bei
Frankfurt
Tel: 49-6103-30-40

## ISRAEL

MRBD Industries Ltd.
P.O. Box 1717

54 Jabotinsky street
Ramat-Gan 52117
Tel: 972-3-721-918-
722-367
TWX 352073

## ITALY

EMESA SpA
Via L-de Viadana 9
20122, Milano
Tel: 02-8690616860307
TWX 335066
Lasi Elettronica
Via Le Lombardia, 6
1-20092 Cinisello Balsamo
Tel.: 39-2-9273578
TWX: 337612

## NETHERLANDS

Techmation Electronics BV

## P.O. Box 9

NL -4175 ZG Haaften
Tel.: 31-04189-2222
TWX: 50423

NORWAY

National Elektro
Ulveneien 75
P.O. Box 53, Oekern

N-Oslo 5
Tel.: 472-64-49-70
TELEX 71265 nen
REPUBLIC OF S. AFRICA
Allied Electronic Components
P.O. Box 6090

Dunswart, 1508
Boksburg East Trasvaal
Tel.: 27-11-892-1001
TWX: 4-25559

## SPAIN

Unitronics SA
Princesa No. 1
Torre de Madrid
Planta 12 Officina 9
Madrid
Tel: 34-242-5204
TWX 22596

## SWEDEN

A. B. Betoma

Box 3005
S17103 Solna 3
Tel: 46-8-820280
TWX 19389
SWITZERLAND
W. Stolz A. G.

Taefernstr. 15
CH-5405 Baden-Daettwil
Tel: 41-56840151
TWX 54070

## UNITED KINGDOM \& IRELAND

Eltek/Elmo Semi. Ltd.
Nelson Rd., Industrial Est.
Dartmouth
Deven T06 9LA
Tel: 4-804 304455
TWX: 42516 ELSEM
HY-COMP Ltd.
7, Shield Road
Ashford Industrial Estate
Ashford, Middlesex
TW15 1AV
Tel: 44-7-842-46273
TWX: 923802

Macro Marketing Ltd.
396 Bath Road
Slough, Berks
Tel.: 44-6286 4422
TWX: 847945
Radio Resistor Co. L.td.
St. Martins Way Industrial Est.
Cambridge Road
Bedford MK 42 OLF
Tel: 44-8442/-3146
TWX: 837508

## SDP

(Semi Ltd.)
Titon House
Yord Road
Hartlepool, Cleveland
Tel.: 44-429-33721
TWX: 587650 Sempro
Thames Components
Thame Park Ind. Estate
Thame, Oxon OX9 3RS
Tel.: 44-84421-3146
TWX 837508
Phoenix Electronics Ltd.
Western Bldg.
Vere Road
Kirkmuirhill, Lankersham
ML11 9 RP, Scotland
Tel.: 44-55589-2393
TWX: 777404
Trim Electronics Ltd.
Trim
County Meath
Eire, Ireland
Tel.: 353-46-36263
TWX: 90342
Far East

## SALES OFFICES

Harris Semiconductor, Inc.
Far East Branch
Ace Shoto Bldg. 3F
1-4-7, Shoto
Shibuya-ku, Tokyo 150
Tel.: 81-3-485-1031
TWX: 326525

## FAR EAST DISTRIBUTORS

## AUSTRALIA

VSI Electronics
35-37 Dickson Avenue
Artarmon, NSW 2064
Tel.: 61-439-4655
TWX A22846

## TAIWAN

Enterprex Int'I Corp. 3900 E. Whiteside Street Los Angeles, CA 90063

Tel.: 213-267-1145
TWX 69-1159

## INDIA

Fegu Electronics
Attn: Raj Saraf
106 Mittal Chambers
Nariman Point
Bombay 400021
Fegu Incorporated
Electronics Division
2584 Wyandotte St.
Mountain View, CA 94043
Tel: 415-961-2380
TWX: 176-572
Zenith Electronics
Attn: Raj Saraf, Mgr. Director
106 Mittal Chambers
Nariman Point
Bombay

## South America

Elko S. R. L.
Av. Belgrano 1661
1093 Buenos Aires
Argentina
Tel.: 54-1-40-8971
TWX: CABINA PUBLICA N9

## hOME OFFICE

P. O. Box 883

Melbourne, FL 32901
(305) 724-7000

TWX: 510-959-6259

## SEMICONDUCTOR CMOS DIGITAL PRODUCTS DIVISION

Harris Semiconductor Spectrum of Products:

Analog<br>Bipolar Digital<br>CMOS Digital<br>Gallium Arsenide<br>Semicustom

Custom


[^0]:    CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

[^1]:    (1) All devices tested at worst case limits.
    (2) Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP; $\mathrm{VI}=\mathrm{VCC}$ or GND.
    (3) Capacitance sampled and guaranteed - not $100 \%$ tested.
    (4) Input pulse levels: 0 V to $3.0 \mathrm{~V} \quad$ Input and Output timing reference levels: 1.5 V Input rise and fall times: $5 \mathrm{~ns} \quad$ Output load: 1TTL Gate and $\overline{\mathrm{J}}=100 \mathrm{pF}$ (including scope and jig)

[^2]:    CAUTION: These devices are sensitive to electronic discharge. Proper I.C. handling procedures should be followed.

[^3]:    * CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied.

[^4]:    (1) All devices tested at worst case limits. Room temp., 5 volt data provided for information - not guaranteed.
    (2) Operating Supply Current (ICCOP) is proportional to Operating Frequency. Example: Typical ICCOP $=5 \mathrm{~mA} / \mathrm{MHz}$.
    (3) Capacitance sampled and guaranteed - not $100 \%$ tested.
    (4) AC Test Conditions: Inputs-TRISE $=$ TFALL $=20 \mathrm{nsec}$; Outputs $-\mathrm{CLOAD}=50 \mathrm{pF}$. All timing measurements at 1.5 V .

[^5]:    HPL is a trademark of Harris Corporation
    PAL is a trademark of MMI
    CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

[^6]:    * Guaranteed and sampled, but not $100 \%$ tested

[^7]:    D5,D4 - 00 designates Counter Latch Command X - don't care

    NOTE: DON'T CARE BITS (X) SHOULD BE 0 TO INSURE COMPATIBILITY WITH FUTURE PRODUCTS.

[^8]:    TEST CONDITION DEFINITION TABLE

[^9]:    CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

[^10]:    *Guaranteed and sampled, but not $100 \%$ tested

[^11]:    $\overline{\text { MRDC }}$ - Memory Read Command
    MWTC - Memory Write Command
    $\overline{\text { IORC - I I O Read Command }}$
    IOWC - I/O Write Command

[^12]:    CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

[^13]:    CAUTION: Electronic devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

[^14]:    *Reserved for future use. Always set to zero (0) to maintain future software compatibility.

[^15]:    Walter J. Niewierski is a technical marketing engineer at Harris Corp, Semiconductor cmos Digital Products Div, Melbourne, FL 32901, where he is responsible for technical support of CMOS digital products. Mr Niewierski has a BSEE from the University of Michigan.

[^16]:    This article is based on a paper presented at Midcon/81.

[^17]:    * Trademark of Harris Corporation
    ** Servicemark of Harris Corporation

[^18]:    * Epoxy ( Ag ) is the type of leadframe that is recommended. The Epoxy $(\mathrm{Au})$ is an emergency back-up when the silver type ( Ag ) is not available.
    ** This part can only be built in Cerdip at this time. Other packages will be built after the $82 C 52 R$ is redesigned.

