

## Microprocessor Products

FOR COMMERCIAL AND MILITARY DIGITAL APPLICATIONS

H HARRIS

## THE NEW HARRIS SEMICONDUCTOR

This Microprocessor Products Databook represents the full line of Harris Semiconductor microprocessor products for commercial and military applications and supersedes previously published microprocessor product databooks under the Harris, GE, RCA or Intersil names. For a complete listing of all Harris Semiconductor products, please refer to the Product Selection Guide (SPG-201R; ordering information below).

For complete, current and detailed technical specifications on any Harris devices please contact the nearest Harris sales, representative or distributor office; or direct literature requests to:

Harris Semiconductor Literature Department P.O. Box 883, MS 53-204

Melbourne, FL 32902
1-800-442-7747
FAX 407-724-7240
For Immediate Fax Service 24 Hours a Day Dial 407-724-7800


Harris AnswerFAX is Easy! Order the product information you need from your own phone and its delivered to your own fax machine!
U.S. HEADQUARTERS

Harris Semiconductor 2401 Palm Bay Road N. E. Palm Bay, Florida 32905
TEL: (407) 724-7000

SOUTH ASIA
Harris Semiconductor H.K. Ltd 13/F Fourseas Building 208-212 Nathan Road Tsimshatsui, Kowloon Hong Kong TEL: (852) 723-6339

EUROPEAN HEADQUARTERS
Harris Semiconductor
Mercure Center
100, Rue de la Fusee
1130 Brussels, Belgium
TEL: 3227242111
NORTH ASIA
Harris K.K.
Kojimachi-Nakata Bldg. 4F
5-3-5 Kojimachi
Chiyoda-ku, Tokyo 102 Japan
TEL: (81) 3-3265-7571
TEL: (81) 3-3265-7572 (Sales)


## MICROPROCESSOR PRODUCTS

Harris Semiconductor is a pioneer in developing and producing advanced CMOS microprocessor products for the most demanding commercial and military applications in this world -- and beyond. Microprocessors include the world's fastest 80C286 microprocessor at 25 MHz , along with the 80 C 86 and 80 C 88 microprocessors. These are complemented with a full line of CMOS peripherals, data communication circuits, and memory products. Additionally, the CDP1800-series microprocessor product line is available with its associated peripheral and memory devices. The heart of this series is the CDP1802A central processing unit (CPU) for use as a general-purpose computing or control element in a wide range of stored-program systems or products. Enhanced versions of the CDP1802A are available which incorporate additional on-chip features.

This databook fully describes Harris Semiconductor's line of CMOS microprocessor products. It includes a complete set of data sheets for product specifications, application notes with design details for specific applications of Harris products, and a description of the Harris quality and high reliability program.

Other Harris Semiconductor advanced digital product lines include the CDP6805 Microcontroller family and a brand new line of Digital Signal Processing (DSP) products. Both families are fully covered in their respective databooks available from the nearest Harris sales, representative, or distributor office; or from our literature department (see previous page).

[^0]General Information

Military Programs

CMOS Microprocessors

CMOS Peripherals

CMOS Data Communications

CMOS Memory

Application Notes
7

Quality and Reliability

Ordering and Packaging
9

Sales Offices

## MICROPROCESSOR PRODUCTS TECHNICAL ASSISTANCE

For technical assistance on the Harris products listed in this databook, please contact Field Applications Engineering staff available at one of the following Harris Sales Offices:

| UNITED STATES |  |  |
| :---: | :---: | :---: |
| CALIFORNIA | Costa Mesa | . 714-433-0600 |
|  | San Jose | . . 408-985-7322 |
| FLORIDA | Palm Bay . | . 407-729-4984 |
| GEORGIA | Duluth. . . | . . 404-476-2035 |
| ILLINOIS | Schaumburg. | . 708-240-3480 |
| INDIANA | Carmel | . 317-843-5180 |
| MASSACHUSETTS | Burlington. . | . 617-221-1850 |
| NEW JERSEY | Voorhees . . | . 609-751-3425 |
| NEW YORK | Hauppauge. . . . . Wappingers Falls | $\begin{aligned} & . .516-342-0291 \\ & . .914-298-1920 \end{aligned}$ |
| TEXAS | Dallas . | . . 214-733-0800 |
| INTERNATIONAL |  |  |
| FRANCE | Paris. | 33-1-346-54046 |
| GERMANY | Munich . | . . 49-89-63813-0 |
| HONG KONG | Kowloon . | . . . 852-723-6339 |
| ITALY | Milano. | . . 39-2-262-0761 |
| JAPAN | Tokyo. | 81-3-3265-7571 |
| KOREA | Seoul. | . . 82-2-551-0931 |
| SINGAPORE | Singapore. . . | . . . . 65-291-0203 |
| TAIWAN | Taipei . . . | . 886-2-716-9310 |
| UNITED KINGDOM | Camberley . . . | 44-2-766-86886 |

For literature requests, please contact Harris at 1-800-442-7747 (1-800-4HARRIS) or call Harris AnswerFAX for immediate fax service at 407-724-7800

## Misworrocessor Productis

## GENERAL INFORMATION

## ALPHA NUMERIC PRODUCT INDEX

CDP1802A, AC 8-Bit Microprocessor ..... 3-3
CDP1802BC8-Bit MicroprocessorCDP1802A/3, AC/3High-Reliability 8-Bit Microprocessor3-3
CDP1805AC 8-Bit Microprocessor ..... 3-353-27
CDP1806AC 8-Bit Microprocessor ..... 3-35
CDP1821C/3 1K x 1 Asynchronous RAM
CDP1822, C $256 \times 4$ Asynchronous RAM. ..... 6-10
CDP1822C/3 High-Reliability $256 \times 4$ Asynchronous RAM ..... 6-16
CDP1823, C $128 \times 8$ Asynchronous RAM ..... 6-21
CDP1823C/3 High-Reliabilty $128 \times 8$ Asynchronous RAM ..... 6-27
CDP1824, C $32 \times 8$ Asynchronous RAM ..... 6-32CDP1824/3, C/3
High-Reliability $32 \times 8$ Asynchronous RAM ..... 6-37
CDP1826C $64 \times 8$ Asynchronous RAM ..... 6-42
CDP1851, C Programmable I/O Interface. ..... 4-5
CDP1852, C Byte-Wide I/O Port ..... 4-17
CDP1852/3, C/3 High-Reliability Byte-Wide I/O Port ..... 4-25
CDP1853, C N-Bit 1 of 8 Decoder ..... 4-30
CDP1853/3, C/3 High-Reliability N-Bit 1 of 8 Decoder ..... 4-34
CDP1854A, AC Programmable UART ..... 5-41
CDP1854A/3, AC/3 High-Reliability Programmable UART ..... 5-58
CDP1855, C 8-Bit Programmable Multiply/Divide Unit ..... 4-38
CDP1857, C 4-Bit Bus Buffer/Separator ..... 4-51CDP1871A, AC
Keyboard Encoder ..... 4-64
CDP1872C High Speed 8-Bit Input Port ..... 4-64
CDP1874C High Speed 8-Bit Input Port ..... 4-64
CDP1875C High Speed 8-Bit Output Port. ..... 4-64
CDP1877, C Programmable Interrupt Controller (PIC) ..... 4-69
CDP1878, C Dual Counter-Timer ..... 4-78
CDP1879, C-1 Real-Time Clock ..... 4-91
CDP1881, C 6-Bit Latch and Decoder Memory Interface ..... 4-107
CDP1882, C 6-Bit Latch and Decoder Memory Interface ..... 4-107
CDP1883, C 7-Bit Latch and Decoder Memory Interface ..... 4-113
CDP6402, C ..... 5-67PAGE
ALPHA NUMERIC PRODUCT INDEX (Continued) PAGE
HD-4702 Programmable Bit Rate Generator. ..... 5-76
HD-4702/883 Programmable Bit Rate Generator ..... 5-82
HD-6402 Universal Asynchronous Receiver Transmitter (UART) ..... 5-88
HD-6402/883 Universal Asynchronous Receiver Transmitter (UART) ..... 5-95
HD-6408 Asynchronous Serial Manchester Adaptor ..... 5-101
HD-6409 Manchester Encoder-Decoder (MED) ..... 5-108
HD-6409/883 Manchester Encoder-Decoder (MED) ..... 5-121
HD-15530 Manchester Encoder-Decoder (MED) ..... 5-127
HD-15531 Manchester Encoder-Decoder (MED) ..... 5-139
HD-15531/883 Manchester Encoder-Decoder (MED) ..... 5-151
HM-6504 4K $\times 1$ Synchronous RAM ..... 6-106
HM-6504/883 4K $\times 1$ Synchronous RAM ..... 6-112
HM-6508 1K $\times 1$ Synchronous RAM ..... 6-54
HM-6508/883 1K $\times 1$ Synchronous RAM ..... 6-59
HM-6514 1K x 4 Synchronous RAM ..... 6-120
HM-6514/883 1K $\times 4$ Synchronous RAM ..... 6-126
HM-6516 2K x 8 Synchronous RAM ..... 6-138
HM-6516/883 2K x 8 Synchronous RAM ..... 6-144
HM-65162 $2 \mathrm{~K} \times 8$ Asynchronous RAM ..... 6-152
HM-65162/883 2K x 8 Asynchronous RAM ..... 6-159
HM-6518 1K $\times 1$ Synchronous RAM ..... 6-67
HM-6518/883 $1 \mathrm{~K} \times 1$ Synchronous RAM ..... 6-72
HM-65262HM-65262/88316K x 1 Asynchronous RAM6-169
16K x 1 Asynchronous RAM ..... 6-175
HM-6551HM-6551/883$256 \times 4$ Synchronous RAM6-80
$256 \times 4$ Synchronous RAM ..... 6-85
HM-6561 $256 \times 4$ Synchronous RAM ..... 6-93
HM-6561/883 $256 \times 4$ Synchronous RAM ..... 6-98
HM-6564 64K Synchronous RAM Module ..... 6-199
HM-65642 $8 \mathrm{~K} \times 8$ Asynchronous RAM ..... 6-183
HM-65642/883 8K $\times 8$ Asynchronous RAM ..... 6-190
HM-6617 $2 \mathrm{~K} \times 8$ Fuse Link PROM. ..... 6-254
HM-6617/883 $2 \mathrm{~K} \times 8$ Fuse Link PROM. ..... 6-261
HM-6642 $512 \times 8$ Fuse Link PROM ..... 6-239
HM-6642/883 $512 \times 8$ Fuse LinkPROM ..... 6-246
HM-8808, A $8 \mathrm{~K} \times 8$ Asynchronous RAM Modules ..... 6-205
HM-8816H 16K x 8 Asynchronous RAM Module ..... 6-213
HM-8832 32K x 8 Asynchronous RAM Module ..... 6-218
HM-91M2 1M-Bit Asynchronous RAM Module ..... 6-232
HM-92560 256K Synchronous RAM Module ..... 6-222
HM-92570 256K Buffered Synchronous RAM Module. ..... 6-227
HS-3182 ARINC 429 Bus Driver ..... 5-158
HS-3282 ARINC 429 Bus Interface Circuit ..... 5-163
ICL232

5-176
ALPHA NUMERIC PRODUCT INDEX (Continued) PAGE
ICM7170 Microprocessor Compatible Real-Time Clock ..... 4-118
IM6654 $512 \times 8$ UV EPROM ..... 6-268
MWS5101, A $256 \times 4$ Asynchronous RAM ..... 6-49
MWS5114 1K x 4 Asynchronous RAM ..... 6-134
80C286 Static 16-Bit Microprocessor ..... 3-50
80C286/883 Static 16-Bit Microprocessor ..... 3-106
80C86 Static 16-Bit Microprocessor ..... 3-118
80 C 88 Static 8/16-Bit Microprocessor ..... 3-150
82C237 Enhanced Programmable DMA Controller ..... 4-131
82C284 Clock Generator and Ready Interface for 80C286 Processors ..... 4-157
82C284/883 Clock Generator and Ready Interface for 80C286 Processors ..... 4-167
82C37A Programmable DMA Controller ..... 4-176
82C50A Asynchronous Communications Element ..... 5-3
82 C 52 Serial Controller Interface ..... 5-23
82C54 Programmable Interval Timer ..... 4-198
82C55A Programmable Peripheral Interface ..... 4-215
82C59A Priority Interrupt Controller ..... 4-237
82C82 Octal Latching Bus Driver ..... 4-256
82C83H Octal Latching Inverting Bus Driver ..... 4-263
82C84A Clock Generator Driver ..... 4-270
82C85 Static Clock Controller/Generator ..... 4-280
82C86H Octal Bus Transceiver ..... 4-299
82C87H Octal Inverting Bus Transceiver ..... 4-306
82C88 Bus Controller ..... 4-313
82C89 Bus Arbiter ..... 4-322
APPUCATION NOTES
App Note 108 82C52 Programmable UART ..... 7-3
App Note 109 82C59A Priority Interrupt Controller ..... 7-15
App Note 111 Harris 80C286 Performance Advantages Over the 80386. ..... 7-29
App Note 112 80C286/80386 Hardware Comparison. ..... 7-41
App Note 120 Interfacing the 80C286-16 with the 80287-10 ..... 7-45
App Note 121 Harris 80C286 Performance Advantages Over the 80386SX ..... 7-47
App Note 400 Using the HS-3282 Bus Interface Circuit ..... 7-61
App Note 6565 Design of Clock Generators for Use with COMSAC Microprocessor CDP1802 ..... 7-67
App Note 7275 User's Guide to the CDP1879 and CDP1879C1 CMOS Real-Time Clocks ..... 7-70
App Note 7374 The CDP1871A Keyboard Encoder ..... 7-88

## PRODUCT INDEX BY FAMILY

## PAGE

## CMOS MICROPROCESSOR DATASHEETS

CDP1802A, AC 8-Bit Microprocessor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-3
CDP1802BC 8-Bit Microprocessor ............................................................................... 3
CDP1802A/3, AC/3 High-Reliability 8-Bit Microprocessor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-27
CDP1805AC 8-Bit Microprocessor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-35
CDP1806AC 8-Bit Microprocessor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-35
80C286
80C286/883
Static 16-Bit Microprocessor 3-50

Static 16-Bit Microprocessor 3-106
80C86 Static 16-Bit Microprocessor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-118
80C88 Static 8/16-Bit Microprocessor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-150
App Note 111 Harris 80C286 Performance Advantages Over the 80386. . . . . . . . . . . . . . . . . . . . 7-29
App Note 112 80C286/80386 Hardware Comparison. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-41
App Note 120 Interfacing the 80C286-16 with the 80287-10 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-45
App Note 121 Harris 80C286 Performance Advantages Over the 80386SX . . . . . . . . . . . . . . . . . . 7-47
App Note 6565 Design of Clock Generators for Use with CDP1802 . . . . . . . . . . . . . . . . . . . . . . . . 7-67
CMOS PERIPHERAL DATASHEETS
CDP1851, C Programmable I/O Interface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-5
CDP1852, C Byte-Wide I/O Port . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 4-17
CDP1852/3, C/3 High-Reliability Byte-Wide I/O Port . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-25
CDP1853, C N-Bit 1 of 8 Decoder. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 4-30
CDP1853/3, C/3 High-Reliability N-Bit 1 of 8 Decoder . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-34
CDP1854A, AC Programmable UART. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
CDP1855, C 8-Bit Programmable Multiply/Divide Unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-38
CDP1857, C 4-Bit Bus Buffer/Separator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-51
CDP1871A, AC Keyboard Encoder . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
CDP1872C High Speed 8-Bit Input Port . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-64
CDP1874C High Speed 8-Bit Input Port . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-64
CDP1875C High Speed 8-Bit Output Port. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-64
CDP1877, C Programmable Interrupt Controller (PIC) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-69
CDP1878, C Dual Counter-Timer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-78
CDP1879, C-1 Real-Time Clock. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-91
CDP1881, C 6-Bit Latch and Decoder Memory Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-107
CDP1882, C 6-Bit Latch and Decoder Memory Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-107
CDP1883, C 7-Bit Latch and Decoder Memory Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-113
ICM7170 Microprocessor Compatible Real-Time Clock . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-118
82 C 237 Enhanced Programmable DMA Controller. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-131
82C284 Clock Generator and Ready Interface for 80 C 286 Processors . . . . . . . . . . . . . . . . . 4-157
82C284/883 Clock Generator and Ready Interface for 80 C 286 Processors . . . . . . . . . . . . . . . . . 4-167
82C37A Programmable DMA Controller . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-176
82C50A Asynchronous Communications Element . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-3
82C52 $\quad \therefore \quad$ Serial Controller Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
82C54 Programmable Interval Timer. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-198
82C55A Programmable Peripheral Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-215
PRODUCT INDEX BY FAMILY (Continued) PAGE
82C59A Priority Interrupt Controller ..... 4-237
82C82 Octal Latching Bus Driver ..... 4-256
82C83H Octal Latching Inverting Bus Driver ..... 4-263
82C84A Clock Generator Driver ..... 4-270
82C85 Static Clock Controller/Generator ..... 4-280
82C86H Octal Bus Transceiver ..... 4-299
82C87H Octal Inverting Bus Transceiver ..... 4-306
82C88 Bus Controller ..... 4-313
82C89 Bus Arbiter ..... 4-322
App Note 109 82C59A Priority Interrupt Controller ..... 7-15
App Note 7275 User's Guide to the CDP1879 and CDP1879C1 CMOS Real-Time Clocks ..... 7-70
App Note 7374 The CDP1871A Keyboard Encoder ..... 7-88
CMOS DATA COMMUNICATIONS DATASHEETS
82C50A Asynchronous Communications Element ..... 5-3
82C52 Serial Controller Interface ..... 5-23
CDP1854A, AC Programmable UART ..... 5-41
CDP1854A/3, AC/3 High-Reliability Programmable UART ..... 5-58
CDP6402, C Universal Asynchronous Receiver Transmitter (UART) ..... 5-67
HD-4702 Programmable Bit Rate Generator ..... 5-76
HD-4702/883 Programmable Bit Rate Generator ..... 5-82
HD-6402 Universal Asynchronous Receiver Transmitter (UART) ..... 5-88
HD-6402/883 Universal Asynchronous Receiver Transmitter (UART) ..... 5-95
HD-6408 Asynchronous Serial Manchester Adaptor ..... 5-101
HD-6409 Manchester Encoder-Decoder (MED) ..... 5-108
HD-6409/883 Manchester Encoder-Decoder (MED) ..... 5-121
HD-15530 Manchester Encoder-Decoder (MED) ..... 5-127
HD-15531 Manchester Encoder-Decoder (MED) ..... 5-139
HD-15531/883 Manchester Encoder-Decoder (MED) ..... 5-151
HS-3182 ARINC 429 Bus Driver ..... 5-158
HS-3282 ARINC 429 Bus Interface Circuit ..... 5-163
ICL232 +5V Powered Dual RS-232 Transmitter/Receiver ..... 5-176
App Note 108 82C52 Programmable UART ..... 7-3
App Note 400 Using the HS-3282 Bus Interface Circuit ..... 7-61
CMOS MEMORY DATASHEETS
S1K - ASYNCHRONOUS RAMs
CDP1821C/3 $1 \mathrm{~K} \times 1$ Asynchronous RAM ..... 6-5
CDP1822, C $256 \times 4$ Asynchronous RAM ..... 6-10
CDP1822C/3 High-Reliability $256 \times 4$ Asynchronous RAM ..... 6-16
CDP1823, C $128 \times 8$ Asynchronous RAM ..... 6-21
CDP1823C/3 High-Reliabilty $128 \times 8$ Asynchronous RAM ..... 6-27
CDP1824, C $32 \times 8$ Asynchronous RAM. ..... 6-32
CDP1824/3, C/3 High-Reliability $32 \times 8$ Asynchronous RAM ..... 6-37
CDP1826C $64 \times 8$ Asynchronous RAM. ..... 6-42
PRODUCT INDEX BY FAMILY (Continued) PAGE
MWS5101, A $256 \times 4$ Asynchronous RAM. ..... 6-49
1K - SYNCHRONOUS RAMs
HM-6508 1K $\times 1$ Synchronous RAM ..... 6-54
HM-6508/883 $1 \mathrm{~K} \times 1$ Synchronous RAM ..... 6-59
HM-6518 1K x 1 Synchronous RAM ..... 6-67
HM-6518/883 1K x 1 Synchronous RAM ..... 6-72
HM-6551 $256 \times 4$ Synchronous RAM ..... 6-80
HM-6551/883 $256 \times 4$ Synchronous RAM ..... 6-85
HM-6561 $256 \times 4$ Synchronous RAM ..... 6-93
HM-6561/883 $256 \times 4$ Synchronous RAM ..... 6-98
4K - SYNCHRONOUS RAMs
HM-6504 4K $\times 1$ Synchronous RAM ..... 6-106
HM-6504/883 $4 K \times 1$ Synchronous RAM ..... 6-112
HM-6514 1K x 4 Synchronous RAM ..... 6-120
HM-6514/883 1K x 4 Synchronous RAM ..... 6-126
4K - ASYNCHRONOUS RAM
MWS5114 1K x 4 Asynchronous RAM ..... 6-134
16K - SYNCHRONOUS RAM
HM-6516 $2 \mathrm{~K} \times 8$ Synchronous RAM ..... 6-138
HM-6516/883 2K x 8 Synchronous RAM ..... 6-144
16K - ASYNCHRONOUS RAMs
HM-65162 2K x 8 Asynchronous RAM ..... 6-152
HM-65162/883 2K x 8 Asynchronous RAM ..... 6-159
HM-65262 16K x 1 Asynchronous RAM ..... 6-169
HM-65262/883 16K $\times 1$ Asynchronous RAM ..... 6-175
64K - ASYNCHRONOUS RAM
HM-65642 $8 \mathrm{~K} \times 8$ Asynchronous RAM ..... 6-183
HM-65642/883 $8 \mathrm{~K} \times 8$ Asynchronous RAM ..... 6-190
CMOS RAM MODULES
HM-6564 64K Synchronous RAM Module ..... 6-199
HM-8808, A 8K x 8 Asynchronous RAM Modules ..... 6-205
HM-8816H 16K $\times 8$ Asynchronous RAM Module ..... 6-213
HM-8832 $32 \mathrm{~K} \times 8$ Asynchronous RAM Module ..... 6-218
HM-92560 256K Synchronous RAM Module ..... 6-222
HM-92570 256K Buffered Synchronous RAM Module. ..... 6-227
HM-91M2 1M-Bit Asynchronous RAM Module ..... 6-232
CMOS PROMs
HM-6642 $512 \times 8$ Fuse Link PROM ..... 6-239
HM-6642/883 $512 \times 8$ Fuse LinkPROM ..... 6-246
HM-6617 $2 \mathrm{~K} \times 8$ Fuse Link PROM. ..... 6-254
HM-6617/883 $2 \mathrm{~K} \times 8$ Fuse Link PROM ..... 6-261
IM6654 $512 \times 8$ UV EPROM ..... 6-268

## MILITARY PROGRAMS

PAGE
MILITARY GRADE PRODUCT OFFERINGS ..... 2-3
MILITARY GRADES AVAILABLE ..... 2-4
HARRIS JAN-SMD-/883 PART NUMBER LISTING ..... 2-6
MILITARY PRODUCT PROGRAM CONTROLS ..... 2-10
PROGRAMS SERVED BY HARRIS ..... 2-11

## Military Grade Product Offerings

Harris High Reliability Products are offered in the following Military grades:

## - JAN (Joint Army Navy)

Registered trademark of the U.S. Government indicating that a device is fully compliant to MIL-M-38510. The Defense Electronics Supply Center (DESC) maintains a continuing audit of manufactur-ing compliance. There are two product assurance classes available for M38510 products (Class S and B ). Devices are defined and identified by their particular detail specification or "slash sheet" number issued by DESC (e.g. M38510/29104BJX). The IC manufacturers who are qualified to supply products to a particular M38510 slash sheet are identified in the Qualified Products List (QPL) issued by DESC.

## - SMD (Standard Military Drawing)

The SMD evolved from the DESC drawing program which was viewed as a preliminary specification prior to JAN approval. SMDs were created to control the proliferation of non-standard Source Control Drawings. The Standard Military Drawing provides standardized MIL-STD-883 processing in conjunction with non-JAN devices as specified in paragraph 1.2.1 of MIL-STD-883. These devices are defined and identified by their Standard Military Drawing number issued by DESC (eg. 5962-8757701RA). The manufacturers qualified to supply a particular SMD device are listed in the back of the individual Standard Military Drawing.

## - Harris Class B Compliant

These devices are fully compliant to MIL-STD-883, Class B and are identified by the /883 suffix on the Harris part number. The parametric limits for an /883 data sheet are controlled by the manufacturer rather than a governmental agency, and therefore, there may be differences in the test methodology and actual limits for "similar" devices made by different manufacturers.

This manufacturer control of the /883 specifications allows the offering of 883 -level products long before they might become available as MIL-M-38510 or SMD devices. In many cases, Harris actually specifies /883 devices with more
stringent conditions than those appearing on the MIL-M38510 slash sheet or SMD describing the same generic device. Harris recommends using our /883 data sheets as the baseline for new military or aerospace source control drawings.

## - Harris Class B "Equivalent"

These devices are processed and tested in a manner equivalent to the MIL-STD-883 compliant devices. They may not be classified as compliant since government standards have not been established for processing these types of components (e.g. Ram Modules). The Class B "Equivalent" products can be identified by the $-8, / B$, or $/ 3$ suffix on the Harris part number.

## Non-Standard Product Offerings

Harris understands the need for customer generated Source Control Drawings with non-standard parameter and/or screening requirements. A Customer Engineering Department is responsible for efficiently expediting the SCDs through a comprehensive review process. Our Customer Engineering Group compares the SCD to its closest equivalent product grade and works closely with the Product Engineer, Manufacturing Engineer, Design Engineer, or applicable individual to compare Harris' screening ability against the customer's non-standard requirement(s). For products processed to non-standard requirements, a unique part number suffix is assigned.

Harris shares the military's objective to utilize standards wherever possible. We recommend using our /883 data sheets as guidelines for generating new Source Control Drawings. In instances where an available military specification or Harris /883 data sheet is inappropriate, it is Harris' sincerest wish to work closely with the customer in establishing an acceptable procurement document. For this reason, the customer is requested to contact the nearest Harris Sales Office or Representative before finalizing the Source Control Drawing. Harris looks forward to working with the customer prior to implementation of the formal drawing so that both parties may create a mutually acceptable procurement document.

Military Grades Available

| PRODUCT | JAN | $\begin{aligned} & \text { SMD/ } \\ & \text { DESC } \end{aligned}$ | 1883 | /8,-8,/3 | PRODUCT | JAN | $\begin{aligned} & \text { SMD/ } \\ & \text { DESC } \end{aligned}$ | 1883 | /8,-8,/3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MICROPROCESSORS |  |  |  |  | PERAPHERALS (Continued) |  |  |  |  |
| CDP1802A |  |  |  | X | MR82C54-10 |  | pending |  | X |
| CDP1802AC |  |  |  | X | MD82C55A |  | X |  | X |
| MG80C286-10 |  | pending | X |  | MR82C55A |  | X |  | X |
| MG80C286-12 |  | pending | X |  | MD82C55A-5 |  | X |  | X |
| MD80C86 |  | X |  | X | MR82C55A-5 |  | X |  | X |
| MR80C86 |  | X |  | X | MD82C59A |  | X |  | X |
| MD80C86-2 |  | X |  | X | MR82C59A |  | X |  | X |
| MR80C86-2 |  | X |  | X | MD82C59A-5 |  | X |  | X |
| MD80C88 |  | X |  | X | MR82C59A-5 |  | X |  | X |
| MR80C88 |  | X |  | X | MD82C59A-12 |  | pending |  | X |
| MD80C88-2 |  |  |  | X | MR82C59A-12 |  | pending |  | X |
| MR80C88-2 |  |  |  | X | MD82C82 |  | X |  | X |
| PERIPHERALS |  |  |  |  | MR82C82 |  | X |  | X |
| CDP1852 |  |  |  | X | MD82C83H |  | X |  | X |
| CDP1852C |  |  |  | X | MR82C83H |  | X |  | X |
| CDP1853 |  |  |  | X | MD82C84A |  | X |  | X |
| CDP1853C |  |  |  | X | MR82C84A |  | X |  | X |
| CDP1854A |  |  |  | X | MD82C85 |  |  |  | X |
| CDP1854AC |  |  |  | X | MR82C85 |  |  |  | X |
| CDP1857 |  |  |  | X | MD82C86H-5 |  | X |  | X |
| CDP1857C |  |  |  | X | MR82C86H-5 |  | X |  | X |
| MD82C237 |  | pending |  | X | MD82C87H-5 |  | X |  | X |
| MR82C237 |  | pending |  | X | MR82C87H-5 |  | X |  | X |
| MD82C237-12 |  | pending |  | X | MD82C88 |  | X |  | X |
| MR82C237-12 |  | pending |  | X | MR82C88 |  | X |  | X |
| MD82C284-10 |  |  | X |  | MD82C89 |  | X |  | X |
| MD82C284-12 |  |  | X |  | MR82C89 |  | X |  | X |
| MD82C37A |  | pending |  | X | DATA COMMUNICATIONS |  |  |  |  |
| MR82C37A |  | pending |  | X | CDP1854A |  |  |  | X |
| MD82C37A-12 |  | pending |  | X | CDP1854AC |  |  |  | X |
| MR82C37A-12 |  | pending |  | X | HD1-15530 |  | X |  | X |
| MD82C37A-5 |  | pending |  | X | HD4-15530 |  | X |  | X |
| MR82C37A-5 |  | pending |  | X | HD1-15531 |  | pending | X | X |
| MD82C50A-5 |  |  |  | X | HD1-15531B |  | pending | X | X |
| MD82C52 |  | X |  | X | HD1-4702 |  | pending | X |  |
| MR82C52 |  | X |  | X | HD4-4702 |  |  |  | X |
| MD82C54 |  | X |  | X | HD1-6402R |  | X | X |  |
| MR82C54 |  | X |  | X | HD1-6402B |  | X | X |  |
| MD82C54-10 |  | pending |  | X | HD1-6409 |  |  | X |  |

## Military Grades Available

| PRODUCT | JAN | $\begin{aligned} & \text { SMD/ } \\ & \text { DESC } \end{aligned}$ | 1883 | /B,-8,/3 | PRODUCT | JAN | $\begin{aligned} & \hline \text { SMD/ } \\ & \text { DESC } \end{aligned}$ | 1883 | /B,-8,/3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA COMMUNHCATIONS (Continued) |  |  |  |  | CMOS RAMs (Continued) |  |  |  |  |
| HD4-6409 |  |  | X |  | HM1-6551B |  |  |  | X |
| HS1-3182 |  | pending |  | X | HM1-6561 |  |  |  | X |
| HS4-3182 |  | pending |  | X | HM1-6561B |  |  |  | X |
| HS1-3282 |  | X |  | X | HM1-65642 |  |  | X | X |
| HS4-3282 |  | X |  | X | HM4-65642 |  |  | X | X |
| MD82C50A-5 |  |  |  | X | HM1-65642B | X |  | X |  |
| MD82C52 |  | X |  | $x$ | HM4-65642B | X |  | X |  |
| MR82C52 |  | X |  | X | HM1-65642C |  |  | X |  |
| CMOS RAMs |  |  |  |  | HM4-65642C |  |  | X |  |
| CDP1821C |  |  |  | X | CMOS PROMS |  |  |  |  |
| CDP1822C |  |  |  | X | HM1-6617 |  | X | X |  |
| CDP1823C |  |  |  | X | HM6-6617 |  | X | X |  |
| CDP1824 |  |  |  | X | HM4-6617 |  | X | X |  |
| CDP1824C |  |  |  | X | HM1-6617B |  | X | X |  |
| HM1-6504 |  | X | X |  | HM6-6617B |  | X | X |  |
| HM1-6504B |  | X | X |  | HM4-6617B |  | X | X |  |
| HM1-6504S | X | X | X |  | HM1-6642 |  | X | X |  |
| HM1-6508 |  |  | X |  | HM6-6642 |  | X | X |  |
| HM1-6508B |  |  | X |  | HM4-6642 |  | X | X |  |
| HM1-6514 |  | x | X |  | HM1-6642B |  | X | X |  |
| HM1-6514B |  | X | X |  | HM6-6642B |  | X | X |  |
| HM1-6514S | X | X | X |  | HM4-6642B |  | X | X |  |
| HM1-6516 | X | X | X |  | CMOS RAM MODULES |  |  |  |  |
| HM4-6516 | X | X | X |  | HM5-6564 |  |  |  | X |
| HM1-6516B |  | X | X |  | HM5-8808 |  |  |  | X |
| HM4-6516B |  | X | X |  | HM5-8808B |  |  |  | X |
| HM1-65162 | X | X | X |  | HM5-8808S |  |  |  | X |
| HM4-65162 | X | X | X |  | HM5-8808A |  |  |  | X |
| HM1-65162B | X | X | X |  | HM5-8808AB |  |  |  | $x$ |
| HM4-65162B | X | X | X |  | HM5-8808AS |  |  |  | X |
| HM1-65162C |  | X | X |  | HM5-8816H |  |  |  | X |
| HM4-65162C |  | X | X |  | HM5-8816HB |  |  |  | X |
| HM1-6518 |  |  | X |  | HM5-8832 |  |  |  | X |
| HM1-6518B |  |  | X |  | HM5-8832B |  |  |  | X |
| HM1-65262 | X | X | X |  | HM5-91M2 |  |  |  | X |
| HM4-65262 | X | X | X |  | HM5-91M2B |  |  |  | X |
| HM1-65262B | X | X | X |  | HM5-92560 |  |  |  | X |
| HM4-65262B | X | X | X |  | HM5-92570 |  |  |  | X |

Harris JAN-SMD-/883 Part Number Listing

| HARRIS PART * | JAN PART * | SMD/DESC PART* | 1883 PART * |
| :---: | :---: | :---: | :---: |
| MICROPROCESSOR PRODUCTS |  |  |  |
| MG80C286-12 |  | Pending | MG80C286-12/883 |
| MG80C286-10 |  | Pending | MG80C286-10/883 |
| MD80C86 |  | 8405201QA |  |
| MR80C86 |  | 8405201XA |  |
| MD80C86-2 |  | 8405202QA |  |
| MR80C86-2 |  | 8405202XA |  |
| MD80C88 |  | 5962-8601601QA |  |
| MR80C88 |  | 5962-8601601XA |  |
| MD82C237 |  | Pending |  |
| MR82C237 |  | Pending |  |
| MD82C237-12 |  | Pending |  |
| MR82C237-12 |  | Pending |  |
| MD82C284-10 |  |  | MD82C284-10/883 |
| MD82C284-12 |  |  | MD82C284-12/883 |
| MD82C37A |  | Pending |  |
| MR82C37A |  | Pending |  |
| MD82C37A-12 |  | Pending |  |
| MR82C37A-12 |  | Pending |  |
| MD82C37A-5 |  | Pending |  |
| MR82C37A-5 |  | Pending |  |
| MD82C52 |  | 8501501XA |  |
| MR82C52 |  | 85015013A |  |
| MD82C54 |  | 8406501 JA |  |
| MR82C54 |  | 84065013A |  |
| MD82C55A |  | 8406602QA |  |
| MR82C55A |  | 8406602XA |  |
| MD82C55A-5 |  | 8406601QA |  |
| MR82C55A-5 |  | 8406601XA |  |
| MD82C59A |  | 5962-8501602YA |  |
| MR82C59A |  | 5962-85016023A |  |
| MD82C59A-5 |  | 5962-8501601YA |  |
| MR82C59A-5 |  | 5962-85016013A |  |
| MD82C82 |  | 8406701RA |  |
| MR82C82 |  | 84067012A |  |
| MD82C83H |  | 8406702RA |  |
| MR82C83H |  | 84067022A |  |
| MD82C84A |  | 8406801VA |  |

Harris JAN－SMD－／883 Part Number Listing

| HARRIS PART＊ | JAN PART＊ | SMD／DESC PART＊ | 1883 PART＊ |
| :---: | :---: | :---: | :---: |
| MICROPROCESSOR PRODUCTS（Continued） |  |  |  |
| MR82C84A |  | 84068012A |  |
| MD82C86H－5 |  | 5962－8757701RA |  |
| MR82C86H－5 |  | 5962－87577012A |  |
| MD82C87H－5 |  | 5962－8757702RA |  |
| MR82C87H－5 |  | 5962－87577022A |  |
| MD82C88 |  | 8406901RA |  |
| MR82C88 |  | 84069012A |  |
| MD82C89 |  | 5962－8552801RA |  |
| MR82C89 |  | 5962－85528012A |  |
| DATA COMMUNICATION PRODUCTS |  |  |  |
| HD1－15530 |  | 7802901JA |  |
| HD4－15530 |  | 78029013A |  |
| HD1－15531 |  |  | HD1－15531／883 |
| HD1－15531B |  |  | HD1－15531B／883 |
| HD1－4702 |  | Pending | HD1－4702／883 |
| HD1－6402B |  | 5962－9052502MQA | HD1－6402B／883 |
| HD1－6402R |  | 5962－9052501MQA | HD1－6402R／883 |
| HD1－6409 |  |  | HD1－6409／883 |
| HD4－6409 |  |  | HD4－6409／883 |
| HS1－3182 |  | Pending |  |
| HS4－3182 |  | Pending |  |
| HS1－3282 |  | 5962－8688001QA |  |
| HS4－3282 |  | 5962－8688001XA |  |
| CMOS MEMORY PRODUCTS |  |  |  |
| 1 K CMOS STATIC RAMS |  |  |  |
| HM1－6508 |  |  | HM1－6508／883 |
| HM1－6508B |  |  | HM1－6508B／883 |
| HM1－6518 |  |  | HM1－6518／883 |
| HM1－6518B |  |  | HM1－6518B／883 |
| HM1－6551 |  |  | HM1－6551／883 |
| HM1－6551B |  |  | HM1－6551B／883 |
| HM1－6561 |  |  | HM1－6561／883 |
| HM1－6561B |  |  | HM1－6561B／883 |
| 4 K CMOS STATIC RAMs |  |  |  |
| HM1－6504 |  | 8102405 VA | HM1－6504／883 |
| HM1－6504B |  | 8102403VA | HM1－6504B／883 |
| HM1－6504S | M38510／24501BVA | 8102401VA | HM1－6504S／883 |



| HARRIS PART * | JAN PART \# | SMD/DESC PART * | 1883 PART |
| :---: | :---: | :---: | :---: |
| CMOS STATIC RAM MODULES |  |  |  |
| HM5-6564 | Harris CMOS Static RAM Modules are available for military and high reliability applications processed to our high-rel DASH 8 program flow. This includes burn-in and value added processing (temperature cycling, SEM inspection, etc.). Please contact your local Harris sales office or representative for details |  |  |
| HM5-8808 |  |  |  |
| HM5-8808B |  |  |  |
| HM5-8808S |  |  |  |
| HM5-8808A |  |  |  |
| HM5-8808AB |  |  |  |
| HM5-8808AS |  |  |  |
| HM5-8816H |  |  |  |
| HM5-8816HB |  |  |  |
| HM5-8832 |  |  |  |
| HM5-8832B |  |  |  |
| HM5-91M2 |  |  |  |
| HM5-91M2B |  |  |  |
| HM5-92560 |  |  |  |
| HM5-92570 |  |  |  |

## Military Product Program Controls

| REQUIREMENT | $\begin{gathered} 1883 \\ \text { REFERENCE } \end{gathered}$ | JAN | DESC/SMD | 1883 | /B,-8, $/ 3$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYSTEM CONTROLS |  |  |  |  |  |
| Product Assurance Plan | 1.2.1.B. 21 | Per Appendix A of MIL M38510 |  |  | Per Harris R\&QA Manual |
| Facility Certification | 1.2.1.B. 28 | RADC/DESC | Harris QC | Harris QC | Harris QC |
| Product Certification | 1.2.1.B. 26 | RADC/DESC | RADC/DESC | Harris QA | Not Required |
| Detail Specifications | 1.2.1.A | Slash Sheet | DESC DWG/SMD | Harris /883 Data Sheet | Harris Catalog |
| Qualifying Activity | 1.2.1.B.1 | RADC/DESC | Harris | Harris | Harris |
| Qualification Test GPC | 1.2.1.B.17 | Required | Per Governing Military Spec | Per Governing Military Spec | Per Harris Spec |
| Qualification Test GPD | 1.2.1.B.17 | Required | Per Governing Military Spec | Per Governing Military Spec | Per Harris Spec |
| QPL Listing |  | MIL M38510 | None | None | None |
| Change Controls | 1.2.1.B. 25 | MIL M38510 paragraph 3.4.2 | DoD 480 | DoD 480 | Harris Internal ECN Controls |
| Change Notification | 1.2.1.B. 25 | DESC | DESC | Data Sheet Registration | Catalog |
| Traceability | 1.2.1.B.27 | Wafer Lot | 6 Week Seal | 6 Week Seal | 6 Week Seal |
| Deviations to 883 | 1.2.1 | Per Slash Sheet | Per DESC DWG/ SMD | None | Per Harris Spec |
| Product Construction | 1.2.1.B.2-12 | Compliant | Compliant | Compliant | May Be NonCompliant |
| LOCATIONS |  |  |  |  |  |
| Fab |  | USA Only | USA | USA | USA |
| Assembly |  | USA Only | USAMMalaysia | USAMMalaysia | Malaysia |
| Screening |  | USA Only | USAMMalaysia | USAMMalaysia | Malaysia |
| Quality Conformance |  | USA Only | USA | USA | Malaysia |

NOTE: -8 is available in support of programs with part requirements dated prior to Dec. 31, 1984 in accordance with paragraph 1.2. of MIL-STD-883 or where 883 is not currently available.

## Programs Served By Harris

| Tube-Launched, Optically Tracked, Wire-Guided Missile | Field Support Tracked Vehicle |
| :---: | :---: |
| Angle Rate Bombing Set | Integrated Solar Sensor Assembly |
| Advanced Medium Range Air-To-Air Missile | Continuous Motion Gyro for ISSA |
| Advanced Capability (MK-48 Torpedo) | Advanced Warning and Control System |
| Position Location and Reporting System | Forward Looking Infrared |
| Joint Tactical Information Distribution System | Ring Laser Gyro Programs |
| Target Acquisition System (MK-23) | Tail Warning System |
| Miniature Vehicle Sensors | Space Telescope |
| Driver's Thermal Viewer | Mariner Series |
| Detecting and Ranging Set | MK 46 NEARTIP |
| Fighting Vehicle System (Bradley) | AV8B HARRIER |
| Helicopter (or Hughes) Night Vision System | F14/A6E SMS |
| Advanced Optic Adjunct | Bearclaw |
| Advanced Light Weight Torpedo | CAINS II |
| Ground Launched Cruise Missile | TAI/MK6 |
| Air Launched Cruise Missile | B1 |
| Medium Range Air-To-Surface Missile | F-16 |
| Modular Universal Laser Equipment | Phalanx |
| Low Altitude Navigation and Targeting Infrared | Stinger |
| Anti-Submarine Warfare | Locust |
| Multiple Launch Rocket System | Sidearm |
| Advanced Self Protection Jammer | Rattler |
| Global Positioning System | Pavetack |
| Distant Early Warning | Viking |
| High Speed Anti-Radar Missile | Skylab |
| Rolling Airframe Missile | Shuttle |
| Medium Depth Mine | Intelsat |
| Terminal Guidance Small Missile | Spacelab |
| Time Division Multiple Access | Voyager |
| Distributed Time Division Multiple Access | Mark 50 |
| Long Range Search and Track | Captor |
| Glide Bomb Unit | Maverick |
| Divisional Air Defense | Phoenix |

PAGE
COMPARISON OF HARRIS CDP1800-SERIES MICROPROCESSORS ..... 3-2
INDUSTRY CMOS MICROPROCESSOR CROSS REFERENCE ..... 3-2
CMOS MICROPROCESSOR DATASHEETS
CDP1802A, AC 8-Bit Microprocessor ..... 3-3
CDP1802BC 8-Bit Microprocessor ..... 3-3
CDP1802A/3, AC/3 High-Reliability 8-Bit Microprocessor ..... 3-27
CDP1805AC 8-Bit Microprocessor ..... 3-35
CDP1806AC 8-Bit Microprocessor ..... 3-35
80C286 Static 16-Bit Microprocessor ..... 3-50
80C286/883 Static 16-Bit Microprocessor ..... 3-106
80C86 Static 16-Bit Microprocessor ..... 3-118
80 C 88 Static 8/16-Bit Microprocessor ..... 3-150
RELATED APPLICATION NOTES
App Note 111 Harris 80C286 Performance Advantages Over the 80386 ..... 7-29
App Note 112 80C286/80386 Hardware Comparison ..... 7-41
App Note 120 Interfacing the 80C286-16 with the 80287-10 ..... 7-45
App Note 121 Harris 80C286 Performance Advantages Over the 80386SX ..... 7-47
App Note 6565 Design of Clock Generators for Use with CDP1802. ..... 7-67

## CMOS Microprocessor Products

Comparison of Harris CMOS CDP1800-Series Microprocessors

| FEATURES | $\begin{aligned} & \text { CDP1802A } \\ & \text { CDP1802AC } \end{aligned}$ | CDP1802BC | CDP1805AC | CDP1806AC |
| :---: | :---: | :---: | :---: | :---: |
| Memory Addressing (Bytes) | 64K | 64K | 64K | 64K |
| On-Chip RAM (Bytes) | - | - | 64K | - |
| Maximum Clock Frequency ( MHz ) | 3.2 | 5 | 5 | 5 |
| Instruction Time Min./Max. ( $\mu \mathrm{s}$ ) | 5/7.5 | 3.2/4.8 | 3.2/16 | 3.2/16 |
| Timer/Counter Bits | - | $\bullet$ | 8 | 8 |
| Prescalers | - | - | + 32 | + 32 |
| Bus Structure | Multiplexed Address Lines |  |  |  |
| Interrupts | Yes | Yes | Yes | Yes |
| Latched I/O Lines | Off-Chip |  |  |  |
| Maximum Operating Temperature Range ( ${ }^{\circ} \mathrm{C}$ ) | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |  |  |
| Number of Pins, Package | $\begin{gathered} 40 \mathrm{D}, \mathrm{E} \\ 44 \mathrm{Q} \end{gathered}$ | $\begin{gathered} 40 \mathrm{D}, \mathrm{E} \\ 44 \mathrm{Q} \end{gathered}$ | $\begin{gathered} 40 \mathrm{D}, \mathrm{E} \\ 44 \mathrm{Q} \end{gathered}$ | $\begin{gathered} 40 \mathrm{D}, \mathrm{E} \\ 44 \mathrm{Q} \end{gathered}$ |
| Serial Interface | Q-Line |  |  |  |

## Industry CMOS Microprocessor Cross Reference

| HARRIS | WTEL | NEC | OKI | AMD |
| :---: | :---: | :---: | :---: | :---: |
| 8-BIT MICROPROCESSOR |  |  |  |  |
| 80C88 | $80 C 88$ | $\mu \mathrm{PD} 70108 \mathrm{D}-5$ |  | - |
| 80C88-2 | 80088-2 | $\mu \mathrm{PD} 70108 \mathrm{D}-8$ | MSM80C88A-2 | - |
| 16-BIT MICROPROCESSOR |  |  |  |  |
| 80C86 | $80 C 86$ | $\mu \mathrm{PD} 70116 \mathrm{D}-5$ | MSM80C86A | $\bullet$ |
| 80C86-2 | 80C86-2 | $\mu \mathrm{PD} 70116 \mathrm{D}-8$ | MSM80C86A-2 | $\bullet$ |
| 80C286-10 | $\begin{aligned} & 80286-10 \\ & 80 C 286-10 \end{aligned}$ | - | * | 80286-10 |
| 80C286-12 | $\begin{aligned} & 80286-12 \\ & 80 C 286-12 \end{aligned}$ | - | " | 80286-12 |
| 80C286-16 | * | $\bullet$ | - | 80286-16 |

## Features

- Input Clock Maximum Frequency Options:

|  | Maximum $\Theta$ <br>  <br> $V_{D D}=5 \mathrm{~V}$ | $V_{\mathrm{DD}}=10 \mathrm{~V}$ |
| :--- | :--- | :--- |
| CDP1802A, AC | 3.2 MHz | 6.4 MHz |
| CDP1802BC | 5.0 MHz |  |

- Minimum Instruction Fetch-Execute Times (© $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ ):

> CDP1802A, AC . . . . . . . . . . . . . . . . . . . . . $5.0 \mu \mathrm{~s}$ CDP1802BC. . . . . . . . . . . . . . . 3.2 s

- Any Combination of Standard RAM and ROM Up to 65,536 Byte
- 8-bit Parallel Organization With Bidirectional Data Bus and Multiplexed Address Bus
- $16 \times 16$ Matrix of Registers for Use as Multiple Program Counters, Data Pointers, or Data Registers
- On-Chip DMA, Interrupt, and Flag Inputs
- Programmable Single-Bit Output Port
- 91 Easy-to-Use Instructions


## Description

The CDP1802 family of CMOS microprocessors are 8-bit register oriented central processing units (CPUs) designed for use as general purpose computing or control elements in a wide range of stored program systems or products.
The CDP1802 types include all of the circuits required for fetching, interpreting, and executing instructions which have been stored in standard types of memories. Extensive input/ output (I/O) control features are also provided to facilitate system design.
The 1800 series architecture is designed with emphasis on the total microcomputer system as an integral entity so that systems having maximum flexibility and minimum cost can be realized. The 1800 series CPU also provides a synchronous interface to memories and external controllers for I/O devices, and minimizes the cost of interface controllers. Further, the I/O interface is capable of supporting devices operating in polled, interrupt driven, or direct memory access modes.

The CDP1802A and CDP1802AC have a maximum input clock frequency of 3.2 MHz at $\mathrm{V}_{\mathrm{DD}}=5$ volts. The CDP1802A and CDP1802AC are functionally identical. They differ in that the CDP1802A has a recommended operating voltage range of 4 to 10.5 volts, and the CDP1802AC a recommended operating voltage range of 4 to 6.5 volts.
The CDP1802BC is a higher speed version of the CDP1802AC, having a maximum input clock frequency of 5.0 MHz at $\mathrm{V}_{\mathrm{DD}}=5$ volt, and a recommended operating voltage range of 4 to 6.5 volts.
All types are supplied in 40-lead Dual-In-Line Sidebrazed Ceramic Packages (D suffix), 40-lead Dual-In-Line Plastic Packages (E suffix), and 44-lead Plastic Chip-Carrier (PLCC) Packages (Q suffix). The CDP1802AC is also available in Chip Form (H suffix).

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 10V-6.4MHz | 5V-3.2MHz | 5V-5MHz |
| :---: | :---: | :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1802AE | CDP1802ACE | CDP1802BCE |
| Burn-in |  | CDP1802AEX | CDP1802ACEX | CDP1802BCEX |
| PLCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1802AQ | CDP1802ACQ | CDP1802BCQ |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1802AD | CDP1802ACD | CDP1802BCD |
| Burn-in |  | CDP1802ADX | CDP1802ACDX | CDP1802BCDX |
| *883B | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | CDP1802AD3 | CDP1802ACD3 | - |

*Respective specifications are included at the end of this data sheet.

## Pinouts

40 LEAD PLASTIC DIP (PACKAGE TYPE E) 40 LEAD SIDEBRAZED CERAMIC DIP (PACKAGE TYPE D) TOP VIEW

| Clock 1 | 40 | $V_{\text {D }}$ |
| :---: | :---: | :---: |
| WAT 2 | 39 | XTAL |
| CLEAR 3 | 38 | DMAIN |
| Q 4 | 37 | DMA OUT |
| Sc1 5 | 36 | INTERRUPT |
| Sco 6 | 35 | MWR |
| MRD 7 | 34 | TPA |
| BUS 78 | 33 | TPB |
| BUS 69 | 32 | MA7 |
| BUS 510 | 31 | MA6 |
| BUS 411 | 30 | MA5 |
| BUS 312 | 29 | MA4 |
| BUS 213 | 28 | MA3 |
| Bus 114 | 27 | MA2 |
| Bus 015 | 26 | MA1 |
| $V_{\text {cc }} 16$ | 25 | MAO |
| N2 17 | 24 | EF1 |
| N1 18 | 23 | EF2 |
| No 19 | 22 | EF3 |
| $\mathrm{v}_{\text {SS }} 20$ | 21 | EF4 |

44 LEAD PLASTIC CHIP CARRIER (PLCC)
(PACKAGE TYPE Q) TOP VIEW


FIGURE 1. TYPICAL CDP1802 SMALL MICROPROCESSOR SYSTEM

## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ :
(All Voltages Referenced to $\mathrm{V}_{S S}$ Terminal)
CDP1802A.
-0.5 V to +11 V
CDP1802AC, CDP1802BC. . . . . . . . . . . . . . . . . . . . -0.5 V to +7 V
Input Voltage Range, All Inputs $\ldots \ldots \ldots \ldots \ldots . .$.
DC Input Current, any One Input. . . . . . . . . . . . . . . . . . . . . . . . $\pm 10 \mathrm{~mA}$
Power Dissipation Per Package ( $P_{D}$ )
$T_{A}=-40$ to $+60^{\circ} \mathrm{C}$ (Package Type E). . . . . . . . . . . . . . . . . . 500 mW
$T_{A}=+60$ to $+85^{\circ} \mathrm{C}$ (Package Type E) ........ . Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW
$T_{A}=-55$ to $+100^{\circ} \mathrm{C}$ (Package Type D) ................. 500 mW
$T_{A}=+100$ to $+125^{\circ} \mathrm{C}$ (Package Type D) . . . . . . Derate Linearly at
$12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type Q)* $\ldots . . . . . . . .5500 \mathrm{~mW}$

Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range
100 mW
Operating Temperature Range ( $T_{A}$ )
(Package Type D.
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
(Package Type E and Q
.$-40^{\circ} \mathrm{C}$ to $+65^{\circ} \mathrm{C}$
Storage Temperature Range ( $T_{\text {sto }}$ )
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{ln}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10 s

-Printed circuit board mount: $57 \mathrm{~mm} \times 57 \mathrm{~mm}$ minimum area $\times 1.6 \mathrm{~mm}$ thick G10 epoxy glass, or equivalent

Recommended Operating Conditions $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | CONDITIONS |  | LImits |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & V_{c c} 1 \\ & \text { (V) } \end{aligned}$ | $V_{D D}$ <br> (V) | CDP1802A |  | CDP1802AC |  | CDP1802BC |  |  |
|  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range | - | - | 4 | 10.5 | 4 | 6.5 | 4 | 6.5 | V |
| Input Voltage Range | - | - | $\mathrm{v}_{\text {ss }}$ | $V_{D D}$ | $\mathrm{v}_{\text {ss }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{v}_{\text {ss }}$ | $V_{\text {DD }}$ | V |
| Maximum Clock Input Rise or Fall Time | 4 to 6.5 | 4 to 6.5 | - | - | - | 1 | - | 1 | $\mu \mathrm{s}$ |
|  | 4 to 10.5 | 4 to 10.5 | - | 1 | - | - | - | - | $\mu \mathrm{s}$ |
| Minimum Instruction Time ${ }^{2}$ | 5 | 5 | 5 | - | 5 | - | 3.2 | - | $\mu \mathrm{s}$ |
|  | 5 | 10 | 4 | - | - | - | - | - | $\mu \mathrm{s}$ |
|  | 10 | 10 | 2.5 | - | - | - | - | - | $\mu \mathrm{s}$ |
| Maximum DMA Transfer Rate | 5 | 5 | - | 400 | - | 400 | - | 667 | $\begin{aligned} & \text { KBytes } \\ & \text { per } \\ & \text { second } \end{aligned}$ |
|  | 5 | 10 | - | 500 | - | - | - | - |  |
|  | 10 | 10 | - | 800 | - | - | $\bullet$ | - |  |
| Maximum Clock Input Frequency, $\mathrm{f}_{\mathrm{CL}}$, Load Capacitance$\left(C_{L}\right)=50 \mathrm{pF}$ | 5 | 5 | DC | 3.2 | DC | 3.2 | DC | 5 | MHz |
|  | 5 | 10 | DC | 4 | $\bullet$ | - | - | $\bullet$ | MHz |
|  | 10 | 10 | DC | 6.4 | - | - | - | - | MHz |

## NOTES:

1. $V_{C C}$ must never exceed $V_{D D}$.
2. Equals 2 machine cycles - one Fetch and one Execute operation for all instructions except Long Branch and Long Skip, which require 3 machine cycles - one Fetch and two Execute operations.

Specifications CDP1802A, CDP1802AC, CDP1802BC
Static Electrical Characteristics at $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Except as Noted

| Characteristic | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $V_{\text {OUT }}$ (V) | $\mathrm{V}_{\mathbf{I N}}(\mathrm{V})$ | $\begin{aligned} & \mathbf{v}_{\mathbf{c c}}, \\ & \mathbf{V}_{\mathbf{D D}} \\ & (\mathrm{V}) \end{aligned}$ | CDP1802A |  |  | CDP1802AC, CDP1802BC |  |  |  |
|  |  |  |  |  | MIN | TYP* | MAX | MIN | TYP* | MAX |  |
| Quiescent Device Current | IDD | - | - | 5 | - | 0.1 | 50 | - | 1 | 200 | $\mu \mathrm{A}$ |
|  |  | - | - | 10 | - | 1 | 200 | - | - | - | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | lol | 0.4 | 0,5 | 5 | 1.1 | 2.2 | - | 1.1 | 2.2 | - | mA |
| $\text { (Except } \overline{\text { XTAL }})$ |  | 0.5 | 0,10 | 10 | 2.2 | 4.4 | - | - | - | - | mA |
| $\overline{\overline{\text { XTAL }}}$ |  | 0.4 | 5 | 5 | 170 | 350 | - | 170 | 350 | - | $\mu \mathrm{A}$ |
| Output High Drive (Source) Current | $\mathrm{l}_{\mathrm{OH}}$ | 4.6 | 0,5 | 5 | -0.27 | -0.55 | - | -0.27 | -0.55 | - | mA |
| $\text { (Except } \overline{\overline{X T A L}})$ |  | 9.5 | 0,10 | 10 | -0.55 | -1.1 | - | - | - | - | mA |
| XTAL |  | 4.6 | 0 | 5 | -125 | -250 | - | -125 | -250 | - | $\mu \mathrm{A}$ |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  |  | - | 0,10 | 10 | - | 0 | 0.1 | - | - | - | V |
| Output Voltage High Level | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - | V |
|  |  | - | 0,10 | 10 | 9.9 | 10 | - | - | - | - | V |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 0.5, 4.5 | - | 5, 10 | - | - | 1 | - | - | - | V |
|  |  | 1,9 | - | 10 | - | - | 3 | - | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 4.5 | - | 5 | 3.5 | - | - | 3.5 | - | - | V |
|  |  | 0.5, 4.5 | - | 5, 10 | 4 | - | - | - | - | - | V |
|  |  | 1,9 | - | 10 | 7 | - | - | $\cdot$ | - | - | V |
| $\overline{\text { CLEAR }}$ Input Voltage Schmitt Hysteresis | $\mathrm{V}_{\mathrm{H}}$ | - | $\cdot$ | 5 | 0.4 | 0.5 | - | 0.4 | 0.5 | - | V |
|  |  | - | - | 5, 10 | 0.3 | 0.4 | - | - | - | - | V |
|  |  | $\cdot$ | $\cdot$ | 10 | 1.5 | 2 | - | - | - | - | V |
| Input Leakage Current | IN | Any Input | 0,5 | 5 | - | $\pm 10^{-4}$ | $\pm 1$ | - | $\pm 10^{-4}$ | $\pm 1$ | $\mu \mathrm{A}$ |
|  |  |  | 0,10 | 10 | - | $\pm 10^{-4}$ | $\pm 1$ | - | - | - | $\mu \mathrm{A}$ |
| 3-State Output Leakage Current | Iout | 0,5 | 0,5 | 5 | - | $\pm 10^{-4}$ | $\pm 1$ | - | $\pm 10^{-4}$ | $\pm 1$ | $\mu \mathrm{A}$ |
|  |  | 0, 10 | 0,10 | 10 | - | $\pm 10^{-4}$ | $\pm 1$ | - | . | - | $\mu \mathrm{A}$ |
| Operating Current CDP1802A, AC (1) $\mathrm{f}=3.2 \mathrm{MHz}$ | $\mathrm{IDOI*}^{* *}$ | . | - | 5 | - | 2 | 4 | - | 2 | 4 | mA |
| $\begin{aligned} & \text { CDP1802BC } \\ & \text { © } \mathrm{f}=5.0 \mathrm{MHz} \end{aligned}$ |  | - | - | 5 | - | - | - | - | 3 | 6 | mA |
| Minimum Data Retention Voltage | $\mathrm{V}_{\mathrm{DR}}$ | $\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{DR}}$ |  |  | - | 2 | 2.4 | - | 2 | 2.4 | V |
| Data Retention Current | $\mathrm{I}_{\text {DR }}$ | $V_{D D}=2.4 \mathrm{~V}$ |  |  | - | 0.05 | $\cdot$ | - | 0.5 | $\bigcirc$ | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ |  |  |  | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance | $\mathrm{Cout}^{\text {O }}$ |  |  |  | - | 10 | 15 | - | 10 | 15 | pF |

*Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
"*Idle "00" at $M(0000), C_{L}=50 \mathrm{pF}$.

## Performance Curves



FIGURE 2. CDP1802A, AC TYPICAL MAXIMUM CLOCK FREQUENCY AS A FUNCTION OF TEMPERATURE


FIGURE 4. TYPICAL TRANSITION TIME vs LOAD CAPACITANCE FOR ALL TYPES


FIGURE 6. CDP1802A, AC MINIMUM OUTPUT LOW (SINK) CURRENT CHARACTERISTICS


FIGURE 3. CDP1802BC TYPICAL MAXIMUM CLOCK FREQUENCY A A FUNCTION OF TEMPERATURE.


FIGURE 5. CDP1802A, AC MINIMUM OUTPUT HIGH (SOURCE) CURRENT CHARACTERISTICS


FIGURE 7. CDP1802BC MINIMUM OUTPUT HIGH (SOURCE) CURRENT CHARACTERISTICS

## Performance Curves (Continued)



FIGURE 8. CDP1802BC MINIMUM OUTPUT LOW (SINK) CURRENT CHARACTERISTICS

NOTES:


BRANCH
$C_{L}: 50 \mathrm{pF}$
FIGURE 9. TYPICAL POWER DISSIPATION AS A FUNCTION OF CLOCK FREQUENCY FOR BRANCH INSTRUCTION AND IDLE INSTRUCTION FOR ALL TYPES


FIGURE 10. TYPICAL CHANGE IN PROPAGATION DELAY AS A FUNCTION OF A CHANGE IN LOAD CAPACITANCE FOR ALL TYPES


FIGURE 11. CDP1802A BLOCK DIAGRAM


FIGURE 12. BASIC DC TIMING WAVEFORMS, ONE INSTRUCTION CYCLE

## Signal Descriptions

## Bus 0 to Bus 7 (Data Bus):

8 -bit bidirectional DATA BUS lines. These lines are used for transferring data between the memory, the microprocessor, and $I / O$ devices.

## N0 to N2 (VO Control Lines):

Activated by an I/O instruction to signal the I/O control logic of a data transfer between memory and I/O interface. These lines can be used to issue command codes or device selection codes to the I/O devices (independently or combined with the memory byte on the data bus when an I/O instruction is being executed). The N bits are low at all times except when an I/O instruction is being executed. During this time their state is the same as the corresponding bits in the N register.

The direction of data flow is defined in the I/O instruction by bit N3 (internally) and is indicated by the level of the MRD signal.
$\overline{\mathrm{MRD}}=\mathrm{V}_{\mathrm{CC}}$ : Data from I/O to CPU and Memory
$\overline{M R D}=V_{S S}$ : Data from Memory to $I / O$

## $\overline{E F 1}$ to $\overline{E F 4}$ (4 Flags):

These inputs enable the I/O controllers to transfer status information to the processor. The levels can be tested by the conditional branch instructions. They can be used in conjunction with the INTERRUPT request line to establish interrupt priorities. These flags can also be used by I/O devices to "call the attention" of the processor, in which case the program must routinely test the status of these flag(s). The flag(s) are sampled at the beginning of every S1 cycle.

## INTERRUPT, $\overline{D M A}-\overline{I N}, \overline{D M A}-\overline{O U T}$ (3 VO Requests)

These inputs are sampled by the CPU during the interval between the leading edge of TPB and the leading edge of TPA.

Interrupt Action: $X$ and $P$ are stored in $T$ after executing current instruction; designator X is set to 2 ; designator P is set to 1 ; interrupt enable is reset to 0 (inhibit); and instruction execution is resumed. The interrupt action requires one machine cycle (S3).

DMA Action: Finish executing current instruction; R(0) points to memory area for data transfer; data is loaded into or read out of memory; and increment $R(0)$.

NOTE: In the event of concurrent DMA and Interrupt requests, DMA-IN has priority followed by DMA-OUT and then Interrupt.

## SC0, SC1, (2 State Code Lines):

These outputs indicate that the CPU is: 1) fetching an instruction, or 2) executing an instruction, or 3) processing a DMA request, or 4) acknowledging an interrupt request. The levels of state code are tabulated below. All states are valid at TPA. $H=V_{C C}, L=V_{S S}$.

| STATE TYPE | STATE CODE LINES |  |
| :--- | :---: | :---: |
|  | SC1 | SC0 |
| S0 (Fetch) | L | L |
| S1 (Execute) | L | H |
| S2 (DMA) | H | L |
| S3 (Interrupt) | H | H |

## TPA, TPB (2 Timing Pulses):

Positive pulses that occur once in each machine cycle (TPB follows TPA). They are used by I/O controllers to interpret codes and to time interaction with the data bus. The trailing edge of TPA is used by the memory system to latch the higher-order byte of the 16 -bit memory address. TPA is suppressed in IDLE when the CPU is in the load mode.

## MA0 to MA7 (8 Memory Address Lines):

In each cycle, the higher-order byte of a 16 -bit CPU memory address appears on the memory address lines MA0-7 first. Those bits required by the memory system can be strobed into external address latches by timing pulse TPA. The low order byte of the 16-bit address appears on the address lines after the termination of TPA. Latching of all 8 higherorder address bits would permit a memory system of 64 K bytes.

## $\overline{M W R}$ (Write Pulse):

A negative pulse appearing in a memory-write cycle, after the address lines have stabilized.

## $\overline{\text { MRD (Read Level): }}$

A low level on $\overline{M R D}$ indicates a memory read cycle. It can be used to control three-state outputs from the addressed memory which may have a common data input and output bus. If a memory does not have a three-state high-impedance output, $\overline{M R D}$ is useful for driving memory/bus separator gates. It is also used to indicate the direction of data transfer during an I/O instruction. For additional information see Table 1.

## Q:

Single bit output from the CPU which can be set or reset under program control. During SEQ or REQ instruction execution, $Q$ is set or reset between the trailing edge of TPA and the leading edge of TPB.

## CLOCK:

Input for externally generated single-phase clock. The clock is counted down internally to 8 clock pulses per machine cycle.

## $\overline{\text { XTAL: }}$

Connection to be used with clock input terminal, for an external crystal, if the on-chip oscillator is utilized. The crystal is connected between terminals 1 and 39 (CLOCK and XTAL) in parallel with a resistance ( 10 megohms typ.). Frequency trimming capacitors may be required at terminals 1 and 39. For additional information, see ICAN-6565.

## WAIT, CLEAR (2 Control Lines):

Provide four control modes as listed in the following truth table:

| $\overline{\text { CLEAR }}$ | $\overline{\text { WAIT }}$ | MODE |
| :---: | :---: | :---: |
| L | L | LOAD |
| L | $H$ | RESET |
| $H$ | L | PAUSE |
| $H$ | $H$ | RUN |

$\mathbf{V}_{\mathrm{DD}} \mathbf{V}_{\mathrm{SS}}, \mathbf{V}_{\mathbf{C C}}$ (Power Levels):
The internal voltage supply $V_{D D}$ is isolated from the Input/ Output voltage supply $V_{C C}$ so that the processor may operate at maximum speed while interfacing with peripheral devices operating at lower voltage. $V_{\text {cc }}$ must be less than or equal to $\mathrm{V}_{\mathrm{DD}}$. All outputs swing from $\mathrm{V}_{\mathrm{SS}}$ to $\mathrm{V}_{\mathrm{CC}}$. The recommended input voltage swing is $V_{S S}$ to $V_{C C}$.

## Architecture

The CPU block diagram is shown in Figure 11. The principal feature of this system is a register array ( $R$ ) consisting of sixteen 16 bit scratchpad registers. Individual registers in the array (R) are designated (selected) by a 4 bit binary code from one of the 4 bit registers labeled $N, P$, and $X$. The contents of any register can be directed to any one of the following three paths:

1. The external memory (multiplexed, higher-order byte first, on to 8 memory address lines)
2. The D register (either of the two bytes can be gated to D)
3. The increment/decrement circuit where it is increased or decreased by one and stored back in the selected 16 bit register

The three paths, depending on the nature of the instruction, may operate independently or in various combinations in the same machine cycle.
With two exceptions, CPU instruction consists of two 8-clockpulse machine cycles. The first cycle is the fetch cycle, and the second - and third if necessary - are execute cycles. During the fetch cycle the four bits in the $\mathbf{P}$ designator select one of the 16 registers $R(P)$ as the current program counter. The selected register $R(P)$ contains the address of the memory location form which the instruction is to be fetched. When the instruction is read out from the memory, the higher order 4 bits of the instruction byte are loaded into the I register and the lower order 4 bits into the N register. The content of the program counter is automatically incremented by one so that $R(P)$ is now "pointing" to the next byte in the memory.

The $X$ designator selects one of the 16 register $R(X)$ to "point" to the memory for an operand (or data) in certain ALU or I/O operations.
The N designator can perform the following five functions depending on the type of instruction fetched:

1. Designate one of the $\mathbf{1 6}$ registers in $\mathbf{R}$ to be acted upon during register operations
2. Indicate to the I/O devices a command code or device selection code for peripherals
3. Indicate the specific operation to be executed during the ALU instructions, types of test to be performed during the Branch instruction, or the specific operation required in a class of miscellaneous instructions (70-73 and 78-7B).
4. Indicate the value to be loaded into $P$ to designate a new register to be used as the program counter $R(P)$
5. Indicate the value to be loaded into $X$ to designate a new register to be used as data pointer $R(X)$
The registers in $R$ can be assigned by a programmer in three different ways: as program counters, as data pointers, or as scratchpad locations (data registers) to hold two bytes of data.

## Program Counters

Any register can be the main program counter; the address of the selected register is held in the P designator. Other registers in R can be used as subroutine program counters. By single instruction the contents of the $\mathbf{P}$ register can be changed to effect a "call" to a subroutine. When interrupts are being serviced, register $R(1)$ is used as the program counter for the user's interrupt servicing routine. After reset, and during a DMA operation, $\mathrm{R}(0)$ is used as the program counter. At all other times the register designated as program counter is at the discretion of the user.

## Data Pointers

The registers in R may be used as data pointers to indicate a location in memory. The register designated by $X$ (i.e., $R(X)$ ) points to memory for the following instructions (see Table 1).

1. ALU operations F1-F5, F7, 74, 75, 77
2. Output instructions 61 through 67
3. Input instructions 69 through 6F
4. Certain miscellaneous instructions - 70-73, 78, 60, FO

The register designated by $N$ (i.e., $R(N)$ ) points to memory for the "load D from memory" instructions ON and 4 N and the "Store D " instruction 5 N . The register designated by P (i.e., the program counter) is used as the data pointer for ALU instructions F8-FD, FF, 7C, 7D, 7F. During these instruction executions, the operation is referred to as "data immediate".

Another important use of R as a data pointer supports the built-in Direct-Memory-Access (DMA) function. When a DMA-In or DMA-Out request is received, one machine cycle is "stolen". This operation occurs at the end of the execute machine cycle in the current instruction. Register $R(0)$ is always used as the data pointer during the DMA operation. The data is read from (DMA-Out) or written into (DMA-In) the memory location pointed to by the $R(0)$ register. At the end of the transfer, $R(0)$ is incremented by one so that the processor is ready to act upon the next DMA byte transfer request. This feature in the 1800 -series architecture saves a substantial amount of logic when fast exchanges of blocks of data are required, such as with magnetic discs or during CRT-display-refresh cycles.

## Data Registers

When registers in $\mathbf{R}$ are used to store bytes of data, four instructions are provided which allow $D$ to receive from or write into either the higher-order or lower-order byte portions of the register designated by N. By this mechanism (together with loading by data immediate) program pointer and data pointer designations are initialized. Also, this technique allows scratchpad registers in R to be used to hold general data. By employing increment or decrement instructions, such registers may be used as loop counters.

## The Q Flip-Flop

An internal flip-flop, $Q$, can be set or reset by instruction and can be sensed by conditional branch instructions. The output of $Q$ is also available as a microprocessor output.

## Interrupt Servicing

Register $R(1)$ is always used as the program counter whenever interrupt servicing is initiated. When an interrupt request occurs and the interrupt is allowed by the program (again, nothing takes place until the completion of the current instruction), the contents of the $X$ and $P$ registers are stored in the temporary register $T$, and $X$ and $P$ are set to new values; hex digit 2 in $X$ and hex digit 1 in $P$. Interrupt Enable is automatically deactivated to inhibit further interrupts. The user's interrupt routine is now in control; the contents of T may be saved by means of a single instruction (78) in the memory location pointed to be $R(X)$. At the conclusion of the interrupt, the user's routine may restore the pre-interrupted value of $X$ and $P$ with a single instruction (70 or 71). The Interrupt Enable flip flop can be activated to permit further interrupts or can be disabled to prevent them.

## CPU Register Summary

| D | 8 Bits | Data Register (Accumulator) |
| :---: | :--- | :--- |
| DF | 1 Bit | Data Flag (ALU Carry) |
| B | 8 Bits | Auxiliary Holding Register |
| R | 16 Bits | 1 of 16 Scratchpad Registers |
| P | 4 Bits | Designates which register is Program <br> Counter |
| X | 4 Bits | Designates which register is Data <br> Pointer |
| N | 4 Bits | 4 Holds Low-Order Instruction Digit |
| T | 8 Bits | Holds High-Order Instruction Digit <br> high nibble) |
| IE after Interrupt (X is |  |  |
| Q | 1 Bit | Interrupt Enable |

## CDP1802 Control Modes

The $\overline{\text { WAIT }}$ and CLEAR lines provide four control modes as listed in the following truth table:

| $\overline{\text { CLEAR }}$ | $\overline{\text { WAIT }}$ | MODE |
| :---: | :---: | :---: |
| L | L | LOAD |
| L | $H$ | RESET |
| $H$ | L | PAUSE |
| $H$ | $H$ | RUN |

The function of the modes are defined as follows:

## Load

Holds the CPU in the IDLE execution state and allows an I/O device to load the memory without the need for a "bootstrap" loader. It modifies the IDLE condition so that DMA-IN operation does not force execution of the next instruction.

## Reset

Registers I, N, Q are reset, IE is set and O's ( $V_{S S}$ ) are placed on the data bus. TPA and TPB are suppressed while reset is held and the CPU is placed in S1. The first machine cycle after termination of reset is an initialization cycle which requires 9 clock pulses. During this cycle the CPU remains in S1 and register X, P, and R(0) are reset. Interrupt and DMA servicing are suppressed during the initialization cycle. The next cycle is an SO, S1, or an S2 but never an S3. With the use of a 71 instruction followed by 00 at memory locations 0000 and 0001, this feature may be used to reset IE, so as to preclude interrupts until ready for them. Powerup reset can be realized by connecting an RC network directly to the CLEAR pin, since it has a Schmitt triggered input, see Figure 13.


The RC time constant should be greater than the oscillator start-up tıme (typically 20 ms ).

FIGURE 13. RESET DIAGRAM

## Pause

Stops the internal CPU timing generator on the first negative high-to-low transition of the input clock. The oscillator continues to operate, but subsequent clock transitions are ignored.

## Run

May be initiated from the Pause or Reset mode functions. If initiated from Pause, the CPU resumes operation on the first negative high-to-low transition of the input clock. When initiated from the Reset operation, the first machine cycle following Reset is always the initialization cycle. The initialization cycle is then followed by a DMA (S2) cycle or fetch (SO) from location 0000 in memory.

## Run-Mode State Transitions

The CPU state transitions when in the RUN and RESET modes are shown in Figure 14. Each machine cycle requires the same period of time, 8 clock pulses, except the initialization cycle, which requires 9 clock pulses. The execution of an instruction requires either two or three machine cycles, S 0 followed by a single S 1 cycle or two S 1 cycles. S 2 is the response to a DMA request and S3 is the interrupt response. Table 2 shows the conditions on Data Bus and MemoryAddress lines during all machine states.

## Instruction Set

The CPU instruction summary is given in Table 1. Hexadecimal notation is used to refer to the 4 bit binary codes.

In all registers bits are numbered from the least significant bit (LSB) to the most significant bit (MSB) starting with 0 .
$R(W)$ : Register designated by W, where

$$
\mathrm{W}=\mathrm{N} \text { or } \mathrm{X}, \text { or } \mathrm{P}
$$

$R(W) .0$ : Lower order byte of $R(W)$
$R(W) .1$ : Higher order byte of $R(W)$

## Operation Notation

$$
M(R(N)) \rightarrow D ; R(N)+1 \rightarrow R(N)
$$

This notation means: The memory byte pointed to by $R(N)$ is loaded into $D$, and $R(N)$ is incremented by 1 .


| INSTRUCTION | MNEMONIC | OP CODE | OPERATION |
| :---: | :---: | :---: | :---: |
| MEMORY REFERENCE |  |  |  |
| LOAD VIA N | LDN | ON | $\mathrm{M}(\mathrm{R}(\mathrm{N})$ ) $\rightarrow \mathrm{D}$; for N not 0 |
| LOAD ADVANCE | LDA | 4N | $M(R(N)) \rightarrow D ; R(N)+1 \rightarrow R(N)$ |
| LOAD VIA X | LDX | FO | $\mathrm{M}(\mathrm{R}(\mathrm{X}) \mathrm{)} \rightarrow \mathrm{D}$ |
| LOAD VIA X AND ADVANCE | LDXA | 72 | $M(R(X)) \rightarrow D ; R(X)+1 \rightarrow R(X)$ |
| LOAD IMMEDIATE | LDI | F8 | $M(R(P)) \rightarrow D ; R(P)+1 \rightarrow R(P)$ |
| STORE VIA N | STR | 5N | $\mathrm{D} \rightarrow \mathrm{M}(\mathrm{R}(\mathrm{N})$ |
| STORE VIA X AND DECREMENT | STXD | 73 | $D \rightarrow M(R(X)) ; R(X)-1 \rightarrow R(X)$ |
| REGISTER OPERATIONS |  |  |  |
| INCREMENT REG N | INC | 1 N | $\mathrm{R}(\mathrm{N})+1 \rightarrow \mathrm{R}(\mathrm{N})$ |
| DECREMENT REG N | DEC | 2N | $\mathrm{R}(\mathrm{N})-1 \rightarrow \mathrm{R}(\mathrm{N})$ |
| INCREMENT REG $X$ | IRX | 60 | $\mathrm{R}(\mathrm{X})+1 \rightarrow \mathrm{R}(\mathrm{X})$ |
| GET LOW REG N | GLO | 8 N | $\mathrm{R}(\mathrm{N}) .0 \rightarrow \mathrm{D}$ |
| PUT LOW REG N | PLO | AN | $\mathrm{D} \rightarrow \mathrm{R}(\mathrm{N}) .0$ |
| GET HIGH REG $N$ | GHI | 9 N | $\mathrm{R}(\mathrm{N}) .1 \rightarrow \mathrm{D}$ |
| PUT HIGH REG N | PHI | BN | $\mathrm{D} \rightarrow \mathrm{R}(\mathrm{N}) .1$ |
| LOGIC OPERATIONS* |  |  |  |
| OR | OR | F1 | $\mathrm{M}(\mathrm{R}(\mathrm{X})$ ) OR D $\rightarrow$ D |
| OR IMMEDIATE | ORI | F9 | $\mathrm{M}(\mathrm{R}(\mathrm{P})$ ) OR D $\rightarrow \mathrm{D} ; \mathrm{R}(\mathrm{P})+1 \rightarrow \mathrm{R}(\mathrm{P})$ |

*The arithmetic operations and the shift instructions are the only instructions that can alter the DF. After an add instruction:

DF $=1$ denotes a carry has occurred
DF $=0$ Denotes a carry has not occurred
After a subtract instruction:
$D F=1$ denotes no borrow. $D$ is a true positive number DF = 0 denotes a borrow. D is two's complement The syntax "-(not DF)" denotes the subtraction of the borrow
**This instruction is associated with more than one mnemonic. Each mnemonic is individually listed.
${ }^{\dagger}$ An idle instruction initiates a repeating S1 cycle. The processor will continue to idle until an I/O request (INTERRUPT, $\overline{\mathrm{DMA}}-\overline{\mathrm{IN}}$, or $\overline{\mathrm{DMA}}$ $\overline{\text { OUT }}$ ) is activated. When the request is acknowledged, the idle cycle is terminated and the I/O request is serviced, and then normal operation is resumed.

TABLE 1. INSTRUCTION SUMMARY (Continued) (See Notes at End of Table)

| INSTRUCTION | MNEMONIC | OP CODE | OPERATION |
| :---: | :---: | :---: | :---: |
| LOGIC OPERATIONS* (Continued) |  |  |  |
| EXCLUSIVE OR | XOR | F3 | $\mathrm{M}(\mathrm{R}(\mathrm{X})$ ) XOR D $\rightarrow$ D |
| EXCLUSIVE OR IMMEDIATE | XRI | FB | $\mathrm{M}(\mathrm{R}(\mathrm{P}) \mathrm{XOR} \mathrm{D} \rightarrow \mathrm{D} ; \mathrm{R}(\mathrm{P})+1 \rightarrow \mathrm{R}(\mathrm{P})$ |
| AND | AND | F2 | $\mathrm{M}(\mathrm{R}(\mathrm{X})$ ) AND $\mathrm{D} \rightarrow \mathrm{D}$ |
| AND IMMEDIATE | ANI | FA | $\mathrm{M}(\mathrm{R}(\mathrm{P})$ ) AND $\mathrm{D} \rightarrow \mathrm{D} ; \mathrm{R}(\mathrm{P})+1 \rightarrow \mathrm{R}(\mathrm{P})$ |
| SHIFT RIGHT | SHR | F6 | SHIFT D RIGHT, LSB(D) $\rightarrow$ DF, $0 \rightarrow \mathrm{MSB}$ (D) |
| SHIFT RIGHT WITH CARRY | SHRC $\}$ | 76** | SHIFT D RIGHT, LSB(D) $\rightarrow$ DF, DF $\rightarrow$ MSB(D) |
| RING SHIFT RIGHT | RSHR |  |  |
| SHIFT LEFT | SHL | FE | SHIFT D LEFT, MSB(D) $\rightarrow$ DF, $0 \rightarrow$ LSB(D) |
| SHIFT LEFT WITH CARRY | SHLC $\}$ | 7E** | SHIFT D LEFT, MSB(D) $\rightarrow$ DF, DF $\rightarrow$ LSB(D) |
| RING SHIFT LEFT | RSHL |  |  |
| ARITHMETIC OPERATIONS* |  |  |  |
| ADD | ADD | F4 | $\mathrm{M}(\mathrm{R}(\mathrm{X})$ ) + D $\rightarrow$ DF, D |
| ADD IMMEDIATE | ADI | FC | $\mathrm{M}(\mathrm{R}(\mathrm{P}) \mathrm{)}+\mathrm{D} \rightarrow \mathrm{DF}, \mathrm{D} ; \mathrm{R}(\mathrm{P})+1 \rightarrow \mathrm{R}(\mathrm{P})$ |
| ADD WITH CARRY | ADC | 74 | $M(R(X))+D+D F \rightarrow D F, D$ |
| ADD WITH CARRY, IMMEDIATE | ADCI | 7 C | $M(R(P))+D+D F \rightarrow D F, D, R(P)+1 \rightarrow R(P)$ |
| SUBTRACT D | SD | F5 | $\mathrm{M}(\mathrm{R}(\mathrm{X}))-\mathrm{D} \rightarrow \mathrm{DF}, \mathrm{D}$ |
| SUBTRACT D IMMEDIATE | SDI | FD | $M(R(P))-D \rightarrow D F, D ; R(P)+1 \rightarrow R(P)$ |
| SUBTRACT D WITH BORROW | SDB | 75 | $\mathrm{M}(\mathrm{R}(\mathrm{X}))$ - D - (Not DF $) \rightarrow \mathrm{DF}, \mathrm{D}$ |
| SUBTRACT D WITH BORROW, IMMEDIATE | SDBI | 7D | $\mathrm{M}(\mathrm{R}(\mathrm{P})$ ) - D - Not DF) $\rightarrow$ DF, $\mathrm{D} ; \mathrm{R}(\mathrm{P})+1 \rightarrow \mathrm{R}(\mathrm{P})$ |
| SUBTRACT MEMORY | SM | F7 | $\mathrm{D}-\mathrm{M}(\mathrm{R}(\mathrm{X})) \rightarrow \mathrm{DF}, \mathrm{D}$ |
| SUBTRACT MEMORY IMMEDIATE | SMI | FF | $D-M(R(P)) \rightarrow$ DF, $\mathrm{D} ; \mathrm{R}(\mathrm{P})+1 \rightarrow \mathrm{R}(\mathrm{P})$ |
| SUBTRACT MEMORY WITH BORROW | SMB | 77 | $D-M(R(X))$-(NOT DF) $\rightarrow$ DF, D |
| SUBTRACT MEMORY WITH BORROW, IMMEDIATE | SMBI | 7F | $D-M(R(P))-(N O T D F) \rightarrow D F, D, R(P)+1 \rightarrow R(P)$ |
| BRANCH INSTRUCTIONS - SHORT BRANCH |  |  |  |
| SHORT BRANCH | BR | 30 | $\mathrm{M}(\mathrm{R}(\mathrm{P})) \rightarrow \mathrm{R}(\mathrm{P}) .0$ |
| NO SHORT BRANCH (SEE SKP) | NBR | 38** | $\mathrm{R}(\mathrm{P})+1 \rightarrow \mathrm{R}(\mathrm{P})$ |
| SHORT BRANCH IF D $=0$ | BZ | 32 | If $D=0, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF D NOT 0 | BNZ | 3A | If $D$ Not $0, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF DF $=1$ | BDF $\}$ | 33** | If $D F=1, M(R(P)) \rightarrow R(P) \cdot 0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF POS OR ZERO | BPZ $\}$ |  |  |
| SHORT BRANCH IF EQUAL OR GREATER | BGE |  |  |
| SHORT BRANCH IF DF $=0$ | BNF | $3 B^{* *}$ | If $D F=0, M(R(P)) \rightarrow R(P) \cdot 0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF MINUS | BM |  |  |
| SHORT BRANCH IF LESS | BL |  |  |
| SHORT BRANCH IF Q = 1 | BQ | 31 | If $Q=1, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF Q $=0$ | BNQ | 39 | If $Q=0, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF EF1 $=1$ ( $\overline{\text { EF1 }}=\mathrm{V}_{\text {SS }}$ ) | B1 | 34 | If $E F 1=1, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF EF1 $=0\left(\underline{\text { EF1 }}=\mathrm{V}_{\text {cc }}\right)$ | BN1 | 3 C | If $E F 1=0, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF EF2 $=1$ ( $\left.\overline{\mathrm{EF} 2}=\mathrm{V}_{\text {SS }}\right)$ | B2 | 35 | If EF2 $=1, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF EF2 $=0\left(\overline{\mathrm{EF2}}=\mathrm{V}_{\text {cc }}\right)$ | BN2 | 3D | If $E F 2=0, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF EF3 $=1\left(\overline{\text { EF3 }}=\mathrm{V}_{\text {SS }}\right)$ | B3 | 36 | If $E F 3=1, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF EF3 $=0$ ( $\left.\overline{\text { EF3 }}=\mathrm{V}_{\text {CC }}\right)$ | BN3 | 3E | If EF3 $=0, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF EF4 $=1\left(\underline{\text { EF4 }}=\mathrm{V}_{\text {SS }}\right)$ | B4 | 37 | If $E F 4=1, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| SHORT BRANCH IF EF4 $=0\left(\mathrm{EF4}=\mathrm{V}_{\mathrm{CC}}\right)$ | BN4 | 3F | If EF4 $=0, M(R(P)) \rightarrow R(P) .0$, Else $R(P)+1 \rightarrow R(P)$ |
| BRANCH INSTRUCTIONS - LONG BRANCH |  |  |  |
| LONG BRANCH NO LONG BRANCH (SEE LSKP) | LBR <br> NLBR | $\begin{aligned} & \mathrm{CO} \\ & \mathrm{C} 8^{* *} \end{aligned}$ | $\begin{aligned} & M(P(P)) \rightarrow R(P) .1, M(R(P)+1) \rightarrow R(P) .0 \\ & R(P)=2 \rightarrow R(P) \end{aligned}$ |

*The arithmetic operations and the shift instructions are the only instructions that can alter the DF. After an add instruction:
$D F=1$ denotes a carry has occurred
DF $=0$ Denotes a carry has not occurred
After a subtract instruction:
$D F=1$ denotes no borrow. $D$ is a true positive number
DF $=0$ denotes a borrow. $D$ is two's complement
The syntax "-(not DF)" denotes the subtraction of the borrow
*"This instruction is associated with more than one mnemonic. Each mnemonic is individually listed.
${ }^{\dagger}$ An idle instruction initiates a repeating S1 cycle. The processor will continue to idle until an I/O request (INTERRUPT, $\overline{\mathrm{DMA}}-\overline{\mathrm{N}}$, or $\overline{\mathrm{DMA}}$ OUT) is activated. When the request is acknowledged, the idle cycle is terminated and the I/O request is serviced, and then normal operation is resumed.

TABLE 1. INSTRUCTION SUMMARY (Continued) (See Notes at End of Table)

| INSTRUCTION | MNEMONIC | OP CODE | OPERATION |
| :---: | :---: | :---: | :---: |
| BRANCH INSTRUCTIONS - LONG BRANCH (Continued) |  |  |  |
| LONG BRANCH IF D $=0$ | LBZ | C2 | $\begin{aligned} & \text { IF } D=0, M(R(P)) \rightarrow R(P) .1, M(R(P)+1) \rightarrow R(P) .0 \\ & \text { Else } R(P)+2 \rightarrow R(P) \end{aligned}$ |
| LONG BRANCH IF D NOT 0 | LBNZ | CA | $\begin{aligned} & \text { IF D Not } 0, M(R(P)) \rightarrow R(P) .1, \\ & M(R(P)+1) \rightarrow R(P) .0 \\ & \text { Else } R(P)+2 \rightarrow R(P) \end{aligned}$ |
| LONG BRANCH IF DF $=1$ | LBDF | C3 | $\begin{aligned} & \text { IF DF }=1, M(R(P)) \rightarrow R(P) .1, M(R(P)+1) \rightarrow R(P) .0 \\ & \text { Else } R(P)+2 \rightarrow R(P) \end{aligned}$ |
| LONG BRANCH IF DF $=0$ | LBNF | CB | $\begin{aligned} & \text { IF DF }=0, M(R(P)) \rightarrow R(P) \cdot 1, M(R(P)+1) \rightarrow R(P) .0 \\ & \text { Else } R(P)+2 \rightarrow R(P) \end{aligned}$ |
| LONG BRANCH IF Q = 1 | LBQ | C1 | $\begin{aligned} & \text { IF Q }=1, M(R(P)) \rightarrow R(P) .1, M(R(P)+1) \rightarrow R(P) .0 \\ & \text { Els } \theta(P)+2 \rightarrow R(P) \end{aligned}$ |
| LONG BRANCH IF Q = 0 | LBNQ | C9 | $\begin{aligned} & \text { IF Q }=0, M(R(P)) \rightarrow R(P) .1, M(R(P)+1) \rightarrow R(P) .0 \\ & \text { Else } R(P)+2 \rightarrow R(P) \end{aligned}$ |
| SKIP INSTRUCTIONS |  |  |  |
| SHORT SKIP (SEE NBR) | SKP | 38** | $\mathrm{R}(\mathrm{P})+1 \rightarrow \mathrm{R}(\mathrm{P})$ |
| LONG SKIP (SEE NLBR) | LSKP | C8** | $\mathrm{R}(\mathrm{P})+2 \rightarrow \mathrm{R}(\mathrm{P})$ |
| LONG SKIP IF $=0$ | LSZ | CE | If $D=0, R(P)+2 \rightarrow R(P)$, Else Continue |
| LONG SKIP IF D NOT 0 | LSNZ | C6 | If D Not $0, R(P)+2 \rightarrow R(P)$, Else Continue |
| LONG SKIP IF DF = 1 | LSDF | CF | If $D F=1, R(P)+2 \rightarrow R(P)$, Else Continue |
| LONG SKIP IF DF $=0$ | LSNF | C7 | If $D F=0, R(P)+2 \rightarrow R(P)$, Else Continue |
| LONG SKIP IF Q = 1 | LSQ | CD | If $Q=1, R(P)+2 \rightarrow R(P)$, Else Continue |
| LONG SKIP IF Q $=0$ | LSNQ | C5 | If $\mathrm{Q}=0, \mathrm{R}(\mathrm{P})+2 \rightarrow \mathrm{R}(\mathrm{P})$, Else Continue |
| LONG SKIP IF IE = 1 | LSIE | CC | If IE $=1, \mathrm{R}(\mathrm{P})+2 \rightarrow \mathrm{R}(\mathrm{P})$, Else Continue |
| CONTROL INSTRUCTIONS |  |  |  |
| IDLE | IDL | 00t | Wait for DMA or INTERRUPT; M(R(0)) $\rightarrow$ BUS |
| NO OPERATION | NOP | C4 | Continue |
| SET P | SEP | DN | $\mathrm{N} \rightarrow \mathrm{P}$ |
| SET $X$ | SEX | EN | $\mathrm{N} \rightarrow \mathrm{X}$ |
| SET Q | SEQ | 7B | $1 \rightarrow \mathrm{Q}$ |
| RESET Q | REQ | 7A | $0 \rightarrow \mathrm{Q}$ |
| SAVE | SAV | 78 | $\mathrm{T} \rightarrow \mathrm{M}(\mathrm{R}(\mathrm{X})$ ) |
| PUSH X, P TO STACK | MARK | 79 | $\begin{aligned} & (X, P) \rightarrow T ;(X, P) \rightarrow M(R(2)) \text { Then } P \rightarrow X ; \\ & R(2)-1 \rightarrow R(2) \end{aligned}$ |
| RETURN | RET | 70 | $\mathrm{M}(\mathrm{R}(\mathrm{X})) \rightarrow(\mathrm{X}, \mathrm{P}) ; \mathrm{R}(\mathrm{X})+1 \rightarrow \mathrm{R}(\mathrm{X}), 1 \rightarrow \mathrm{E}$ |
| DISABLE | DIS | 71 | $M(R(X)) \rightarrow(X, P) ; R(X)+1 \rightarrow R(X), 0 \rightarrow I E$ |
| INPUT-OUTPUT BYTE TRANSFER |  |  |  |
| OUTPUT 1 | OUT 1 | 61 | $\mathrm{M}(\mathrm{R}(\mathrm{X})) \rightarrow \mathrm{BUS} ; \mathrm{R}(\mathrm{X})+1 \rightarrow \mathrm{R}(\mathrm{X}) ; \mathrm{N}$ LINES $=1$ |
| OUTPUT 2 | OUT 2 | 62 | $M(R(X)) \rightarrow B U S ; R(X)+1 \rightarrow R(X) ; N$ LINES $=2$ |
| OUTPUT 3 | OUT 3 | 63 | $M(R(X)) \rightarrow B U S ; R(X)+1 \rightarrow R(X) ; ~ N$ LINES $=3$ |
| OUTPUT 4 | OUT 4 | 64 | $M(R(X)) \rightarrow B$ SUS; $R(X)+1 \rightarrow R(X) ; N$ LINES $=4$ |
| OUTPUT 5 | OUT 5 | 65 | $\mathrm{M}(\mathrm{R}(\mathrm{X})) \rightarrow \mathrm{BUS} ; \mathrm{R}(\mathrm{X})+1 \rightarrow \mathrm{R}(\mathrm{X})$; N LINES $=5$ |
| OUTPUT 6 | OUT 6 | 66 | $M(R(X)) \rightarrow B U S ; R(X)+1 \rightarrow R(X) ; N$ LINES $=6$ |
| OUTPUT 7 | OUT 7 | 67 | $M(R(X)) \rightarrow B U S ; R(X)+1 \rightarrow R(X) ; N$ LINES $=7$ |
| INPUT 1 | INP 1 | 69 | $B U S \rightarrow M(R(X)) ; B U S \rightarrow D ; N$ LINES $=1$ |
| INPUT 2 | INP 2 | 6A | BUS $\rightarrow$ M (R(X)); BUS $\rightarrow$ D N LINES $=2$ |
| INPUT 3 | INP 3 | 6B | BUS $\rightarrow \mathrm{M}(\mathrm{R}(\mathrm{X})$ ); BUS $\rightarrow \mathrm{D} ; \mathrm{N}$ LINES $=3$ |
| INPUT 4 | INP 4 | 6C | BUS $\rightarrow \mathrm{M}(\mathrm{R}(\mathrm{X})$ ); BUS $\rightarrow \mathrm{D} ; \mathrm{N}$ LINES $=4$ |
| INPUT 5 | INP 5 | 6D | BUS $\rightarrow \mathrm{M}(\mathrm{R}(\mathrm{X})$ ); BUS $\rightarrow \mathrm{D} ; \mathrm{N}$ LINES $=5$ |

"The arthmetic operations and the shift instructions are the only instructions that can alter the DF. After an add instruction:
$D F=1$ denotes a carry has occurred
$D F=0$ Denotes a carry has not occurred
After a subtract instruction:
$D F=1$ denotes no borrow. $D$ is a true positive number
$D F=0$ denotes a borrow. $D$ is two's complement
The syntax "-(not DF)" denotes the subtraction of the borrow
**This instruction is associated with more than one mnemonic. Each mnemonic is individually listed.
${ }^{\dagger}$ An idle instruction initiates a repeating S1 cycle. The processor will continue to idle until an I/O request (INTERRUPT, $\overline{\mathrm{DMA}}-\overline{\mathrm{N}}$, or $\overline{\mathrm{DMA}}$ $\overline{O U T}$ ) is activated. When the request is acknowledged, the idle cycle is terminated and the I/O request is serviced, and then normal operation is resumed.

TABLE 1. INSTRUCTION SUMMARY (Continued) (See Notes at End of Table)

| INSTRUCTION | MNEMONIC | OP CODE | OPERATION |
| :--- | :--- | :--- | :--- |
|  |  |  |  |
| INPUT-OUTPUT BYTE TRANSFER (Continued) |  |  |  |
| INPUT 6 | INP 6 | 6 E | BUS $\rightarrow M(R(X)) ;$ BUS $\rightarrow \mathrm{D} ;$ N LINES $=6$ |
| INPUT 7 | INP 7 | 6 F | BUS $\rightarrow \mathrm{M}(\mathrm{R}(\mathrm{X})) ;$ BUS $\rightarrow \mathrm{D} ;$ N LINES $=7$ |

*The arithmetic operations and the shift instructions are the only instructions that can alter the DF. After an add instruction:

DF $=1$ denotes a carry has occurred
DF $=0$ Denotes a carry has not occurred
After a subtract instruction:
$D F=1$ denotes no borrow. $D$ is a true positive number
$\mathrm{DF}=0$ denotes a borrow. D is two's complement
The syntax "-(not DF)" denotes the subtraction of the borrow
*This instruction is associated with more than one mnemonic. Each mnemonic is individually listed.
${ }^{\dagger}$ An idle instruction initiates a repeating S1 cycle. The processor will continue to ide until an I/O request (INTERRUPT, DMA-IN, or DMA$\overline{O U T}$ ) is activated. When the request is acknowledged, the idle cycle is terminated and the I/O request is serviced, and then normal operation is resumed.

## NOTES FOR TABLE 1

1. Long-Branch, Long-Skip and No Op instructions require three cycles to complete ( 1 fetch +2 execute).

Long-Branch instructions are three bytes long. The first byte specifies the condition to be tested; and the second and third byte, the branching address.

The long-branch instructions can:
a. Branch unconditionally
b. Test for $\mathrm{D}=0$ or $\mathrm{D} \neq 0$
c. Test for $D F=0$ or $D F=1$
d. Test for $Q=0$ or $Q=1$
e. Effect an unconditional no branch

If the tested condition is met, then branching takes place; the branching address bytes are loaded in the high-and-low order bytes of the current program counter, respectively. This operation effects a branch to any memory location.
If the tested condition is not met, the branching address bytes are skipped over, and the next instruction in sequence is fetched and executed. This operation is taken for the case of unconditional no branch (NLBR).
2. The short-branch instructions are two bytes long. The first byte specifies the condition to be tested, and the second specifies the branching address.
The short branch instruction can:
a. Branch unconditionally
b. Test for $\mathrm{D}=0$ or $\mathrm{D} \neq 0$
c. Test for DF $=0$ or $\mathrm{DF}=1$
d. Test for $Q=0$ or $Q=1$
e. Test the status ( 1 or 0 ) of the four EF flags
f. Effect an unconditional no branch

If the tested condition is met, then branching takes place; the branching address byte is loaded into the low-order byte position of the current program counter. This effects a branch within the current 256 -byte page of the memory, i.e., the page which holds the branching address. If the tested condition is not met, the branching address byte is skipped over, and the next instruction in sequence is fetched and executed. This same action is taken in the case of unconditional no branch (NBR).
3. The skip instructions are one byte long. There is one Unconditional Short-Skip (SKP) and eight Long-Skip instructions.

The Unconditional Short-Skıp instruction takes 2 cycles to complete ( 1 fetch +1 execute). Its action is to skip over the byte following it. Then the next instruction in sequence is fetched and executed. This SKP instruction is identical to the unconditional no-branch instruction (NBR) except that the skipped-over byte is not considered part of the program.

The Long-Skip instructions take three cycles to complete ( 1 fetch +2 execute).

They can:
a. Skip unconditionally
b. Test for $\mathrm{D}=0$ or $\mathrm{D} \neq 0$
c. Test for $\mathrm{DF}=0$ or $\mathrm{DF}=1$
d. Test for $\mathrm{Q}=0$ or $\mathrm{Q}=1$
e. Test for $I E=1$

If the tested condition is met, then Long Skip takes place; the current program counter is incremented twice. Thus two bytes are skipped over and the next instruction in sequence is fetched and executed. If the tested condition is not met, then no action is taken. Execution is continued by fetching the next instruction in sequence.

## Timing Waveforms



NOTES:

1. This timing diagram is used to show signal relationships only and does not represent any specific machine cycle.
2. All measurements are referenced to $50 \%$ point of the waveforms.
3. Shaded areas indicate "Don't Care" or undefined state. Multiple transitions may occur during this period.

FIGURE 15. TIMING WAVEFORMS

Dynamic Electrical Characteristics at $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} ; \mathrm{V}_{\mathrm{DD}} \pm 5 \%$

| CHARACTERISTIC |  |  | CDP1802A, <br> CDP1802AC LIMITS |  | CDP1802BC <br> LIMITS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

## PROPAGATION DELAY TIMES

| Clock to TPA, TPB | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 150 \\ & 100 \end{aligned}$ | $\begin{aligned} & 300 \\ & 250 \\ & 150 \end{aligned}$ | $\begin{gathered} 200 \\ - \\ - \end{gathered}$ | 300 - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock-to-Memory High-Address Byte | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 600 \\ & 400 \\ & 300 \end{aligned}$ | $\begin{aligned} & 850 \\ & 600 \\ & 400 \end{aligned}$ | 475 - - | 525 - - | ns |
| Clock-to-Memory Low-Address Byte Valid | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & \hline 250 \\ & 150 \\ & 100 \end{aligned}$ | $\begin{aligned} & 350 \\ & 250 \\ & 150 \end{aligned}$ | 175 - - | 250 - - | ns |
| Clock to $\overline{\text { MRD }}$ | $t_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 150 \\ & 100 \end{aligned}$ | $\begin{aligned} & 300 \\ & 250 \\ & 150 \end{aligned}$ | 175 - - | 275 - - | ns |
| Clock to $\overline{\text { MRD }}$ | tpLH | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 150 \\ & 100 \end{aligned}$ | $\begin{aligned} & 350 \\ & 290 \\ & 175 \end{aligned}$ | $175$ | 275 - - | ns |
| Clock to $\overline{\text { MWR }}$ | ${ }_{\text {t }}^{\text {PLH }}$, $\mathrm{t}_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 150 \\ & 100 \end{aligned}$ | $\begin{aligned} & 300 \\ & 250 \\ & 150 \end{aligned}$ | 175 - - | 225 - - | ns |
| Clock to (CPU DATA to BUS) Valid | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 300 \\ & 250 \\ & 100 \end{aligned}$ | $\begin{aligned} & 450 \\ & 350 \\ & 200 \end{aligned}$ | 250 - - | 375 - - | ns |
| Clock to State Code | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 300 \\ & 250 \\ & 150 \end{aligned}$ | $\begin{aligned} & 450 \\ & 350 \\ & 250 \end{aligned}$ | 250 - - | 400 - - | ns |
| Clock to Q | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 250 \\ & 150 \\ & 100 \end{aligned}$ | $\begin{aligned} & 400 \\ & 250 \\ & 150 \end{aligned}$ | 200 | 300 - - | ns |
| Clock to $\mathrm{N}(0-2)$ | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} \hline 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 300 \\ & 200 \\ & 150 \end{aligned}$ | $\begin{aligned} & 550 \\ & 350 \\ & 250 \end{aligned}$ | 275 - - | 350 - - | ns |

MINIMUM SET UP AND HOLD TIMES:

| Data Bus Input Set Up | $\mathrm{t}_{\text {SU }}$ | 5 | 5 | -20 | 25 | -20 | 0 | ns |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 5 | 10 | 0 | 50 | - | - |  |
|  |  | 10 | 10 | -10 | 40 | - | - |  |
| Data Bus Input Hold | $\mathrm{t}_{\mathrm{H}^{* *}}$ | 5 | 5 | 150 | 200 | 125 | 150 | ns |
|  |  | 5 | 10 | 100 | 125 | - | - |  |
|  |  | 10 | 10 | 75 | 100 | - | - |  |
| $\overline{\text { DMA }}$ Set Up | $\mathrm{t}_{\text {SU }}$ | 5 | 5 | 0 | 30 | 0 | 30 | ns |
|  |  | 5 | 10 | 0 | 20 | - | - |  |
| $\overline{\text { DMA }}$ Hold |  | 10 | 10 | 0 | 10 | - | - |  |
|  |  | $\mathrm{t}_{\mathrm{H}^{* *}}$ | 5 | 5 | 150 | 250 | 100 | 150 |
|  |  | 5 | 10 | 100 | 200 | - | - | ns |
|  |  | 10 | 10 | 75 | 125 | - | - |  |
| Interrupt Set Up |  | $\mathrm{t}_{\text {SU }}$ | 5 | 5 | -75 | 0 | -75 | 0 |
|  |  | 5 | 10 | -50 | 0 | - | - | ns |
|  |  | 10 | 10 | -25 | 0 | - | - |  |

*Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $V_{D D}$.
**Maximum limits of minimum characteristics are the values above which all devices function

Dynamic Electrical Characteristics at $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} ; \mathrm{V}_{\mathrm{DD}} \pm 5 \%$ (Continued)

| CHARACTERISTIC | SYMBOL | $\begin{aligned} & V_{c c} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & \text { (V) } \end{aligned}$ | CDP1802A, CDP1802AC LIMITS |  | CDP1802BC LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | TYP* | MAX | TYP* | MAX |  |
| MINIMUM SET UP AND HOLD TIMES: (Continued) |  |  |  |  |  |  |  |  |
| Interrupt Hold | $\mathrm{th}^{* *}$ | 5 5 10 | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 100 \\ & 75 \\ & 50 \end{aligned}$ | $\begin{aligned} & 150 \\ & 100 \\ & 75 \end{aligned}$ | 75 - - | 125 - - | ns |
| $\overline{\text { WAIT }}$ Set Up | tsu | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{gathered} 10 \\ -10 \\ 0 \end{gathered}$ | $\begin{aligned} & 50 \\ & 15 \\ & 25 \end{aligned}$ | 20 - - | 40 - - | ns |
| $\overline{\text { EF1-4 Set Up }}$ | $t_{\text {su }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & -30 \\ & -20 \\ & -10 \end{aligned}$ | $\begin{aligned} & 20 \\ & 30 \\ & 40 \end{aligned}$ | -30 - - | 0 <br> - | ns |
| $\overline{\text { EF1-4 }}$ Hold | $t_{\text {H** }}{ }^{*}$ | $\begin{gathered} 5 \\ 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 150 \\ & 100 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{aligned} & 200 \\ & 150 \\ & 100 \\ & \hline \end{aligned}$ | 100 - - | 150 - - | ns |
| Minimum Pulse Width Times: $\overline{\text { CLEAR }}$ Pulse Width | ${ }^{\text {twL** }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 150 \\ & 100 \\ & 75 \end{aligned}$ | $\begin{aligned} & 300 \\ & 200 \\ & 150 \end{aligned}$ | 100 - - | 150 - - | ns |
| $\overline{\text { CLOCK }}$ Pulse Width | twL | 5 5 10 | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{gathered} 125 \\ 100 \\ 60 \end{gathered}$ | $\begin{aligned} & 150 \\ & 125 \\ & 75 \end{aligned}$ | 90 <br> . | 100 <br> - | ns |

*Typical values are for $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$ -
**Maximum limits of minimum characteristics are the values above which all devices function

Timing Specifications as a function of $T\left(T=1 / f_{\text {CLOCK }}\right)$ at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}$

| CHARACTERISTIC | SYMBOL | $v_{c c}$ <br> (V) | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1802A, CDP1802AC LIMITS |  | CDP1802BC LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP* | MIN | TYP* |  |
| High-Order Memory-Address Byte Set Up To TPA $\downarrow$ Time | $\mathrm{t}_{\text {su }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 2 T-550 \\ & 2 T-350 \\ & 2 T-250 \end{aligned}$ | $\begin{aligned} & \text { 2T-400 } \\ & \text { 2T-250 } \\ & \text { 2T-200 } \end{aligned}$ | $2 \mathrm{~T}-325$ - - | 2T-275 - - | ns |
| High-Order Memory-Address Byte Hold after TPA Time | ${ }_{\text {H }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & T / 2-25 \\ & T / 2-35 \\ & T / 2-10 \end{aligned}$ | $\begin{aligned} & T / 2-15 \\ & T / 2-25 \\ & T / 2-+0 \end{aligned}$ | T/2-25 $\cdot$ - | T/2-15 - - | ns |
| Low-Order Memory-Address Byte Hold after WR Time | 4 | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & \mathrm{T}-30 \\ & \mathrm{~T}-20 \\ & \mathrm{~T}-10 \end{aligned}$ | $\begin{aligned} & \mathrm{T}+0 \\ & \mathrm{~T}+0 \\ & \mathrm{~T}+0 \end{aligned}$ | T-30 - - | $T+0$ - - | ns |
| CPU Data to Bus Hold after WR Time | $t_{H}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & \text { T-200 } \\ & \text { T-150 } \\ & \text { T-100 } \end{aligned}$ | $\begin{aligned} & \mathrm{T}-150 \\ & \mathrm{~T}-100 \\ & \mathrm{~T}-50 \end{aligned}$ | T-175 <br>  <br> - | T-125 - - | ns |
| Required Memory Access Time Address to Data | $t_{\text {ACC }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & 5 \mathrm{~T}-375 \\ & \text { 5T-250 } \\ & \text { 5T-190 } \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~T}-250 \\ & 5 \mathrm{~T}-150 \\ & 5 \mathrm{~T}-100 \end{aligned}$ | 5T-225 - - | 5T-175 - - | ns |
| $\overline{M R D}$ to TPA | $\mathrm{t}_{\text {su }}$ | $\begin{gathered} 5 \\ 5 \\ 10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ 10 \end{gathered}$ | $\begin{aligned} & T / 2-25 \\ & T / 2-20 \\ & T / 2-15 \end{aligned}$ | $\begin{aligned} & T / 2-18 \\ & T / 2-15 \\ & T / 2-10 \end{aligned}$ | T/2-20 - - | T/2-15 - - | ns |

*Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$

## CDP1802A, CDP1802AC, CDP1802BC

TABLE 2. CONDITIONS ON DATA BUS AND MEMORY ADDRESS LINES DURING ALL MACHINE STATES

| STATE | 1 | N | MNEMONIC | OPERATION | DATA BUS | MEMORY <br> ADDRESS | $\overline{\text { MRD }}$ | $\overline{M W R}$ | N LINES | NOTES ${ }^{\text {a }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S1 | RESET |  |  | $0 \rightarrow \mathrm{I}, \mathrm{N}, \mathrm{Q}, \mathrm{X}, \mathrm{P} ; 1 \rightarrow \mathrm{IE}$ | 00 | XXXX | 1 | 1 | 0 | A |
|  | Initialize Not Programmer Accessible |  |  | $0000 \rightarrow R$ | 00 | XXXX | 1 | 1 | 0 | B |
| S0 |  | FETCH |  | MRP $\rightarrow \mathrm{I}, \mathrm{N} ; \mathrm{RP}+1 \rightarrow \mathrm{RP}$ | MRP | RP | 0 | 1 | 0 | C |
| S1 | 0 | 0 | IDL | IDLE | MR0 | RO | 0 | 1 | 0 | D, 3 |
|  | 0 | 1-F | LDN | MRN $\rightarrow$ D | MRN | RN | 0 | 1 | 0 | 3 |
|  | 1 | O-F | INC | $\mathrm{RN}+1 \rightarrow \mathrm{RN}$ | Float | RN | 1 | 1 | 0 | 1 |
|  | 2 | O-F | DEC | $\mathrm{RN}-1 \rightarrow \mathrm{RN}$ | Float | RN | 1 | 1 | 0 | 1 |
|  | 3 | O-F | Short Branch | Taken: MRP $\rightarrow$ RP. 0 Not Taken; RP + $1 \rightarrow$ RP | MRP | RP | 0 | 1 | 0 | 3 |
|  | 4 | 0-F | LDA | MRN $\rightarrow$ D; RN + $1 \rightarrow$ RN | MRN | RN | 0 | 1 | 0 | 3 |
|  | 5 | O-F | STR | D $\rightarrow$ MRN | D | RN | 1 | 0 | 0 | 2 |
|  | 6 | 0 | IRX | $R X+1 \rightarrow R X$ | MRX | RX | 0 | 1 | 0 | 2 |
|  | 6 | 1 | OUT 1 | MRX $\rightarrow$ BUS; RX $+1 \rightarrow \mathrm{RX}$ | MRX | RX | 0 | 1 | 1 | 6 |
|  |  | 2 | OUT 2 |  |  |  |  |  | 2 |  |
|  |  | 3 | OUT 3 |  |  |  |  |  | 3 |  |
|  |  | 4 | OUT 4 |  |  |  |  |  | 4 |  |
|  |  | 5 | OUT 5 |  |  |  |  |  | 5 |  |
|  |  | 6 | OUT 6 |  |  |  |  |  | 6 |  |
|  |  | 7 | OUT 7 |  |  |  |  |  | 7 |  |
|  |  | 9 | INP 1 | BUS $\rightarrow$ MRX, D | $\begin{aligned} & \text { Data } \\ & \text { from I/O } \\ & \text { Device } \end{aligned}$ | RX | 1 | 0 | 1 | 5 |
|  |  | A | INP 2 |  |  |  |  |  | 2 |  |
|  |  | B | INP 3 |  |  |  |  |  | 3 |  |
|  |  | C | INP 4 |  |  |  |  |  | 4 |  |
|  |  | D | INP 5 |  |  |  |  |  | 5 |  |
|  |  | E | INP 6 |  |  |  |  |  | 6 |  |
|  |  | F | INP 7 |  |  |  |  |  | 7 |  |
|  | 7 | 0 | RET | $\operatorname{MRX}_{1 \rightarrow \mathrm{IE}}(X, P) ; R X+1 \rightarrow R X ;$ | MRX | RX | 0 | 1 | 0 | 3 |
|  |  | 1 | DIS | $\operatorname{MRX}_{0 \rightarrow I E}(X, P) ; R X+1 \rightarrow R X ;$ | MRX | RX | 0 | 1 | 0 | 3 |
|  |  | 2 | LDXA | MRX $\rightarrow$ D; $R X+1 \rightarrow R X$ | MRX | RX | 0 | 1 | 0 | 3 |
|  |  | 3 | STXD | $D \rightarrow M R X ; R X-1 \rightarrow R X$ | D | RX | 1 | 0 | 0 | 2 |
|  |  | 4 | ADC | MRX + D + DF $\rightarrow$ DF, D | MRX | RX | 0 | 1 | 0 | 3 |
|  |  | 5 | SDB | MRX - D - DFN $\rightarrow$ DF, D | MRX | RX | 0 | 1 | 0 | 3 |

NOTES:
A. $I E=1$, TPA, TPB suppressed, state $=S 1$.
B. BUS $=0$ for entire cycle.
C. Next state always $\mathbf{S 1}$.
D. Wait for DMA or INTERRUPT.
E. Suppress TPA, wait for DMA.
F. IN REQUEST has priority over OUT REQUEST.
G. Number refers to machine cycle. See Figure 16 timing waveforms for machine cycles 1 through 9 .

CDP1802A, CDP1802AC, CDP1802BC

TABLE 2. CONDITIONS ON DATA BUS AND MEMORY ADDRESS LINES DURING ALL MACHINE STATES (Continued)

| STATE | 1 | N | MNEMONIC | OPERATION | DATA BUS | MEMORY ADDRESS | $\overline{\text { MRD }}$ | $\overline{M W R}$ | $\stackrel{N}{\text { NINES }}$ | NOTES ${ }^{\text {a }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { S1 } \\ \text { (Cont.) } \end{gathered}$ | $\begin{array}{\|c\|} \hline 7 \\ \text { (c } \\ o \\ \mathrm{n} \\ \mathrm{t} .) \end{array}$ | 6 | SHRC | $\mathrm{LSB}(\mathrm{D}) \rightarrow \mathrm{DF} ; \mathrm{DF} \rightarrow \mathrm{MSB}(\mathrm{D})$ | Float | RX | 1 | 1 | 0 | 1 |
|  |  | 7 | SMB | D - MRX - DFN $\rightarrow$ DF, D | MRX | RX | 0 | 1 | 0 | 3 |
|  |  | 8 | SAV | $\mathrm{T} \rightarrow \mathrm{MRX}$ | T | RX | 1 | 0 | 0 | 2 |
|  |  | 9 | MARK | $\begin{aligned} & (X, P) \rightarrow T, M R 2 ; P \rightarrow X ; \\ & \text { R2 }-1 \rightarrow R 2 \end{aligned}$ | T | R2 | 1 | 0 | 0 | 2 |
|  |  | A | REQ | $0 \rightarrow$ Q | Float | RP | 1 | 1 | 0 | 1 |
|  |  | B | SEQ | $1 \rightarrow \mathrm{Q}$ | Float | RP | 1 | 1 | 0 | 1 |
|  |  | C | ADCI | MRP + D + DF $\rightarrow$ DF, D; RP + 1 | MRP | RP | 0 | 1 | 0 | 3 |
|  |  | D | SDBI | MRP - D - DFN $\rightarrow$ DF, D; RP + 1 | MRP | RP | 0 | 1 | 0 | 3 |
|  |  | E | SHLC | MSB(D) $\rightarrow$ DF; DF $\rightarrow$ LSB(D) | Float | RP | 1 | 1 | 0 | 1 |
|  |  | F | SMBI | D - MRP - DFN $\rightarrow$ DF, D; RP + 1 | MRP | RP | 0 | 1 | 0 | 3 |
|  | 8 | 0-F | GLO | RN. $\mathrm{O} \rightarrow \mathrm{D}$ | RN. 0 | RN | 1 | 1 | 0 | 1 |
|  | 9 | O-F | GHI | RN. $1 \rightarrow$ D | RN. 1 | RN | 1 | 1 | 0 | 1 |
|  | A | 0-F | PLO | $\mathrm{D} \rightarrow$ RN. 0 | D | RN | 1 | 1 | 0 | 1 |
|  | B | O-F | PHI | $\mathrm{D} \rightarrow$ RN. 1 | D | RN | 1 | 1 | 0 | 1 |
| S1\#1 | C | $\begin{aligned} & 0-3, \\ & 8-B \end{aligned}$ | Long Branch | Taken: MRP $\rightarrow$ B; RP + $1 \rightarrow$ RP | MRP | RP | 0 | 1 | 0 | 4 |
| \#2 |  |  |  | Taken: B $\rightarrow$ RP.1; MRP $\rightarrow$ RP. 0 | M(RP + 1) | RP + 1 | 0 | 1 | 0 | 4 |
| S1\#1 |  |  |  | Not Taken: RP + $1 \rightarrow$ RP | MRP | RP | 0 | 1 | 0 | 4 |
| \#2 |  |  |  | Not Taken: RP + $1 \rightarrow$ RP | M(RP + 1) | RP + 1 | 0 | 1 | 0 | 4 |
| S1\#1 |  | $\begin{aligned} & \hline 5 \\ & 6 \\ & 7 \\ & C \\ & D \\ & E \\ & F \end{aligned}$ | Long Skıp | Taken: RP + $1 \rightarrow$ RP | MRP | RP | 0 | 1 | 0 | 4 |
| \#2 |  |  |  | Taken: RP + $1 \rightarrow \mathrm{RP}$ | M(RP + 1) | RP + 1 | 0 | 1 | 0 | 4 |
| S1\#1 |  |  |  | Not Taken: No Operation | MRP | RP | 0 | 1 | 0 | 4 |
| \#2 |  |  |  | Not Taken: No Operation | MRP | RP | 0 | 1 | 0 | 4 |
| S1\#1 |  | 4 | NOP | No Operation | MRP | RP | 0 | 1 | 0 | 4 |
| \#2 |  |  |  | No Operation | MRP | RP | 0 | 1 | 0 | 4 |
| S1 | D | O-F | SEP | $\mathrm{N} \rightarrow \mathrm{P}$ | NN | RN | 1 | 1 | 0 | 1 |
|  | E | O-F | SEX | $\mathrm{N} \rightarrow \mathrm{X}$ | NN | RN | 1 | 1 | 0 | 1 |
| S1 | F | 0 | LDX | MRX $\rightarrow$ D | MRX | RX | 0 | 1 | 0 | 3 |
|  |  | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 7 \end{aligned}$ | OR AND XOR ADD SD SM | MRX ORD $\rightarrow$ D MRX AND D $\rightarrow$ D MRX XOR D $\rightarrow$ D MRX + D $\rightarrow$ DF, D $M R X-D \rightarrow D F, D$ $D-M R X \rightarrow D F, D$ | MRX | RX | 0 | 1 | 0 | 3 |
|  |  | 6 | SHR | LSB(D) $\rightarrow$ DF; $0 \rightarrow$ MSB(D) | Float | RX | 1 | 1 | 0 | 1 |

## NOTES:

A. $I E=1, T P A, T P B$ suppressed, state $=S 1$.
B. $B U S=0$ for entire cycle.
C. Next state always S 1 .
D. Wait for DMA or INTERRUPT.

TABLE 2. CONDITIONS ON DATA BUS AND MEMORY ADDRESS LINES DURING ALL MACHINE STATES (Continued)

| STATE | 1 | N | MNEMONIC | OPERATION | DATA BUS | MEMORY <br> ADDRESS | $\overline{\text { MRD }}$ | $\overline{\text { MWR }}$ | $\begin{gathered} \mathrm{N} \\ \text { LINES } \end{gathered}$ | NOTES ${ }^{\text {G }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S1 (Cont.) | F(c0nt) | $\begin{aligned} & \hline 8 \\ & 9 \\ & \text { A } \\ & \text { B } \\ & \text { C } \\ & \text { D } \\ & \text { F } \end{aligned}$ | LDI ORI ANI XRI ADI SDI SMI | $\mathrm{MRP} \rightarrow \mathrm{D} ; \mathrm{RP}+1 \rightarrow \mathrm{RP}$ <br> MRP OR D $\rightarrow \mathrm{D} ; \mathrm{RP}+1 \rightarrow$ RP <br> MRP AND D $\rightarrow$ D; RP $+1 \rightarrow$ RP <br> MRP XOR D $\rightarrow$ D; RP + $1 \rightarrow$ RP <br> $M R P+D \rightarrow D F, D ; R P+1 \rightarrow R P$ <br> MRP - D $\rightarrow$ DF, D; RP + $1 \rightarrow R P$ <br> $D-M R P \rightarrow D F, D ; R P+1 \rightarrow R P$ | MRP | RP | 0 | 1 | 0 | 3 |
|  |  | E | SHL | $\mathrm{MSB}(\mathrm{D}) \rightarrow \mathrm{DF} ; 0 \rightarrow$ LSB(D) | Float | RP | 1 | 1 | 0 | 1 |
| S2 | DMA IN |  |  | BUS $\rightarrow$ MR0; R0 + $1 \rightarrow$ RO | Data from I/O Device | R0 | 1 | 0 | 0 | F, 7 |
|  | DMA OUT |  |  | MR0 $\rightarrow$ BUS; R0 + $1 \rightarrow$ R0 | MR0 | R0 | 0 | 1 | 0 | F, 8 |
| S3 | INTERRUPT |  |  | $X, P \rightarrow T ; 0 \rightarrow I E, 1 \rightarrow P ; 2 \rightarrow X$ | Float | RN | 1 | 1 | 0 | 9 |
| S1 | LOAD |  |  | IDLE ( $\overline{\text { CLEAR, }} \overline{\text { WAIT }}=0$ ) | M(R0-1) | R0-1 | 0 | 1 | 0 | E, 3 |

NOTES:
A. $I E=1$, TPA, TPB suppressed, state $=$ S1 .
B. $B U S=0$ for entire cycle.
C. Next state always S1.
D. Wait for DMA or INTERRUPT.
E. Suppress TPA, wait for DMA.
F. IN REQUEST has priority over OUT REQUEST.
G. Number refers to machine cycle. See Figure 16 timing waveforms for machine cycles 1 through 9 .


GENERAL TIMING WAVEFORMS


NO. 1 NON MEMORY CYCLE TIMING WAVEFORMS
high impedance state
FIGURE 16. MACHINE CYCLE TIMING WAVEFORMS (PROPAGATION DELAYS NOT SHOWN)


NO. 2 MEMORY WRITE CYCLE TIMING WAVEFORMS


NO. 3 MEMORY READ CYCLE TIMING WAVEFORMS


NO. 4 LONG BRANCH OR LONG SKIP CYCLE TIMING WAVEFORMS

DON'T CARE" OR INTERNAL DELAYS
high impedance state
FIGURE 16. MACHINE CYCLE TIMING WAVEFORMS (PROPAGATION DELAYS NOT SHOWN) (Continued)

*User generated sıgnal
NO. 5 INPUT CYCLE TIMING WAVEFORMS

*User generated signal
NO. 6 OUTPUT CYCLE TIMING WAVEFORMS

FIGURE 16. MACHINE CYCLE TIMING WAVEFORMS (PROPAGATION DELAYS NOT SHOWN) (Continued)

*User generated signal
NO. 7 DMA IN CYCLE TIMING WAVEFORMS

*User generated signal
NO. 8 DMA OUT CYCLE TIMING WAVEFORMS
"DON'T CARE" OR INTERNAL DELAYS
HIGH IMPEDANCE STATE

FIGURE 16. MACHINE CYCLE TIMING WAVEFORMS (PROPAGATION DELAYS NOT SHOWN) (Continued)

*User generated signal
NO. 9 INTERRUPT CYCLE TIMING WAVEFORMS

## DON'T CARE" OR INTERNAL DELAYS

HIGH IMPEDANCE STATE
FIGURE 16. MACHINE CYCLE TIMING WAVEFORMS (PROPAGATION DELAYS NOT SHOWN) (Continued)

## Operating and Handling Considerations

## 1. Handling

All inputs and outputs of Harris CMOS devices have a network for electrostatic protection during handling.
2. Operating

## Operating Voltage

During operation near the maximum supply voltage limit, care should be taken to avoid or suppress power supply turn-on and turn-off transients, power supply ripple, or ground noise; any of these conditions must not cause $V_{D D}-V_{S S}$ to exceed the absolute maximum rating.

## Input Signals

To prevent damage to the input protection circuit, input signals should never be greater than $\mathrm{V}_{\mathrm{DD}}$ nor less than $\mathrm{V}_{\mathrm{SS}}$. Input currents must not exceed 10 mA even when the power supply is off.

## Unused Inputs

A connection must be provided at every input terminal. All unused input terminals must be connected to either $V_{D D}$ or $V_{S S}$, whichever is appropriate.

## Output Short Circuits

Shorting of outputs to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ may damage CMOS devices by exceeding the maximum device dissipation.

## Features

- For Use In Aerospace, Military, and Critical Industrial Equipment
- Minimum Instruction Fetch-Execute time of $2.2 \mu \mathrm{~s}$ (Maximum Clock Frequency of 7.4 MHz ) at $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+\mathbf{2 5 ^ { \circ }} \mathrm{C}$
- Operation Over the Full Military Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- Any Combination of Standard RAM and ROM Up To 65,536 Bytes
- 8-Bit Parallel Organization With Bidirectional Data Bus and Multiplexed Address Bus
- $16 \times 16$ Matrix of Registers for Use as Multiple Program Counters, Data Pointers, or Data Registers
- On-Chip DMA, Interrupt, and Flag Inputs
- High Noise Immunity . . . . . . . . . . . . . . 30\% of $V_{D D}$


## Description

The CDP 1802A/3 high-reliability LSI CMOS 8-bit registeroriented central-processing unit (CPU) is designed for use as a general-purpose computing or control element in a wide range of stored-program systems or products.

The CDP1802A/3 includes all of the circuits required for fetching, interpreting, and executing instructions which have been stored in standard types of memories. Extensive input/output (I/O) control features are also provided to facilitate system design.

The 1800 series architecture is designed with emphasis on the total microcomputer system as an integral entity so that systems having maximum flexibility and minimum cost can be realized. The 1800 series CPU also provides a synchronous interface to memories and external controllers for I/O devices, and minimizes the cost of interface controllers. Further, the I/O interface is capable of supporting devices operating in polled, interrupt-driven, or direct memory-access modes.
The CDP1802A/3 and CDP1802AC/3 are functionally identical. They differ in that the CDP1802A/3 has a recommended operating voltage range of 4 V to 10.5 volts, and the CDP1802AC/3 a recommended operating voltage range of 4 to 6.5 volts.

The CDP1802A/3 is functionally identical to its predecessor, the CDP1802. The "A" version includes some performance enhancements and can be used as a direct replacement in systems using the CDP1802.

These types are supplied in 40 lead dual-in-line sidebrazed ceramic packages (D suffix), that conforms to Mil-M-38510 case outline D-5.

## Pinout

40 LEAD SIDEBRAZED CERAMIC DIP (PACKAGE TYPE D) TOP VIEW


## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ):
(All Voltages Referenced to $\mathrm{V}_{\mathrm{SS}}$ Termınal)
CDP1802A/3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.5 V to +11 V
CDP1802AC/3. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.5 V to +7 V
Input Voltage Range, All Inputs .............. -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$
DC Input Current, any One Input.
Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ )
$T_{A}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (Package Type D) . . . . . . . . . . . . . 500 mW
$\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Package Type D) . . . . Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW

Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range . . . . . . . . . . . . . . . . 100 mW
Operating Temperature Range ( $T_{A}$ ):
Package Type D
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stg }}$ ) $\ldots \ldots \ldots \ldots-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{ln}$. $(1.59 \pm 0.79 \mathrm{~mm})$
from case for 10s max
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions $\mathrm{T}_{\mathrm{A}}=$ Full-Package Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges.

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1802A/3 |  | CDP1802AC/3 |  |  |
|  | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {S }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |
| Maxımum Clock Input Rise or Fall Tıme | - | 1 | - | 1 | $\mu \mathrm{s}$ |

## Performance Characteristics

| CHARACTERISTIC | $\mathbf{v}_{\mathrm{DD}}$ | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1802A/3 |  | CDP1802AC/3 |  |  |
|  |  | $-55^{\circ} \mathrm{C}$ to $+25^{\circ} \mathrm{C}$ | $+125^{\circ} \mathrm{C}$ | $-55^{\circ} \mathrm{C}$ to $+25^{\circ} \mathrm{C}$ | $+125^{\circ} \mathrm{C}$ |  |
| Minimum Instruction Time (Note 1) | $\begin{gathered} \hline 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 4.5 \\ & 2.2 \end{aligned}$ | $\begin{aligned} & 5.9 \\ & 2.8 \end{aligned}$ | $4.5$ | $5.9$ | $\mu \mathrm{s}$ |
| Maximum DMA Transfer Rate | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 450 \\ & 925 \end{aligned}$ | $\begin{aligned} & 340 \\ & 700 \end{aligned}$ | $450$ | $340$ | Kbytes/s |
| Maximum Clock Input Frequency, Load Capacitance $\left(\mathrm{C}_{\mathrm{L}}\right)=50 \mathrm{pF} \quad \mathrm{f}_{\mathrm{CL}}$ | $\begin{gathered} \hline 5 \\ 10 \end{gathered}$ | $\begin{aligned} & \hline \mathrm{DC}-3.6 \\ & \mathrm{DC}-7.4 \end{aligned}$ | $\begin{aligned} & \mathrm{DC}-2.7 \\ & \mathrm{DC}-5.6 \end{aligned}$ | $D C-3.6$ | DC-2.7 | MHz |

NOTES:

1. Equals 2 machine cycles - one Fetch and one Execute operation for all instructions except Long Branch and Long Skip, which require 3 machine cycles - one Fetch and two Execute operations.


FIGURE 1. TYPICAL CDP1802A/3 SMALL MICROPROCESSOR SYSTEM

Static Electrical Characteristics All Limits are 100\% Tested

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{V}_{\text {OUT }}$ <br> (V) | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | $\mathbf{v}_{\mathrm{CC}}, \mathbf{v}_{\mathrm{DD}}$ <br> (V) | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Quiescent Device Current | $\mathrm{I}_{\mathrm{DD}}$ | - | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 100 \\ & 120 \end{aligned}$ | - | 250 300 | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | $\mathrm{I}_{\mathrm{OL}}$ | 0.4 | 0, 5 | 5 | 1.20 | - | 0.90 | - | mA |
| (Except $\overline{\text { XTAL }}$ ) |  | 0.5 | 0, 10 | 10 | 2.50 | - | 1.85 | - | mA |
| $\overline{\text { XTAL }}$ |  | 0.4 | 5 | 5 | 185 | - | 140 | - | $\mu \mathrm{A}$ |
| Output High Drive (Source) Current | $\mathrm{IOH}^{\text {a }}$ | 4.6 | 0, 5 | 5 | - | -0.30 | - | -0.20 | mA |
| (Except $\overline{\mathrm{XTAL}}$ ) |  | 9.5 | 0, 10 | 10 | - | -0.60 | - | -0.40 | mA |
| $\overline{\text { XTAL }}$ |  | 4.6 | 0 | 5 | - | -135 | - | -100 | $\mu \mathrm{A}$ |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0.1 | - | 0.2 | V |
|  |  | - | 0, 10 | 10 | - | 0.1 | - | 0.2 | V |
| Output Voltage High Level | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | - | 4.8 | - | V |
|  |  | - | 0, 10 | 10 | 9.9 | - | 9.8 | - | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | 0.5, 4.5 | - | 5 | - | 1.5 | - | 1.5 | V |
|  |  | 1, 9 | - | 10 | - | 3 | - | 3 | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 4.5 | - | 5 | 3.5 | - | 3.5 | - | V |
|  |  | 1,9 | - | 10 | 7 | - | 7 | - | V |
| Input Leakage Current | IN | Any Input | 0, 5 | 5 | - | $\pm 1$ | - | $\pm 5$ | $\mu \mathrm{A}$ |
|  |  |  | 0, 10 | 10 | - | $\pm 1$ | - | $\pm 5$ | $\mu \mathrm{A}$ |
| 3-State Output Leakage Current | lout | 0,5 | 0,5 | 5 | - | $\pm 1$ | - | $\pm 5$ | $\mu \mathrm{A}$ |
|  |  | 0, 10 | 0, 10 | 10 | - | $\pm 1$ | - | $\pm 5$ | $\mu \mathrm{A}$ |

NOTE:

1. 5 V level characteristics apply to part CDP1802AC/3.

5 V and 10 V level characteristics apply to part CDP1802A/3.


FIGURE 2. TYPICAL MAXIMUM CLOCK FREQUENCY AS A FUNCTION OF TEMPERATURE


FIGURE 3. TYPICAL MAXIMUM CLOCK FREQUENCY AS A FUNCTION OF SUPPLY VOLTAGE


FIGURE 4. TYPICAL TRANSITION TIME VS. LOAD CAPACITANCE


FIGURE 6. MINIMUM OUTPUT LOW (SINK) CURRENT CHARACTERISTICS


FIGURE 5. MINIMUM OUTPUT HIGH (SOURCE) CURRENT CHARACTERISTICS


FIGURE 7. TYPICAL POWER DISSIPATION AS A FUNCTION OF CLOCK FREQUENCY FOR BRANCH INSTRUCTION AND IDLE INSTRUCTION


FIGURE 8. TYPICAL CHANGE IN PROPAGATION DELAY AS A FUNCTION OF A CHANGE IN LOAD CAPACITANCE

Specifications CDP1802A/3, CDP1802AC/3

Timing Specifications as a function of $T\left(T=1 / f_{\text {CLOCK }}\right), C_{L}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | $V_{D D}$ <br> (V) | LIMITS* |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ | $+125^{\circ} \mathrm{C}$ |  |
| High-Order Memory-Address Byte | $t_{\text {su }}$ | 5 | 2T-450 | 2T-580 | ns |
| Set Up to TPA Time |  | 10 | 2T-210 | 2T-275 | ns |
| High-Order Memory-Address Byte <br> Hold After TPA Time | $t_{H}$ | 5 | T/2+0 | T/2+0 | ns |
|  |  | 10 | T/2/+0 | T/2+0 | ns |
| Low-Order Memory-Address Byte Hold After WR Time | $t_{\text {H }}$ | 5 | T-30 | T-40 | ns |
|  |  | 10 | T-10 | T-20 | ns |
| CPU Data to Bus Hold After WR Time | $t_{H}$ | 5 | T-170 | T-250 | ns |
|  |  | 10 | T-80 | T-110 | ns |
| Required Memory Access Time <br> Address to Data | $t_{\text {ACC }}$ | 5 | $5 \mathrm{~T}-300$ | 5T-400 | ns |
|  |  | 10 | $5 \mathrm{~T}-150$ | 5T-200 | ns |

*These limits are not directly tested.

Implicit Characteristics** $T_{A}=-55^{\circ} \mathrm{C}$ to $+25^{\circ} \mathrm{C}$

| CHARACTERISTICS |  | SYMBOL | $\mathbf{V}_{\mathrm{DD}}(\mathbf{V})$ | TYPICAL VALUES | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Typical Total Power Dissipation | $\mathrm{f}=2 \mathrm{MHz}$ |  | 5 - | 4 | mW |
| Idle "00" at $M(000), C_{L}=50 \mathrm{pF}$ | $\mathrm{f}=4 \mathrm{MHz}$ |  | 10 | 30 | mW |
| Effective Input Capacitance Any Input |  | $\mathrm{C}_{\mathrm{IN}}$ | - | 5 | pF |
| Effective 3-State Termınal Capacitance DATA BUS |  |  | - | 7.5 | pF |
| Mınımum Data Retentıon Voltage |  | VDR | - | 2.4 | V |
| Data Retention Current |  | IDR | 2.4 | 10 | $\mu \mathrm{A}$ |

**These characteristics are not tested. Typical values are provided for guidance only.


NOTES:

1. This timing diagram is used to show signal relationships only and does not represent any specific machine cycle.
2. All measurements are referenced to $50 \%$ point of the waveforms.
3. Shaded areas indicate "don't care" or undefined state. Multiple transitions may occur during this period.

FIGURE 9. TIMING WAVEFORMS

Specifications CDP1802A/3, CDP1802AC/3
Dynamic Electrical Characteristics $C_{L}=50 \mathrm{pF}$, Timing Measurement at $0.5 \mathrm{~V}_{\mathrm{DD}}$ Point

| CHARACTERISTIC | SYMBOL | $\mathrm{V}_{\mathrm{DD}}(\mathrm{V})$ | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ TO $+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Propagation Delay Times | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 5 | - | 275 | - | 370 | ns |
| Clock to TPA, TPB |  | 10 | - | 125 | - | 170 |  |
| Clock-to-Memory High Address | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 5 | - | 725 | - | 950 | ns |
| Byte |  | 10 | - | 340 | - | 450 |  |
| Clock-to-Memory Low-Address | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 5 | - | 340 | - | 425 | ns |
| Byte Valid |  | 10 | - | 150 | - | 200 |  |
| Clock to $\overline{\mathrm{MRD}}$ | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 5 | - | 340 | - | 425 | ns |
|  |  | 10 | - | 150 | - | 200 |  |
| Clock to $\overline{\mathrm{MWR}}$ | $\mathrm{t}_{\text {PLH }} \mathrm{t}_{\text {PHL }}$ | 5 | - | 275 | - | 370 | ns |
|  |  | 10 | - | 125 | - | 170 |  |
| Clock to (CPU DATA to BUS) Valid | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 5 | - | 430 | - | 550 | ns |
|  |  | 10 | - | 200 | - | 260 |  |
| Clock to State Code | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 5 | - | 440 | - | 550 | ns |
|  |  | 10 | - | 200 | - | 260 |  |
| Clock to Q | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 5 | - | 375 | - | 475 | ns |
|  |  | 10 | - | 175 | - | 230 |  |
| Clock to N (0-2) | $\mathrm{t}_{\mathrm{PLH}}, \mathrm{t}_{\text {PHL }}$ | 5 | - | 400 | - | 525 | ns |
|  |  | 10 | - | 200 | - | 260 |  |
| Interface Timing Requirements: <br> Data Bus Input Setup | tsu | 5 | 10 | - | 10 | - | ns |
|  |  | 10 | 20 | - | 20 | - |  |
| Data Bus Input Hold (Note 1) | $\mathrm{t}_{\mathrm{H}}$ | 5 | 175 | - | 230 | - | ns |
|  |  | 10 | 80 | - | 110 | - |  |
| $\overline{\overline{\text { DMA }} \text { Setup }}$ | $\mathrm{t}_{\text {su }}$ | 5 | 10 | - | 10 | - | ns |
|  |  | 10 | 20 | - | 20 | - |  |
| $\overline{\text { DMA }}$ Hold (Note 1) | $\mathrm{t}_{\mathrm{H}}$ | 5 | 200 | - | 270 | - | ns |
|  |  | 10 | 100 | - | 135 | - |  |
| Interrupt Setup | tsu | 5 | 10 | - | 10 | - | ns |
|  |  | 10 | 20 | - | 20 | - |  |
| Interrupt Hold (Note 1) | $\mathrm{t}_{\mathrm{H}}$ | 5 | 175 | - | 230 | - | ns |
|  |  | 10 | 80 | - | 110 | - |  |
| $\overline{\overline{W A I T}}$ Setup | $\mathrm{t}_{\text {su }}$ | 5 | 30 | - | 30 | - | ns |
|  |  | 10 | 20 | - | 20 | - |  |
| $\overline{\overline{E F 1-4}}$ Setup | tsu | 5 | 20 | - | 20 | - | ns |
|  |  | 10 | 50 | - | 50 | - |  |
| $\overline{\text { EF1-4 Hold (Note 1) }}$ | $\mathrm{t}_{\mathrm{H}}$ | 5 | 100 | - | 135 | - | ns |
|  |  | 10 | 50 | - | 65 | - |  |
| Required Pulse Width Times (Note 1): | $t_{\text {WL }}$ | 5 | 150 | - | 200 | - | ns |
| $\overline{\text { CLEAR Pulse Width (Note 1) }}$ |  | 10 | 75 | - | 100 | - |  |
| CLOCK Pulse Width | ${ }^{\text {twL }}$ | 5 | 140 | - | 185 | - | ns |
|  |  | 10 | 68 | - | 90 | - |  |

5 V level characteristics apply to part CDP1802AC/3
5 V level and 10 V level characteristics apply to part CDP1802A/3
NOTE:

1. Minimum input Setup and Hold Times required by part CDP1802A/3


| TYPE | V $_{\text {DD }}$ | TEMPERATURE | TIME |
| :--- | :---: | :---: | :---: |
| CDP1802A | 11 V | $+125^{\circ} \mathrm{C}$ | 160 Hours |
| CDP1802AC | 7 V | $+125^{\circ} \mathrm{C}$ | 160 Hours |

FIGURE 10. BIAS/STATIC BURN-IN CIRCUIT

# CMOS 8-Bit Microprocessor With On-Chip RAM* and Counter/Timer 

## Features

- Instruction Time of $3.2 \mu \mathrm{~s},-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- 123 Instructions - Upwards Software Compatible With CDP1802
- BCD Arithmetic Instructions
- Low-Power IDLE Mode
- Pin Compatible With CDP1802 Except for Terminal 16
- 64K-Byte Memory Address Capability
- 64 Bytes of On-Chip RAM*
- $16 \times 16$ Matrix of On-Board Registers
- On-Chip Crystal or RC Controlled Oscillator
- 8-Bit Counter/Timer
*CDP1805AC Only


## Description

The CDP1805AC and CDP1806AC are functional and performance enhancements of the CDP1802 CMOS 8-Bit register-oriented microprocessor series and are designed for use in general-purpose applications.

The CDP1805AC hardware enhancements include a 64-byte RAM and an 8-bit presettable down counter. The Counter/Timer which generates an internal interrupt request, can be programmed for use in time-base, event-counting, and pulse-duration measurement applications. The Counter/Timer underflow output can also be directed to the Q output terminal. The CDP1806AC hardware enhancements are identical to the CDP1805AC, except the CDP1806AC contains no on-chip RAM.

The CDP1805AC and CDP1806AC are identical to the CDP1804AC, except for the on-chip memory, and may be used for CDP1804AC development purposes.

The CDP1805AC and CDP1806AC software enhancements include 32 more instructions than the CDP1802. The 32 new software instructions add subroutine call and return capability, enhanced data transfer manipulation, Counter/ Timer control, improved interrupt handling, single-instruction loop counting, and BCD arithmetic.

Upwards software and hardware compatibility is maintained when substituting a CDP1805AC or CDP1806AC for other CDP1800-series microprocessors. Pinout is identical except for the replacement of $V_{C C}$ with $\overline{M E}$ on the CDP1805AC and the replacement of $V_{C C}$ with $V_{D D}$ on the CDP1806AC.
The CDP1805AC and CDP1806AC have an operating voltage range of 4 V to 6.5 V and are supplied in a 40 lead hermetic dual-in-line ceramic package (D suffix), 40 lead dual-in-line plastic package ( E suffix) and 44 lead plastic leaded chip carrier (PLCC) package (Q suffix).

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | CDP1805AC | CDP1806AC |
| :--- | :---: | :--- | :--- |
| Plastic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1805ACE | CDP1806ACE |
|  |  | CDP1805ACEX | CDP1806ACEX |
| PLCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1805ACQ | CDP1806ACQ |
| Ceramic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1805ACD | CDP1806ACD |
|  |  | CDP1805ACDX | CDP1806ACDX |

## Pinouts



* $\overline{M E}$ For CDP1805AC
$V_{D D}$ for CDP1806AC

Schematic


FIGURE 1. TYPICAL CDP1805AC, CDP1806AC SMALL MICROPROCESSOR SYSTEM

| Absolute Maximum Ratings |  |
| :---: | :---: |
| DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ): <br> (All Voltages Referenced to $\mathrm{V}_{\text {SS }}$ Terminal) . . . . . . . -0.5 V to +7 V |  |
| Input Voltage Range, All inputs | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, any One Input. | $\pm 10 \mathrm{~mA}$ |
| Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ ) |  |
| $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (Package Type E). | 500 mW |
| $\mathrm{T}_{\mathrm{A}}=+60^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type E) | . Derate Linearly |
| At $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |  |
| $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (Package Type D) | 500mW |
| $\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Package Type D) | Derate Linearly at |
| $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |  |
| $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type | 500 m |

Device Dissipation Par Output Transistor
$T_{A}=$ Full Package Temperature Range 100 mW
Operating Temperature Range ( $T_{A}$ ):
Package Type D. . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Package Type E and Q . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stg }}$ ) $\ldots \ldots \ldots \ldots . . . .5^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{ln}$. ( $1.59 \pm 0.79 \mathrm{~mm}$ ) from case for 10 s

*Printed circuit board mount: $57 \mathrm{~mm} \times 57 \mathrm{~mm}$ minimum area $\times 1.6 \mathrm{~mm}$ thick G10 epoxy glass, or equivalent.

Recommended Operating Conditions $T_{A}=$ Full-Package Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges.

| CHARACTERISTIC | SYMBOL | $\begin{aligned} & \text { CONDITION } \\ & V_{D D} \\ & (V) \end{aligned}$ | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1805ACD, CDP1805ACE CDP1806ACD, CDP1806ACE |  |  |
|  |  |  | MIN | MAX |  |
| DC Operating Voltage Range |  | - | 4 | 6.5 | V |
| Input Voltage Range |  | - | $\mathrm{V}_{\text {ss }}$ | $V_{D D}$ | V |
| Minimum Instruction Time* (fcL $=5 \mathrm{MHz}$ ) |  | 5 | 3.2 | - | $\mu \mathrm{s}$ |
| Maximum DMA Transfer Rate |  | 5 | - | 0.625 | Mbyte/s |
| Maximum Clock Input Frequency, Load Capacitance ( $\mathrm{C}_{\mathrm{L}}$ ) $=50 \mathrm{pF}$ |  | 5 | DC | 5 | MHz |
| Maximum External Counter/Timer Clock Input Frequency to $\overline{\mathrm{EF} 1}, \overline{\mathrm{EF} 2}$ | $\mathrm{t}_{\text {cLx }}$ | 5 | DC | 2 | MHz |

*Equals 2 machine cycles - one Fetch and one Execute operation for all instructions except Long Branch, Long Skip, NOP, and "68" family instructions, which are more than two cycles.

Specifications CDP1805AC, CDP1806AC
Static Electrical Characteristics at $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$, Except as Noted

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & v_{o} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & V_{\mathbf{I N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1805ACD, CDP1805ACE CDP1806ACD, CDP1806ACE |  |  |  |
|  |  |  |  |  | MIN | TYP* | MAX |  |
| Quiescent Device Current | $I_{\text {DD }}$ | - | 0,5 | 5 | - | 50 | 200 | $\mu \mathrm{s}$ |
| Output Low Drive (Sink) Current (Except XTAL) | loL | 0.4 | 0,5 | 5 | 1.6 | 4 | - | mA |
| $\overline{\text { XTAL Output }}$ | loL | 0.4 | 5 | 5 | 0.2 | 0.4 | - | mA |
| Output High Drive (Source) Current (Except XTAL | IOH | 4.6 | 0,5 | 5 | -1.6 | -4 | - | mA |
| $\overline{\text { XTAL }}$ | IOH | 4.6 | 0 | 5 | -0.1 | -0.2 | - | mA |
| Output Voltage Low Level | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | V |
| Output Voltage High Level | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | $\bullet$ | V |
| Input Low Voltage (BUSO - BUS7, $\overline{\mathrm{ME}}$ ) | $V_{\text {IL }}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | V |
| Input High Voltage (BUSO-BUS7, $\overline{\mathrm{ME}}$ ) | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 4.5 | - | 5 | 3.5 | - | - | V |
| Schmitt Trigger Input Voltage (Except BUSO - BUS7, ME) <br> Positive Trigger Threshold | $V_{P}$ | 0.5, 4.5 | - | 5 | 2.2 | 2.9 | 3.6 | V |
| Negative Trigger Threshold | $\mathrm{V}_{\mathrm{N}}$ | 0.5, 4.5 | - | 5 | 0.9 | 1.9 | 2.8 | V |
| Hysteresis | $\mathrm{V}_{\mathrm{H}}$ | 0.5, 4.5 | - | 5 | 0.3 | 0.9 | 1.6 | V |
| Input Leakage Current | IN | - | 0,5 | 5 | - | $\pm 0.1$ | $\pm 5$ | $\mu \mathrm{A}$ |
| 3-State Output Leakage Current | lout | 0, 5 | 0, 5 | 5 | - | $\pm 0.2$ | $\pm 5$ | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | pF |
| Output Capacitance | $\mathrm{C}_{\text {OUt }}$ | - | - | - | - | 10 | 15 | pF |
| Total Power Dissipation** Run | - | - | - | 5 | - | 35 | 50 | mW |
| Idle "00" at M (0000) |  | - | - | 5 | - | 12 | 18 | mW |
| Minimum Data Retention Voltage | $V_{\text {DR }}$ | $V_{D D}=V_{D R}$ |  |  | - | 2 | 2.4 | V |
| Data Retention Current | $\mathrm{I}_{\mathrm{DR}}$ | $V_{D D}=2.4$ |  |  | - | 25 | 100 | $\mu \mathrm{A}$ |

*Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
**External clock: $f=5 \mathrm{MHz}, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns} . \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$


Fig. 2 - Block diagram for CDP1805AC and CDP1806AC.

## 3

TIMING WAVEFORMS FOR POSSIBLE OPERATING MODES


92CM-34989
*NOTE
ME HAS A MINIMUM SETUP AND HOLD TIME WITH RESPECT TO THE
BEGINNING OF CLOCK 70. FOR A MEMORY READ OPERATION, RAM DATA
WILL APPEAR ON THE DATA BUS DURING THE TIME WIE IS ACTIVE AFTER
OUT OPERATION IS PERFORMED ONINTERNAL, RAM DATA TONCE, AWMATA
ENOUGH TIME TO BE LATCHED INTO AN EXTERNAL DEVICE THE INTERNAL
RAM IS AUTOMATICALLY DESELECTED AT THE END OF CLOCK 71,
INDEPENDENT OF ME

* for CDPI805aC ONLY

Fig. 3 - Internal memory operation timing waveforms for CDP1805AC and CDP1806AC.

## CDP1805AC, CDP1806AC



Fig. 4 - External memory operation timing waveforms for CDP1805AC and CDP1806AC.

## ENHANCED CDP1805AC and CDP1806AC OPERATION

## TIMING

Timing for the CDP1805AC and CDP1806AC is the same as the CDP1802 microprocessor series, with the following exceptions:

- 4.5 clock cycles are provided for memory access instead of 5 .
- Q changes $1 / 2$ clock cycle earlier during the SEQ and REQ instructions.
- Flag lines (EF1-EF4) are sampled at the end of the S0 cycle instead of at the beginning of the S1 cycle.
- Pause can only occur on the low-to-hgh transition of either TPA or TPB, instead of any negative clock transition.


## SPECIAL FEATURES

Schmitt triggers are provided on all inputs, except $\overline{M E}$ and

## SIGNAL DESCRIPTIONS

## BUS 0 to BUS 7 (Data Bus):

8-bit bidirectional DATA BUS lines. These lines are used for transferring data between the memory, the microprocessor, and I/O devices.

## N0 to $\mathbf{N} 2$ (I/O) Lines:

Activated by an I/O instruction to signal the I/O control logic of a data transfer between memory and I/O interface. These lines can be used to issue command codes or device

BUS 0-BUS 7, for maximum immunity from noise and slow signal transitions. A Schmitt trigger in the oscillator section allows operation with an RC or crystal.
The CDP1802-series LOAD mode is not retained. This mode (WAIT, CLEAR $=0$ ) is not allowed on the CDP1805AC and CDP1806AC.

A low power mode is provided, which is initiated via the IDLE instruction. In this mode all external signals, except the oscillator, are stopped on the low-to-high transition of TPB. All outputs remain in their previous states, $\overline{M R D}$ is set to a logic " 1 ", and the data bus floats. The IDLE mode is exited by a DMA or INT condition. The INT includes both external interrupts and interrupts generated by the Counter/Timer. The only restrictions are that the Timer mode, which uses the TPA $\div 32$ clock source, and the underflow condition of the Pulse Width Measurement modes are not available to exit the IDLE mode.

## EF1 to EF4 (4 Flags):

These inputs enable the I/O controllers to transfer status information to the processor. The levels can be tested by the conditional branch instructions. They can be used in conjunction with the INTERRUPT request line to establish interrupt priorities. The flag(s) are sampled at the end of every S0 cycle. EF1 and EF2 are also used for event counting and pulse-width measurement in conjunction with the Counter/Timer.

## $\overline{\text { INTERRUPT, }} \overline{\text { DMA-IN }}$, DMA-OUT (3 I/O Requests)

$\overline{\text { DMA-IN and DMA-OUT are sampled during TPB every S1, }}$ S2, and S3 cycle. INTERRUPT is sampled during TPB every S1 and S2 cycle.
Interrupt Action: X and P are stored in T after executing current instruction; designator $X$ is set to 2 ; designator $P$ is set to 1 ; interrupt enable (MIE) is reset to 0 (inhibit); and instruction execution is resumed. The interrupt action requires one machine cycle (S3).
DMA Action: Finısh executing current instruction; R(0) points to memory area for data transfer; data is loaded into or read out of memory; and $R(0)$ is incremented.
Note: In the event of concurrent DMA and INTERRUPT requests, DMA-IN has priority followed by DMA-OUT and then INTERRUPT. (The interrupt request is not internally latched and must be held true after DMA.)

## SCO, SC1, (2 State Code Lines):

These outputs indicate that the CPU is: 1) fetching an instruction, or 2) executing an instruction, or 3) processing a DMA request, or 4) acknowledging an interrupt request. The levels of state code are tabulated below. All states are valid at TPA.

| State Type | State Code Lines |  |
| :--- | :---: | :---: |
|  | SC1 | SC0 |
| S0 (Fetch) | L | L |
| S1 (Execute) | L | H |
| S2 (DMA) | H | L |
| S3 (Interrupt) | H | H |

$H=V_{D D}, L=V_{s s}$.

## TPA, TPB (2 Timing Pulses):

Positive pulses that occur once in each machine cycle (TPB follows TPA). They are used by I/O controllers to interpret codes and to time interaction with the data bus. The trailing edge of TPA is used by the memory system to latch the high-order byte of the multiplexed 16-bit memory address.

## MAO to MA7 (8 Memory Address Lines):

In each cycle, the higher-order byte of a 16-bit memory address appears on the memory address lines MA0-7 first. Those bits required by the memory system can be strobed into external address latches by timing pulse TPA. The low-order byte of the 16-bit address appears on the address lines $1 / 2$ clock after the termination of TPA.

## MWR (Write Pulse):

A negative pulse appearing in a memory-write cycle, after the address lines have stabilized.

## $\overline{\text { MRD (Read Level): }}$

A low level on $\overline{M R D}$ indicates a memory read cycle. It can be used to control three-state outputs from the addressed memory and to indicate the direction of data transfer during an $\mathrm{I} / \mathrm{O}$ instruction.

Q:
Single bit output from the CPU which can be set or reset, under program control. During SEQ and REQ instruction execution, $Q$ is set or reset between the trailing edge of TPA and the leading edge of TPB. The $Q$ line can also be controlled by the Counter/Timer underflow via the Enable Toggle Q instruction.

The Enable Toggle Q command connects the Q-line flipflop to the output of the counter, such that each time the counter decrements from 01 to its next value, the $Q$ line changes state. This command is cleared by a LOAD COUNTER (LDC) instruction with the Counter/Timer stopped, a CPU reset, or a BRANCH COUNTER INTERRUPT ( BCl ) instruction with the counter interrupt flip-flop set.

## CLOCK:

Input for externally generated single-phase clock. The maximum clock frequency is 5 MHz at $\mathrm{V}_{D D}=5 \mathrm{~V}$. The clock is counted down internally to 8 clock pulses per machine cycle.

## $\overline{\text { XTAL: }}$

Connection to be used with clock input terminal, for an external crystal, if the on-chip oscillator is utilized.

## $\overline{\text { WAIT, }} \overline{\text { CLEAR (2 Control Lines): }}$

Provide four control modes as listed in the following truth table.

| $\overline{\text { CLEAR }}$ | $\overline{\text { WAIT }}$ | MODE |
| :---: | :---: | :---: |
| L | L | NOT ALLOWED |
| L | H | RESET |
| $H$ | L | PAUSE |
| $H$ | $H$ | RUN |

## $\overline{M E}$ (Memory Enable CDP1805AC Only):

This active low input is used to select or deselect the internal RAM. It must be active prior to clock 70 for an internal RAM access to take place. Internal RAM data will appear on the data bus during the time that ME is active (after clock 31). Thus, if this data is to be latched into an external device (i.e., during an OUTPUT instruction or DMA OUT cycle), $\overline{M E}$ should be wide enough to provide enough time for valid data to be latched. The internal RAM is automatically deselected after clock 71. TVE is ineffective when $\overline{M R D} \cdot \overline{M W R}=1$.

The internal RAM is not internally mask-decoded. Decoding of the starting address is performed externally, and may reside in any 64-byte block of memory.

## VDD (CDP1806AC Only):

This input replaces the $\overline{M E}$ signal of the CDP1805AC and must be connected to the positive power supply.

## VDD, VSS, (Power Levels):

$V_{\text {ss }}$ is the most negative supply voltage terminal and is normally connected to ground. $V_{D D}$ is the positive supply voltage terminal. All outputs swing from $V_{s s}$ to $V_{\text {DD }}$. The recommended input voltage swing is from $V_{\text {ss }}$ to $V_{\text {DD }}$.

## ARCHITECTURE

Fig. 2 shows a block diagram of the CDP1805AC and CDP1806AC. The principal feature of this system is a register array ( R ) consisting of sixteen 16-bit scratchpad registers. Individual registers in the array ( R ) are designated (selected) by a 4-bit binary code from one of the 4-bit registers labeled $\mathrm{N}, \mathrm{P}$, and X . The contents of any register can be directed to any one of the following paths:

1. the external memory (multiplexed, higher-order byte first on to 8 memory address lines)
2. the $D$ register (either of the two bytes can be gated to $D$ )
3. the increment/decrement circuit where it is increased or decreased by one and stored back in the selected 16-bit register.
4. to any other 16-bit scratch pad register in the array.

The four paths, depending on the nature of the instruction, may operate independently or in various combinations in the same machine cycle.
Most instructions consist of two 8-clock-pulse machine cycles. The first cycle is the fetch cycle, and the second -and more if necessary - are execute cycles. During the fetch cycle the four bits in the $P$ designator select one of the 16 registers $R(P)$ as the current program counter. The selected register $R(P)$ contains the address of the memory location from which the instruction is to be fetched. When the instruction is read out from the memory, the higherorder 4 bits of the instruction byte are loaded into the I register and the lower-order 4 bits into the N register. The content of the program counter is automatically incremented by one so that $R(P)$ is now "pointing" to the next byte in the memory.

The $X$ designator selects one of the 16 registers $R(X)$ to "point" to the memory for an operand (or data) in certain ALU or I/O operations.
The N designator can perform the following five functions depending on the type of instruction fetched:

1. designate one of the 16 registers in $R$ to be acted upon during register operations
2. indicate to the I/O devices a command code or device-selection code for peripherals
3. indicate the specific operation to be executed during the ALU instructions, types of tests to be performed during the Branch instructions, or the specific operation required in a class of miscellaneous instructions
4. indicate the value to be loaded into $P$ to designate a new register to be used as the program counter $R(P)$
5. indicate the value to be loaded into $X$ to designate a new register to be used as data pointer $R(X)$.

The registers in R can be assigned by a programmer in three different ways as program counters, as data pointers, or as scratchpad locations (data registers) to hold two bytes of data.

## Program Counters

Any register can be the main program counter; the address of the selected register is held in the $P$ designator. Other registers in $R$ can be used as subroutine program counters. By a single instruction the contents of the $P$ register can be changed to effect a "call" to subroutine. When interrupts are being serviced, register $R(1)$ is used as the program
counter for the user's interrupt servicing routine. After reset, and during a DMA operation, $R(0)$ is used as the program counter. At all other times the register designated as program counter is at the discretion of the user.

## Data Pointers

The registers in $R$ may be used as data pointers to indicate a location in memory. The register designated by $X$ (i.e., $R(X)$ ) points to memory for the following instructions (see Table I):

1. ALU operations
2. output instructions
3. input instructions
4. register to memory transfer
5. memory to register transfer
6. interrupt and subroutine handling.

The register designated by N (i.e., $\mathrm{R}(\mathrm{N})$ ) points to memory for the "load D from memory" instructions 0 N and 4 N and the "Store D" instruction 5N. The register designated by $P$ (i.e., the program counter) is used as the data pointer for ALU instructions F8-FD, FF, 7C, 7D, 7F, and the RLDI instruction 68 CN . During these instruction executions, the operation is referred to as "data immediate".
Another important use of $R$ as a data pointer supports the built-in Direct-Memory-Access (DMA) function. When a DMA-In or DMA-Out request is received, one machine cycle is "stolen". This operation occurs at the end of the execute machine cycle in the current instruction. Register $R(0)$ is always used as the data pointer during the DMA operation. The data is read from (DMA-Out) or written into (DMA-In) the memory location pointed to by the R(0) register. At the end of the transfer, $R(0)$ is incremented by one so that the processor is ready to act upon the next DMA byte transfer request. This feature in the CDP1805AC and CDP1806AC architecture saves a substantial amount of logic when fast exchanges of blocks of data are required, such as with magnetic discs or during CRT-display-refresh cycles.

## Data Registers

When registers in R are used to store bytes of data, instructions are provided which allow $D$ to receive from or write into either the higher-order- or lower-order-byte portions of the register designated by N . By this mechanism (together with loading by data immediate) program pointer and data pointer designations are initialized. Also, this technique allows scratchpad registers in R to be used to hold general data. By employing increment or decrement instructions, such registers may be used as loop counters. The new RLDI, RLXA, RSXD, and RNX instructions also allow loading, storing, and exchanging the full 16 -bit contents of the $R$ registers without affecting the $D$ register. The new DBNZ instruction allows decrementing and branching-on-not-zero of any 16-bit $R$ register also without affecting the D register.

## The Q Flip-Flop

An internal flip-flop, Q, can be set or reset by instruction and can be sensed by conditional branch instructions. It can also be driven by the underflow output of the counter/timer. The output of $Q$ is also available as a microprocessor output.

Register Summary

| $D$ | 8 Bits | Data Register (Accumulator) |
| :---: | :---: | :--- |
| DF | 1 Bit | Data Flag (ALU Carry) |
| B | 8 Bits | Auxiliary Holding Register |
| R | 16 Bits | 1 of 16 Scratchpad Registers |
| $P$ | 4 Bits | Designates which Register is <br> Program Counter |
| $X$ | 4 Bits | Designates which Register is <br> Data Pointer |
| $N$ | 4 Bits | Holds Low-Order Instr. Digit |
| $I$ | 4 Bits | Holds High-Order Instr. Digit |
| $T$ | 8 Bits | Holds old X, P after Interrupt <br> (X is high nibble) |
| $Q$ | 1 Bit | Output Flip-Flop |
| CNTR | 8 -Bits | Counter/Timer |
| CH | 8 Bits | Holds Counter Jam Value |
| MIE | 1 Bit | Master Interrupt Enable |
| CIE | 1 Bit | Counter Interrupt Enable |
| XIE | 1 Bit | External Interrupt Enable |
| CIL | 1 Bit | Counter Interrupt Latch |

## Interrupt Servicing

Register $R(1)$ is always used as the program counter whenever interrupt servicing is initialized. When an interrupt request occurs and the interrupt is allowed by the program (again, nothing takes place until the completion of the current instruction), the contents of the $X$ and $P$ registers are stored in the temporary register $T$, and $X$ and $P$ are set to new values, hex digit 2 in $X$ and hex digit 1 in $P$. Master Interrupt Enable is automatically deactivated to inhibit further interrupts. The user's interrupt routine is now in control; the contents of T may be saved by means of a single SAV instruction (78) in the memory location pointed to by $R(X)$ or the contents of T, D, and DF may be saved using a single DSAV instruction (6876). At the conclusion of the interrupt, the user's routine may restore the pre-interrupted value of $X$ and $P$ with either a RET instruction (70) which permits further interrupts, or a DIS instruction (71), which disables further interrupts.

## Interrupt Generation and Arbitration (See Fig. 5)

Interrupt requests can be generated from the following sources:

1. Externally through the interrupt input (Request not latched)
2. Internally due to Counter/Timer response (Request is latched)
a. On the transition from count (01) 18 $^{6}$ to its next value (counter underflow)
b. On the transition of $\overline{\mathrm{EF}}$ in pulse measurement mode 1
c. On the $f$ transition of $\overline{E F 2}$ in pulse measurement mode 2

For an interrupt to be serviced by the CPU, the appropriate Interrupt Enable flip-flops must be set. Thus, the External Interrupt Enable flip-flop must be set to service an external interrupt request, and the Counter Interrupt Enable flip-flop must be set to service an internal Counter/Timer interrupt request. In addition, the Master Interrupt Enable flip-flop (as used in the CDP1802) must be set to service either type of request. All 3 flip-flops are initially enabled with the application of a hardware reset, and, can be selectively enabled or disabled with software: CIE, CID instructions for the CIE flip-flop; XIE, XID instructions for the XIE flip-flop; RET, DIS instructions for the MIE flip-flop.
Short branch instructions on Counter Interrupt (BCI) and External Interrupt (BXI) can be placed in the user's interrupt service routine to provide a means of identifying and prioritizing the interrupt source. Note, however, that since the External Interrupt request is not latched, it must remain active until the short branch is executed if this priority arbitration scheme is used.
Interrupt requests can also be polled if automatic interrupt service is not desired (MIE=0). With the Counter Interrupt and External Interrupt short branch instructions, the branch will be taken if an interrupt request is pending, regardless of the state of any of the 3 Interrupt Enable flip-flops. The latched counter interrupt request signal wili be reset when the branch is taken, when the CPU is reset, or with a LDC instruction with the Counter stopped. Note, that exiting a counter-initiated interrupt routine without resetting the counter-interrupt latch will result in immediately re-entering the interrupt routine.


Fig. 5 - Interrupt logic-control diagram for CDP1805AC and CDP1806AC.

## CDP1805AC, CDP1806AC

## Counter/Timer and Controls (see Fig. 6)

This logic consists of a presettable 8-bit down-counter (Modulo N type), and a conditional divide-by-32 prescaler. After counting down to (01) ${ }_{18}$ the counter returns to its initial value at the next count and sets the Counter Interrupt Latch. It will continue decrementing on subsequent counts. If the counter is preset to ( 00$)_{18}$ a full 256 counts will occur.
During a Load Counter instruction (LDC) if the counter was stopped with a STPC instruction, the counter and its holding register (CH) are loaded with the value in the D register and any previous counter interrupt is cleared. If the LDC is executed when the counter is running, the contents of the D register are loaded into the holding register (CH) only and any previous counter interrupt is not cleared. (LDC RESETS the Counter Interrupt Latch only when the Counter is stopped). After counting down to (01) ${ }_{18}$ the next count will load the new initial value into the counter, set the Counter Interrupt Latch, and operation will continue.
The Counter/Timer has the following five programmable modes:

1. Event Counter 1: Input to counter is connected to the EF1 terminal. The high-to-low transition decrements the counter.
2. Event Counter 2: Input to counter is connected to the EF2 terminal. The high-to-low transition decrements the counter.
3. Timer: Input to counter is from the divide-by-32 prescaler clocked by TPA. The prescaler is decremented on the low-to-high transition of TPA. The divide-by-32 prescaler is reset when the counter is in a mode other than the Timer mode, system RESET, or stopped by a STPC.
4. Pulse Duration Measurement 1: Input to counter connected to TPA. Each low-to-high transition of TPA
decrements the counter if the input signal at EF1 terminal (gate input) is low. On the transition of EF1 to the positive state, the count is stopped, the mode is cleared, and the interrupt request latched. If the counter underflows while the input is low, interrupt will also be set, but counting will continue.
5. Pulse Duration Measurement 2: Operation is identical to Pulse Duration Measurement 1, except EF2 is used as the gate input.

The modes can be changed without affecting the stored count.
Those modes which use $\overline{E F 1}$ and $\overline{E F 2}$ terminals as inputs do not exclude testing these flags for branch instructions.
The Stop Counter (STPC) instruction clears the counter mode and stops counting. The STPC instruction should be executed prior to a GEC instruction, if the counter is in the Event Counter Mode 1 or 2.
In addition to the five programmable modes, the Decrement Counter instruction (DTC) enables the user to count in software. In order to avoid conflict with counting done in the other modes, the instruction should be used only after the mode has been cleared by a Stop Counter instruction.
The Enable Toggle Q instruction (ETQ) connects the Q-line flip-flop to the output of the counter, such that each time the counter decrements from 01 to its next value, the Q output changes state. This action is independent of the counter mode and the Interrupt Enable flip-flops. The Enable Toggle Q condition is cleared by an LDC with the Counter/Timer stopped, system Reset, or a BCI with $\mathrm{Cl}=1$.
Note: SEQ and REQ instructions are independent of ETQ-they can SET or RESET Q while the Counter is running.


Fig. 6 - Timer/Counter diagram for CDP1805AC and CDP1806AC.

## On-Board Clock (see Figs. 7, 8 and 9)

Clock circuits may use either an external crystal or an RC network.

A typical crystal oscillator circuit is shown in Fig. 7. The crystal is connected between terminals 1 and 39 (CLOCK and $\overline{\mathrm{XTAL}}$ ) in parallel with a resistance, RF ( 1 megohm typ.). Frequency trimming capacitors, $\mathrm{C}_{\text {In }}$ and $\mathrm{C}_{\text {out, }}$ may be required at terminals 1 and 39 . For additional information on crystal oscillators, see ICAN-6565.

Because of the Schmitt Trigger input, an RC oscillator can be used as shown in Fig. 8. The frequency is approximately 1/RC (see Fig. 9).


Fig. 7 - Typical 5 MHz crystal oscillator.

*Pin numbers refer to $40-$ Pin DIP
Fig. 8 - RC network for oscillator.


Fig. 9 - Nominal component values as a function

CONTROL MODES

| $\overline{\text { CLEAR }}$ | $\overline{\text { WAIT }}$ | MODE |
| :---: | :---: | :---: |
| L | L | NOT ALLOWED |
| L | H | RESET |
| $H$ | L | PAUSE |
| $H$ | $H$ | RUN |

The function of the modes are defined as follows:

## RESET

The levels on the CDP1805A and CDP1806A external signal lines will asynchronously be forced by RESET to the following states:
Q=0
MRD=1
TPB $=0$

## Internal changes caused by RESET are:

$\mathrm{I}, \mathrm{N}$ instruction register is cleared to 00 . XIE and CIE are set to allow interrupts following initialize. CIL is cleared (any pending counter interrupt is cleared), counter is stopped, the counter mode is cleared, and ETQ is disabled.

## Initialization Cycle

The first machine cycle followiing termination of RESET is an initialization cycle which requires 9 clock pulses. During this cycle the CPU remains in S1 and the following additional changes occur:
$1 \rightarrow$ MIE
$X, P \rightarrow T$ (The old value of $X, P$ will be put into $T$. This only has meaning following an orderly Reset with power applied).
$\mathrm{X}, \mathrm{P}, \mathrm{RO}-0(\mathrm{X}, \mathrm{P}$, and RO are cleared).
Interrupt and DMA servicing is suppressed during the initialization cycle. The next cycle is an S0 or an S2 but never an S1 or S3. The use of a 71 instruction followed by 00 at memory locations 0000 and 0001, may be used to reset MIE so as to preclude interrupts until ready for them.

## Reset and Initialize do not affect:

D (Accumulator)
DF
R1, R2, R3, R4, R5, R6, R7, R8, R9, FA, RB, RC, RD, RE, RF
CH (Counter Holding Register)
Counter (the counter is stopped but the value is unaffected)

## Power-up Reset/Run Circuit

Power-up Reset/Run can be realized with the circuit shown in Fig. 10.

Fig. 10 - Reset/run diagram.
.


## PAUSE

Pause is a low power mode which stops the internal CPU timing generator and freezes the state of the processor. The CPU may be held in the Pause mode indefinitely. Hardware pause can occur at two points in a machine cycle, on the low-to-high transition of either TPA or TPB. A TPB pause can also be initiated by software with the execution of an IDLE instruction. In the pause mode. the oscillator continues to run but subsequent clock transitions are ignored. TPA and TPB remain at their previous state (see Fig. 11).
Pause is entered from RUN by dropping WAIT low. Appropriate Setup and Hold times must be met.
If Pause is entered while in the event counter mode, the appropriate Flag transition will continue to decrement the counter.
Hardware-initiated pause is exited to RUN by raising the Wait line high. Pause entered with an IDLE instruction requires DMA, INTERRUPT or RESET to resume execution.

## TPA PAUSE TIMING



## TPB PAUSE TIMING

NOTE:
PAUSE (IN CLOCK WAVEFORM) WHILE REPRESENTED HERE AS ONE CLOCK CYCLE IN DURATION, COULD BE INFINITELY LONG.


Fig. 11 - Pause mode timing waveforms.

## RUN

May be initiated from the Pause or Reset mode functions. If initiated from Pause, the CPU resumes operation at the point it left off. If paused at TPA, it will resume on the next high-to-low clock transition, while if paused at TPB, it will resume on the next low-to-high clock transition (see Fig. 11). When initiated from the Reset operation, the first machine cycle following Reset is always the initialization cycle. The initialization cycle is then followed by a DMA (S2) cycle or fetch (SO) from location 0000 in memory.

## SCHMITT TRIGGER INPUTS

All inputs except BUS 0-BUS 7 and ME contain a Schmitt Trigger circuit, which is especially useful on the CLEAR input as a power-up RESET (see Fig. 10) and the CLOCK input (see Figs. 7 and 8).

## STATE TRANSITIONS

The CDP1805A and CDP1806A state transitions are shown in Fig. 12. Each machine cycle requires the same period of time, 8 clock pulses, except the initialization cycle (INIT) which requires 9 clock pulses. Reset is asynchronous and can be forced at any time.

$\begin{array}{ll}\text { PRIORITY } & \text { RESET } \\ & \text { FORCE SO, } \mathrm{S}\end{array}$
FORCE S0, S1
DMA
INT
INT• $\overline{\text { DMA }}$

Fig. 12 - State transition diagram.

## INSTRUCTION SET

1. Instruction Set - Refer to Harris Literature Department.
2. Conditions on data bus and memory address lines during all machine states - refer to Harris Literature Department.


Fig. 13 - Timing waveforms for CDP1805AC and CDP1806AC.

## Specifications CDP1805AC, CDP1806AC

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$; Input $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns}$; Input Pulse Levels = 0.1 V to VDD-0.1 V; VDD $=5 \mathrm{~V}, \pm 5 \%$.

| CHARACTERISTIC |  | LIMITSCDP1805AC, CDP1806AC |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Typ.* | Max. |  |
| Propagation Delay Times: |  |  |  | ns |
| Clock to TPA, TPB | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 150 | 275 |  |
| Clock-to-Memory High-Address Byte | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 325 | 550 |  |
| Clock-to-Memory Low-Address Byte | $\mathrm{tPLH}, \mathrm{t}_{\text {PHL }}$ | 275 | 450 |  |
| Clock to MRD | $\mathrm{t}_{\text {PLH }}, \mathrm{t}_{\text {PHL }}$ | 200 | 325 |  |
| "Clock to $\overline{M W R}$ | $\mathrm{t}_{\text {PLH, }} \mathrm{t}_{\text {PHL }}$ | 150 | 275 |  |
| Clock to (CPU DATA to BUS) | $\mathrm{tPLH} \mathrm{t}_{\text {PHL }}$ | 375 | 625 |  |
| Clock to State Code | $\mathrm{t}_{\text {PLH, }} \mathrm{t}_{\text {PHL }}$ | 225 | 400 |  |
| Clock to Q | $\mathrm{t}_{\text {PLH, }} \mathrm{t}_{\text {PHL }}$ | 250 | 425 |  |
| Clock to N | $\mathrm{t}_{\text {PLH, }} \mathrm{t}_{\text {PHL }}$ | 250 | 425 |  |
| Clock to Internal RAM Data to BUS | $\mathrm{tPLH}, \mathrm{t}_{\text {PHL }}$ | 420 | 650 |  |
| Minimum Set Up and Hold Times:- |  |  |  | ns |
| Data Bus Input Set-Up | $t_{\text {su }}$ | -100 | 0 |  |
| Data Bus Input Hold | $\mathrm{t}_{\mathrm{H}}$ | 125 | 225 |  |
| $\overline{\overline{D M A}}$ Set-Up | tsu | -75 | 0 |  |
| DMA Hold | $t_{H}$ | 100 | 175 |  |
| $\overline{\mathrm{ME}}$ Set-Up | tsu | 125 | 320 |  |
| ME Hold | $t_{H}$ | 0 | 50 |  |
| Interrupt Set-Up | tsu | -100 | 0 |  |
| Interrupt Hold | $\mathrm{t}_{\mathrm{H}}$ | 100 | 175 |  |
| WAIT Set-Up | tsu | 20 | 50 |  |
| EF1-4 Set-Up | tsu | -125 | 0 |  |
| $\overline{\text { EF1-4 }}$ Hold | $t_{H}$ | 175 | 300 |  |
|  |  |  |  | ns |
| CLEAR Pulse Width | $t_{w L}$ | 100 | 175 |  |
| $\overline{\text { CLOCK Pulse Width }}$ | $t_{w}$ | 75 | 100 |  |

- Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.

Maximum lımits of minimum characteristics are the values above which all devices function.
TIMING SPECIFICATIONS as a function of $T(T=1 / f C L O C K)$ at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \pm 5 \%$.

| CHARACTERISTIC |  | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1805AC, CDP1806AC |  |  |
|  |  | Min. | Typ.* |  |
| High-Order Memory-Address Byte Set-Up to TPA Time | tsu | 2T-275 | 2T-175 | ns |
| $\overline{\mathrm{MRD}}$ to TPA Time | tsu | T/2-100 | T/2-75 |  |
| High-Order Memory-Address Byte Hold after TPA Time | $t_{H}$ | T/2+75 | T/2+100 |  |
| Low-Order Memory-Address Byte Hold after WR Time | $t_{H}$ | T+180 | T+240 |  |
| CPU Data to Bus Hold after WR Time | $t_{H}$ | T+110 | T+150 |  |
| Required Memory Access Time Address to Data | $t_{\text {AcC }}$ | 4.5T-440 | 4.5T-330 |  |

[^1]
## Operating and Handling Considerations

## 1. Handling

All inputs and outputs of Harris CMOS devices have a network for electrostatic protection during handling.
2. Operating

## Operating Voltage

During operation near the maximum supply voltage limit, care should be taken to avoid or suppress power supply turn-on and turn-off transients, power supply ripple, or ground noise; any of these conditions must not cause $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS}}$ to exceed the absolute maximum rating.

## Input Signals

To prevent damage to the input protection circuit, input signals should never be greater than $\mathrm{V}_{\mathrm{DD}}$ nor less than $\mathrm{V}_{\mathrm{SS}}$. Input currents must not exceed 10 mA even when the power supply is off.

## Unused Inputs

A connection must be provided at every input terminal. All unused input terminals must be connected to either $V_{D D}$ or $\mathrm{V}_{\mathrm{SS}}$, whichever is appropriate.

## Output Short Circuits

Shorting of outputs to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ may damage CMOS devices by exceeding the maximum device dissipation.

## High Performance Microprocessor With Memory Management and Protection

## Features

- Compatible with NMOS 80286
- Wide Range of Clock Rates:
-DC to 25 MHz (80C286-25)
-DC to 20 MHz (80C286-20)
-DC to 16 MHz (80C286-16)
-DC to 12.5 MHz (80C286-12)
-DC to 10 MHz (80C286-10)
- Static CMOS Design for Low Power Operation
- ICCSB $=5 \mathrm{~mA}$ Maximum
- ICCOP $=185 \mathrm{~mA}$ Maximum (80C286-10)

220mA Maximum (80C286-12)
260mA Maximum (80C286-16)
310mA Maximum (80C286-20)
410mA Maximum (80C286-25)

- High Performance Processor (Up to 19 Times the 8086 Throughput)
- Large Address Space:
- 16 Megabytes Physical/1 Gigabyte Virtual per Task
- Integrated Memory Management, Four-Level Memory Protection and Support for Virtual Memory and Operating Systems
- Two 80C86 Upward Compatible Operating Modes:
- 80C286 Real Address Mode P PVAM
- Compatible with 80287 Numeric Data Co-Processor
- High Bandwidth Bus Interface ( 25 Megabyte/Sec)
- Available in:
-68 Pin PGA (Commercial, Industrial, and Military)
- 68 Pin PLCC (Commercial and Industrial)


## Description

The Harris 80 C 286 is a static CMOS version of the NMOS 80286 microprocessor. The 80 C 286 is an advanced, high-performance microprocessor with specially optimized capabilities for multiple user and multi-tasking systems. The 80C286 has built-in memory protection that supports operating system and task isolation as well as program and data privacy within tasks. A 25 MHz 80 C 286 provides up to nineteen times the throughput of a standard 5 MHz 8086 . The 80 C 286 includes memory management capabilities that map 230 (one gigabyte) of virtual address space per task into 224 bytes ( 16 megabytes) of physical memory.
The 80C286 is upwardly compatible with 80C86 and 80C88 sofware (the 80 C 286 instruction set is a superset of the $80 \mathrm{C} 86 / 80 \mathrm{C} 88$ instruction set). Using the 80C286 real address mode, the 80C286 is object code compatible with existing 80 C 86 and 80 C 88 software. In protected virtual address mode, the 80 C 286 is source code compatible with 80 C 86 and 80 C 88 software but may require upgrading to use virtual address as supported by the 80C286's integrated memory management and protection mechanism. Both modes operate at full 80 C 286 performance and execute a superset of the 80 C 86 and 80 C 88 instructions.
The 80 C 286 provides special operations to support the efficient implementation and execution of operating systems. For example, one instruction can end execution of one task, save its state, switch to a new task, load its state, and start execution of the new task. The 80C286 also supports virtual memory systems by providing a segment-not-present exception and restartable instructions.

## Pin Configurations

Component Pad View - As viewed from underside of the component when mounted on the board.


P.C. Board Vlew - As viewed from the component side of the PC board

P.C. Board View - As viewed from the component side of the PC. board


Ordering Information

| PACKAGE | TEMPERATURE RANGE | 10 MHz | 12.5 MHz | 16 MHz | 20MHz | 25 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PGA | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | - | CG80C286-12 | CcG80C286-16 | CG80C286-20 | - |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CG80C286-10 | IG80C286-12 | - | - | - |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MG80C286-10/883 | MG80C286-12/883 | - | - | - |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | - | CS80C286-12 | CS80C286-16 | CS80C286-20 | CS80C286-25 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | - | IS80C286-12 | IS80C286-16 | IS80C286-20 | - |

*Respective $/ 883$ specifications are included at the end of this data sheet.

Functional Diagram


## Pin Description

The following pin function descriptions are for the 80C286 microprocessor-
TABLE 1.


TABLE 1. CONTINUED

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| COD/INTA | 66 | 0 | CODE/INTERRUPT ACKNOWLEDGE distınguishes instruction fetch cycles from memory data read cycles Also distınguishes interrupt acknowledge cycles from I/O cycles COD/INTA is held at high impedance to the last valid logic state during bus hold acknowledge Its tıming is the same as $M / \overrightarrow{I O}$ |
| $\overline{\text { LOCK }}$ | 68 | O | BUS LOCK indicates that other system bus masters are not to gain control of the system bus for the current and following bus cycles The LOCK signal may be activated explicitly by the "LOCK" instruction prefix or automatically by 80C286 hardware during memory XCHG instructions, interrupt acknowledge, or descriptor table access. $\overline{\text { LOCK }}$ is active LOW and is held at a high impedance logic one during bus hold acknowledge |
| $\overline{\text { READY }}$ | 63 | 1 | BUS READY termınates a bus cycle Bus cycles are extended without limit untıl terminated by $\overline{\operatorname{READY}}$ LOW $\overline{R E A D Y}$ is an active LOW synchronous input requiring setup and hold times relative to the system clock be met for correct operation $\overline{\text { READY }}$ is ignored during bus hold acknowledge (Note 1) |
| HOLD <br> HLDA | $\begin{aligned} & 64 \\ & 65 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | BUS HOLD REQUEST AND HOLD ACKNOWLEDGE control ownership of the 80C286 local bus The HOLD input allows another local bus master to request control of the local bus When control is granted, the 80 C 286 will float its bus drivers and then activate HLDA, thus entering the bus hold acknowledge condition The local bus will remain granted to the requesting master untıl HOLD becomes inactive which results in the 80 C 286 deactivatıng HLDA and regaining control of the local bus This terminates the bus hold acknowledge condition HOLD may be asynchronous to the system clock. These signals are active HIGH Note that HLDA never floats. |
| INTR | 57 | 1 | INTERRUPT REQUEST requires the 80C286 to suspend its current program execution and service a pending external request Interrupt requests are masked whenever the interrupt enable bit in the flag word is cleared When the 80C286 responds to an interrupt request, it performs two interrupt acknowledge bus cycles to read an 8-bit interrupt vector that identifies the source of the interrupt To ensure program interruption, INTR |

vector that identifies the source of the interrupt To ensure program interruption, INTR must remain active until an interrupt acknowledge bus cycle is initiated. INTR is sampled at the begınnıng of each processor cycle and must be actıve HIGH at least two processor cycles before the current instruction ends in order to interrupt before the next instruction INTR is level sensitive, active HIGH, and may be asynchronous to the system clock

NON-MASKABLE INTERRUPT REQUEST interrupts the 80C286 with an internally supplied vector value of two No interrupt acknowledge cycles are performed. The interrupt enable bit in the 80 C 286 flag word does not affect this input The NMI input is active HIGH, may be asynchronous to the system clock, and is edge triggered after internal synchronization For proper recognition, the input must have been previously LOW for at least four system clock cycles and remain HIGH for at least four system clock cycles

PROCESSOR EXTENSION OPERAND REQUEST AND ACKNOWLEDGE: extend the memory management and protection capabilities of the 80 C 286 to processor extensions. The PEREQ input requests the 80 C 286 to perform a data operand transfer for a processor extension. The PEACK output signals the processor extension when the requested operand is being transferred. PEREQ is active HIGH. PEACK is active LOW and is held at a high impedance logic one during bus hold acknowledge. PEREQ may be asynchronous to the system clock.

PROCESSOR EXTENSION BUSY AND ERROR: Indicates the operating condition of a processor extension to the 80C286. An active $\overline{\text { BUSY input stops } 80 C 286 \text { program }}$ execution on WAIT and some ESC instructions until BUSY becomes inactive (HIGH). The 80 C 286 may be interrupted while waiting for $\overline{B U S Y}$ to become inactive. An active $\overline{\text { ERROR }}$ input causes the 80 C 286 to perform a processor extension interrupt when executing WAIT or some ESC instructions. These inputs are active LOW and may be asynchronous to the system clock

TABLE 1. CONTINUED

| SYMBOL |  | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |


| RESET | 29 | 1 | SYSTEM RESET: clears the internal logic of the 80 C 286 and is activeHIGH. The 80 C 2 may be reinitialized at any time with a LOW to HIGH transition on RESET which remains active for more than 16 system clock cycles. During RESET active, the output pins of the 80C286 enter the state shown below <br> 80C286 Pin State During Reset |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Pin Value | Pin Names |
|  |  |  |  | $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{PEACK}}, \mathrm{A}_{23}-\mathrm{A}_{0}, \overline{\mathrm{BHE}}, \overline{\text { LOCK }}$ M/IO, COD/INTA, HLDA (Note 2) D15-D0 |

Operation of the 80 C 286 begins after a HIGH to LOW transition on RESET. The HIGH to LOW transition of RESET must be synchronous to the system clock. Approximately 50 system clock cycles are required by the 80 C 286 for internal initializations before the first bus cycle to fetch code from the power-on execution address is performed A LOW to HIGH transition of RESET synchronous to the system clock will end a processor cycle at the second HIGH to LOW transition of the system clock The LOW to HIGH transition of RESET may be asynchronous to the system clock; however, in this case it cannot be predetermined which phase of the processor clock will occur during the next system clock period. Synchronous LOW to HIGH transitions of RESET are required only for systems where the processor clock must be phase synchronous to another clock

| $V_{\text {SS }}$ | $9,35,60$ | 1 | SYSTEM GROUND are the ground pins (all must be connected to system ground) |
| :---: | :---: | :---: | :--- |
| $V_{C C}$ | 30,62 | 1 | SYSTEM POWER: +5 volt power supply pins. A $01 \mu$ F capacitor between pins 60 and 62 <br> is recommended |

NOTES: 1. READY is an open-collector signal and should be pulled inactive with an appropriate resistor ( $620 \Omega$ at 10 MHz and $12.5 \mathrm{MHz}, 470 \Omega$ at $16 \mathrm{MHz}, 390 \Omega$ at $20 \mathrm{MHz}, 270 \Omega$ at 25 MHz ).
2. HLDA is only Low if HOLD is inactive (Low).
3. All unused inputs should be pulled to their inactive state with pull up/down resistors.

## Functional Description

## Introduction

The Harris 80 C 286 microprocessor is a static CMOS version of the NMOS 80286 microprocessor. The 80C286 is an advanced, high-performance microprocessor with specially optimized capabilities for multiple user and multi-tasking systems. Depending on the application, the 80C286's performance is up to nineteen times faster than the standard 5 MHz 8086 's, while providing complete upward software compatibility with Harris 80C86 and 80 C 88 CPU family.

The 80C286 operates in two modes: 80C286 real address mode and protected virtual address mode. Both modes execute a superset of the 80C86 and 80C88 instruction set.

In 80C286 real address mode programs use real addresses with up to one megabyte of address space. Programs use virtual addresses in protected virtual address mode, also called protected mode. In protected mode, the 80C286 CPU automatically maps 1 gigabyte of virtual addresses per task into a 16 megabyte real address space. This mode also provides memory protection to isolate the operating system and ensure privacy of each tasks' programs and data. Both modes provide the same base instruction set, registers and addressing modes.

The Functional Description describes the following: Static operation, the base 80 C 286 architecture common to both modes, 80C286 real address mode, and finally, protected mode.

## Static Operation

The 80 C 286 is comprised of completely static circuitry. Internal registers, counters, and latches are static and require no refresh as with dynamic circuit design. This elimınates the mınimum operating frequency restriction typically placed on microprocessors. The CMOS 80C286 can operate from DC to the specified upper frequency limit. The clock to the processor may be stopped at any point (either phase one or phase two of the processor clock cycle) and held there indefinitely. There is, however, a significant decrease in power requirement if the clock is stopped in phase two of the processor clock cycle. Details on the clock relationships will be discussed in the Bus Operatıon section. The ability to stop the clock to the processor is especially useful for system debug or power critical applications.

The 80C286 can be single-stepped using only the CPU clock. This state can be maintained as long as necessary. Single step clock information allows simple interface circuitry to provide critical information for system debug.

Static design also allows very low frequency operation (down to DC). In a power critical situation, this can provide low power operation since 80C286 power dissıpation is directly related to operatıng frequency. As the system frequency is reduced, so is the operating power untIl, ultimately, with the clock stopped in phase two of the processor clock cycle, the 80C286 power requirement is the standby current ( 5 mA maximum).

## 80C286 Base Architecture

The 80C86, 80C88, and 80C286 CPU family all contain the same basic set of registers, instructions, and addressing modes The 80 C 286 processor is upwardly compatible with the 80C86 and 80C88 CPU's.

## Register Set

The 80 C 286 base architecture has fifteen registers as shown in Figure 1 These registers are grouped into the following four categories.

GENERAL REGISTERS: Eight 16-bit general purpose registers used to contain arithmetic and logical operands. Four of these (AX, BX, CX and DX) can be used either in their entirety as 16 -bit words or split into pairs of separate 8 -bit regısters.

SEGMENT REGISTERS: Four 16-bit special purpose registers select, at any given time, the segments of memory that are immediately addressable for code, stack and data. (For usage, refer to Memory Organization.)



FIGURE 1. REGISTER SET


FIGURE 2. STATUS AND CONTROL REGISTER BIT FUNCTIONS

BASE AND INDEX REGISTERS: Four of the general purpose registers may also be used to determine offset addresses of operands in memory. These registers may contain base addresses or indexes to particular locations within a segment. The addressing mode determines the specific registers used for operand address calculations.

STATUS AND CONTROL REGISTERS: Three 16-bit special purpose registers record or control certain aspects of the 80C286 processor state. These include the Flags register and Machine Status Word register shown in

Figure 2, and the Instruction Pointer, which contains the offset address of the next sequential instruction to be executed.

## Flags Word Description

The Flags word (Flags) records specific characteristics of the result of logical and arithmetic instrucitons (bits 0,2 , $4,6,7$ and 11) and controls the operation of the 80 C 286 within a given operating mode (bits 8 and 9). Flags is a 16 -bit register. The function of the flag bits is given in Table 2.

TABLE 2. FLAGS WORD BIT FUNCTIONS

| BIT POSITION | NAME | FUNCTION |
| :---: | :---: | :--- |
| 0 | CF | Carry Flag - Set on high-order bit carry or borrow, cleared otherwise |
| 2 | PF | Parity Flag - Set if low-order 8-bits of result contain an even number of 1-bits, cleared <br> otherwise |
| 4 | AF | Set on carry from or borrow to the low order four bits of AL, cleared otherwise |
| 6 | ZF | Zero Flag - Set if result is zero, cleared otherwise |
| 7 | SF | Sign Flag - Set equal to high-order bit of result (0 if positive, 1 If negative) |
| 11 | OF | Overflow Flag - Set if result is a too-large positive number or a too-small negative <br> number (excluding sign-bit) to fit in destination operand, cleared otherwise |
| 8 | TF | Single Step Flag - Once set, a single step interrupt occurs after the next instruction <br> executes TF is cleared by the single step interrupt |
| 10 | DF | Interrupt-enable Flag - When set, maskable interrupts will cause the CPU to transfer <br> control to an interrupt vector specified location |
| Direction Flag - Causes string instructions to auto decrement the appropriate index <br> registers when set Clearing DF causes auto increment |  |  |

## Instruction Set

The instruction set is divided into seven categories: data transfer, arithmetıc, shift/rotate/logical, strıng manipulation, control transfer, high level instructions, and processor control. These categories are summarized in Figure 3.
An 80C286 instruction can reference zero, one, or two operands, where an operand may reside in a register, in the instruction itself, or in memory. Zero-operand instructions (e.g. NOP ane HLT) are usually one byte long. One-operand instructions (e.g. INC and DEC) are usually two bytes long but some are encoded in only one byte. One-operand instructions may reference a register or memory location. Two-operand instructions permit the following six types of instruction operations-

- Register to Regıster
- Memory to Memory
- Memory to Register
- Register to Memory
- Immediate to Regıster
- Immediate to Memory

| GENERAL PURPOSE |  |
| :--- | :--- |
| MOV | Move byte or word |
| PUSH | Push word onto stack |
| POP | Pop word off stack |
| PUSHA | Push all regısters on stack |
| POPA | Pop all regısters from stack |
| XCHG | Exchange byte or word |
| XLAT | Translate byte |
| INPUT/OUTPUT |  |
| IN | Input byte or word |
| OUT | Output byte or word |
| ADDRESS OBJECT |  |
| LEA | Load effective address |
| LDS | Load pointer using DS |
| LES | Load pointer using ES |
| FLAG TRANSFER |  |
| LAHF | Load AH register from flags |
| SAHF | Store AH regıster in flags |
| PUSHF | Push flags onto stack |
| POPF | Pop flags off stack |

FIGURE 3A. DATA TRANSFER INSTRUCTIONS

| MOVS | Move byte or word strıng |
| :--- | :--- |
| INS | Input bytes or word strıng |
| OUTS | Output bytes or word strıng |
| CMPS | Compare byte or word string |
| SCAS | Scan byte or word strıng |
| LODS | Load byte or word strıng |
| STOS | Store byte or word string |
| REP | Repeat |
| REPE/REPZ | Repeat while equal/zero |
| REPNE/REPNZ | Repeat while not equal/not zero |

FIGURE 3C. STRING INSTRUCTIONS

Two-operand instructions (e.g. MOV and ADD) are usually three to six bytes long. Memory to memory operations are provided by a spécial class of string instructions requiring one to three bytes. For detalled instruction formats and encodings refer to the instruction set summary at the end of this document.

| ADDITION |  |  |
| :--- | :--- | :---: |
| ADD | Add byte or word |  |
| ADC | Add byte or word with carry |  |
| INC | Increment byte or word by 1 |  |
| AAA | ASCII adjust for addition |  |
| DAA | Decimal adjust for addition |  |
| SUBTRACTION |  |  |
| SUB | Subtract byte or word |  |
| SBB | Subtract byte or word with borrow |  |
| DEC | Decrement byte or word by 1 |  |
| NEG | Negate byte or word |  |
| CMP | Compare byte or word |  |
| AAS | ASCII adjust for subtraction |  |
| DAS | Decimal adjust for subtraction |  |
| MULTIPLICATION |  |  |
| MUL | Multiply byte or word unsigned |  |
| IMUL | Integer multıply byte or word |  |
| AAM | ASCII adjust for multiply |  |
| DIVISION |  |  |
| DIV | Divide byte or word unsigned |  |
| IDIV | Integer divide byte or word |  |
| AAD | ASCII adjust for division |  |
| CBW | Convert byte to word |  |
| CWD | Convert word to doubleword |  |

FIGURE 3B. ARITHMETIC INSTRUCTIONS

| LOGICALS |  |
| :--- | :--- |
| NOT | "Not" byte or word |
| AND | "And" byte or word |
| OR | "Inclusive or" byte or word |
| XOR | "Exclusive or" byte or word |
| TEST | "Test" byte or word |
| SHIFTS |  |
| SHL/SAL | Shift logıcal/arithmetic left byte or word |
| SHR | Shift logıcal right byte or word |
| SAR | Shift arithmetic right byte or word |
| ROTATES |  |
| ROL | Rotate left byte or word |
| ROR | Rotate right byte or word |
| RCL | Rotate through carry left byte or word |
| RCR | Rotate through carry right byte or word |

FIGURE 3D. SHIFT/ROTATE LOGICAL INSTRUCTIONS

| CONDITIONAL TRANSFERS |  | UNCONDITIONAL TRANSFERS |  |
| :---: | :---: | :---: | :---: |
| JA/JNBE | Jump if above/not below nor equal | CALL | Call procedure |
| JAE/JNB | Jump if above or equal/not below | RET | Return from procedure |
| JB/JNAE | Jump if below/not above nor equal | JMP | Jump |
| JBE/JNA | Jump if below or equal/not above |  |  |
| JC | Jump if carry | ITERATION CONTROLS |  |
| JE/JZ | Jump if equal/zero |  |  |
| JG/JNLE | Jump if greater/not less nor equal | LOOP | Loop |
| JGE/JNL | Jump if greater or equal/not less | LOOPE/LOOPZ | Loop if equal/zero |
| JLIJNGE | Jump if less/not greater nor equal | LOOPNE/LOOPNZ | Loop if not equal/not zero |
| JLE/JNG | Jump if less or equal/not greater | JCXZ | Jump if register CX $=0$ |
| JNC | Jump if not carry |  |  |
| JNE/JNZ | Jump if not equal/not zero | INTERRUPTS |  |
| JNO | Jump if not overflow |  |  |
| JNP/JPO | Jump if not parity/parity odd | INT | Interrupt |
| JNS | Jump if not sign | INTO | Interrupt if overflow |
| JO | Jump if overflow | IRET | Interrupt return |
| JP/JPE | Jump if parity/parity even |  |  |
| JS | Jump if sign |  |  |

FIGURE 3E. PROGRAM TRANSFER INSTRUCTIONS

| FLAG OPERATIONS |  |
| :--- | :--- |
| STC | Set carry flag |
| CLC | Clear carry flag |
| CMC | Complement carry flag |
| STD | Set direction flag |
| CLD | Clear direction flag |
| STI | Set interrupt enable flag |
| CLI | Clear interrupt enable flag |
| EXTERNAL SYNCHRONIZATION |  |
| HLT | Halt untıl interrupt or reset |
| WAIT | Wait for TEST pın active |
| ESC | Escape to extension processor |
| LOCK | Lock bus during next instruction |
| NO OPERATION |  |
| NOP | No operation |
| EXECUTION ENVIRONMENT CONTROL |  |
| LMSW | Load machine status word |
| SMSW | Store machine status word |

FIGURE 3F. PROCESSOR CONTROL INSTRUCTIONS

| ENTER | Format stack for procedure entry |
| :--- | :--- |
| LEAVE | Restore stack for procedure exit |
| BOUND | Detects values outside prescribed range |

FIGURE 3G. HIGH LEVEL INSTRUCTIONS

## Memory Organization

Memory is organızed as sets of variable-length segments. Each segment is a linear contiguous sequence of up to 64 K (216) 8-bit bytes. Memory is addressed using a two-component address (a pointer) that consists of a 16 -bit segment selector and a 16 -bit offset. The segment selector indicates the desired segment in memory. The offset component indicates the desired byte address within the segment. (See Figure 4).

All instructions that address operands in memory must specify the segment and the offset. For speed and compact instruction encoding, segment selectors are usually stored in the high speed segment registers. An instruction need specify only the desired segment register and offset in order to address a memory operand.


FIGURE 4. TWO COMPONENT ADDRESS

## tABLE 3. SEGMENT REGISTER SELECTION RULES

| Memory <br> Reference Needed | Segment Register <br> Used | Implicit Segment <br> Selection Rule |
| :--- | :---: | :--- |
| Instructıons | Code (CS) | Automatıc with instructıon prefetch |
| Stack | Stack (SS) | All stack pushes and pops Any memory reference which uses BP as a <br> base regıster |
| Local Data | Data (DS) | All data references except when relative to stack or string destinatıon |
| External (Global) Data | Extra (ES) | Alternate data segment and destınation of string operatıon |

Most instructions need not explicitly specify which segment register is used The correct segment register is automatıcally chosen according to the rules of Table 3. These rules follow the way programs are written (see Figure 5) as independent modules that require areas for code and data, a stack, and access to external data areas

Special segment override instruction prefixes allow the implicit segment register selection rules to be overriden for special cases. The stack, data and extra segments may coincide for simple programs. To access operands not residing in one of the four immediately available segments, a full 32-bit pointer or a new segment selector must be loaded

## Addressing Modes

The 80C286 provides a total of eight addressing modes for instructions to specify operands. Two addressing modes are provided for instructions that operate on register or immedıate operands:

REGISTER OPERAND MODE: The operand is located in one of the 8 or 16-bit general registers.

IMMEDIATE OPERAND MODE: The operand is included in the instruction

Six modes are provided to specify the location of an operand in a memory segment. A memory operand address consists of two 16-bit components' segment selector and offset. The segment selector is supplied by a segment register either implicitly chosen by the addressing mode or explıcitly chosen by a segment override prefix. The offset is calculated by summing any combination of the following three address elements:
the displacement (an 8 or 16 -bit immedıate value contained in the instruction)
the base (contents of either the BX or BP base registers) the index (contents of either the SI or DI Index registers)


FIGURE 5. SEGMENTED MEMORY HELPS STRUCTURE SOFTWARE

Any carry out from the 16 -bit addition is ignored. Eight-bit displacements are sign extended to 16-bit values.

Combinations of these three address elements define the six memory addressing modes, described below.

DIRECT MODE. The operand's offset is contained in the instruction as an 8 or 16-bit displacement element.

REGISTER INDIRECT MODE: The operand's offset is in one of the registers $\mathrm{SI}, \mathrm{DI}, \mathrm{BX}$ or BP .

BASED MODE: The operand's offset is the sum of an 8 or 16-bit displacement and the contents of a base register (BX or BP)

INDEXED MODE: The operand's offset is the sum of an 8 or 16-bit displacement and the contents of an index register (SI or DI).

BASED INDEXED MODE• The operand's offset is the sum of the contents of a base register and an index register.

BASED INDEXED MODE WITH DISPLACEMENT: The operand's offset is the sum of a base register's contents, an index register's contents, and an 8 or 16 -bit displacement.

## Data Types

The 80C286 directly supports the following data types:
Integer: A signed binary numeric value contained in an 8 -bit byte or a 16 -bit word. All operations assume a 2's complement representation. Signed 32 and 64-bit integers are supported using the 80287 Numeric Data Processor.

Ordinal: An unsigned binary numeric value contaıned in an 8 -bit byte or 16 -bit word.

Pointer: A 32-bit quantity, composed of a segment selector component and an offset component. Each component is a 16-bit word.

String: A contiguous sequence of bytes or words. A string may contain from 1 byte to 64 K bytes.

ASCII: A byte representation of alphanumeric and control characters using the ASCII standard of character representation.

BCD: A byte (unpacked) representation of the decimal digits 0-9.

Packed A byte (packed) representation of two decımal
BCD: digits $0-9$ storing one digit in each nibble of the byte.

Floating A signed 32,64 or 80 -bit real number
Point: representation. (Floating point operands are supported using the 80287 Numeric Processor extension).

Figure 6 graphically represents the data types supported by the 80C286.


TABLE 4. INTERRUPT VECTOR ASSIGNMENTS

| FUNCTION | INTERRUPT NUMBER | RELATED INSTRUCTIONS | DOES RETURN ADDRESS POINT TO INSTRUCTION CAUSING EXCEPTION? |
| :---: | :---: | :---: | :---: |
| Divide error exception | 0 | DIV, IDIV | Yes |
| Single step interrupt | 1 | All |  |
| NMI interrupt | 2 | INT 2 or NMI pin |  |
| Breakpoint interrupt | 3 | INT 3 |  |
| INTO detected overflow exception | 4 | INTO | No |
| BOUND range exceeded exception | 5 | BOUND | Yes |
| Invalid opcode exception | 6 | Any undefıned opcode | Yes |
| Processor extension not available exception | 7 | ESC of WAIT | Yes |
| Reserved-do not use | 8-15 |  |  |
| Processor extension error interrupt | 16 | ESC or WAIT |  |
| Reserved | 17-31 |  |  |
| User defined | 32-255 |  |  |

## I/O Space

The I/O space consists of 64 K 8 -bit ports, 32 K 16 -bit ports, or a combination of the two. I/O instructions address the I/O space with either an 8-bit port address, specified in the instruction, or a 16-bit port address in the DX register. 8 -bit port addresses are zero extended such that $\mathrm{A}_{15}-\mathrm{A}_{8}$ are LOW. I/O port addresses 00F8(H) through 00FF(H) are reserved.

## Interrupts

An interrupt transfers execution to a new program locatıon. The old program address (CS:IP) and machine state (Flags) are saved on the stack to allow resumption of the interrupted program. Interrupts fall into three classes: hardware initiated, INT instructions, and instruction exceptions Hardware initiated interrupts occur in response to an external input and are classified as non-maskable or maskable. Programs may cause an interrupt with an INT instruction. Instruction exceptions occur when an unusual condition which prevents further instruction processing is detected while attempting to execute an instruction. The return address from an exceptıon will always point to the instruction causıng the exception and include any leading instruction prefixes.

A table containing up to 256 pointers defines the proper interrupt service routine for each interrupt. Interrupts $0-$ 31, some of which are used for instruction exceptions, are reserved For each interrupt, an 8 -bit vector must be supplied to the 80C286 which identifies the appropriate table entry. Exceptions supply the interrupt vector internally INT instructions contain or imply the vector and allow access to all 256 interrupts. Maskable hardware initiated interrupts supply the 8-bit vector to the CPU during an interrupt acknowledge bus sequence. Nonmaskable hardware interrupts use a predefined internally supplied vector.

## Maskable Interrupt (INTR)

The 80C286 provides a maskable hardware interrupt request pin, INTR. Software enables this input by setting the interrupt flag bit (IF) in the flag word. All 224 user-defined interrupt sources can share this input, yet they can retain separate interrupt handlers. An 8-bit vector read by the CPU during the interrupt acknowledge sequence (discussed in System Interface section) identifies the source of the interrupt.

The processor automatically disables further maskable interrupts internally by resetting the IF as part of the response to an interrupt or exception. The saved flag word will reflect the enable status of the processor prior to the interrupt. Until the flag word is restored to the flag register, the interrupt flag will be zero unless specifically set. The interrupt return instruction includes restoring the flag word, thereby restoring the original status of IF.

## Non-Maskable Interrupt Request (NMI)

A non-maskable interrupt input (NMI) is also provided. NMI has higher priority than INTR. A typical use of NMI would be to activate a power failure routine. The activation of this input causes an interrupt with an internally supplied vector value of 2 . No external interrupt acknowledge sequence is performed.

While executing the NMI servicing procedure, the 80 C 286 will service nether further NMI requests, INTR requests, nor the processor extension segment overrun interrupt until an interrupt return (IRET) instruction is executed or the CPU is reset. If NMI occurs while currently servicing an NMI, its presence will be saved for servicing after executing the first IRET instruction. IF is cleared at the beginning of an NMI interrupt to inhibit INTR interrupts.

## Single Step Interrupt

The 80C286 has an internal interrupt that allows programs to execute one instruction at a time. It is called the single step interrupt and is controlled by the single step flag bit (TF) in the flag word. Once this bit is set, an internal single step interrupt will occur after the next instruction has been executed. The interrupt clears the TF bit and uses an internally supplied vector of 1 . The IRET instruction is used to set the TF bit and transfer control to the next instruction to be single stepped.

## Interrupt Priorities

When simultaneous interrupt requests occur, they are processed in a fixed order as shown in Table 5. Interrupt processing involves saving the flags, return address, and setting CS:IP to point at the first instruction of the interrupt handler. If another enabled interrupt should occur, it is processed before the next instruction of the current interrupt handler is executed. The last interrupt processed is therefore the first one serviced.

TABLE 5. INTERRUPT PROCESSING ORDER

| ORDER | INTERRUPT |
| :---: | :--- |
| 1 | Instruction exception |
| 2 | Single step |
| 3 | NMI |
| 4 | Processor extension segment overrun |
| 5 | INTR |
| 6 | INT instruction |

## Initialization and Processor Reset

Processor initialization or start up is accomplished by driving the RESET input pin HIGH. RESET forces the 80 C 286 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as RESET is active. After RESET becomes inactive, and an internal processing interval elapses, the 80C286 begins execution in real address mode with the instruction at physical location FFFFFO(H). RESET also sets some regısters to predefined values as shown in Table 6.

TABLE 6. 80 C 286 INITIAL REGISTER STATE AFTER RESET

| Flag word | $0002(\mathrm{H})$ |
| :--- | :--- |
| Machine status word | $\mathrm{FFFO}(\mathrm{H})$ |
| Instruction pointer | $\mathrm{FFFO}(\mathrm{H})$ |
| Code segment | $\mathrm{FOOO}(\mathrm{H})$ |
| Data segment | $0000(\mathrm{H})$ |
| Extra segment | $0000(\mathrm{H})$ |
| Stack segment | $0000(\mathrm{H})$ |

HOLD must not be active during the time from the leading edge of the initial RESET to 34 CLKs after the trailing edge of the initial RESET of an 80C286 system.

## Machine Status Word Description

The machine status word (MSW) records when a task switch takes place and controls the operating mode of the 80 C 286 . It is a 16 -bit register of which the lower four bits are used. One bit places the CPU into protected mode, while the other three bits, as shown in Table 7, control the

TABLE 7. MSW BIT FUNCTIONS

| BIT POSITION | NAME | FUNCTION |
| :---: | :---: | :--- |
| 0 | PE | Protected mode enable places the 80C286 into protected mode and cannot be cleared <br> except by RESET. |
| 1 | MP | Monitor processor extension allows WAIT instructions to cause a processor extension <br> not present exception (number 7) |
| 2 | EM | Emulate processor extension causes a processor extension not present exception <br> (number 7) on ESC instructions to allow emulating a processor extension |
| 3 | TS | Task switched indicates the next instruction using a processor extension will cause <br> exception 7, allowing software to test whether the current processor extension context <br> belongs to the current task. |

TABLE 8. RECOMMENDED MSW ENCODINGS FOR PROCESSOR EXTENSION CONTROL

| TS | MP | EM | RECOMMENDED USE | INSTRUCTIONS <br> CAUSING <br> EXCEPTION 7 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | Initıal encoding after RESET 80 c 286 operation is identical to <br> $80 C 86 / 88$ | None |
| 0 | 0 | 1 | No processor extension is avaılable Software will emulate its <br> function | ESC |
| 1 | 0 | 1 | No processor extension is avaılable Software will emulate its <br> function The current processor extension context may belong to <br> another task | ESC |
| 0 | 1 | 0 | A processor extension exists | None |
| 1 | 1 | 0 | A processor extension exists The current processor extension <br> context may belong to another task The exception 7 on WAIT allows <br> software to test for an error pending from a previous processor <br> extension operatıon | ESC or WAIT |

processor extension interface After RESET, this register contaıns FFFO(H) which places the 80C286 in 80C286 real address mode

The LMSW and SMSW instructions can load and store the MSW in real address mode The recommended use of TS, EM, and MP is shown in Table 8.

## Halt

The HLT instruction stops program execution and prevents the CPU from using the local bus until restarted. Either NMI, INTR with IF = 1, or RESET will force the 80C286 out of halt. If interrupted, the saved CS:IP will point to the next instruction after the HLT.

## 80C286 Real Address Mode

The 80 C 286 executes a fully upward-compatıble superset of the 80C86 instruction set in real address mode. In real address mode the 80C286 is object code compatıble with 80 C 86 and 80 C 88 software. The real address mode architecture (registers and addressing modes) is exactly as described in the 80C286 Base Architecture section of this Functional Description.

## Memory Size

Physical memory is a contıguous array of up to $1,048,576$ bytes (one megabyte) addressed by pins $A_{0}$ through $A_{19}$ and $\overline{\mathrm{BHE}} \mathrm{A}_{20}$ through $\mathrm{A}_{23}$ should be ignored.

## Memory Addressing

In real address mode physical memory is a contiguous array of up to $1,048,576$ bytes (one megabyte) addressed by pin $A_{0}$ through $\mathrm{A}_{19}$ and $\overline{\mathrm{BHE}}$. Address bits $\mathrm{A}_{20}-\mathrm{A}_{23}$ may not always be zero in real mode. $A_{20}-A_{23}$ should not be used by the system while the 80 C 286 is operating in Real Mode.

The selector portion of a pointer is interpreted as the upper 16 -bits of a 20 -bit segment address. The lower four bits of the 20-bit segment address are always zero. Segment addresses, therefore, begin on multiples of 16 bytes See Figure 7 for a graphic representation of address information.

All segments in real address mode are 64 K bytes in size and may be read, written, or executed. An exception or interrupt can occur if data operands or instructions attempt
to wrap around the end of a segment (e.g. a word with its low order byte at offset FFFF(H) and its high order byte at offset $0000(\mathrm{H})$. If, in real address mode, the information contained in a segment does not use the full 64 K bytes, the unused end of the segment may be overlayed by another segment to reduce physical memory requirements.

TABLE 9. REAL ADDRESS MODE ADDRESSING INTERRUPTS

| FUNCTION | INTERRUPT <br> NUMBER | RELATED <br> INSTRUCTIONS | RETURN ADDRESS <br> BEFORE INSTRUCTION |
| :--- | :---: | :---: | :---: |
| Interrupt table limit too small exceptıon | 8 | INT vector is not within table limit | Yes |
| Processor extensıon segment overrun <br> interrupt | 9 | ESC with memory operand extending <br> beyond offset FFFF(H) | No |
| Segment overrun exception | 13 | Word memory reference with offset $=$ <br> FFFF(H) or an attempt to execute past <br> the end of a segment | Yes |

## Reserved Memory Locations

The 80 C 286 reserves two fixed areas of memory in real address mode (see Figure 8), system initialızatıon area and interrupt table area. Locations from addresses FFFFO(H) through $\operatorname{FFFFF}(\mathrm{H})$ are reserved for system initıalization. Initial execution begins at location FFFFO(H) Locations $00000(\mathrm{H})$ through $003 F F(H)$ are reserved for interrupt vectors.


INITIAL CS:IP VALUE IS F000:FFFO.

FIGURE 8. 80C286 REAL ADDRESS MODE INITIALLY RESERVED MEMORY LOCATIONS

## Interrupts

Table 9 shows the interrupt vectors reserved for exceptıons and interrupts which indıcate an addressing error. The exceptions leave the CPU in the state existing before attempting to execute the failing instruction (except for

PUSH, POP, PUSHA, or POPA). Refer to the next section on protected mode initialızation for a discussion on exception 8.

## Protected Mode Initialization

To prepare the 80C286 for protected mode, the LIDT instruction is used to load the 24-bit interrupt table base and 16-bit limit for the protected mode interrupt table. This instruction can also set a base and limit for the interrupt vector table in real address mode. After reset, the interrupt table base is initialızed to $000000(\mathrm{H})$ and its size set to 03FF(H). These values are compatible with 80 C 86 and 80 C 88 software. LIDT should only be executed in preparation for protected mode.

## Shutdown

Shutdown occurs when a severe error is detected that prevents further instruction processing by the CPU. Shutdown and halt are externally signalled via a halt bus operation. They can be distınguished by $\mathrm{A}_{1} \mathrm{HIGH}$ for halt and $A_{1}$ LOW for shutdown. In real address mode, shutdown can occur under two conditions:

- Exceptions 8 or 13 happen and the IDT lımit does not include the interrupt vector.
- A CALL INT or PUSH instruction attempts to wrap around the stack segment when SP is not even.

An NMI input can bring the CPU out of shutdown if the IDT limit is at least $000 \mathrm{~F}(\mathrm{H})$ and SP is greater than $0005(\mathrm{H})$, otherwise shutdown can only be exited via the RESET input.

## Protected Virtual Address Mode

The 80C286 executes a fully upward-compatible superset of the 80 C 86 instruction set in protected virtual address mode (protected mode). Protected mode also provides memory management and protection mechanisms and associated instructions.

The 80C286 enters protected virtual address mode from real address mode by setting the PE (Protection Enable) bit of the machine status word with the Load Machine Status Word (LMSW) instruction. Protected mode offers
extended physical and virtual memory address space, memory protection mechanisms, and new operations to support operating systems and virtual memory.

All registers, instructions, and addressing modes described in the 80 C 286 Base Architecture section of this Functional Description remain the same. Programs for the 80C86, 80C88, and real address mode 80C286 can be run in protected mode; however, embedded constants for segment selectors are different.

## Memory Size

The protected mode 80 C 286 provides a 1 gıgabyte virtual address space per task mapped into a 16 megabyte physical address space defined by the address pins $\mathrm{A}_{23}-\mathrm{A}_{0}$ and $\overline{\mathrm{BHE}}$ The virtual address space may be larger than the physical address space since any use of an address that does not map to a physical memory location will cause a restartable exception

CPU


FIGURE 9. PROTECTED MODE MEMORY ADDRESSING

## Memory Addressing

As in real address mode, protected mode uses 32-bit pointers, consistıng of 16 -bit selector and offset components The selector, however, specifies an index into a memory resident table rather than the upper 16-bits of a real memory address. The 24-bit base address of the desired segment is obtaıned from the tables in memory. The 16 -bit offset is added to the segment base address to form the physical address as shown in Figure 9 The tables
are automatically referenced by the CPU whenever a segment register is loaded with a selector. All 80 C 286 instructions which load a segment register will reference the memory based tables without additional software. The memory based tables contaın 8 byte values called descriptors

## Descriptors

Descriptors define the use of memory. Special types of descriptors also define new functions for transfer of control and task switching. The 80C286 has segment descriptors for code, stack and data segments, and system control descriptors for special system data segments and control transfer operations. Descriptor accesses are performed as locked bus operations to assure descriptor integrity in multi-processor systems.

## Code and Data Segment Descriptors (S = 1)

Besides segment base addresses, code and data descriptors contaın other segment attributes includıng segment size ( 1 to 64 K bytes), access rights (read only, read/write, execute only, and execute/read), and presence in memory (for virtual memory systems) (See Figure 10). Any segment usage violatıng a segment attribute indicated by the segment descriptor will prevent the memory cycle and cause an exception or interrupt.

## CODE OR DATA SEGMENT DESCRIPTOR


*Must be set to 0 for compatability with future upgrades

ACCESS RIGHTS BYTE DEFINITION


FIGURE 10. CODE AND DATA SEGMENT DESCRIPTOR FORMATS

Code and data (including stack data) are stored in two types of segments: code segments and data segments. Both types are identified and defined by segment descriptors $(S=1)$. Code segments are identified by the executable ( E ) bit set to 1 in the descriptor access rights byte. The access rights byte of both code and data segment descriptor types have three fields in common: present (P) bit, Descriptor Privilege Level (DPL), and accessed (A) bit. If $P=0$, any attempted use of this segment will cause a not-present exception. DPL specifies the privilege level of the segment descriptor. DPL controls when the descriptor may be used by a task (refer to privilege discussion below). The A bit shows whether the segment has been previously accessed for usage profiling, a necessity for virtual memory systems. The CPU will always set this bit when accessing the descriptor.

Data segments ( $S=1, E=0$ ) may be either read-only or read-write as controlled by the W bit of the access rights byte. Read-only ( $\mathrm{W}=0$ ) data segments may not be written into. Data segments may grow in two directions, as determined by the Expansion Dırection (ED) bit: upwards ( $E D=0$ ) for data segments, and downwards ( $E D=1$ ) for a segment containing a stack. The limit field for a data segment descriptor is interpreted differently depending on the ED bit (see Figure 10).

A code segment ( $S=1, E=1$ ) may be execute-only or execute/read as determined by the Readable (R) bit. Code segments may never be written into and execute-only code segments ( $R=0$ ) may not be read. A code segment may also have an attribute called conforming (C). A conforming code segment may be shared by programs that execute at different privilege levels. The DPL of a conforming code segment defines the range of privilege levels at which the segment may be executed (refer to privilege discussion below). The limit field identifies the last byte of a code segment.

## System Segment Descriptors ( $\mathrm{S}=0$, Type $=1-3$ )

In addition to code and data segment descriptors, the protected mode 80C286 defines System Segment Descriptors. These descriptors define special system data segments which contain a table of descriptors (Local Descriptor Table Descriptor) or segments which contain the execution state of a task (Task State Segment Descriptor).

Figure 11 gives the formats for the special system data segment descriptors. The descriptors contain a 24 -bit base address of the segment and a 16-bit limit. The access byte defines the type of descriptor, its state and privilege level. The descriptor contents are valid and the segment is in physical memory if $P=1$. If $P=0$, the segment is not valid. The DPL field is only used in Task State Segment descriptors and indicates the privilege level at which the descriptor may be used (see Privilege). Since the Local Descriptor Table descriptor may only be used by a special privileged instruction, the DPL field is not used. Bit 4 of the access byte is 0 to indicate that it is a system control descriptor. The type field specifies the descriptor type as indicated in Figure 11.
SYSTEM SEGMENT DESCRIPTOR

*Must be set to 0 for compatability with future upgrades
SYSTEM SEGMENT DESCRIPTOR FIELDS

| Name | Value | Description |
| :---: | :---: | :--- |
| TYPE | 1 | Available Task State Segment (TSS) |
|  | 2 | Local Descriptor Table <br> Busy Task State Segment (TSS) |
| P | 0 | Descriptor contents are not valid <br> Descriptor contents are valid |
| DPL | $0-3$ | Descriptor Privilege Level |
| BASE | 24 -bit <br> number | Base Address of special system data <br> segment in real memory |
| LIMIT | 16 -bit <br> number | Offset of last byte in segment |

FIGURE 11. SYSTEM SEGMENT DESCRIPTOR FORMAT
Gate Descriptors ( $\mathrm{S}=0$, Type $=\mathbf{4 - 7}$ )
Gates are used to control access to entry points withın the target code segment. The gate descriptors are call gates, task gates, interrupt gates and trap gates. Gates provide a level of indirection between the source and destination of the control transfer. This indirection allows the CPU to automatically perform protection checks and control entry point of the destination. Call gates are used to change privilege levels (see Privilege), task gates are used to perform a task switch, and interrupt and trap gates are used to specify interrupt service routines. The interrupt gate disables interrupts (resets IF) while the trap gate does not.

Figure 12 shows the format of the gate descriptors. The descriptor contaıns a destınation pointer that poınts to the descriptor of the target segment and the entry point offset. The destınation selector in an interrupt gate, trap gate, and call gate must refer to a code segment descriptor. These gate descriptors contain the entry point to prevent a program from constructing and using an illegal entry point. Task gates may only refer to a task state segment. Since task gates invoke a task switch, the destination offset is not used in the task gate.

Exception 13 is generated when the gate is used if a destination selector does not refer to the correct descriptor type. The word count field is used in the call gate descriptor to indicate the number of parameters (0-31 words) to be automatically copied from the caller's stack to the stack of the called routine when a control transfer changes privilege levels. The word count field is not used by any other gate descriptor.

The access byte format is the same for all descriptors. $\mathrm{P}=$ 1 indicates that th gate contents are valid. $\mathrm{P}=0$ indicates the contents are not valid and causes exception 11 if referenced. DPL is the descriptor privilege level and specifies when this descriptor may be used by a task (refer
to privilege discussion below). Bit 4 must equal 0 to indicate a system control descriptor. The type field specifies the descriptor type as indicated in Figure 12.

GATE DESCRIPTOR

*Must be set to 0 for compatibility with future upgrades
GATE DESCRIPTOR FIELDS

| Name | Value | Description |
| :---: | :---: | :--- |
| TYPE | 4 | -Call Gate <br> -Task Gate <br> - interrupt Gate <br> -Trap Gate |
| P | 0 | -Descriptor Contents are not <br> valid <br> -Descriptor Contents are <br> valid |
| DPL | $0-3$ | Descriptor Privilege Level |
| WORD <br> COUNT | $0-31$ | Number of words to copy <br> from callers stack to called <br> procedures stack Only used <br> with call gate |
| DESTINATION |  |  |
| SELECTOR | selector | Selector to the target code <br> segment (Call, Interrupt or |
| Trap Gate) <br> Selector to the target task <br> state segment (Task Gate) |  |  |
| DESTINATION <br> OFFSET | 16-bit <br> offset | Entry point within the target <br> code segment |

FIGURE 12. GATE DESCRIPTOR FORMAT

## Segment Descriptor Cache Registers

A segment descriptor cache register is assigned to each of the four segment registers (CS, SS, DS, ES). Segment descriptors are automatically loaded (cached) into a segment descriptor cache register (Figure 13) whenever the associated segment register is loaded with a selector.


FIGURE 13. DESCRIPTOR CACHE REGISTERS

Only segment descriptors may be loaded into segment descriptor cache registers. Once loaded, all references to that segment of memory use the cached descriptor information instead of reaccessing the descriptor. The descriptor cache registers are not visible to programs. No instructions exist to store their contents. They only change when a segment register is loaded.

## Selector Fields

A protected mode selector has three fields: descriptor entry index, local or global descriptor table indicator (TI), and selector privilege (RPL) as shown in Figure 14. These fields select one of two memory based tables of descriptors, select the appropriate table entry and allow high-speed testing of the selector's privilege attribute (refer to privilege discussion below).


FIGURE 14. SELECTOR FIELDS

## Local and Global Descriptor Tables

Two tables of descriptors, called descriptor tables, contain all descriptors accessible by a task at any given time A descriptor table is a linear array of up to 8192 descriptors The upper 13 bits of the selector value are an index into a descriptor table. Each table has a 24-bit base register to locate the descriptor table in physical memory and a 16-bit limit register that confine descriptor access to the defined limits of the table as shown in Figure 15. A restartable exception (13) will occur if an attempt is made to reference a descriptor outside the table limits.


FIGURE 15. LOCAL AND GLOBAL DESCRIPTOR TABLE DEFINITION

One table, called the Global Descriptor table (GDT), contains descriptors available to all tasks. The other table, called the Local Descriptor Table (LDT), contains descriptors that can be private to a task. Each task may have its own private LDT. The GDT may contain all descriptor types except interrupt and trap descriptors. The LDT may contain only segment, task gate, and call gate descriptors. A segment cannot be accessed by a task if its segment descriptor does not exist in either descriptor table at the time of access.

The LGDT and LLDT instructions load the base and limit of the global and local descriptor tables. LGDT and LLDT are privileged, i.e. they may only be executed by trusted programs operating at level 0 . The LGDT instruction loads a six byte field containing the 16-bit table limit and 24-bit physical base address of the Global Descriptor Table as shown in Figure 16. The LDT instruction loads a selector which refers to a Local Descriptor Table descriptor containing the base address and limit for an LDT, as shown in Figure 11.

*Must be set to 0 for compatability with future upgrades
FIGURE 16. GLOBAL DESCRIPTOR TABLE AND INTERRUPT DESCRIPTOR TABLE DATA TYPE

## Interrupt Descriptor Table

The protected mode 80 C 286 has a third descriptor table, called the Interrupt Descriptor Table (IDT) (see Figure 17), used to define up to 256 interrupts. It may contain only task gates, interrupt gates and trap gates. The IDT (Interrupt Descriptor Table) has a 24-bit physical base and 16-bit limit register in the CPU. The priviledged LIDT instruction loads these registers with a six byte value of identical form to that of the LGDT instruction (see Figure 16 and Protected Mode Initialization).


## FIGURE 17. INTERRUPT DESCRIPTOR TABLE DEFINITION

References to IDT entries are made via INT instructions, external interrupt vectors, or exceptions. The IDT must be at least 256 bytes in size to allocate space for all reserved interrupts.

## Privilege

The 80 C 286 has a four-level hierarchical privilege system which controls the use of privileged instructions and access to descriptors (and their associated segments)
within a task. Four-level privilege, as shown in Figure 18, is an extension of the userssupervisor mode commonly found in minicomputers. The privilege levels are numbered 0 through 3 . Level 0 is the most privileged level. Privilege levels provide protection within a task. (Tasks are isolated by providing private LDT's for each task.) Operating system routines, interrupt handlers, and other system software can be included and protected within the virtual address space of each task using the four levels of privilege. Each task in the system has a separate stack for each of its privilege levels.

Tasks, descriptors, and selectors have a privilege level attribute that determines whether the descriptor may be used. Task privilege affects the use of instructions and descriptors. Descriptor and selector privilege only affect access to the descriptor.


NOTE PL becomes numerically lower as privilege level increases
FIGURE 18. HIERARCHICAL PRIVILEGE LEVELS

## Task Privilege

A task always executes at one of the four privilege levels. The task privilege level at any specific instant is called the Current Privilege Level (CPL) and is defined by the lower two bits of the CS register. CPL cannot change during execution in a single code segment. A task's CPL may only be changed by control transfers through gate descriptors to a new code segment (See Control Transfer). Tasks begin executıng at the CPL value specified by the code segment selector withın TSS when the task is initiated via a task switch operation (See Figure 19). A task executing at Level 0 can access all data segments defined in the GDT and the task's LDT and is considered the most trusted level. A task executing a Level 3 has the most restricted access to data and is considered the least trusted level.

## Descriptor Privilege

Descriptor privilege is specified by the Descriptor Privilege Level (DPL) field of the descriptor access byte. DPL specifies the least trusted task privilege level (CPL) at which a task may access the descriptor. Descriptors with DPL $=0$ are the most protected Only tasks executıng at privilege level $0(C P L=0)$ may access them. Descriptors with DPL $=3$ are the least protected (i.e. have the least restricted access) since tasks can access them when $C P L=0,1,2$, or 3 ). This rule applies to all descriptors, except LDT descriptors.

TABLE 10. DESCRIPTOR TYPES USED FOR CONTROL TRANSFER

| CONTROL TRANSFER TYPES | OPERATION TYPES | DESCRIPTOR <br> REFERENCED | DESCRIPTOR <br> TABLE |
| :--- | :--- | :--- | :--- |
| Intersegment within the same privilege levels | JMP, CALL, RET, IRET* | Code Segment | GDT/LDT |
|  | CALL | Call Gate | GDT/LDT |
|  | Interrupt Instruction, Exception <br> External Interrupt | Trap or Interrupt <br> Gate | IDT |
| Intersegment to a lower privilege level <br> (changes task CPL) | RET, IRET* | Code Segment | GDT/LDT |
|  | CALL, JMP | Task State Segment | GDT |
|  | CALL, JMP | Task Gate | GDT/LDT |
|  | IRET** <br> Interrupt Instruction, Exception <br> External Interrupt | Task Gate | IDT |

*NT (Nested Task bit of flag word) $=0 \quad$ **NT (Nested Task bit of flag word) $=1$

## Selector Privilege

Selector privilege is specified by the Requested Privilege Level (RPL) field in the least significant two bits of a selector. Selector RPL may establish a less trusted privilege level than the current privilege level for the use of a selector. This level is called the task's effective privilege level (EPL). RPL can only reduce the scope of a task's access to data with this selector. A task's effective privilege is the numeric maximum of RPL and CPL. A selector with RPL $=0$ imposes no additional restriction on its use while a selector with RPL $=3$ can only refer to segments at privilege Level 3 regardless of the task's CPL. RPL is generally used to verify that pointer parameters passed to a more trusted procedure are not allowed to use data at a more privileged level than the caller (refer to pointer testing instructions).

## Descriptor Access and Privilege Validation

Determining the ability of a task to access a segment involves the type of segment to be accessed, the instruction used, the type of descriptor used and CPL, RPL, and DPL. The two basic types of segment accesses are control transfer (selectors loaded into CS) and data (selectors loaded into DS, ES or SS).

## Data Segment Access

Instructions that load selectors into DS and ES must refer to a data segment descriptor or readable code segment descriptor. The CPL of the task and the RPL of the selector must be the same as or more privileged (numerically equal to or lower than) than the descriptor DPL. In general, a task can only access data segments at the same or less privileged levels than the CPL or RPL (whichever is numerically higher) to prevent a program from accessing data it cannot be trusted to use.

An exception to the rule is a readable conforming code segment. This type of code segment can be read from any privilege level.

If the privilege checks fail (e.g. DPL is numerically less than the maximum of CPL and RPL) or an incorrect type of descriptor is referenced (e.g. gate descriptor or execute only code segment) exception 13 occurs. If the segment is not present, exception 11 is generated.

Instructions that load selectors into SS must refer to data segment descriptors for writable data segments. The descriptor privilege (DPL) and RPL must equal CPL. All other descriptor types or a privilege level violation will cause exception 13. A not present fault causes exception 12.

## Control Transfer

Four types of control transfer can occur when a selector is loaded into CS by a control transfer operation (see Table 10). Each transfer type can only nocur if the operation which loaded the selector references the correct descriptor type. Any violation of these descriptor usage rules (e.g. JMP through a call gate or RET to a Task State Segment) will cause exception 13

The ability to reference a descriptor for control transfer is also subject to rules of privilege. A CALL or JUMP instruction may only reference a code segment descriptor with DPL equal to the task CPL or a conforming segment with DPL of equal or greater privilege than CPL. The RPL of the selector used to reference the code descriptor must have as much privilege as CPL.

RET and IRET instructions may only reference code segment descriptors with descriptor privilege equal to or less privileged than the task CPL. The selector loaded into CS is the return address from the stack. After the return, the selector RPL is the task's new CPL. If CPL changes, the old stack pointer is popped after the return address.

When a JMP or CALL references a Task State Segment descriptor, the descriptor DPL must be the same or less privileged than the task's CPL. Reference to a valid Task

State Segment descriptor causes a task switch (see Task Switch Operation). Reference to a Task State Segment descriptor at a more privileged level than the task's CPL generates exception 13.

When an instruction or interrupt references a gate descriptor, the gate DPL must have the same or less privilege than the task CPL. If DPL is at a more privileged level than CPL, exception 13 occurs If the destination selector contained in the gate references a code segment descriptor, the code segment descriptor DPL must be the same or more privileged than the task CPL. If not, Exception 13 is issued. After the control transfer, the code segment descriptors DPL is the task's new CPL. If the destination selector in the gate references a task state segment, a task switch is automatically performed (see Task Switch Operation).
The privilege rules on control transfer require:

- JMP or CALL direct to a code segment (code segment descriptor) can only be a conforming segment with DPL of equal or greater privilege than CPL or a nonconforming segment at the same privilege level.
- interrupts within the task, or calls that may change privilege levels, can only transfer control through a gate at the same or a less privileged level than CPL to a code segment at the same or more privileged level than CPL.
- return instructions that don't switch tasks can only return control to a code segment at the same or less privileged level.
- task switch can be performed by a call, jump or interrupt which references either a task gate or task state segment at the same or less privileged level.


## Privilege Level Changes

Any control transfer that changes CPL within the task, causes a change of stacks as part of the operation. Initial values of SS:SP for privilege levels 0,1 , and 2 are kept in the task state segment (refer to Task Switch Operation). During a JMP or CALL control transfer, the new stack pointer is loaded into the SS and SP registers and the previous stack pointer is pushed onto the new stack.

When returning to the original privilege level, its stack is restored as part of the RET or IRET instruction operation. For subroutine calls that pass parameters on the stack
table 11. SEGMENT REGISTER LOAD CHECKS

| ERROR DESCRIPTION | EXCEPTION <br> NUMBER |
| :--- | :---: |
| Descriptor table limit exceeded | 13 |
| Segment descriptor not-present | 11 or 12 |
| Privilege rules violated | 13 |
| Invalid descriptor/segment type segment <br> register load |  |
| -Read only data segment load to SS <br> -Special control descriptor load to DS, ES, SS | 13 |
| -Execute only segment load to DS, ES, SS |  |
| -Data segment load to CS |  |
| -Read/Execute code segment load SS |  |$\quad$| ( |
| :--- |

and cross privilege levels, a fixed number of words, as specified in the gate, are copied from the previous stack to the current stack. The inter-segment RET instruction with a stack adjustment value will correctly restore the previous stack pointer upon return.

## Protection

The 80 C 286 includes mechanisms to protect critical instructions that effect the CPU execution state (e g HLT) and code or data segments from improper usage. These protection mechanisms are grouped into three forms:

- Restricted usage of segments (e.g. no write allowed to read-only data segments). The only segments available for use are defined by descriptors in the Local Descriptor Table (LDT) and Global Descriptor Table (GDT)
- Restricted access to segments via the rules of privilege and descriptor usage.
- Privileged instructions or operations that may only be executed at certain privilege levels as determined by the CPL and I/O Privilege Level (IOPL). The IOPL is defined by bits 14 and 13 of the flag word

These checks are performed for all instructions and can be split into three categories: segment load checks (Table 11), operand reference checks (Table 12), and privileged instruction checks (Table 13). Any violation of the rules shown will result in an exception A not-present exception related to the stack segment causes exception 12.

The IRET and POPF instructions do not perform some of their defined functions if CPL is not of sufficient privilege (numerically small enough). Precisely these are:

- The IF bit is not changed if CPL is greater than IOPL.
- The IOPL field of the flag word is not changed if CPL is greater than 0 .

No exceptions or other indication are given when these conditions occur.

TABLE 12. OPERAND REFERENCE CHECKS

| ERROR DESCRIPTION | EXCEPTION <br> NUMBER |
| :--- | :---: |
| Write into code segment | 13 |
| Read from execute-only code segment | 13 |
| Write to read-only data segment | 13 |
| Segment limit exceeded (Note1) | 12 or 13 |

NOTE 1 Carry out in offset calculations is ignored

TABLE 13. PRIVILEGED INSTRUCTION CHECKS

| ERROR DESCRIPTION | EXCEPTION <br> NUMBER |
| :---: | :---: |
| CPL $\neq 0$ when executing the following <br> Instructions <br> LIDT, LLDT, LGDT, LTR, LMSW, CTS, HLT | 13 |
| CPT > IOPL when executing the following <br> Instructions <br> INS, IN, OUTS, OUT, STI, CLI, LOCK | 13 |

TABLE 14. PROTECTED MODE EXCEPTIONS

| INTERRUPT <br> VECTOR | FUNCTION | RETURN ADDRESS <br> AT FALLING <br> INSTRUCTION? | ALWAYS <br> RESTARTABLE? | ERROR CODE <br> ON STACK? |
| :---: | :--- | :---: | :---: | :---: |
| 8 | Double exception detected | Yes | No (Note 2) | Yes |
| 9 | Processor extension segment overrun | No | No (Note 2) | No |
| 10 | Invalıd task state segment | Yes | Yes | Yes |
| 11 | Segment not present | Yes | Yes | Yes |
| 12 | Stack segment overrun or stack segment not present | Yes | Yes (Note 1) | Yes |
| 13 | General protection | Yes | No (Note 2) | Yes |

NOTES 1 When a PUSHA or POPA instruction attempts to wrap around the stack segment, the machine state after the exception will not be restartable because stack segment wrap around is not permitted This condition is identified by the value of the saved SP being either $0000(\mathrm{H}), 0001(\mathrm{H})$, FFFE(H), or FFFF(H)
2 These exceptions indicate a violation to privilege rules or usage rules has occurred Restart is generally not attempted under those conditions

## Exceptions

The 80C286 detects several types of exceptions and interrupts in protected mode (see Table 14). Most are restartable after the exceptional condition is removed. Interrupt handlers for most exceptions can read an error code, pushed on the stack after the return address, that identifies the selector involved ( 0 if none). The return address normally points to the failing instruction, includıng all leadıng prefixes. For a processor extension segment overrun exception, the return address will not point at the ESC instruction that caused the exception; however, the processor extension registers may contain the address of the failing instruction.

These exceptions indicate a violation to privilege rules or usage rules has occurred. Restart is generally not attempted under those conditions.

All these checks are performed for all instructions and can be split into three categories: segment load checks (Table 11), operand reference checks (Table 12), and privileged instruction checks (Table 13) Any violation of the rules shown will result in an exception. A not-present exception causes exception 11 or 12 and is restartable.

## Special Operations

## Task Switch Operation

The 80 C 286 provides a built-in task switch operation which saves the entire 80C286 execution state (registers, address space, and a link to the previous task), loads a new execution state, and commences execution in the new task. Like gates, the task switch operation is invoked by executing an inter-segment JMP or CALL instruction which refers to a Task State Segment (TSS) or task gate descriptor in the GDT or LDT. An INT instruction, exception, or external interrupt may also invoke the task switch operatıon by selecting a task gate descriptor in the associated IDT descriptor entry.

The TSS descriptor points at a segment (see Figure 19) containing the entire 80C286 execution state while a task gate descriptor contains a TSS selector. The limit field of the descriptor must be greater than $002 \mathrm{~B}(\mathrm{H})$.

Each task must have a TSS associated with it. The current TSS is identıfied by a special register in the 80C286 called
the Task Regıster (TR). This regıster contains a selector referring to the task state segment descriptor that defines the current TSS. A hidden base and limit register assoclated with TR are loaded whenever TR is loaded with a new selector. The IRET instruction is used to return control to the task that called the current task or was interrupted. Bit 14 in the flag register is called the Nested Task (NT) bit. It controls the function of the IRET instruction. If NT $=0$, the IRET instruction performs the regular current task by popping values off the stack; when NT $=1$, IRET performs a task switch operation back to the previous task.

When a CALL, JMP, or INT instruction initiates a task switch, the old (except for case of JMP) and new TSS will be marked busy and the back link field of the new TSS set to the old TSS selector. The NT bit of the new task is set by CALL or INT initiated task switches. An interrupt that does not cause a task switch will clear NT. NT may also be set or cleared by POPF or IRET instructions.

The task state segment is marked busy by changing the descriptor type field from Type 1 to Type 3. Use of a selector that references a busy task state segment causes Exception 13.

## Processor Extension Context Switching

The context of a processor extension is not changed by the task switch operation. A processor extension context need only be changed when a different task attempts to use the processor extension (which still contains the context of a previous task). The 80 C 286 detects the first use of a processor extension after a task switch by causing the processor extension not present exception (7). The interrupt handler may then decide whether a context change is necessary.

Whenever the 80 C 286 switches tasks, it sets the Task Switched (TS) bit of the MSW. TS indicates that a processor extension context may belong to a different task than the current one. The processor extension not present exception (7) will occur when attempting to execute an ESC or WAIT instruction if TS = 1 and a processor extension is present (MP = 1 in MSW).


FIGURE 19. TASK STATE SEGMENT AND TSS REGISTERS

## Pointer Testing Instructions

The 80C286 provides several instructions to speed pointer testing and consistency checks for maintaining system integrity (see Table 15). These instructions use the memory management hardware to verify that a
selector value refers to an appropriate segment without risking an exception. A condition flag (ZF) indicates whether use of the selector or segment will cause an exception.

TABLE 15. 80C286 POINTER TEST INSTRUCTIONS

| INSTRUCTION | OPERANDS | FUNCTION |
| :---: | :--- | :--- |
| ARPL | Selector, <br> Register | Adjust Requested Privilege Level: adjusts the RPL of the selector to the numeric maximum <br> of current selector RPL value and the RPL value in the register. Set zero flag if selector RPL <br> was changed by ARPL. |
| VERR | Selector | VERify for Read: sets the zero flag if the segment referred to by the selector can be read |
| VERW | Selector | VERify for Write: sets the zero flag if the segment referred to by the selector can be written. |
| LSL | Register, <br> Selector | Load Segment Limit: reads the segment limit into the register if privilege rules and descrip- <br> tor type allow. Set zero flag if successful |
| LAR | Register, <br> Selector | Load Access Rights. reads the descriptor access rights byte into the register if privilege <br> rules allow. Set zero flag if successful |

## Double Fault and Shutdown

If two separate exceptions are detected during a single instruction execution, the 80C286 performs the double fault exceptıon (8). If an exception occurs during processing of the double fault exception, the 80 C 286 will enter shutdown. During shutdown no further instructions or exceptions are processed. Either NMI (CPU remains in protected mode) or RESET (CPU exits protected mode) can force the 80 C 286 out of shutdown. Shutdown is externally signalled via a HALT bus operation with $\mathrm{A}_{1}$ LOW.

## Protected Mode Initialization

The 80C286 initially executes in real address mode after RESET To allow initialization code to be placed at the top of physical memory, $\mathrm{A}_{23}-20$ will be HIGH when the 80C286 performs memory references relative to the CS register untll $C S$ is changed. $A_{23-20}$ will be zero for references to the DS, ES, or SS segments. Changing CS in real address mode will force $A_{23-20}$ LOW whenever CS is
used again. The initial CS:IP value of F000:FFF0 provides 64 K bytes of code space for initialization code without changing CS.

Protected mode operation requires several registers to be initialized. The GDT and IDT base registers must refer to a valid GDT and IDT. After executing the LMSW instruction to set PE, the 80C286 must immediately execute an intrasegment JMP instruction to clear the instruction queue of instructions decoded in real address mode.

To force the 80 C 286 CPU registers to match the initial protected mode state assumed by software, execute a JMP instruction with a selector referring to the initial TSS used in the system. This will load the task register, local descriptor table register, segment registers and initial general register state. The TR should point at a valid TSS since any task switch operation involves saving the current task state.
generates Multibus ${ }^{\text {TM }}$ bus arbitration signals. These components can provide the critical timing required for most system bus interfaces including the Multibus.

## Bus Hold Circuitry

To avoid high current conditions caused by floating inputs to CMOS devices, and to eliminate the need for pull-up/down resistors, "bus-hold" circuitry has been used on the 80C286 pins 4-6, 36-51 and 66-68 (See Figure 20A and 20B). The circuit shown in Figure 20A will maintain the last valid logic state if no driving source is present (i.e. an unconnected pin or a driving source which goes to a high impedance state). The circuit shown in Figure 20B will maintain a high impedance logic one state if no driving source is present. To overdrive the "bus-hold" circuits, an external driver must be capable of sinking or sourcing approximately 400 microamps 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.


FIGURE 20A. BUS HOLD CIRCUITRY - PINS 36-51, 66, 67


FIGURE 20B. BUS HOLD CIRCUITRY - PINS 4-6, 68

## Physical Memory and I/O Interface

A maximum of 16 megabytes of physical memory can be addressed in protected mode. One megabyte can be addressed in real address mode. Memory is accessible as bytes or words. Words consist of any two consecutive bytes addressed with the least significant byte stored in the lowest address. Byte transfers occur on either half of the 16-bit local data bus. Even bytes are accessed over $D_{7-0}$ while odd bytes are transferred over $D_{15-8}$. Even addressed words are transferred over $\mathrm{D}_{15-0}$ in one bus cycle, while odd addressed word require two bus operations. The first transfers data on $\mathrm{D}_{15-8}$, and the second transfers data on D7-0. Both byte data transfers occur automatically, transparent to software.

Two bus signals, $\mathrm{A}_{0}$ and $\overline{\mathrm{BHE}}$, control transfers over the lower and upper halves of the data bus. Even address byte transfers are indicated by $A_{0}$ LOW and BHE HIGH. Odd address byte transfers are indicated by $\mathrm{A}_{0} \mathrm{HIGH}$ and $\overline{\mathrm{BHE}}$ LOW. Both $\mathrm{A}_{0}$ and $\overline{\mathrm{BHE}}$ are LOW for even address word transfers.

The I/O address space contains 64 K addresses in both modes. The I/O space is accessible as either bytes or words, as is memory. Byte wide peripheral devices may be attached to either the upper or lower byte of the data bus. Byte-wide I/O devices attached to the upper data byte ( $\mathrm{D}_{15-8}$ ) are accessed with odd I/O addresses. Devices on the lower data byte are accessed with even I/O addresses. An interrupt controller such as Harris's 82C59A must be connected to the lower data byte ( $\mathrm{D}_{7-0}$ ) for proper return of the interrupt vector.

## Bus Operation

The 80C286 uses a double frequency system clock (CLK input) to control bus timing. All signals on the local bus are measured relative to the system CLK input. The CPU divides the system clock by 2 to produce the internal processor clock, which determines bus state. Each processor clock is composed of two system clock cycles named phase 1 and phase 2. The 82C284 clock generator output (PCLK) identifies the next phase of the processor clock. (See Figure 21.)


FIGURE 21. SYSTEM AND PROCESSOR CLOCK RELATIONSHIPS

Six types of bus operations are supported; memory read, memory write, I/O read, I/O write, interrupt acknowledge, and halt/shutdown. Data can be transferred at a maximum rate of one word per two processor clock cycles.

The 80C286 bus has three basic states: idle ( $\mathrm{T}_{1}$ ), send status (TS), and perform command (TC). The 80C286 CPU also has a fourth local bus state called hold ( $\mathrm{T}_{\mathrm{H}}$ ). $\mathrm{T}_{\mathrm{H}}$ indicates that the 80C286 has surrendered control of the local bus to another bus master in response to a HOLD request.

Each bus state is one processor clock long. Figure 22 shows the four 80C286 local bus states and allowed transitions.


FIGURE 22. 80 C 286 BUS STATES

## Bus States

The idle ( $T_{\mid}$) state indicates that no data transfers are in progress or requested. The first active state $T_{S}$ is signaled by status line $\overline{S_{1}}$ or $\overline{\mathrm{S}_{0}}$ going LOW and identifying phase 1 of the processor clock. During Ts, the command encoding, the address, and data (for a write operation) are available on the 80 C 286 output pins. The 82 C 288 bus controller decodes the status signals and generates Multibus compatible read/write command and local transceiver control signals.

After TS, the perform command (TC) state is entered. Memory or I/O devices respond to the bus operation during ${ }^{T} \mathrm{C}$, either transferring read data to the CPU or accepting write data. TC states may be repeated as often as necessary to ensure sufficient time for the memory or I/O device to respond. The $\overline{\text { READY }}$ signal determines whether $T_{C}$ is repeated. A repeated $T_{C}$ state is called a wait state.

During hold $\left(\mathrm{TH}_{H}\right)$, the 80C286 will float all address, data, and status output drivers enabling another bus master to use the local bus. The 80 C 286 HOLD input signal is used to place the 80 C 286 into the $T_{H}$ state. The 80 C 286 HLDA output signal indıcates that the CPU has entered $\mathrm{T}_{\mathrm{H}}$.

## Pipelined Addressing

The 80C286 uses a local bus interface with pipelıned timing to allow as much time as possible for data access. Pipelined timıng allows a new bus operation to be initiated every two processor cycles, while allowing each individual bus operation to last for three processor cycles.


FIGURE 23. BASIC BUS CYCLE

The timing of the address outputs is pipelined such that the address of the next bus operation becomes available during the current bus operation. Or, in other words, the first clock of the next bus operation is overlapped with the last clock of the current bus operation. Therefore, address decode and routing logic can operate in advance of the next bus operation.

External address latches may hold the address stable for the entire bus operation, and provide additional AC and DC buffering.

The 80C286 does not maintain the address of the current bus operation during all $T_{C}$ states. Instead, the address for the next bus operation may be emitted during phase 2 of any $T_{C}$. The address remains valıd during phase 1 of the first TC to guarantee hold time, relative to ALE, for the address latch inputs.

## Bus Control Signals

The 82C288 bus controller provides control signals; address latch enable (ALE), Read/Write commands, data transmit/receive (DT/ $\overline{\mathrm{R}}$ ), and data enable (DEN) that control the address latches, data transceivers, write enable, and output enable for memory and I/O systems.

The Address Latch Enable (ALE) output determınes when the address may be latched. ALE provides at least one system CLK period of address hold time from the end of the previous bus operation until the address for the next bus operation appears at the latch outputs. This address hold time is required to support Multibus and common memory systems.

The data bus transceivers are controlled by 82 C 288 outputs Data Enable (DEN) and Data Transmit/Receive ( $D T / \bar{R}$ ). DEN enables the data transceivers, while $D T / \bar{R}$ controls tranceiver direction. DEN and DT/ $\overline{\mathrm{R}}$ are timed to prevent bus contention between the bus master, data bus transceivers, and system data bus transceivers

## Command Timing Controls

Two system tımıng customization options, command extension and command delay, are provided on the 80C286 local bus.

Command extension allows additional tıme for external devices to respond to a command and is analogous to inserting wait states on the 80C86. External logic can control the duration of any bus operation such that the operation is only as long as necessary The READY input signal can extend any bus operation for as long as necessary.

Command delay allows an increase of address or write data setup time to system bus command active for any bus operation by delaying when the system bus command becomes active. Command delay is controlled by the 82C288 CMDLY input. After TS, the bus controller samples CMDLY at each failing edge of CLK. If CMDLY is HIGH, the 82C288 will not activate the command signal. When CMDLY is LOW, the 82C288 will activate the command signal. After the command becomes active, the CMDLY input is not sampled.

When a command is delayed, the available response time from command active to return read data or accept write data is less. To customize system bus tımıng, an address decoder can determine which bus operations require delaying the command. The CMDLY input does not affect the timing of ALE, DEN or DT/ $\bar{R}$.
Figure 24 illustrates four uses of CMDLY. Example 1 shows delaying the read command two system CLKs for cycle $\mathrm{N}-1$ and no delay for cycle N , and example 2 shows delaying the read command one system CLK for cycle $\mathrm{N}-1$ and one system CLK delay for cycle $N$.

## Bus Cycle Termination

At maximum transfer rates, the 80 C 286 bus alternates between the status and command states. The bus status signals become inactive after TS so that they may cor-


FIGURE 24. CMDLY CONTROLS THE LEADING EDGE OF COMMAND SIGNAL
rectly signal the start of the next bus operation after the completion of the current cycle. No external indication of $T^{C}$ e exists on the 80C286 local bus. The bus master and bus controller enter TC directly after Ts and continue executing TC cycles until terminated by the assertion of READY.

## $\overline{\text { READY Operation }}$

The current bus master and 82C288 bus controller terminate each bus operation simultaneously to achieve maxımum bus operation bandwidth. Both are informed in advance by READY active (open-collector output from 82C284) which identifies the last $T_{C}$ cycle of the current bus operation. The bus master and bus controller must see the same sense of the $\overline{\operatorname{READY}}$ signal, thereby requiring $\overline{\operatorname{READY}}$ to be synchronous to the system clock.

## Synchronous Ready

The 82C284 clock generator provides $\overline{\text { READY }}$ synchronization from both synchronous and asynchronous sources (see Figure 25). The synchronous ready input (SRDY) of the clock generator is sampled with the falling edge of CLK at the end of phase 1 of each TC. The state of SRDY is then broadcast to the bus master and bus controller via the $\overline{R E A D Y}$ output line.

## Asynchronous Ready

Many systems have devices or subsystems that are asynchronous to the system clock. As a result, their ready outputs cannot be guaranteed to meet the 82C284 SRDY setup and hold time requirements. But the 82C284 asynchronous ready input ( $\overline{\mathrm{ARDY}}$ ) is designed to accept such signals. The $\overline{A R D Y}$ input is sampled at the beginning of each TC cycle by 82C284 synchronization logic. This provides one system CLK cycle time to resolve its value before broadcasting it to the bus master and bus controller.
$\overline{A R D Y}$ or $\overline{\text { ARDYEN }}$ must be HIGH at the end of Ts. $\overline{\text { ARDY }}$ cannot be used to terminate the bus cycle with no wait states.

Each ready input of the 82 C 284 has an enable pin (SRDYEN and $\overline{\text { ARDYEN }}$ ) to select whether the current bus operation will be terminated by the synchronous or asynchronous ready. Either of the ready inputs may terminate a bus operation. These enable inputs are active low and have the same timing as their respective ready inputs. Address decode logic usually selects whether the current bus operation should be terminated by $\overline{\text { ARDY }}$ or SRDY.

## Data Bus Control

Figures 26,27 , and 28 show how the DT/ $\bar{R}, D E N$, data bus, and address signals operate for different combinations of read, write, and idle bus operations. DT//̄ goes active (LOW) for a read operation. DT/R remains HIGH before, during, and between write operations.

The data bus is driven with write data during the second phase of Ts. The delay in write data timing allows the read data drivers, from a previous read cycle, sufficient time to enter three-state OFF before the 80C286 CPU begins driving the local data bus for write operations Write data will always remain valid for one system clock past the last TC to provide sufficient hold time for Multibus or other similar memory or I/O systems. During write-read or write-Idle sequences the data bus enters a high impedance state during the second phase of the processor cycle after the last TC. In a write-write sequence the data bus does not enter a high impedance state between $T_{C}$ and $T_{S}$.

## Bus Usage

The 80C286 local bus may be used for several functions: instruction data transfers, data transfers by other bus masters, instruction fetching, processor extension data transfers, interrupt acknowledge, and halt/shutdown This section describes local bus activities which have special signals or requirements Note that I/O transfers take place in exactly the same manner as memory transfers (i.e. to the 80 C 286 the timıng, etc. of an $1 / \mathrm{O}$ transfer is identical to a memory transfer).

## HOLD and HLDA

HOLD and HLDA allow another bus master to gain control of the local bus by placıng the 80 C 286 bus into the $\mathrm{T}_{\mathrm{H}}$ state. The sequence of events required to pass control between the 80 C 286 and another local bus master are shown in Figure 29.

In this example, the 80 C 286 is initially in the $\mathrm{TH}_{H}$ state as signaled by HLDA being active. Upon leaving $T_{H}$, as signaled by HLDA going inactive, a write operation is started. During the write operation another local bus master requests the local bus from the 80 C 286 as shown by the HOLD signal. After completing the write operation, the 80C286 performs one T, bus cycle, to guarantee write data hold time, then enters $T_{H}$ as signaled by HLDA going active.

The CMDLY signal and $\overline{\text { ARDY }}$ ready are used to start and stop the write bus command, respectively. Note that $\overline{\text { SRDY }}$ must be inactive or disabled by $\overline{\text { SRDYEN }}$ to guarantee $\overline{\mathrm{ARDY}}$ will termınate the cycle.

HOLD must not be actıve during the tıme from the leading edge of RESET until 34 CLKs following the trailing edge of RESET unless the 80C286 is in the Halt condition. To ensure that the 80C286 remains in the Halt condition until
the processor Reset operation is complete, no interrupts should occur after the execution of HLT untıl 34 CLKs after the trailing edge of the RESET pulse.

## LOCK

The CPU asserts an active lock signal during InterruptAcknowledge cycles, the XCHG instruction, and during some descriptor accesses. Lock is also asserted when the LOCK prefix is used. The LOCK prefix may be used with the following ASM-286 assembly instructions; MOVS, INS and OUTS For bus cycles other than InterruptAcknowledge cycles, Lock will be active for the first and subsequent cycles of a series of cycles to be locked. Lock will not be shown active during the last cycle to be locked. For the next-to-last cycle, Lock will become inactive at the end of the first $T_{C}$ regardless of the number of wait states inserted. For Interrupt-Acknowledge cycles, Lock will be active for each cycle, and will become inactive at the end of the first $T_{C}$ for each cycle regardless of the number of wait-states inserted.

## Instruction Fetching

The 80C286 Bus Unit (BU) will fetch instructions ahead of the current instruction being executed. This activity is called prefetching. It occurs when the local bus would otherwise be idle and obeys the following rules.

A prefetch bus operation starts when at least two bytes of the 6 -byte prefetch queue are empty.

The prefetcher normally performs word prefetches independent of the byte alignment of the code segment base in physical memory.

The prefetcher will perform only a byte code fetch operation for control transfers to an instruction beginning on a numerically odd physical address

Prefetching stops whenever a control transfer or HLT instruction is decoded by the IU and placed into the instruction queue.

In real address mode, the prefetcher may fetch up to 6 bytes beyond the last control transfer or HLT instruction in a code segment.

In protected mode, the prefetcher will never cause a segment overrun exception. The prefetcher stops at the last physical memory word of the code segment. Exception 13 will occur if the program attempts to execute beyond the last full instruction in the code segment.

If the last byte of a code segment appears on an even physical memory address, the prefetcher will read the next physical byte of memory (perform a word code fetch). The value of this byte is ignored and any attempt to execute it causes exception 13.


ARDY


NOTES:

1. SRDYEN is active low
2. If SRDYEN is high, the state of SRDY will not effect READY
3. ARDYEN is active low

FIGURE 25. SYNCHRONOUS AND ASYNCHRONOUS READY


FIGURE 26. BACK TO BACK READ-WRITE CYCLE


FIGURE 27. BACK TO BACK WRITE-READ CYCLE


FIGURE 28. BACK TO BACK WRITE-WRITE CYCLE


## NOTES:

1. Status lines are held at a high impedance logic one by the 80 C 286 during a HOLD state.
2. Address, $M \overline{1 O}$ and COD/INTA may start floating during any $T_{C}$ depending on when internal $80 C 286$ bus arbiter decides to release bus to external HOLD. The float starts in ø2 of $T_{C}$.
3. $\overline{\mathrm{BHE}}$ and $\overline{\text { LOCK }}$ may start floating after the end of any $\mathrm{T}_{\mathrm{C}}$ depending on when internal 80 C 286 bus arbiter decides to release bus to external HOLD. The float starts in $\varnothing 1$ of $\mathrm{T}_{\mathrm{C}}$.
4. The minimum HOLD to HLDA time is shown. Maximum is one $T_{H}$ longer.
5. The earliest HOLD time is shown. It will always allow a subsequent memory cycle if pending is shown.
6. The minimum HOLD to HLDA time is shown. Maximum is a function of the instruction, type of bus cycle and other machine state (i.e., Interrupts, Waits, Lock, etc.).
7. Asynchronous ready allows termination of the cycle. Synchronous ready does not signal ready in this example. Synchronous ready state is ignored after ready is signaled via the asynchronous input.

FIGURE 29. MULTIBUS WRITE TERMINATED BY ASYNCHRONOUS READY WITH BUS HOLD

## Processor Extension Transfers

The processor extension interface uses 1/O port addresses $00 \mathrm{F8}(\mathrm{H})$, and $00 \mathrm{FC}(\mathrm{H})$ which are part of the $\mathrm{I} / \mathrm{O}$ port address range reserved by Harris. An ESC instruction with Machine Status Word bits EM $=0$ and $T_{S}=0$ will perform I/O bus operations to one or more of these I/O port addresses independent of the value of IOPL and CPL.

ESC instructions with memory references enable the CPU to accept PEREQ inputs for processor extension operand transfers. The CPU will determine the operand starting address and read/write status of the instruction. For each operand transfer, two or three bus operations are performed, one word transfer with I/O port address 00FA(H) and one or two bus operations with memory. Three bus operations are required for each word operand aligned on an odd byte address.

## Interrupt Acknowledge Sequence

Figure 30 illustrates an interrupt acknowledge sequence performed by the 80C286 in response to an INTR input. An interrupt acknowledge sequence consists of two INTA bus operations. The first allows a master 82C59A Programmable Interrupt Controller (PIC) to determıne which if any of its slaves should return the interrupt vector. An eight bit vector is read on $D_{0}-D_{7}$ of the 80C286 during the second INTA bus operation to select an interrupt handler routine from the interrupt table.

The Master Cascade Enable (MCE) signal of the 82 C 288 is used to enable the cascade address drivers during INTA bus operations (See Figure 30) onto the local adress bus for distribution to slave interrupt controllers via the system address bus. The 80 C 286 emits the $\overline{\text { LOCK }}$ signal (active LOW) during TS of the first INTA bus operation. A local bus "hold" request will not be honored until the end of the second INTA bus operation.

Three idle processor clocks are provided by the 80C286 between INTA bus operations to allow for the minimum INTA to INTA time and CAS (cascade address) out delay of the 82C59A. The second INTA bus operation must always have at least one extra $T_{C}$ state added via logic controlling $\overline{\text { READY }} A_{23}-A_{0}$ are in three-state OFF until after the first $T_{C}$ state of the second INTA bus operation. This prevents bus contention between the cascade address drivers and CPU address drivers. The extra TC state allows time for the 80 C 286 to resume driving the address lines for subsequent bus operations.

## Local Bus Usage Priorities

The 80C286 local bus is shared among several internal units and external HOLD requests. In case of simultaneous requests, their relative priorities are:


The 80C286 externally indicates halt or shutdown conditions as a bus operation. These conditions occur due to a HLT instruction or multiple protection exceptions while attempting to execute one instruction. A halt or shutdown bus operation is signalled when $\overline{\mathrm{S}_{1}}, \overline{\mathrm{~S}_{0}}$, and COD $/ \overline{N T A}$ are LOW and $M / \overline{\mathrm{OO}}$ is HIGH . $\mathrm{A}_{1} \mathrm{HIGH}$ indicates halt, and $A_{1}$ LOW indicates shutdown. The 82 C 288 bus controller does not issue ALE, nor is $\overline{\text { READY }}$ required to terminate a halt or shutdown bus operation.

During halt or shutdown, the 80 C 286 may service PEREQ or HOLD requests. A processor extension segment overrun during shutdown will inhibit further service of PEREQ. Either NMI or RESET will force the 80C286 out of either halt or shutdown. An INTR, if interrupts are enabled, or a processor extension segment overrun exception will also force the 80C286 out of halt.


NOTES
1 Data is ignored
2 First INTA cycle should have at least one wait state ınserted to meet 82C59A minımum INTA pulse width
3 Second INTA cycle must have at least one wait state inserted since the CPU will not drive $A_{23}-A_{0}, \overline{B H E}$, and $\overline{\text { LOCK }}$ until after the first $T_{C}$ state The CPU imposed one/clock delay prevents bus contention between cascade address buffer being disabled by MCE ! and address outputs Without the wait state, the 80 C 286 address will not be valid for a memory cycle started immediately after the second INTA cycle. The 82C59A also requires one wait state for mınımum INTA pulse width
$4 \overline{\text { LOCK }}$ is active for the first INTA cycle to prevent the 82289 from releasing the bus between INTA cycles in a multi-master system. $\overline{\text { LOCK }}$ is also active for the second INTA cycle
$5 A_{23}-A_{0}$ exits three-state OFF during $\phi 2$ of the second $T_{C}$ in the INTA cycle

FIGURE 30. INTERRUPT ACKNOWLEDGE SEQUENCE


FIGURE 31. BASIC $\mathbf{8 0 C 2 8 6}$ SYSTEM CONFIGURATION

## System Configurations

The versatile bus structure of the 80 C 286 micro-system, with a full complement of support chips, allows flexible configuration of a wide range of systems. The basic configuration, shown in Figure 31, is similar to an 80C86 maximum mode system. It includes the CPU plus an 82C59A interrupt controller, 82C284 clock generator, and the 82C288 Bus Controller. The 80 C 86 latches ( 82 C 82 and 82 C 83 H ) and transceivers ( 82 C 86 H and 82 C 87 H ) may be used in an 80C286 microsystem.

As indicated by the dashed lines in Figure 31, the ability to add processor extensions is an integral feature of 80C286 based microsystems. The processor extension interface allows external hardware to perform special functions and transfer data concurrent with CPU execution of other instructions. Full system integrity is maintained because the 80 C 286 supervises all data transfers and instruction execution for the processor extension.

An 80C286 system which includes the 80287 numeric processor extension (NPX) uses this interface. The 80C286/80287 system has all the instructions and data types of an 80 C 86 or 80 C 88 with 8087 numeric processor extension. The 80287 NPX can perform numeric calcula-
tions and data transfers concurrently with CPU program execution. Numerics code and data have the same integrity as all other information protected by the 80C286 protection mechanism.

The 80C286 can overlap chip select decoding and address propagation during the data transfer for the previous bus operation. This information is latched into the $82 \mathrm{C} 82 / 83 \mathrm{H}$ 's by ALE during the middle of a Ts cycle. The latched chip select and address information remains stable during the bus operation while the next cycle's address is being decoded and propagated into the system. Decode logic can be implemented with a high speed PROM or PAL.

The optional decode logic shown in Figure 31 takes advantage of the overlap between address and data of the 80 C 286 bus cycle to generate advanced memory and I/Oselect signals. This minimizes system performance degradation caused by address propagation and decode delays. In addition to selecting memory and I/O, the advanced selects may be used with configurations supporting local and system buses to enable the appropriate bus interface for each bus cycle. The COD/INTA


FIGURE 32. MULTIBUS SYSTEM BUS INTERFACE
and $M / \overline{I O}$ signals are applied to the decode logic to distinguish between interrupt, I/O, code, and data bus cycles.

By adding the 82289 bus arbiter chip the 80C286 provides a Multibus system bus interface as shown in Figure 32. The ALE output of the 82 C 288 for the Multibus bus is connected to its CMDLY input to delay the start of commands one system CLK as required to meet Multibus
address and write data setup times. This arrangement will add at least one extra $T_{C}$ state to each bus operation which uses the Multibus.

A second 82 C 288 bus controller and additional latches and transceivers could be added to the local bus of Figure 32. This configuration allows the 80 C 286 to support an on-board bus for local memory and peripherals, and the Multibus for system bus interfacing.

## Absolute Maximum Ratings

Supply Voltage $\qquad$ Input, Output or I/O Voltage Applied ... GND - 1.0V to VCC + 1.0V Storage Temperature Range . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ Lead Temperature (Soldering, Ten Seconds) . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$

## Reliability Information

$\theta_{\mathrm{jc}} \cdot \ldots . . . . . .7^{\circ} \mathrm{C} / \mathrm{W}$ (PGA Package), $9^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC Package)
$\theta_{\text {ja }} \ldots \ldots . . . .41^{\circ} \mathrm{C} / \mathrm{W}$ (PGA Package), $33^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC Package) Maximum Package Power Dissipation

PLCC Package
PGA Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.22W
Gate Count . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22,500
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 operations sections of this specification is not implied

## Operating Conditions

Operating Voltage Range
(80C286-10, -12) .....
(80C286-16, -20, -25).
$\ldots+4.5 \mathrm{~V}$ to +5.5 V
+4.75 V to +5.25 V

Operating Temperature Range
180C286-10, -12, -16, -20 .
C80C286-12, -16, -20, -25
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
D.C. Electrical Specifications

| $V_{C C}=+5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $(\mathrm{C} 80 \mathrm{C} 286-12)$ |
| :--- | :--- | :--- |
| $V_{C C}=+5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $(\mathrm{C} 80 \mathrm{C} 286-16,-20,-25)$ |
| $V_{C C}=+5 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $(180 \mathrm{C} 286-10,-12)$ |
| $V_{C C}=+5 \mathrm{~V} \pm 5 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $(180 \mathrm{C} 286-16,-20)$ |


| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 | VCC +0.5 | V |  |
| $V_{\text {ILC }}$ | CLK Input LOW Voltage | -0.5 | 1.0 | V |  |
| $\mathrm{V}_{\text {IHC }}$ | CLK Input HIGH Voltage | 3.6 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | - | 0.4 | V | $\mathrm{I}^{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $\begin{gathered} 3.0 \\ v_{\mathrm{CC}}-0.4 \end{gathered}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA} \\ & \mathrm{I} \mathrm{OH}=-100 \mu \mathrm{~A} \end{aligned}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathbb{I N}}=\mathrm{GND} \text { or } \mathrm{V}_{\mathrm{CC}}$ <br> Pins 29, 31, 57, 59, 61, 63-64 |
| ${ }^{\text {I SH}}$ | Input Sustaining Current on $\overline{\text { BUSY }}$ and $\overline{\text { ERROR Pins }}$ | $-30$ | $-500$ | $\mu \mathrm{A}$ | VIN $=$ GND (See Note 5) |
| $\mathrm{I}_{\mathrm{BHL}}$ | Input Sustaining Current LOW | 38 | 200 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 N}=1.0 \mathrm{~V}$ (See Note 1) |
| 1 BHH | Input Sustaining Current HIGH | -50 | -400 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 N}=3.0 \mathrm{~V}$ (See Note 2) |
| ${ }^{1} 0$ | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{GND} \text { or } \mathrm{V}_{\mathrm{CC}}$ <br> Pins 1,7-8, 10-28, 32-34 |
| ICCOP | Active Power Supply Current |  | $\begin{aligned} & 185 \\ & 220 \\ & 260 \\ & 310 \\ & 410 \end{aligned}$ | mA <br> mA <br> mA <br> mA <br> mA | 80C286-10 (See Note 4) <br> 80C286-12 (See Note 4) <br> 80C286-16 (See Note 4) <br> 80C286-20 (See Note 4) <br> 80C286-25 (See Note 4) |
| 'CCsB | Standby Power Supply Current | - | 5 | mA | (See Note 3) |

Capacitance $\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}\right.$; All Measurements Referenced to Device GND)

| SYMBOL | PARAMETER | TYP | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{CLK}}$ | CLK Input Capacitance | 10 | pF | FREQ $=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Other Input Capacitance | 10 | pF |  |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance | 10 | pF |  |

NOTES $1 I_{B H L}$ should be measured after lowering $V_{I N}$ to $G N D$ and then rasing to 10 V on the following pins. 36-51, 66, 67
$2 \mathrm{I}_{\mathrm{BH}}$ should be measured after raising $\mathrm{V}_{\mathbb{N}}$ to $V_{\mathrm{CC}}$ and then lowering to 30 V on the following pins 4-6, 36-51, 66-68.
3. ICCSB tested with the clock stopped in phase two of the processor clock cycle $\mathrm{V}_{\mathbb{N}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=\mathrm{VCC}$ (Max), outputs unloaded.
$4{ }^{1} \mathrm{CCOP}$ measured at 10 MHz for the $80 \mathrm{C} 286-10,12.5 \mathrm{MHz}$ for the $80 \mathrm{C} 286-12,16 \mathrm{MHz}$ for the $80 \mathrm{C} 286-16,20 \mathrm{MHz}$ for the $80 \mathrm{C} 286-20$, and 25 MHz for the $80 \mathrm{C} 286-25 \mathrm{~V}_{\mathrm{IN}}=24 \mathrm{~V}$ or $04 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{VCC}$ (Max), outputs unloaded
$5 I_{S H}$ should be measured after raising $V_{I N}$ to $V_{C C}$ and then lowering to GND on pins 53 and 54

## Specifications 80C286

A.C. Electrical Specifications $V_{C C}=+5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 80 \mathrm{C} 286-12), \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(180 \mathrm{C} 286-10,-12)$ $V_{C C}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C80C286-16), $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( $180 \mathrm{C} 286-16$ ) A.C. Timings are Referenced to 0.8 V and 2.0 V Points of the Signals as Illustrated in Datasheet Waveforms, Unless Otherwise Specified.

|  | PARAMETER | 10MHz |  | 12.5MHz |  | 16 MHz |  | UNIT | TEST CONDITION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |

## TIMING REQUIREMENTS

| 1 | System Clock (CLK) Period | 50 | - | 40 | - | 31 | - | ns |  |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 2 | System Clock (CLK) LOW Time | 12 | - | 11 | - | 7 | - | ns | $@ 1.0 \mathrm{~V}$ |
| 3 | System Clock (CLK) HIGH Time | 16 | - | 13 | - | 11 | - | ns | @ 3.6V |
| 17 | System Clock (CLK) RISE Time | - | 8 | - | 8 | - | 5 | ns | 1.0 V to 3.6V |
| 18 | System Clock (CLK) FALL Time | - | 8 | - | 8 | - | 5 | ns | 3.6 V to 1.0V |
| 4 | Asynchronous Inputs SETUP Time | 20 | - | 15 | - | 5 | - | ns | (Note 1) |
| 5 | Asynchronous Inputs HOLD Time | 20 | - | 15 | - | 5 | - | ns | (Note 1) |
| 6 | RESET SETUP Time | 19 | - | 10 | - | 10 | - | ns |  |
| 7 | RESET HOLD Time | 0 | - | 0 | - | 0 | - | ns |  |
| 8 | Read Data SETUP Time | 8 | - | 5 | - | 5 | - | ns |  |
| 9 | Read Data HOLD Time | 4 | - | 4 | - | 3 | - | ns |  |
| 10 | $\overline{R E A D Y}$ SETUP Time | 26 | - | 20 | - | 12 | - | ns |  |
| 11 | READY HOLD Time | 25 | - | 20 | - | 5 | - | ns |  |
| 20 | Input RISE/FALL Times | - | 10 | - | 8 | - | 6 | ns | 0.8 V to 2.0V |

TIMING RESPONSES

| $12 A$ | Status/PEACK Active Delay | 1 | 22 | 1 | 21 | 1 | 18 | ns | $1,($ Notes 3,7$)$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $12 B$ | Status/PEACK Inactive Delay | 1 | 30 | 1 | 24 | 1 | 20 | ns | $1,($ Notes 3,6$)$ |
| 13 | Address Valid Delay | 1 | 35 | 1 | 32 | 1 | 27 | ns | $1,($ Notes 2,3$)$ |
| 14 | Write Data Valid Delay | 0 | 40 | 0 | 31 | 0 | 28 | ns | $1,($ Notes 2,3$)$ |
| 15 | Address/Status/Data Float Delay | 0 | 47 | 0 | 32 | 0 | 29 | ns | $2,($ Note 5$)$ |
| 16 | HLDA Valid Delay | 0 | 47 | 0 | 25 | 0 | 25 | ns | $1,($ Notes 3,8$)$ |
| 19 | Address Valid to Status SETUP Time | 27 | - | 22 | - | 16 | - | ns | $1,($ Notes 3,4$)$ |

NOTES: 1. Asynchronous inputs are INTR, NMI, HOLD, PEREQ, ERROR, and BUSY. This specification is given only for testing purposes, to assure recognition at a specific CLK edge.
2. Delay from 1.0 V on the CLK to 0.8 V or 2.0 V .
3. Output load: $C_{L}=100 \mathrm{pF}$.
4. Delay measured from address either reaching 0.8 V or 2.0 V (valid) to status going active reaching 0.8 V or status going inactive reaching 2 OV .
5. Delay from 1.0 V on the CLK to Float (no current drive) condition.
6. Delay from 1.0 V on the CLK to 0.8 V for min. (HOLD time) and to 2.0 V for max (inactive delay).
7. Delay from 1.0 V on the CLK to 2.0 V for min. (HOLD time) and to 0.8 V for max. (active delay).
8. Delay from 1.0 V on the CLK to 2.0 V .

## A.C. Test Conditions

| TEST CONDITION | $I_{\mathrm{L}}$ (CONSTANT CURRENT SOURCE) | $C_{\mathrm{L}}$ |
| :---: | :---: | :---: |
| 1 | $\|2.0 \mathrm{~mA}\|$ | 100 pF |
| 2 | $-6 \mathrm{~mA}\left(\mathrm{~V}_{\mathrm{OH}}\right.$ to Float $)$ <br> $8 \mathrm{~mA}\left(\mathrm{VOL}_{\mathrm{OL}}\right.$ to Float $)$ | 100 pF |

## Specifications 80C286

A.C. Electrical Specifications $\quad V_{C C}=+5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 80 \mathrm{C} 286-20,-25), T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(180 \mathrm{C} 286-20)$ A.C. Timings are Referenced to the 1.5 V Point of the Signals as Illustrated in Datasheet Waveforms, Unless Otherwise Specified.

| SYMBOL | PARAMETER | 20MHz |  | 25MHz |  | UNIT | TEST CONDITION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| TIMING REQUIREMENTS |  |  |  |  |  |  |  |
| 1 | System Clock (CLK) Period | 25 | - | 20 | - | ns |  |
| 2 | System Clock (CLK) LOW Time | 6 | - | 5 | - | ns | @ 1.0V |
| 3 | System Clock (CLK) HIGH Time | 9 | - | 7 | - | ns | @ 3.6V |
| 17 | System Clock (CLK) RISE Time | - | 4 | - | 4 | ns | 1.0 V to 3.6 V |
| 18 | System Clock (CLK) FALL Time | - | 4 | - | 4 | ns | 3.6 V to 1.0V |
| 4 | Asynchronous Inputs SETUP Time | 4 | - | 4 | - | ns | (Note 1) |
| 5 | Asynchronous Inputs HOLD Time | 4 | - | 4 | - | ns | (Note 1) |
| 6 | RESET SETUP Time | 10 | - | 10 | - | ns |  |
| 7 | RESET HOLD Time | 0 | - | 0 | - | ns |  |
| 8 | Read Data SETUP Time | 3 | - | 3 | - | ns |  |
| 9 | Read Data HOLD Time | 2 | - | 2 | - | ns |  |
| 10 | $\overline{\text { READY }}$ SETUP Time | 10 | - | 9 | - | ns |  |
| 11 | $\overline{\text { READY }}$ HOLD Time | 3 | - | 3 | - | ns |  |
| 20 | Input RISE/FALL Times | - | 6 | - | 6 | ns | 0.8V to 2.0V |
| TIMING RESPONSES |  |  |  |  |  |  |  |
| 12A | Status/ $\overline{\text { PEACK }}$ Active Delay | 1 | 15 | 1 | 12 | ns | 1, (Notes 3, 6) |
| 12B | Status/PEACK Inactive Delay | 1 | 16 | 1 | 13 | ns | 1, (Notes 3, 6) |
| 13 | Address Valid Delay | 1 | 23 | 1 | 20 | ns | 1. (Notes 2, 3) |
| 14 | Write Data Valid Delay | 0 | 27 | 0 | 24 | ns | 1, (Notes 2, 3) |
| 15 | Address/Status/Data Float Delay | 0 | 25 | 0 | 24 | ns | 2, (Note 5) |
| 16 | HLDA Valid Delay | 0 | 20 | 0 | 19 | ns | 1, (Notes 2, 3) |
| 19 | Address Valid to Status SETUP Time | 9 | - | 12 | - | ns | 1, (Notes 3, 4) |

NOTES• 1. Asynchronous inputs are INTR, NMI, HOLD, PEREQ, ERROR, and BUSY. This specification is given only for testing purposes, to assure recognition at a specific CLK edge.
2. Delay from 1.0 V on the CLK to 1.5 V .
3. Output load: $C_{L}=100 \mathrm{pF}$.
4. Delay measured from address reaching 1.5 V to status reaching 1.5 V .
5. Delay from 1.0 V on the CLK to Float (no current drive) condition.
6. Delay from 1.0 V on the CLK to 1.5 V .

## A.C. Test Conditions

| TEST CONDITION | $I_{\mathrm{L}}$ (CONSTANT CURRENT SOURCE) | $C_{L}$ |
| :---: | :---: | :---: |
| 1 | $\|2.0 \mathrm{~mA}\|$ | 100 pF |
| 2 | $-6 \mathrm{~mA}\left(\mathrm{VOH}_{\mathrm{OH}}\right.$ to Float) <br> $8 \mathrm{~mA}\left(\mathrm{~V}_{\mathrm{OL}}\right.$ to Float) | 100 pF |

## A.C. Specifications (Continued)

C80C286-12, -16
I80C286-10, -12,-16
A.C. DRIVE AND MEASURE POINTS-CLK INPUT


NOTE: For A.C testing, input rise and fall times are driven at 1 ns per volt.

## A.C. Specifications (Continued)

C80C286-20, -25
180C286-20
A.C. DRIVE AND MEASURE POINTS-CLK INPUT


NOTES. 1. Typical Output Rise/Fall Time is 6 ns .
2. For A.C. testing, input rise and fall times are driven at 1 ns per volts.
A.C. Electrical Specifications (Continued) 82 C 284 and 82C288 Timing Specifications are given for reference only and no guarantee is implied.
82 C 284 TIMING

| SYMBOL | PARAMETER | 10MHz |  | 12.5MHz |  | 16 MHz |  | UNIT | TEST CONDITION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| TIMING REQUIREMENTS |  |  |  |  |  |  |  |  |  |
| 11 | $\overline{\text { SRDY/SRDYEN Setup Time }}$ | 15 | - | 15 | - | 10 | - | ns |  |
| 12 | $\overline{\text { SRDY/SRDYEN }}$ Hold Time | 2 | - | 2 | - | 1 | - | ns |  |
| 13 | $\overline{\text { ARDY } / \overline{A R D Y E N ~}}$ Setup Time | 5 | - | 5 | - | 3 | - | ns | (Note 1) |
| 14 | $\overline{\text { ARDY/ARDYEN }}$ Hold Time | 30 | - | 25 | - | 20 | - | ns | (Note 1) |
| TIMING RESPONSES |  |  |  |  |  |  |  |  |  |
| 19 | PCLK Delay | 0 | 20 | 0 | 16 | 0 | 15 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=75 \mathrm{pF} \\ & \mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=1 \mathrm{~mA} \end{aligned}$ |

## 82C288 TIMING



| TIMING REQUIREMENTS |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 12 | CMDLY Setup Time | 15 | - | 15 | - | 10 | - | ns |  |
| 13 | CMDLY Hold Time | 1 | - | 1 | - | 0 | - | ns |  |

TIMING RESPONSES

| 16 | ALE Active Delay | 1 | 16 | 1 | 16 | 1 | 12 | ns |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 17 | ALE Inactive Delay | - | 19 | - | 19 | - | 15 | ns |  |
| 19 | $\mathrm{DT} / \overline{\mathrm{R}}$ Read Active Delay | - | 23 | - | 23 | - | 18 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| 20 | DEN Read Active Delay | - | 21 | - | 21 | - | 16 | ns | $\mathrm{IOL}=16 \mathrm{~mA} \mathrm{Max}$ |
| 21 | DEN Read Inactive Delay | 3 | 23 | 3 | 21 | 5 | 14 | ns | $\mathrm{IOL}=1 \mathrm{mAMax}$ |
| 22 | $\mathrm{DT} / \bar{R}$ Read Inactive Delay | 5 | 24 | 5 | 18 | 5 | 14 | ns |  |
| 23 | DEN Write Active Delay | - | 23 | - | 23 | - | 17 | ns |  |
| 24 | DEN Write Inactive Delay | 3 | 23 | 3 | 23 | 3 | 15 | ns |  |
| 29 | Command Active Delay from CLK | 3 | 21 | 3 | 21 | 3 | 15 | ns | $C_{\mathrm{L}}=300 \mathrm{pF}$ |
| 30 | Command Inactive Delay from CLK | 3 | 20 | 3 | 20 | 3 | 15 | ns | $\mathrm{IOL}=32 \mathrm{mAMax}$ |

NOTE 1. These times are given for testing purposes to ensure a predetermined action.


## Waveforms (Continued)

## 80C286 ASYNCHRONOUS INPUT SIGNAL TIMING



## NOTES

1. PCLK indicates which processor cycle phase will occur on the next CLK. PCLK may not indicate the correct phase until the first cycle is performed.
2. These inputs are asynchronous The setup and hold times shown assure recognition for testing purposes

80 C 286 RESET INPUT TIMING AND SUBSEQUENT PROCESSOR CYCLE PHASE


NOTE
When RESET meets the setup tıme shown, the next CLK will start or repeat $\phi 2$ of a processor cycle.

EXITING AND ENTERING HOLD


NOTES
1 These signals may not be driven by the 80C286 during the tıme shown The worst case in terms of latest float time is shown
2. The data bus will be driven as shown if the last cycle before $T_{1}$ in the diagram was a write $T_{C}$

3 The 80C286 puts its status pins in a high impedance logic one state during $T_{H}$
4 For HOLD request set up to HLDA, refer to Figure 29
5. $\overline{\mathrm{BHE}}$ and $\overline{\mathrm{LOCK}}$ are driven at this tıme but will not become valıd untıl $\mathrm{T}_{S}$
6. The data bus will remain in a high impedance state if a read cycle is performed

## Waveforms (Continued)

## 80C286 PEREQ/PEACK TIMING FOR ONE TRANSFER ONLY



ASSUMING WORD-ALIGNED MEMORY OPERAND. IF ODD ALIGNED, 80 C 286 TRANSFERS TO/FROM MEMORY BYTE-AT-A-TIME WITH TWO MEMORY CYCLES.

## NOTES.

1 PEACK always goes active during the first bus operation of a processor extension data operand transfer sequence The first bus operation will be either a memory read at operand address or $1 / \mathrm{O}$ read at port address 00FA(H)
2 To prevent a second processor extension data operand transfer, the worst case maxımum tıme (Shown above) is $3 \times$ (1)-12A max -(4)mın. The actual, configuration dependent, maximum time is $3 \times(1)-12 A_{\max }-(4) \min ^{2}+N \times 2 \times(1) N$ is the number of extra $T_{C}$ states added to either the first or second bus operation of the processor extension data operand transfer sequence

INITIAL 80C286 PIN STATE DURING RESET


NOTES
1 Setup time for RESET I may be violated with the consideration that $\phi 1$ of the processor clock may begin one system CLK period later
2 Setup and hold tımes for RESET ! must be met for proper operation, but RESET ! may occur during $\boldsymbol{\phi} 1$ or $\phi 2$.
3 The data bus is only guaranteed to be in a high impedance state at the time shown


FIGURE 33. 80C286 INSTRUCTION FORMAT EXAMPLES

## $80 C 286$ Instruction Set Summary

## Instruction Timing Notes

The instruction clock counts listed below establish the maximum execution rate of the 80 C 286 . With no delays in bus cycles, the actual clock count of an 80C286 program will average $5 \%$ more than the calculated clock count, due to instruction sequences which execute faster than they can be fetched from memory.

To calculate elapsed times for instruction sequences, multiply the sum of all instruction clock counts, as listed in the table below, by the processor clock period. An 12.5 MHz processor clock has a clock period of 80 nanoseconds and requires an 80C286 system clock (CLK input) of 25 MHz .

## Instruction Clock Count Assumptions

1. The instruction has been prefetched, decoded and is ready for execution. Control transfer instruction clock counts include all time required to fetch, decode, and prepare the next instruction for execution.
2. Bus cycles do not require wait states.
3. There are no processor extension data transfer or local bus HOLD requests.
4. No exceptions occur during instruction execution.

## Instruction Set Summary Notes

Addressing displacements selected by the MOD field are not shown. If necessary they appear after the instruction fields shown.

Above/below refers to unsigned value
Greater refers to more positive signed values
Less refers to less positive (more negative) signed values
If $d=1$, then "to" register, if $d=0$ then "from" register
if $w=1$, then word instruction; if $w=0$, then byte instruction
if $s=0$, then 16 -bit immediate data form the operand
if $s=1$ then an ımmediate data byte is sign-extended to form the 16 -bit operand

```
x don't care
z used for string primitives for comparison with ZF
FLAG
```

If two clock counts are given, the smaller refers to a register operand and the larger refers to a memory operand
$\begin{aligned} * & \text { add one clock if offset calculation requires summing } \\ & 3 \text { elements }\end{aligned}$
$\mathrm{n}=$ number of times repeated
$\mathrm{m}=$ number of bytes of code in next instruction
Level (L)-Lexical nesting level of the procedure
The following comments describe possible exceptions, side effects and allowed usage for instructions in both operating modes of the 80C286.

## Real Address Mode Only

1. This is a protected mode instruction. Attempted execution in real address mode will result in an undefined opcode exception (6).
2. A segment overrun exception.(13) will occur if a word operand reference at offset $\operatorname{FFFF}(\mathrm{H})$ is attempted.
3. This instruction may be executed in real address mode to initialize the CPU for protected mode.
4. The IOPL and NT fields will remain 0 .
5. Processor extension segment overrun interrupt (9) will occur if the operand exceeds the segment limit.

## Either Mode

6. An exception may occur, depending on the value of the operand.
$7 \overline{\text { LOCK }}$ is automatically asserted regardless of the presence or absence of the LOCK instruction prefix.
7. $\overline{\text { LOCK }}$ does not reamain active between all operand transfers.

## Protected Virtual Address Mode Only

9. A general protection exception (13) will occur if the memory operand cannot be used due to either a segment limit or access rights violation. If a stack segment limit is violated, a stack segment overrun exception (12) occurs.
10. For segment load operations, the CPL, RPL and DPL must agree with privilege rules to avoid an exception. The segment must be present to avoid a not-present exception (11). If the SS register is the destination and a segment not-present violation occurs, a stack exception (12) occurs.
11. All segment descriptor accesses in the GDT or LDT made by this instruction will automatically assert $\overline{\text { LOCK }}$ to maintain descriptor integrity in multiprocessor systems.
12. JMP, CALL, INT, RET, IRET instructions referring to another code segment will cause a general protection exception (13) if any privilege rule is violated.
13. A general protection exception (13) occurs if CPL $\neq 0$.
14. A general protection exception (13) occurs if CPL $>$ IOPL.
15. The IF field of the flag word is not updated if CPL $>$ IOPL. The IOPL field is updated only if CPL $=0$.
16. Any violation of privilege rules as applied to the selector operand does not cause a protection exception; rather, the instruction does not return a result and the zero flag is cleared.
17. If the starting address of the memory operand violates a segment limit, or an invalid access is attempted, a general protection exception (13) will occur before the ESC instruction is executed. A stack segment overrun exception (12) will occur if the stack limit is violated by the operand's starting address. If a segment limit is violated during an attempted data transfer then a processor extension segment overrun exception (9) occurs.
18. The destination of an INT, JMP, CALL, RET or IRET instruction must be in the defined limit of a code segment or a general protection exception (13) will occur.

80C286 Instruction Set Summary

| FUNCTION | FORMAT |  |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Real Address Mode | Protected Virtual Address Mode |  | Protected Virtual Address Mode |
| DATA TRANSFER MOV = Move: |  |  |  |  |  |  |  |  |
| Register to Register/Memory | 1000100 w | modreg r/m |  |  | 2,3* | 2,3* | 2 | 9 |
| Register/memory to register | 1000101 w | modreg r/m |  |  | $2.5{ }^{*}$ | 2,5* | 2 | 9 |
| Immediate to register/memory | 1100011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 2,3* | 2,3* | 2 | 9 |
| Immediate to register | 1011 w reg | data | data if $w=1$ |  | 2 | 2 |  |  |
| Memory to accumulator | 1010000 w | addr-low | addr-high |  | 5 | 5 | 2 | 9 |
| Accumulator to memory | 1010001 w | addr-low | addr-high |  | 3 | 3 | 2 | 9 |
| Register/memory to segment register | 10001110 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2,5* | 17,19* | 2 | 9,10,11 |
| Segment register to register/memory | 10001100 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2,3* | 2,3* | 2 | 9 |
| PUSH = Push: |  |  |  |  |  |  |  |  |
| Memory | 11111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  | 5* | 5* | 2 | 9 |
| Register | 01010 reg |  |  |  | 3 | 3 | 2 | 9 |
| Segment register | 000 reg 110 |  |  |  | 3 | 3 | 2 | 9 |
| munoditate | 01101080 | deta |  |  | 3 | 3 " | 2 | - |
| Punhin man Puth | 01100000 | ". ${ }^{\text {a }}$ |  | $\cdots \cdots$ | 17 | 17 | 2 | . |
| $\mathrm{POP}=\mathrm{POP}$ |  |  |  |  |  |  |  |  |
| Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 5* | 5* | 2 | 9 |
| Register | 01011 reg |  |  |  | 5 | 5 | 2 | 9 |
| Segment register | 000 reg 111 | $(\mathrm{reg}=01)$ |  |  | 5 | 20 | 2 | 9,10,11 |
| Topene Pog An | 01100001 |  | $\cdots$ | ' ... '.. | 62. | \% | 2 | $\cdots$ |
| XCHG = Exhcange: |  |  |  |  |  |  |  |  |
| Register/memory with register | 1000011 w | modreg r/m |  |  | 3,5* | 3,5* | 2,7 | 7.9 |
| Register with accumulator | 10010 reg |  |  |  | 3 | 3 |  |  |
| $\mathrm{N}=$ Input from: |  |  |  |  |  |  |  |  |
| Fixed port | 1110010 w | port |  |  | 5 | 5 |  | 14 |
| Variable port | 1110110 w |  |  |  | 5 | 5 |  | 14 |
| OUT = Output to: |  |  |  |  |  |  |  |  |
| Fixed port | 1110011 w | port |  |  | 3 | 3 |  | 14 |
| Variable port | 1110111 w |  |  |  | 3 | 3 |  | 14 |
| XLAT = Translate byte to AL | 11010111 |  |  |  | 5 | 5 |  | 9 |
| LEA = Load EA to register | 10001101 | mod reg r/m |  |  | $3 *$ | 3* |  |  |
| LDS = Load pointer to DS | 11000101 | mod reg r/m | $(\bmod \neq 11)$ |  | 7* | 21* | 2 | 9,10,11 |
| LES = Load pointer to ES | 11000100 | mod reg r/m | $(\bmod \neq 1)$ |  | 7* | 21* | 2 | 9,10,11 |

Shaded areas indicate instructions not available in 80C86/88 microsystems.

## 80C286 Instruction Set Summary (Continued)

| FUNCTION | FORMAT |  |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Real <br> Addrese <br> Mode | Protected Virtual Addrese Mode | Real <br> Address <br> Mode | Protected Virtual Addrese Mode |
| DATA TRANSFER (Continued) |  |  |  |  |  |  |  |  |
| LAHF Load AH with flags | 10011111 |  |  |  | 2 | 2 |  |  |
| SAHF $=$ Store AH into flags | 10011110 |  |  |  | 2 | 2 |  |  |
| PUSHF = Push flags | 10011100 |  |  |  | 3 | 3 | 2 | 9 |
| POPF $=$ Pop flags | 10011101 |  |  |  | 5 | 5 | 2,4 | 9,15 |
| ARITHMETIC ADD = Add: |  |  |  |  |  |  |  |  |
| Reg/memory with registar to either | 000000 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate to register/memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if swor | 3,7* | 3,7* | 2 | 9 |
| mmediate to accumulator | 0000010 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| ADC = Add with carry: |  |  |  |  |  |  |  |  |
| Reg/memory with register to either | 000100 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| immediate to register/memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s} \mathbf{w}=01$ | 3,7* | 3,7* | 2 | 9 |
| Immediate to accumulator | 0001010 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| NC = increment: |  |  |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 2,7* | 2,7* | 2 | 9 |
| Register | 01000 reg |  |  |  | 2 | 2 |  |  |
| SUB $=$ Subtract: |  |  |  |  |  |  |  |  |
| Reg/memory and register to either | 001010 dw | modreg r/m |  |  | $2,7^{\circ}$ | 2,7* | 2 | 9 |
| Immediate from register/memory | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} \mathbf{w}=01$ | 3,7* | 3,7* | 2 | 9 |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| SBB = Subtract with borrow: |  |  |  |  |  |  |  |  |
| Reg/memory and register to ether | 000110 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s} \mathbf{w}=01$ | 3,7* | 3,7* | 2 | 9 |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| DEC $=$ Decrement |  |  |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 2,7* | 2,7* | 2 | 9 |
| Register | 01001 reg |  |  |  | 2 | 2 |  |  |
| CMP = Compare |  |  |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | modreg $\quad \mathrm{r} / \mathrm{m}$ |  |  | 2,6* | 2,6* | 2 | 9 |
| Register with register/memory | 0011100 w | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate with register/memory | 100000 sw | $\bmod 111 \mathrm{r} / \mathrm{m}$ | data | data if $s$ w $=01$ | 3,6* | 3,6* | 2 | 9 |
| Immediate with accumulator | 0011110 w | data | data if w=1 |  | 3 | 3 |  |  |
| NEG = Change sign | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | 2 | $7{ }^{*}$ | 2 | 7 |
| AAA = ASCll adjust for add | 00110111 |  |  |  | 3 | 3 |  |  |
| DAA = Decımal adjust for add | 00100111 |  |  |  | 3 | 3 |  |  |

80C286 Instruction Set Summary (Continued)


Shaded areas indicate instructions not available in 80C86/88 microsystems

80C286 Instruction Set Summary (Continued)

| FUNCTION | FORMAT |  |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Real Addrese Mode | Protected Virtual Addrese Mode | Real Addrees Mode | Protected Virtual Addrees Mode |
| ARITHMETIC (Continued) AND = And: |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reg/memory and register to either | 001000 dw | modreg $\mathrm{r} / \mathrm{m}$ |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate to register/memory | 1000000w | $\bmod 100 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 3,7* | 3,7* | 2 | 9 |
| mmediate to accumulator | 0010010 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| TEST = And function to flags, no result: |  |  |  |  |  |  |  |  |
| Register/memory and register | 1000010 w | modreg r/m |  |  | 2,6* | $2.6{ }^{*}$ | 2 | 9 |
| Immediate data and register/memory | 1111011 w | mod $000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 3,6* | 3,6 ${ }^{\text { }}$ | 2 | 9 |
| mmediate data and accumulator | 1010100 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| $\mathrm{OR}=0 \mathrm{r}$ : |  |  |  |  |  |  |  |  |
| Reg/memory and register to erther | 000010 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| mmediate to register/memory | 1000000 w | mod $001 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 3,7* | 3.7* | 2 | 9 |
| mmediate to accumulator | 0000110 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| XOR = Exclusive or: |  |  |  |  |  |  |  |  |
| Reg/memory and reguster to erther | 001100 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| mmediate to regıster/memory | 1000000 w | $\bmod 110 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 3,7* | 3,7* | 2 | 9 |
| mmediate to accumulator | 0011010 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| NOT = Invert regıster/memory | 1111011 w | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  | $2,7^{*}$ | 2,7* | 2 | 9 |
| STRING MANIPULATION: |  |  |  |  |  |  |  |  |
| MOVS = Move byte/word | 1010010 w |  |  |  | 5 | 5 | 2 | 9 |
| CMPS = Compare byte/word | 1010011 w |  |  |  | 8 | 8 | 2 | 9 |
| SCAS $=$ Scan byte/word | 1010111 w |  |  |  | 7 | 7 | 2 | 9 |
| LODS = Load byte/wd to AL/AX | 1010110 w |  |  |  | 5 | 5 | 2 | 9 |
| STOS $=$ Stor byte/wd from AL/A | 1010101 w |  |  |  | 3 | 3 | 2 | 9 |
|  <br>  <br> Repeated by count in CX | $\frac{014015}{10 \operatorname{set} 14}$ |  |  |  | * <br> 需 | 6 者 |  |  |
| MOV ${ }_{5}=$ Move string | 11110011 | 1010010 w |  |  | $5+4 n$ | $5+4 n$ | 2 | 9 |
| CMPS $=$ Compare string | 11110012 | 1010011 w |  |  | $5+9 n$ | $5+9 n$ | 2,8 | 8,9 |
| SCAS $=$ Scan string | 11110012 | 1010111 w |  |  | $5+8 n$ | $5+8 n$ | 2,8 | 8,9 |
| LODS $=$ Load string | 11110011 | 1010110 w |  |  | $5+4 n$ | $5+4 n$ | 2,8 | 8,9 |
| STOS $=$ Store string | 11110011 | 1010101 w |  |  | $4+3 n$ | $4+3 n$ | 2,8 | 8,9 |
|  |  | $\frac{\text { vteves }}{\text { viveviven }}$ |  |  |  |  |  |  |

[^2]
## 80C286 Instruction Set Summary (Continued)

| FUNCTION | ORRMAT |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Real <br> Address Mode | Protected <br> Virtual <br> Address Mode | Real Address Mode | Protected Virtual Address Mode |
| CONTROL TRANSFER CALL = Call: |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
| Direct within segment | 11101000 | disp-low | disp-high | $7+m$ | $7+m$ | 2 | 18 |
| Register/memory | 11111111 | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  | $7+m, 11+m^{*}$ | $7+m, 11+{ }^{*}$ | 2,8 | 8,9,18 |
| indirect within segment |  |  |  |  |  |  |  |
| Direct intersegment | 10011010 | segment | fset | $13+m$ | $26+m$ | 2 | 11,12,18 |
| Protected Mode Only (Direct intersegment): |  | segment selector |  |  |  |  |  |
| Via call gate to same privilege level |  |  |  |  | $41+m$ |  | 8,11,12,18 |
| Via call gate to different privilege level, no parameters |  |  |  |  | $82+m$ |  | 8,11,12,18 |
| Via call gate to different privilege level, x parameters |  |  |  |  | $86+4 x+m$ |  | 8,11,12,18 |
| Via TSS |  |  |  |  | $177+m$ |  | 8,11,12,18 |
| Via task gate |  |  |  |  | $182+m$ |  | 8,11,12,18 |
| Indirect intersegment | 11111111 | $\bmod 011 \mathrm{r} / \mathrm{m}$ | $(\bmod \neq 11)$ | $16+m$ | $29+{ }^{*}$ | 2 | 8,9,11,12,18 |
| Protected Mode Only (Indirect intersegment): |  |  |  |  |  |  |  |
| Via call gate to same privilege level |  |  |  |  | $44+\mathrm{m}^{*}$ |  | 8,9,11,12,18 |
| Via call gate to different privilege level, no parameters |  |  |  |  | $83+{ }^{*}$ |  | 8,9,11,12,18 |
| Via call gate to different privilege level, x parameters |  |  |  |  | $90+4 \mathrm{x}+\mathrm{m}^{*}$ |  | 8,9,11,12,18 |
| Via TSS |  |  |  |  | $180+{ }^{*}$ |  | 8,9,11,12,18 |
| Via task gate |  |  |  |  | $185+{ }^{*}$ |  | 8,9,11,12,18 |
| JMP = Unconditional Jump: |  |  |  |  |  |  |  |
| Short/long | 11101011 | disp-low |  | $7+m$ | $7+m$ |  | 18 |
| Direct within segment | 11101001 | disp-low | disp-high | $7+m$ | $7+m$ |  | 18 |
| Register/memory indirect within segment | 11111111 | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  | $7+m, 11+\mathrm{m}^{*}$ | $7+m, 11+m^{*}$ | 2 | 9,18 |
| Direct intersegment | 11101010 | segment offset |  | $11+m$ | $23+m$ |  | 11,12,18 |
| Protected Mode Only (Direct intersegment): $\quad$ segment selector |  |  |  |  |  |  |  |
| Via call gate to same privilege level |  |  |  |  | $38+m$ |  | 8,11,12,18 |
| Via TSS |  |  |  |  | $175+m$ |  | 8,11,12,18 |
| Via task gate |  |  |  |  | $180+m$ |  | 8,11,12,18 |
| Indirect intersegment | 11111111 | $\bmod 101 \mathrm{r} / \mathrm{m}$ | $(\bmod \neq 11)$ | $15+\mathrm{m}^{*}$ | $26+{ }^{*}$ | 2 | 8,9,11,12,18 |
| Protected Mode Only (Indirect intersegment): |  |  |  |  |  |  |  |
| Via call gate to same privilege level |  |  |  |  | $41+{ }^{*}$ |  | 8,9,11,12,18 |
| Via TSS |  |  |  |  | $178+\mathrm{m}^{*}$ |  | 8,9,11,12,18 |
| Via task gate |  |  |  |  | $183+$ m* |  | 8,9,11,12,18 |
| RET = Return from CALL: |  |  |  |  |  |  |  |
| Within segment | 11000011 |  |  | $11+m$ | $11+m$ | 2 | 8,9,18 |
| Within seg addıng ımmed to SP | 11000010 | data-low | data-high | $11+m$ | $11+m$ | 2 | 8,9,18 |
| Intersegment | 11001011 |  |  | $15+m$ | $25+m$ | 2 | 8,9,11,12,18 |
| Intersegment adding immediate to SP | 11001010 | data-low | data-hıgh | $15+m$ |  | 2 | 8,9,11,12,18 |
| Protected Mode Only (RET): <br> To different privilege level |  |  |  |  | $55+m$ |  | 9,11,12,18 |

## 80C286 Instruction Set Summary (Continued)



Shaded areas indicate instructions not avaılable in 80C86/88 mıcrosystems
$80 C 286$ Instruction Set Summary (Continued)


80C286 Instruction Set Summary (Continued)

| FUNCTION | FORMAT |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Real <br> Addrese Mode | Profected Virtual Addrese Mode | need Achicese Mode | Protected Virtual Actrece Mode |
| monemow cominvol (Covimeas <br>  <br>  |  |  |  | $\begin{aligned} & 20 \\ & 2 y^{4} \end{aligned}$ | $7,1{ }^{2}$ |  |  |
|  | 0000,113 | onocoseo | modrot otw |  | 23 | 1. | $\stackrel{1}{*}$ |
|  | 0000111 | 00000001 | mot150.6al |  | 2e: | - | * 6 |
|  | 0000, 11 | 00000001 | modtor min |  | 20 | 4 | * |
| $\boldsymbol{H}^{\text {Luy }}$ | 00001111 | 00000010 | modred v/m |  | 14,10* | 1 , | , 11, 值 |
| Lat = Lemed megnent linh Wom regwetertmennary | 00001111 | 00000011 | modrer trat |  | 14,4** | 1 | \%,11.3* |
|  wom thatinuthemy |  | 01.100011 | modxe | 10*,11* | 2 | d |  |
|  | 00001111 | 00000000 | mod 100 mm | 4,48* | 1 | -17, ${ }^{\text {cte }}$ |  |
| Went woulyway momest | 00001111 | 00000000 | mod 101 mm | 14,16* | 1 | $0,11, *$ |  |

Shaded areas indicate instructions not available in 80C86/88 microsystems

|  | LO |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| 0 | ADD <br> b,f,r/m | ADD <br> w,f,r/m | $\begin{gathered} \mathrm{ADD} \\ \mathrm{~b}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \mathrm{ADD} \\ \mathrm{w}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \text { ADD } \\ \mathrm{b}, \mathrm{a} \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & \text { w,ıa } \end{aligned}$ | $\begin{gathered} \text { PUSH } \\ \text { ES } \end{gathered}$ | $\begin{gathered} \text { POP } \\ \text { ES } \end{gathered}$ | OR b,f,r/m | OR $\mathbf{w}, \mathrm{f}, \mathrm{r} / \mathrm{m}$ | $\underset{b, t, r / m}{\mathrm{OR}}$ | $\begin{gathered} \text { OR } \\ w, t, r / m \end{gathered}$ | $\begin{aligned} & \mathrm{OR} \\ & \mathrm{~b}, \mathrm{I} \end{aligned}$ | $\begin{aligned} & \text { OR } \\ & w, 1 \end{aligned}$ | PUSH CS | PVAM $n$ |
| 1 | ADC <br> b,f,r/m | ADC $w, f, r / m$ | ADC <br> b,t,r/m | ADC w,t,r/m | ADC b,ia | $\begin{aligned} & \text { ADC } \\ & \text { w,ia } \end{aligned}$ | PUSH SS | $\begin{aligned} & \text { POP } \\ & \text { SS } \end{aligned}$ | $\left\|\begin{array}{c} \mathrm{SBB} \\ \mathrm{~b}, \mathrm{f}, \mathrm{r} / \mathrm{m} \end{array}\right\|$ | $\begin{gathered} \mathrm{SBB} \\ \mathrm{w}, \mathrm{f}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\underset{\mathrm{b}, \mathrm{t}, \mathrm{r} / \mathrm{m}}{\mathrm{SBB}}$ | $\begin{gathered} \mathrm{SBB} \\ \mathrm{w}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \text { SBB } \\ \mathrm{b}, 1 \end{gathered}$ | SBB <br> w, 1 | PUSH DS | $\begin{aligned} & \text { POP } \\ & \text { DS } \end{aligned}$ |
| 2 | AND b,f,r/m | AND w,f,r/m | $\begin{gathered} \text { AND } \\ \mathrm{b}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | AND w,t,r/m | $\begin{gathered} \text { AND } \\ b, 1 a \end{gathered}$ | $\begin{aligned} & \text { AND } \\ & \text { w,ia } \end{aligned}$ | $\begin{aligned} & \text { SEG } \\ & =E S \end{aligned}$ | DAA | $\begin{aligned} & \text { SUB } \\ & b, f, r / m \end{aligned}$ | $\begin{gathered} \text { SUB } \\ \mathrm{w}, \mathrm{f}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \text { SUB } \\ b, t, r / m \end{gathered}$ | $\begin{gathered} \text { SUB } \\ \mathrm{w}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \text { SUB } \\ \mathrm{b}, \mathrm{l} \end{gathered}$ | $\begin{gathered} \text { SUB } \\ \text { w,1 } \end{gathered}$ | $\begin{aligned} & \text { SEG } \\ & =\text { CS } \end{aligned}$ | DAS |
| 3 | $\begin{gathered} \mathrm{XOR} \\ \mathrm{~b}, \mathrm{f}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \text { XOR } \\ \mathrm{w}, \mathrm{f}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \text { XOR } \\ b, t, r / m \end{gathered}$ | $\left.\begin{gathered} \text { XOR } \\ w, t, r / m \end{gathered} \right\rvert\,$ | $\begin{gathered} \mathrm{XOR} \\ \mathrm{~b}, \mathrm{a} \end{gathered}$ | $\begin{aligned} & \text { XOR } \\ & \text { w,ia } \end{aligned}$ | $\begin{aligned} & \text { SEG } \\ & =S S \end{aligned}$ | AAA | $\begin{gathered} \text { CMP } \\ \text { b, } \mathrm{f}, \mathrm{r} / \mathrm{m} \end{gathered}$ | CMP w,f,r/m | $\begin{gathered} \mathrm{CMP} \\ \mathrm{~b}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | CMP w,t,r/m | $\begin{gathered} \text { CMP } \\ \mathrm{b}, \mathrm{i} \end{gathered}$ | $\underset{\mathrm{w}, \mathrm{I}}{\mathrm{CMP}}$ | $\begin{aligned} & \text { SEG } \\ & =\mathrm{DS} \end{aligned}$ | AAS |
| 4 | $\begin{gathered} \text { INC } \\ \text { AX } \end{gathered}$ | $\begin{aligned} & \text { INC } \\ & \text { CX } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { DX } \end{aligned}$ | $\begin{gathered} \text { INC } \\ B X \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { SP } \end{gathered}$ | INC $B P$ | $\begin{gathered} \text { INC } \\ \text { SI } \end{gathered}$ | $\begin{gathered} \hline \text { INC } \\ \text { DI } \end{gathered}$ | $\begin{gathered} \mathrm{DEC} \\ \mathrm{AX} \end{gathered}$ | DEC <br> CX | $\begin{gathered} \text { DEC } \\ \text { DX } \end{gathered}$ | $\begin{gathered} \mathrm{DEC} \\ \mathrm{BX} \end{gathered}$ | $\begin{gathered} \mathrm{DEC} \\ \mathrm{SP} \end{gathered}$ | $\begin{gathered} \mathrm{DEC} \\ \mathrm{BP} \end{gathered}$ | $\begin{gathered} \mathrm{DEC} \\ \mathrm{SI} \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { DI } \end{gathered}$ |
| 5 | $\begin{aligned} & \text { PUSH } \\ & \text { AX } \end{aligned}$ | $\begin{aligned} & \text { PUSH } \\ & \text { CX } \end{aligned}$ | $\begin{aligned} & \text { PUSH } \\ & \text { DX } \end{aligned}$ | PUSH BX | $\begin{aligned} & \text { PUSH } \\ & \text { SP } \end{aligned}$ | PUSH BP | $\begin{aligned} & \text { PUSH } \\ & \text { SI } \end{aligned}$ | $\begin{aligned} & \text { PUSH } \\ & \text { DI } \end{aligned}$ | $\begin{aligned} & \text { POP } \\ & \text { AX } \end{aligned}$ | $\begin{aligned} & \text { POP } \\ & \text { CX } \end{aligned}$ | $\begin{aligned} & \text { POP } \\ & \text { DX } \end{aligned}$ | $\begin{aligned} & \text { POP } \\ & \text { BX } \end{aligned}$ | $\begin{aligned} & \text { POP } \\ & \text { SP } \end{aligned}$ | $\begin{gathered} \mathrm{POP} \\ \mathrm{BP} \end{gathered}$ | $\begin{aligned} & \text { POP } \\ & \text { SI } \end{aligned}$ | $\begin{gathered} \text { POP } \\ \text { DI } \end{gathered}$ |
| 6 | PUSHA | POPA | BOUND | ARPL |  |  |  |  | PUSH w,1 | IMUL $w, t, r / m, 1$ | $\begin{gathered} \text { PUSH } \\ \text { b, } \end{gathered}$ | $\left\|\begin{array}{c} \text { IMUL } \\ b, t, r / m, 1 \end{array}\right\|$ | INSB | INSW | OUTSB | OUTSW |
| 7 | JO | JNO | JB/ JNAE | JNB/ JAE | $\begin{aligned} & \text { JE/ } \\ & \text { JZ } \end{aligned}$ | JNE/ JNZ | JBE/ JNA | JNBE/ JA | JS | JNS | $\begin{aligned} & \text { JP/ } \\ & \text { JPE } \end{aligned}$ | JNP/ JPO | JL/ JNGE | JNL/ JGE | JLE/ <br> JNG | $\begin{gathered} \text { JNLE/ } \\ \text { JG } \end{gathered}$ |
| 8 | Immed <br> b,r/m | Immed <br> $\mathrm{w}, \mathrm{r} / \mathrm{m}$ | Immed <br> b,r/m | Immed is,r/m | $\begin{aligned} & \text { TEST } \\ & \mathrm{b}, \mathrm{r} / \mathrm{m} \end{aligned}$ | TEST <br> w,r/m | XCHG <br> b,r/m | XCHG <br> w,r/m | $\underset{\text { M,f,r/m }}{\mathrm{MOV}}$ | $\begin{gathered} \text { MOV } \\ \mathrm{w}, \mathrm{f}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \mathrm{b}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{gathered} \mathrm{MOV} \\ \mathrm{w}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\left.\begin{gathered} \mathrm{MOV} \\ \mathrm{sr}, \mathrm{f}, \mathrm{r} / \mathrm{m} \end{gathered} \right\rvert\,$ | LEA | $\begin{gathered} \mathrm{MOV} \\ \mathrm{sr}, \mathrm{t}, \mathrm{r} / \mathrm{m} \end{gathered}$ | $\begin{aligned} & \mathrm{POP} \\ & \mathrm{r} / \mathrm{m} \end{aligned}$ |
| 9 | $\begin{gathered} \mathrm{XCHG} \\ \mathrm{AX} \end{gathered}$ | $\begin{gathered} \mathrm{XCHG} \\ \mathrm{CX} \end{gathered}$ | $\begin{gathered} \mathrm{XCHG} \\ \mathrm{DX} \end{gathered}$ | $\begin{gathered} \mathrm{XCHG} \\ \mathrm{BX} \end{gathered}$ | $\begin{gathered} \mathrm{XCHG} \\ \mathrm{SP} \end{gathered}$ | XCHG BP | $\left\lvert\, \begin{gathered} \mathrm{XCHG} \\ \mathrm{SI} \end{gathered}\right.$ | $\begin{gathered} \mathrm{XCHG} \\ \mathrm{DI} \end{gathered}$ | CBW | CWD | $\begin{gathered} \text { CALL } \\ \text { I,d } \end{gathered}$ | WAIT | PUSHF | POPF | SAHF | LAHF |
| A | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{~m}-\mathrm{AL} \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { m-AX } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { AL-m } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { AX-m } \end{aligned}$ | MOVSB | MOVSW | CMPSB | CMPSW | $\begin{aligned} & \text { TEST } \\ & \text { b, }, 1, \mathrm{a} \end{aligned}$ | $\begin{aligned} & \text { TEST } \\ & \mathrm{w}, 1, \mathrm{a} \end{aligned}$ | STOSB | STOSW | LODSB | LODSW | SCASB | SCASW |
| B | $\begin{aligned} & \text { MOV } \\ & \text { I-AL } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-CL } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-DL } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-BL } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-AH } \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{I}-\mathrm{CH} \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-DH } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-BH } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-AX } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-CX } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-DX } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-BX } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-SP } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { I-BP } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { I-SI } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { I-DI } \end{gathered}$ |
| C | $\begin{gathered} \text { Shift } \\ b, 1 \end{gathered}$ | Shift w, | $\begin{gathered} \text { RET } \\ (1+S P) \end{gathered}$ | RET | LES | LDS | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{~b}, \mathrm{I}, \mathrm{r} / \mathrm{m} \end{aligned}$ | , MOV | ENTER | LEAVE | $\begin{array}{\|c\|} \hline \text { RET } \\ \text { I,(i+SP) } \end{array}$ | $\begin{gathered} \text { RET } \\ 1 \end{gathered}$ | $\left\|\begin{array}{c} \text { INT } \\ \text { Type } 3 \end{array}\right\|$ | $\begin{aligned} & \text { INT } \\ & \text { (any) } \end{aligned}$ | INTO | IRET |
| D | $\begin{gathered} \text { Shift } \\ b \end{gathered}$ | Shift w | Shift b, CL | Shift <br> b,CL | AAM | AAD |  | XLAT | $\begin{gathered} \text { ESC } \\ 0 \end{gathered}$ | $\begin{gathered} \text { ESC } \\ 1 \end{gathered}$ | $\begin{gathered} \text { ESC } \\ 2 \end{gathered}$ | $\begin{gathered} \text { ESC } \\ 3 \end{gathered}$ | $\begin{gathered} \text { ESC } \\ 4 \end{gathered}$ | $\begin{gathered} \text { ESC } \\ 5 \end{gathered}$ | $\begin{gathered} \text { ESC } \\ 6 \end{gathered}$ | $\begin{gathered} \text { ESC } \\ 7 \end{gathered}$ |
| E | LOOPNZ/ LOOPNE | LOOPZ/ LOOPE | LOOP | Jcxz | $\begin{gathered} \text { in } \\ \text { b } \end{gathered}$ | $\begin{aligned} & \text { in } \\ & \mathrm{w} \end{aligned}$ | $\begin{gathered} \text { OUT } \\ \mathrm{b} \end{gathered}$ | $\begin{gathered} \text { OUT } \\ \text { w } \end{gathered}$ | $\begin{gathered} \text { CALL } \\ d \end{gathered}$ | $\begin{gathered} \text { JMP } \\ d \end{gathered}$ | $\underset{\mathrm{I}, \mathrm{~d}}{\mathrm{JMP}}$ | $\begin{aligned} & \mathrm{JMP} \\ & \mathrm{si}, \mathrm{~d} \end{aligned}$ | $\begin{gathered} \text { IN } \\ \text { DX,b } \end{gathered}$ | $\underset{\mathrm{DX}, \mathrm{w}}{\mathrm{IN}}$ | $\begin{aligned} & \text { OUT } \\ & \text { DX,b } \end{aligned}$ | $\begin{aligned} & \text { OUT } \\ & \text { DX,w } \end{aligned}$ |
| F | LOCK |  | REP | REPZ | HLT | CMC | $\begin{aligned} & \text { Grp } 1 \\ & b, r / m \end{aligned}$ | $\begin{aligned} & \text { Grp } 1 \\ & w, r / m \end{aligned}$ | CLC | STC | CLI | STI | CLD | STD | Grp 2 <br> b,r/m | Grp 2 w,r/m |

## 80C286 Machine Instruction Encoding Matrix (Continued)

where:

| $\bmod \mathrm{r} / \mathrm{m}$ | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Immed | ADD | OR | ADC | SBB | AND | SUB | XOR | CMP |
| Shift | ROL | ROR | RCL | RCR | SHL/SAL | SHR | - | SAR |
| Grp 1 | TEST | - | NOT | NEG | MUL | IMUL | DIV | IDIV |
| Grp 2 | INC | DEC | CALL id | $\underset{\mathrm{l}, \mathrm{Id}}{\mathrm{CALL}}$ | JMP <br> Id | $\begin{aligned} & \text { JMP } \\ & \text { I, } 1 \mathrm{~d} \end{aligned}$ | PUSH | - |
| PVAM 0 | SLDT | STR | LLDT | LTR | VERR | VERW | - | - |
| PVAM 1 | SGDT | SIDT | LGDT | LIDT | SMSW | - | LMSW | - |
| PVAM 2 | LAR |  |  |  |  |  |  |  |
| PVAM 3 | LSL |  |  |  |  |  |  |  |
| PVAM 6 | CLTS |  |  |  |  |  |  |  |

$$
\begin{aligned}
& b=\text { byte operation } \\
& d=\text { direct } \\
& f=\text { from CPU reg } \\
& l=\text { immediate } \\
& \text { Ia }=\text { immediate to } A X \\
& I d=\text { indirect } \\
& \text { IS }=\text { immediate byte sign extension } \\
& l=\text { long ie. intersegment } \\
& n=2 \text { nd byte of PVAM instruction }
\end{aligned}
$$

## $\mathrm{m}=$ memory

$r / m=E A$ is second byte
$\mathbf{s} \mid=$ short intrasegment
sr = segment regıster
$t=$ to CPU register
$v=$ varıable
$w=$ word operation
$z=$ zero

## Footnotes

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if $\bmod =11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
if mod $=00$ then DISP $=0^{*}$, disp-low and disp-high are absent
if mod = 01 then DISP = disp-low sign extended to 16 bits, disphigh is absent
If $\bmod =10$ then DISP $=$ disp-high: disp-low
If $\mathrm{r} / \mathrm{m}=000$ then $E A=(B X)+(S I)+$ DISP
If $r / m=001$ then $E A=(B X)+(D I)+D I S P$
if $r / m=010$ then $E A=(B P)+(S I)+D I S P$
if $r / m=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then $\mathrm{EA}=(\mathrm{SI})+$ DISP
if $r / m=101$ then $E A=(D I)+$ DISP
If $r / m=110$ then $E A+(B P)+D I S P^{*}$
if $r / m=111$ then $E A=(B X)+D I S P$
DISP follows 2nd byte of instruction (before data is required)

* except if $\mathrm{mod}=00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EQ}=$ disp-high: disp-low.


## Segment Override Prefix

## 001 reg 110

reg is assigned according to the following:

| REG | SEGMENT REGISTER |
| :---: | :---: |
| 00 | ES |
| 01 | CS |
| 10 | SS |
| 11 | DS |

REG is assigned according to the following table:

| $\mathbf{1 6 - B I T}(w=1)$ | $\mathbf{8 - B I T}(\mathbf{w}=\mathbf{0})$ |  |  |
| :---: | :---: | :---: | :---: |
| 000 | AX | 000 | AL |
| 001 | CX | 001 | CL |
| 010 | DX | 010 | DL |
| 011 | BX | 011 | BL |
| 100 | SP | 100 | AH |
| 101 | BP | 101 | CH |
| 110 | SI | 110 | DH |
| 111 | DI | 111 | BH |

The physical addresses of all operands addressed by the BP register are computed using the SS segment register. The physical addresses of the destination operands of the string primitive operations (those addressed by the DI register) are computed using the ES segment, which may not be overridden.

# High Performance Microprocessor With Memory Management and Protection 

## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Compatible with NMOS 80286/883
- 10MHz Operation (80C286-10/883)
- 12.5MHz Operation (80C286-12/883)
- Static CMOS Design for Low Power Operation
- ICCSB = 5mA Maximum
- ICCOP $=185 \mathrm{~mA}$ Maximum (80C286-10/883)
- ICCOP $=220 \mathrm{~mA}$ Maximum (80C286-12/883)
- Large Address Space:
- 16 Megabytes Physical
- 1 Gigabyte Virtual per Task
- Integrated Memory Management, Four-Level Memory Protection and Support for Virtual Memory and Operating Systems
- Two 80C86 Upward Compatible Operating Modes:
- 80C286/883 Real Address Mode
- Protected Virtual Address Mode
- Compatible with 80287 Numeric Data Co-processor
- Available in 68 Pin PGA (Pin Grid Array) Package
- Wide Operating Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 80C286/883 is a static CMOS version of the NMOS 80286 microprocessor. The $80 \mathrm{C} 286 / 883$ is an advanced, high-performance microprocessor with specially optimized capabilities for multiple user and multi-tasking systems. The 80C286/883 has built-in memory protection that supports operating system and task isolation as well as program and data privacy within tasks. The 80C286/883 includes memory management capabilities that map $2^{30}$ (one gigabyte) of virtual address space per task into $2^{24}$ bytes ( 16 megabytes) of physical memory.

The 80C286/883 is upwardly compatible with 80C86 and 80C88 software (the $80 \mathrm{C} 286 / 883$ instruction set is a superset of the $80 \mathrm{C} 86 / 80 \mathrm{C} 88$ instruction set). Using the $80 \mathrm{C} 286 / 883$ real address mode, the 80C286/ 883 is object code compatible with existing 80 C 86 and 80 C 88 software. In protected virtual address mode, the 80C286/883 is source code compatible with 80 C 86 and 80 C 88 software but may require upgrading to use virtual address as supported by the 80C286/883's integrated memory management and protection mechanism. Both modes operate at full 80C286/883 performance and execute a superset of the 80C86 and 80C88 instructions.

The 80C286/883 provides special operations to support the efficient implementation and execution of operating systems. For example, one instruction can end execution of one task, save its state, switch to a new task, load its state, and start execution of the new task. The segment-notpresent exception and restartable instructions.

## Pin Configurations

COMPONENT PAD VIEWS
As viewed from underside of the component when mounted on the board.



P.C. BOARD VIEWS

As viewed from the component side of the P.c. board.


## Absolute Maximum Ratings

Supply Voltage
.+8.0 V
Input, Output or I/O Voltage Applied .... GND -1.0V to VCC +1.0 V
Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering, 10 Seconds) . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
ESD Classification
Class 1

## Reliability Information

$\theta_{\text {jc }}$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $17^{\circ} \mathrm{C} / \mathrm{W}$ (PGA Package)

Maximum Package Power Dissipation . . . . . . . . . . . . . . . . . . . .1.22W
Typical Derating Factor . . . . . . . . . . . $17 \mathrm{~mA} / \mathrm{MHz}$ Increase in ICCOP Gate Count

22,500 Gates

CAUTION: Stresses above those listed in the "Absolute Maximum Ratıngs" 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 operation section of this specification is not implied.

## Operating Conditions

 Operating Temperature Range $\ldots \ldots \ldots \ldots \ldots . .5^{\circ} \mathrm{C}$ to $+125^{\circ}$ System Clock (CLK) RISE Time (From 1.0V to 3.6V) .... . .8ns (Max) System Clock (CLK) FALL Time (From 3.6V to 1.0 V ) . . . . . 8ns (Max)

Input RISE/FALL Time (From 0.8 V to 2.0 V )
80C286-10/883
10ns (Max)
.8ns (Max)

TABLE 1. 80C286/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input LOW Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -0.5 | 0.8 | V |
| Input HIGH Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.0 | $\mathrm{v}_{\mathrm{CC}}+0.5$ | V |
| CLK Input LOW Voltage | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -0.5 | 1.0 | V |
| CLK Input HIGH Voltage | $\mathrm{V}_{\mathrm{IHC}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.6 | $\mathrm{v}_{\mathrm{CC}}+0.5$ | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{l} \mathrm{OL}=2.0 \mathrm{~mA}, \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \hline \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA}, \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
|  |  | $\begin{aligned} & \mathrm{OH}=-100 \mu \mathrm{~A}, \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \end{aligned}$ |  |  | $\mathrm{V}_{\mathrm{CC}}-0.4$ | - | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=G N D \text { or } V_{C C} \\ & V_{C C}=5.5 V, \text { Pins } 29, \\ & 31,57,59,61,63-64 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | 10 | $\mu \mathrm{A}$ |
| Input Sustaining Current LOW | $\mathrm{I}_{\mathrm{BHL}}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { and } 5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{N}}=1.0 \mathrm{~V}, \text { Note } 1 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 38 | 200 | $\mu \mathrm{A}$ |
| Input Sustaining Current HIGH | ${ }^{\text {IBHH }}$ | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { and } 5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=3.0 \mathrm{~V}, \text { Note } 2 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -50 | -400 | $\mu \mathrm{A}$ |
| Input Sustaining <br> Current on $\qquad$ $\overline{B U S Y}$ and $\overline{E R R O R}$ Pins | ISH | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { and } 5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{GND}, \text { Note } 5 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -30 | -500 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{array}{\|l} \hline V_{\mathrm{O}}=\mathrm{GND} \text { or } \mathrm{V}_{\mathrm{CC}} \\ \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \text { Pins } 1, \\ 7-8,10-28,32-34 \end{array}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | 10 | $\mu \mathrm{A}$ |
| Active Power Supply Current | I'cop | $\begin{array}{\|l} 80 \mathrm{C} 286-10 / 883, \\ \text { Note } 4 \end{array}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 185 | mA |
|  |  | $\begin{aligned} & 80 \mathrm{C} 286-12 / 883, \\ & \text { Note } 4 \end{aligned}$ |  |  | - | 220 | mA |
| Standby Power Supply Current | ${ }^{\prime} \mathrm{CCSB}$ | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { Note 3 } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 5 | mA |

NOTES: 1. $I_{B H L}$ should be measured after lowering $V_{I N}$ to $G N D$ and then raising to 1.0 V on the following pins: 36-51, 66, 67
2. $\mathrm{I}_{\mathrm{BH}}$ should be measured after raising $\mathrm{V}_{\mathrm{IN}}$ to $\mathrm{V}_{\mathrm{CC}}$ and then lowering to 3.0 V on the following pins: 4-6, 36-51, 66-68.
3. $\mathrm{I}_{\mathrm{CCSB}}$ should be tested with the clock stopped in phase two of the processor clock cycle. $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=55 \mathrm{~V}$, outputs unloaded.
4. ICCOP measured at 10 MHz for the $80 \mathrm{C} 286-10 / 883$ and 12.5 MHz for the $80 \mathrm{C} 286-12 / 883 . \mathrm{V}_{I N}=2.4 \mathrm{~V}$ or $0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, outputs unloaded.
5. ISH should be measured after raising $\mathrm{V}_{\mathrm{IN}}$ to $\mathrm{V}_{\mathrm{CC}}$ and then lowerng to OV on pins 53 and 54.

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

TABLE 2. 80C286/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
A.C. Timings are Referenced to 0.8 V and 2.0V Points of the Signals as Illustrated in Datasheet Waveforms, Unless Otherwise Noted. Device Guaranteed and 100\% Tested.

| PARAMETERS | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | 80C286/883 |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 10 MHz |  | 12.5 MHz |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| System Clock (CLK) Period | 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | - | 40 | - | ns |
| System Clock (CLK) Low Time | 2 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} @ 1.0 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 11 | - | ns |
| System Clock (CLK) High Time | 3 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} @ 3.6 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 16 | - | 13 | - | ns |
| Asynchronous Inputs SETUP Time Note 1 | 4 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 15 | - | ns |
| Asynchronous Inputs HOLD Time Note 1 | 5 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 15 | - | ns |
| RESET SETUP Time | 6 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 19 | - | 10 | - | ns |
| RESET HOLD Time | 7 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Read Data SETUP Time | 8 |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 8 | - | 5 | - | ns |
| Read Data HOLD Time | 9 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 4 | - | 4 | - | ns |
| $\overline{\text { READY }}$ SETUP Time | 10 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 20 | - | ns |
| $\overline{\text { READY }}$ HOLD Time | 11 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 25 | - | 20 | - | ns |
| Status/PEACK <br> Active Delay <br> Note 4 | 12A | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V}, C_{L}=100 \mathrm{pF} \\ & \mathrm{I}_{\mathrm{L}}=\|2 \mathrm{~mA}\| \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 1 | 22 | 1 | 21 | ns |
| Status/PEACK <br> Inactive Delay <br> Note 3 | 12B |  | 9,10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | 30 | 1 | 24 | ns |
| Address Valid Delay Note 2 | 13 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | 35 | 1 | 32 | ns |
| Write Data Valid Delay Note 2 | 14 |  | 9,10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | 40 | 0 | 31 | ns |
| HLDA Valid Delay Note 5 | 15 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | 47 | 0 | 25 | ns |

NOTES: 1. Asynchronous inputs are INTR, NMI, HOLD, PEREQ, ERROR, and BUSY. This specification is given only for testing purposes, to assure recognition at a specific CLK edge.
2. Delay from 1.0 V on the CLK to 0.8 V or 2.0 V .
3. Delay from 1.0 V on the CLK to 08 V for Min (HOLD time) and to 2.0 V for Max (inactive delay).
4. Delay from 1.0 V on the CLK to 2.0 V for Mın (HOLD time) and to 0.8 V for Max (active delay).
5. Delay from 1.0 V on the CLK to 2.0 V .

TABLE 3. 80C286/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | 80C286/883 |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 10MHz |  | 12.5 MHz |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CLK Input Capacitance | $\mathrm{C}_{\text {CLK }}$ | FREQ $=1 \mathrm{MHz}$ | 5 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Other Input Capacitance | $\mathrm{CIN}_{\text {IN }}$ |  | 5 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| I/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  | 5 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Address/Status/Data Float Delay | 15 |  | 1,3,4,5 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | 47 | 0 | 32 | ns |
| Address Valid to Status SETUP Time | 19 | $\mathrm{L}=\|2.0 \mathrm{~mA}\|$ | 1, 2, 5 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 27 | - | 20 | - | ns |

NOTES 1. Output Load: $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$
2 Delay measured from address ether reaching 08 V or 2 OV (valid) to status going active reaching 0.8 V or status going inactive reaching 2.0 V .
3 Delay from 10 V on the CLK to Float (no current drive) condition.
4. $\mathrm{I}_{\mathrm{L}}=-6 \mathrm{~mA}$ ( $\mathrm{V}_{\mathrm{OH}}$ to Float), $\mathrm{I}=8 \mathrm{~mA}$ ( $\mathrm{V}_{\mathrm{OL}}$ to Float).
5. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Group C \&D | Samples/5005 | $1,7,9$ |

## A.C. Electrical Specifications (Continued)

82C284 and 82C288 TIMING SPECIFICATIONS ARE GIVEN FOR REFERENCE ONLY, AND NO GUARANTEE IS IMPLIED.
82C284 TIMING

| SYMBOL | PARAMETER | 10 MHz |  | 12.5MHz |  | UNIT | TEST CONDITION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| TIMING REQUIREMENTS |  |  |  |  |  |  |  |
| 11 | SRDY/SRDYEN Setup Time | 15 | - | 15 | - | ns |  |
| 12 | SRDY/SRDYEN Hold Time | 2 | - | 2 | - | ns |  |
| 13 | $\overline{\text { ARDY/ARDYEN }}$ Setup Time | 5 | - | 5 | - | ns | (Note 1) |
| 14 | $\overline{\text { ARDY/ARDYEN }}$ Hold Time | 30 | - | 25 | - | ns | (Note 1) |
| TIMING RESPONSES |  |  |  |  |  |  |  |
| 19 | PCLK Delay | 0 | 20 | 0 | 16 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=75 \mathrm{pF} \\ & \mathrm{IOL}=5 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |

$82 C 288$ TIMING

| SYMBOL | PARAMETER | 10MHz |  | 12.5MHz |  | UNIT | TEST CONDITION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| TIMING REQUIREMENTS |  |  |  |  |  |  |  |
| 12 | CMDLY Setup Time | 15 | - | 15 | - | ns |  |
| 13 | CMDLY Hold Time | 1 | - | 1 | - | ns |  |
| TIMING RESPONSES |  |  |  |  |  |  |  |
| 16 | ALE Active Delay | 1 | 16 | 1 | 16 | ns |  |
| 17 | ALE Inactive Delay | - | 19 | - | 19 | ns |  |
| 19 | DT//̄R Read Active Delay | - | 23 | - | 23 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| 20 | DEN Read Active Delay | 0 | 21 | 0 | 21 | ns | $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \mathrm{Max}$ |
| 21 | DEN Read Inactive Delay | 3 | 23 | 3 | 21 | ns | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \mathrm{Max}$ |
| 22 | DT/R/ Read Inactive Delay | 5 | 24 | 5 | 18 | ns |  |
| 23 | DEN Write Active Delay | - | 23 | - | 23 | ns |  |
| 24 | DEN Write Inactive Delay | 3 | 23 | 3 | 23 | ns |  |
| 29 | Command Active Delay from CLK | 3 | 21 | 3 | 21 | ns | $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$ |
| 30 | Command Inactive Delay from CLK | 3 | 20 | 3 | 20 | ns | $\mathrm{I}^{\mathrm{OL}}=32 \mathrm{~mA} \mathrm{Max}$ |

NOTE 1. These times are given for testing purposes to ensure a predetermined action.
A.C. Specifications (Continued)
A.C. DRIVE AND MEASURE POINTS - CLK INPUT


NOTE:. For A.C. testing, input rise and fall times are driven at 1 ns per volt.

80C286/883


## Waveforms (Continued)

80C286/883 ASYNCHRONOUS INPUT SIGNAL TIMING


NOTES: 1. PCLK indicates which processor cycle phase will occur on the next CLK PCLK may not indicate the correct phase until the first cycle is performed

2 These inputs are asynchronous The setup and hold times shown assure recognition for testing purposes

80C286/883 RESET INPUT TIMING AND SUBSEQUENT PROCESSOR CYCLE PHASE


NOTE When RESET meets the setup time shown, the next CLK will start or repeat $\phi 2$ of a processor cycle


NOTES: 1. These signals may not be driven by the $80 C 286 / 883$ during the time shown. The worst case in terms of latest float time is shown.
2. The data bus will be driven as shown if the last cycle before $T_{f}$ in the diagram was a write $T_{C}$.
3. The 80C286/883 puts its status pins in a high impedance logic one state during $T_{H}$.
4. For HOLD request set up to HLDA, refer to Figure 29.
5. $\overline{\mathrm{BHE}}$ and $\overline{\mathrm{LOCK}}$ are driven at this tıme but will not become valid until $\mathrm{T}_{\mathbf{S}}$.
6. The data bus will remain in a high impedance state if a read cycle is performed.

## Waveforms (Continued)

80C286/883 PEREQ/PEACK TIMING FOR ONE TRANSFER ONLY
BUS CYCLE TYPE


ASSUMING WORD-ALIGNED MEMORY OPERAND. IF ODD ALIGNED, 8OC286/883 TRANSFERS TO/FROM MEMORY BYTE-AT-A-TIME WITH TWO MEMORY CYCLES.

NOTES: 1. $\overline{\text { PEACK }}$ always goes active during the first bus operation of a processor extension data operand transfer sequence. The first bus operation will be either a memory read at operand address or I/O read at port address OOFA(H).
2. To prevent a second processor extension data operand transfer, the worst case maximum time (Shown above) is $3 \times(1)-12 A_{\text {max. }}$ - (4) min. The actual, configuration dependent, maxımum time is: $\left.3 \times(1)-12 A_{\max }-{ }^{-(4)}\right)_{\min .}+N \times 2 \times(1) . N$ is the number of extra $T_{C}$ states added to erther the first or second bus operation of the processor extension data operand transfer sequence.

INITIAL 80C286/883 PIN STATE DURING RESET


NOTES: 1. Setup time for RESET $\uparrow$ may be violated with the consideration that $\phi 1$ of the processor clock may begin one system CLK period later.
2. Setup and hold times for RESET $\downarrow$ must be met for proper operation, but RESET $\downarrow$ may occur during $\phi 1$ or $\phi 2$.
3. The data bus is only guaranteed to be in a high impedance state at the tume shown.

## Burn-In Circuit

80C286/883 PGA


NOTES• 1 Supply Voltage
$V_{D D}=55 \mathrm{~V}$
$V_{S S}=0.0 \mathrm{~V}$
2 Input Voltage Limits
$\mathrm{V}_{\mathrm{IL}}($ Maxımum $)=0.8 \mathrm{~V}$
$\mathrm{V}_{\mathrm{IH}}$ (Minımum) $=2 \mathrm{OV}$
3. Component Values
$R C=1 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{RI}=10 \mathrm{k} \Omega \pm 5 \%$
$R O=$ Two Series $27 k \Omega \pm 5 \%$
4. Capacitor Values C1 $=0.1$ Mıcrofarads
5. Oven Type and Frequency Requirements

Wakefield Oven Board $f_{0}=100 \mathrm{kHz}, f_{3}=12.5 \mathrm{kHz}$
$f_{4}=6.25 \mathrm{kHz}, \mathrm{f}_{5}=3.125 \mathrm{kHz}, \mathrm{f}_{7}=781.25 \mathrm{~Hz}$.
6 Special Requirements
(a) ELECTROSTATIC DISCHARGE SENSITIVE. Proper Precautions Must be Used When Handling Units
(b) All Power Supplies Must be at Zero Volts When the Boards are Inserted into the Ovens.
(c) When Powering Up, the Inputs Must be Held Below the $V_{D D}$ Voltage.
(d) If an Excessive Current is Indicated at Final Inspection, Check to See if a Part is Inserted Backwards or is Latched Up

## Metallization Topology

DIE DIMENSIONS:
$315 \times 320 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si-Al
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$

## DIE ATTACH:

Material: Si-Au Eutectic Alloy
Temperature: Ceramic PGA - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY: $2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
LEAD TEMPERATURE (10 Seconds Soldering): $\leq 300^{\circ} \mathrm{C}$

## Metallization Mask Layout



## Packaging



```
Features
- Compatible with NMOS }808
- Completely Static CMOS Design
    - DC
```

$\qquad$

```
                5MHz (80C86)
    - DC
                            8MHz (80C86-2)
- Low Power Operation
    - ICCSB
        ................................. . 500\muA (Max)
    - ICCOP
        . . . . . . . . . . . . . . . . . . . . . . 10mA/MHz (Typ)
- 1MByte of Direct Memory Addressing Capability
-24 Operand Addressing Modes
- Bit, Byte, Word and Block Move Operations
- 8 Bit and 16 Bit Signed/Unsigned Arithmetic
    - Binary, or Decimal
    - Multiply and Divide
- Wide Operating Temperature Range
    - C80C86 ...............................00}\textrm{C}\mathrm{ to +700}\textrm{C
    - I80C86 ............................ -400}\textrm{C}\mathrm{ to +850}\textrm{C
    - M80C86 .......................... - 550
```


## 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 (with the exception of CLOCK) and industry standard operation allow use of existing NMOS 8086 hardware and software designs.

## Ordering Information

| PACKAGE | TEMP. RANGE | 5 MHz | 8 MHz |
| :---: | :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP80C86 | CP80C86-2 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP80C86 | IP80C86-2 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS80C86 | CS80C86-2 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS80C86 | IS80C86-2 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD80C86 | CD80C86-2 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID80C86 | ID80C86-2 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD80C86/B | MD80C86-2/B |
| SMD\# |  | 8405201QA | 8405202QA |
| LCC SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR80C86/B | MR80C86-2/B |
|  |  | 8405201XA | 8405202XA |

## Pinouts



Functional Diagram



## 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 $80 C 86$ (without regard to additional bus buffers).

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| AD15-ADO | 2-16, 39 | I/O | ADDRESS DATA BUS: These lines constitute the time multiplexed memory/IO address (T1) and data (T2, T3, TW, T4) bus. AO is analogous to BHE for the lower byte of the data bus, pins D7-DO. It is LOW during T1 when a byte is to be transferred on the lower portion of the bus in memory or I/O operations. Eight-bit oriented devices tied to the lower half would normally use AO to condition chip select functions (See BHE). These lines are active HIGH and are held at high impedance to the last valid logic level during interrupt acknowledge and local bus "hold acknowledge" or "grant sequence". |
| A19/S6 A18/S5 A17/S4 A16/S3 | 35-38 | 0 | ADDRESS/STATUS: During T1, 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 T2, T3, TW, T4. S6 is always LOW. The status of the interrupt enable FLAG bit (S5) is updated at the beginning of each clock cycle. S4 and S3 are encoded as shown. <br> This information indicates which segment register is presently being used for data accessing. <br> These lines are held at high impedance to the last valid logic level during local bus "hold acknowledge" or "grant sequence". |
| BHE/S7 | 34 | 0 | BUS HIGH ENABLE/STATUS: During T1 the bus high enable signal ( $\overline{\mathrm{BHE}}$ ) should be used to enable data onto the most significant half of the data bus, pins D15-D8. Eight bit oriented devices tied to the upper half of the bus would normally use $\overline{\mathrm{BHE}}$ to condition chip select functions. $\overline{\text { BHE }}$ is LOW during T1 for read, write, and interrupt acknowledge cycles when a byte is to be transferred on the high portion of the bus. The $\mathbf{S 7}$ status information is available during T2, T3 and T4. The signal is active LOW, and is held at high impedance to the last valid logic level during interrupt acknowledge and local bus "hold acknowledge" or "grant sequence"; it is LOW during T1 for the first interrupt acknowledge cycle. |
| $\overline{\mathrm{RD}}$ | 32 | 0 | READ: Read strobe indicates that the processor is performing a memory or I/O read cycle, depending on the state of the $\mathrm{M} / \overline{\mathrm{OO}}$ or $\overline{\mathrm{S} 2} \mathrm{pin}$. This signal is used to read devices which reside on the 80 C 86 local bus. $\overline{\text { RD }}$ is active LOW during T2, T3 and TW of any read cycle, and is guaranteed to remain HIGH in T2 until the 80 C 86 local bus has floated. <br> This line is held at a high impedance logic one state during "hold acknowledge" or "grant sequence". |
| READY | 22 | I | READY: is the acknowledgement from the addressed memory or I/O device that will complete the data transfer. The RDY signal from memory or I/O 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: is 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. |

## Pin Description (Continued)

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 <br> NUMBER | TYPE |  |
| :---: | :---: | :---: | :--- |
| $\overline{\text { TEST }}$ | 23 | 1 | TEST: input is examined by the "Wait" instruction. If the $\overline{\text { TEST input is LOW execution con- }}$ <br> tinues, otherwise the processor waits in an "Idle" state. This input is synchronized internally <br> during each clock cycle on the leading edge of CLK. |
| NMI | 17 | 1 | NON-MASKABLE INTERRUPT: is an edge triggered input which causes a type 2 interrupt. A <br> subroutine is vectored to via an interrupt vector lookup table located in system memory. NMI <br> is not maskable internally by software. A transition from LOW to HIGH initiates the interrupt <br> 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 <br> transition LOW to HIGH and remain active HIGH for at least four clock cycles. It restarts <br> execution, as described in the Instruction Set description, when RESET returns LOW. RESET <br> is internally synchronized. |
| CLK | 19 | 1 | CLOCK: provides the basic timing for the processor and bus controller. It is asymmetric with <br> a 33\% duty cycle to provide optimized internal timing. |
| VCC | 40 |  | VCC: +5V power supply pin. A $0.1 \mu \mathrm{~F}$ capacitor between pins 20 and 40 is recommended for <br> decoupling. |
| GND | 1,20 |  | GND: Ground. Note: both must be connected. A $0.1 \mu \mathrm{~F}$ capacitor between pins 1 and 20 is <br> recommended for decoupling. |
| MN/MX | 33 | 1 | MINIMUM/MAXIMUM: Indicates what mode the processor is to operate in. The two modes <br> are discussed in the following sections. |

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 below.

MINIMUM MODE SYSTEM

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| M/ $\overline{\mathrm{O}}$ | 28 | O | STATUS LINE: logically equivalent to $\overline{\mathrm{S} 2}$ in the maximum mode. It is used to distinguish a memory access from an I/O access. M/IO becomes valid in the T4 preceding a bus cycle and remains valid until the final T 4 of the cycle ( $M=\mathrm{HIGH}, \mathrm{IO}=\mathrm{LOW}$ ). $\mathrm{M} / \overline{\mathrm{O}}$ is held to a high impedance logic one during local bus "hold acknowledge". |
| $\overline{\mathrm{WR}}$ | 29 | 0 | WRITE: indicates that the processor is performing a write memory or write I/O cycle, depending on the state of the $\mathrm{M} / \overline{\mathrm{O}}$ signal. $\overline{\mathrm{WR}}$ is active for $\mathrm{T} 2, \mathrm{~T} 3$ and TW of any write cycle. It is active LOW, and is held to high impedance logic one during local bus "hold acknowledge". |
| $\overline{\text { INTA }}$ | 24 | 0 | INTERRUPT ACKNOWLEDGE: is used as a read strobe for interrupt acknowledge cycles. It is active LOW during T2, T3 and TW of eacn interrupt acknowledge cycle. Note that INTA is never floated. |
| ALE | 25 | 0 | ADDRESS LATCH ENABLE: is provided by the processor to latch the address into the 82C82/82C83 address latch. It is a HIGH pulse active during clock LOW of T1 of any bus cycle. Note that ALE is never floated. |
| DT/R | 27 | 0 | DATA TRANSMIT/RECEIVE: is needed in a 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/R is equivalent to $S 1$ in maximum mode, and its timing is the same as for $M / \bar{O}(T=H I G H, R=L O W) . D T / \bar{R}$ is held to a high impedance logic one during local bus "hold acknowledge". |
| $\overline{\text { DEN }}$ | 26 | $\bigcirc$ | 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 T2 until the middle of T4, while for a write cycle it is active from the beginning of T2 until the middle of T4. $\overline{D E N}$ is held to a high impedance logic one during local bus "hold acknowledge". |

## Pin Description (Continued)

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 below.

## MINIMUM MODE SYSTEM (Continued)

| SYMBOL | PIN <br> NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :--- |$|$| HOLD |
| :--- |
| HLDA |

The following pin function descriptions are for the 80C86 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 below.

## MAXIMUM MODE SYSTEM

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\frac{\overline{\mathrm{S} 0}}{\frac{\mathrm{~S} 1}{\mathrm{~S} 2}}$ | 26 27 28 | O O O | STATUS: is active during T4, T1 and T2 and is returned to the passive state $(1,1,1)$ during T3 or during TW when READY is HIGH. This status is used by the 82 C 88 Bus Controller to <br>  used to indicate the beginning of a bus cycle, and the return to the passive state in T3 or TW is used to indicate the end of a bus cycle. <br> These signals are held at a high impedance logic one state during "grant sequence". |
|  |  |  | $\overline{\mathbf{S 2}} \quad \overline{\overline{\mathbf{S 1}}} \mathbf{}$ |
|  |  |  | 0 0 0 Interrupt Acknowledge <br> 0 0 1 Read I/O Port <br> 0 1 0 Write I/O Port <br> 0 1 1 Halt <br> 1 0 0 Code Access <br> 1 0 1 Read Memory <br> 1 1 0 Write Memory <br> 1 1 1 Passive |
| $\frac{\overline{R Q} / \overline{\mathrm{GTO}}}{\overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}}$ | 31, 30 | 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 bi-girectional with $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ having higher priority than $\overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1} . \overline{\mathrm{RQ}} / \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 $\overline{R Q} / \overline{G T}$ Sequence Timing) <br> 1. A pulse of 1 CLK wide from another local bus master indicates a local bus request ("hold") to the 80C86 (pulse 1). <br> 2. During a T4 or TI clock cycle, a pulse 1 CLK wide from the $80 C 86$ to the requesting master (pulse 2) indicates that the 80C86 has allowed the local bus to float and that it will enter the "grant sequence" state at the next CLK. The CPU's bus interface unit is disconnected logically from the local bus during "grant sequence". <br> 3. A pulse 1 CLK wide from the requesting master indicates to the 80 C 86 (pulse 3) that the "hold" request is about to end and that the 80 C 86 can reclaim the local bus at the next CLK. The CPU then enters T4 (or T1 if no bus cycles pending). <br> Each Master-Master exchange of the local bus is a sequence of 3 pulses. There must be one idle CLK cycle after each bus exchange. Pulses are active low. |

## Pin Description (Continued)

The following pin function descriptions are for the 80C86 system in maximum mode (i.e., $M N / \overline{M X}=$ GND). Only the
pin functions which are unique to maximum mode are described below.

## MAXIMUM MODE SYSTEM (Continued)

| SYMBOL | PIN <br> NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
|  |  |  | If the request is made while the CPU is performing a memory cycle, it will release the local bus during T4 of the cycle when all the following conditions are met: <br> 1. Request occurs on or before 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 executing. <br> If the local bus is idle when the request is made the two possible events will follow: <br> 1. Local bus will be released during the next cycle. <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 $\overline{\text { 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 is held at a high impedance logic one state during "grant sequence". In MAX mode, $\overline{\text { LOCK }}$ is automatically generated during T2 of the first INTA cycle and removed during T2 of the second INTA cycle. |
| QS1, QSO | 24,25 | 0 | QUEUE STATUS: The queue status is valid during the CLK cycle after which the queue operation is performed. <br> QS1 and QS0 provide status to allow external tracking of the internal 80C86 instruction queue. Note that QS1, QSO never become high impedance. |
|  |  |  |  |
|  |  |  | 0 0 No Operation <br> 0 <br> 1 0 First byte of op code <br> from queue <br> 1 1 Empty the Queue <br> Subsequent byte from <br> queue |

## Functional Description

## Static Operation

All 80 C 86 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 80C86 can operate from DC to the specified 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. 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 80C86 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 80C86 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 asynchronous 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 $\mathbf{1}$ million bytes, addressed as $00000(\mathrm{H})$ to $\operatorname{FFFFF}(\mathrm{H})$. The memory is logically divided into code, data, extra and stack segments of up to 64 K bytes each, with each segment falling on 16-byte boundaries. (See Figure 1).


FIGURE 1. $80 C 86$ MEMORY ORGANIZATION
TABLE A.

| TYPE OF MEMORY REFERENCE | DEFAULT SEGMENT BASE | ALTERNATE SEGMENT 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 |

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 the specific rules of Table A. 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 A).

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 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 if 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 (D15-D8) and a low bank (D7-D0) of 512 K 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, 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 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 located. Locations 00000 H through $003 F F H$ are reserved for interrupt operations. Each of the 256 possible interrupt service routines is accessed thru its own pair of 16-bit pointers - segment address pointer and offset address pointer. The first pointer, used as the offset address, is loaded into the IP and the second pointer, which designates the base address is loaded into the CS. At this point program control is transferred to the interrupt routine. The pointer elements are assumed to have been stored at the respective places in reserved memory prior to occurrence of interrupts.


FIGURE 2. RESERVED MEMORY LOCATIONS

## Minimum and Maximum Operation Modes

The requirements for supporting minimum and maximum 80C86 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 (MN/ $\overline{\mathrm{MX}}$ ) 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 MN/ $\overline{M X}$ pin is strapped to GND, the $80 C 86$ defines pins 24 through 31 and 34 in maximum mode. When the MN/MX pin is strapped to VCC, the 80C86 generates bus control signals itself on pins 24 through 31 and 34.

The minimum mode 80 C 86 can be used with either a multiplexed or demultiplexed bus. This architecture provides the 80C86 processing power in a highly integrated form.

The demultiplexed mode requires two 82C82 latches (for 64 K addressability) or three 82 C 82 latches (for a full megabyte of addressing). An 82C86 or 82C87 transceiver can also be used if data bus buffering is required. (See Figure 6a.) The 80 C 86 provides $\overline{D E N}$ and DT/ $\bar{R}$ to control the transceiver, and ALE to latch the addresses. This configuration of the minimum mode provides the standard demultiplexed bus structure with heavy bus buffering and relaxed bus timing requirements.

The maximum mode employs the 82 C 88 bus controller (See Figure 6b). The 82 C 88 decodes status lines $\overline{\mathrm{SO}}, \overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$, and provides the system with all bus control signals.

Moving the bus control to the 82C88 provides better source and sink current capability to the control lines, and frees the $80 C 86$ pins for extended large system features. Hardware lock, queue status, and two request/grant interfaces are provided by the 80C86 in maximum mode. These features allow coprocessors in local bus and remote bus configurations.

## 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 82C82 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 T1, T2, T3 and T4 (see Figure 3). The address is emitted from the processor during T1 and data transfer occurs on the bus during T3 and T4. T2 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 T3 and T4. Each inserted wait state is the same duration as a CLK cycle. Periods can occur between 80 C 86 driven bus cycles. These are referred to as idle" states (TI) or inactive CLK cycles. The processor uses these cycles for internal housekeeping and processing.

During T1 of any bus cycle, the ALE (Address Latch Enable) signal is emitted (by either the processor or the 82C88 bus controller, depending on the MN/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{SO}}, \overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ are used by the bus controller, in maximum mode, to identify the type of bus transaction according to Table B.

TABLE B.

| $\overline{\mathbf{S 2}}$ | $\overline{\mathbf{S 1}}$ | $\overline{\mathbf{S O}}$ | CHARACTERISTICS |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | Interrupt |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| 1 | 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) |



FIGURE 3. BASIC SYSTEM TIMING

Status bits S3 through S7 are time multiplexed with high order address bits and the $\overline{\mathrm{BHE}}$ signal, and are therefore valid during T2 through T4. S3 and S4 indicate which segment register (see Instruction Set Description) was used for this bus cycle in forming the address, according to Table C.

TABLE C.

| S4 | S3 | CHARACTERISTICS |
| :---: | :---: | :--- |
| 0 | 0 | Alternate Data (extra segment) |
| 0 | 1 | Stack |
| 1 | 0 | Code or None |
| 1 | 1 | Data |

S5 is a reflection of the PSW interrupt enable bit. S6 is always zero and S 7 is a spare status bit.

## I/O Addressing

In the 80 C 86 , I/O operations can address up to a maximum of $64 \mathrm{~K} \mathrm{I/O} \mathrm{byte} \mathrm{registers} \mathrm{or} 32 \mathrm{~K}$ I/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 I/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 D7DO 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 for approximately 7 clock cycles. After this interval, the 80 C 86 operates normally beginning with the instruction in absolute location FFFFOH. (See Figure 2). 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$ s (or 4 CLK cycles, whichever is greater) after power-up, to allow complete initialization of the 80C86.

NMI will not be recognized prior to the second CLK cycle following the end of RESET. If NMI is asserted sooner than nine clock cycles after the end of RESET, the processor may execute one instruction before responding to the interrupt.

## Bus Hold Circuitry

To avoid high current conditions caused by floating inputs to CMOS devices and to eliminate need for pull-up/down resistors, "bus-hold" circuitry has been used on the 80C86 pins 2-16, 26-32 and 34-39. (See Figure 4a and 4b). These circuits will maintain the last valid logic state if no driving source is present (i.e. an 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.


FIGURE 4A. BUS HOLD CIRCUITRY PIN 2-16, 34-39


FIGURE 4B. BUS HOLD CIRCUITRY PIN 26-32

## 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. 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 $3 F F H$, 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 register are 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. The activation of this pin causes a type 2 interrupt.

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 block-type 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 (IF) 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 block type instruction. INTR may be removed anytime after the falling edge of the first $\overline{N T}$ TA signal. 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 5) the processor executes two successive (back-to-back) interrupt acknowledge cycles. The 80C86 emits the LOCK signal (Max mode only) from T2 of the first bus cycle until T2 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 80C86 by the 82C59A Interupt 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{SO}}$


FIGURE 5. INTERRUPT ACKNOWLEDGE SEQUENCE
and the 82C88 bus controller issues one ALE. The 80C86 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 at the end of the local bus hold. An NMI or interrupt request (when interrupts enabled) or RESET will force the 80C86 out of the "HALT" state.

## Read/Modify/Write (Semaphore) Operations Via Lock

The $\overline{\text { LOCK }}$ status information is provided by the processor when 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 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 decoding of the software "LOCK" prefix instruction. 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{RQ}} / \overline{\mathrm{GT}}$ pin will be recorded and then honored at the end of the $\overline{\mathrm{LOCK}}$.

## External Synchronization Via TEST

As an alternative to interrupts, the 80C86 provides a single software-testable input pin (TEST). This input is utilized by executing a WAIT instruction. The single WAIT instruction is repeatedly executed until the TEST input goes active (LOW). The execution of WAIT does not consume bus cycles once the queue is full.
If a local bus request occurs during WAIT execution, the 80 C 86 three-states all output drivers while inputs and I/O pins are held at valid logic levels by internal bus-hold circuits. If interrupts are enabled, the 80C86 will recognize interrupts and process them when it regains control of the bus. The WAIT instruction is then refetched, and reexecuted.

TABLE D. $80 C 86$ REGISTER MODEL

| $\mathbf{A X}$ | $\mathbf{A H}$ |
| :---: | :---: |
| $\mathbf{B X}$ | $\mathbf{B H}$ |
| $\mathbf{C X}$ | $\mathbf{C H}$ |
|  | $\mathbf{B L}$ |
| $\mathbf{D H}$ | $\mathbf{C L}$ |



ACCUMULATOR BASE COUNT
DATA

STACK POINTER BASE POINTER SOURCE INDEX DESTINATION INDEX

INSTRUCTION POINTER STATUS FLAGS

CODE SEGMENT
data segment STACK SEGMENT EXTRA SEGMENT

## Basic System Timing

Typical system configurations for the processor operating in minimum mode and in maximum mode are shown in Figures 6A and 6B, respectively. In minimum mode, the $\mathrm{MN} / \overline{\mathrm{MX}}$ 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 82C88 bus controller uses to generate MULTIBUS ${ }^{\text {n }}$ compatible bus control signals. Figure 3 shows the signal timing relationships.

## System Timing - Minimum System

The read cycle begins in T1 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 address/data bus (ADO-AD15) at this time, into the $82 \mathrm{C} 82 / 82 \mathrm{C} 83$ latch. The $\overline{\mathrm{BHE}}$ and AO signals address the low, high or both bytes. From T1 to T4 the M/IO signal indicates a memory or I/O operation. At T2, the address is removed from the address/data bus and the bus is held at the last valid logic state by internal bus hold devices. The read control signal is also asserted at T2. The read ( $\overline{R D}$ ) 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 three-state its bus drivers. If a transceiver (82C86/82C87) is required to buffer the 80 C 86 local bus, signals DT/R and $\overline{D E N}$ 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{I O}$ signal is again asserted to indicate a memory or l/O write operation. In T2, immediately following the address emission, the processor emits the data to be written into the addressed location. This data remains valid until at least the middle of T4. During T2, T3 and TW, the processor asserts the write control signal. The write (WR) signal becomes active at the beginning of T2 as opposed to the read which is delayed somewhat into T2 to provide time for output drivers to become inactive.
The $\overline{B H E}$ and $A O$ signals are used to select the proper byte(s) of the memory/IO word to be read or written according to Table $E$.
table E.

| $\overline{B H E}$ | AO | CHARACTERISTCS |
| :---: | :---: | :--- |
| 0 | 0 | Whole word |
| 0 | 1 | Upper byte from/to odd address |
| 1 | 0 | Lower byte from/to even address |
| 1 | 1 | None |

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


FIGURE 6A. MINIMUM MODE $80 C 86$ TYPICAL CONFIGURATION


FIGURE 6B. MAXIMUM MODE $80 C 86$ TYPICAL CONFIGURATION

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 held at the last valid logic state by internal bus hold devices. (See Figure 4). In the second of two successive INTA cycles a byte of information is read from the data bus (D7-D0) 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 complexity 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 82C82/82C83 latch for latching the system address, and an 82C86/82C87 transceiver to allow for bus loading greater than the 80C86 is capable of handling. Signals ALE, $\overline{D E N}$, and DT/ $\bar{R}$ are generated by the 82C88 instead of the processor in this configuration, although their timing remains relatively the same. The 80C86
status outputs ( $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}$ and $\overline{\mathrm{SO}}$ ) provide type-of-cycle information and become 82 C 88 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 issues control signals specifying memory read or write, I/O read or write, or interrupt acknowledge. 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 as read strobes, and hence, data is not valid at the leading edge of write. The 82C86/82C87 transceiver receives the usual T and $\overline{\mathrm{OE}}$ inputs from the 82C88 DT/ $\overline{\mathrm{R}}$ and DEN signals.

The pointer into the interrupt vector table, which is passed during the second $\overline{\operatorname{NTA}}$ 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, the 82C86/82C87 transceiver must be disabled when reading from the master 82C59A during the interrupt acknowledge sequence and software "poll".

Absolute Maximum Ratings


Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $27.5^{\circ} \mathrm{C} / \mathrm{W}$ | $5.9{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $62.2{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $8.6{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . . . . . . . . . . . . . . . . . . . . . . . . 620mW |  |  |
| Ceramic LCC Package |  | 664 mW |
| ate Coun |  |  |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Supply Voltage $\ldots \ldots \ldots \ldots \ldots \ldots \ldots . \ldots 4.5 \mathrm{~V}$ to +5.5 V Operating Temperature Range: $\mathrm{C} 80 \mathrm{C} 86 /-2 \ldots \ldots .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
M80C86-2 ONLY . . . . . . . . . . . . . . . . . . . . . . . +4.75 V to +5.25 V I80C86/-2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ M80C86/-2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
D.C. Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 80 \mathrm{C} 86, \mathrm{C} 80 \mathrm{C} 86-2)$
$V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ (I80C86, I80C86-2)
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C86)
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C86-2)

| 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}$ | C80C86, $180 \mathrm{C86}$ (Note 5) M80C86 (Note 5) |
| VIL | Logical Zero Input Voltage |  | 0.8 | V |  |
| VIHC | CLK Logical One Input Voltage | $\mathrm{V}_{\text {CC }}-0.8$ |  | V |  |
| VILC | CLK Logical Zero Input Voltage |  | 0.8 | V |  |
| VOH | Output High Voltage | $\begin{gathered} 3.0 \\ v_{C C}-0.4 \end{gathered}$ |  | $\begin{aligned} & \hline \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & 1 \mathrm{OH}=-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}$ |
| 11 | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | VIN = GND or VCC DIP <br> Pins 17-19, 21-23, 33 |
| IBHH | Input Current-Bus Hold High | -40 | -400 | $\mu \mathrm{A}$ | VIN $=3.0 \mathrm{~V} \quad$ (Note 1) |
| IBHL | Input Current-Bus Hold Low | 40 | 400 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0.8 \mathrm{~V} \quad$ (Note 2) |
| 10 | Output Leakage Current | - | -10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \hline \text { VOUT = GND } \\ & \text { (Note 4) } \end{aligned}$ |
| ICCSB | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V} \quad$ (Note 3) |
| ICCOP | Operating Power Supply Current | - | 10 | $\mathrm{mA} / \mathrm{MHz}$ | FREQ $=$ Max, $\mathrm{VIN}=\mathrm{VCC}$ or GND, Outputs Open |

Capacitance $T_{A}=25{ }^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | 25 | pF | FREQ $=1 \mathrm{MHz}$ All <br> measurements are referenced <br> to device GND |
| COUT | Output Capacitance | 25 | pF |  |
| $\mathrm{CI} / \mathrm{O}$ | I/O Capacitance | 25 | pF |  |

NOTES 1. IBHH should be measured after raising VIN to $V_{C C}$ and then lowering to 3.0 V on the following pins. 2-16, 26-32, 34-39
2. IBHL should be measured after lowering VIN to GND and then raising to 0.8 V on the following pins: 2-16, 34-39
3. ICCSB tested during clock high time after halt instruction executed. VIN $=V_{C C}$ or $G N D, V_{C C}=5.5 \mathrm{~V}$, Outputs unloaded

4 IO should be measured by putting the pin in a high impedance state and then driving VOUT to GND on the following pins: 26-29 and 32.
5. $\mathrm{MN} / \overline{\mathrm{MX}}$ is a strap option and should be held to $\mathrm{V}_{\mathrm{CC}}$ or GND
A.C. Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C80C86, C80C86-2) $V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ ( $180 \mathrm{C} 86,180 \mathrm{C} 86-2$ )
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$; $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125{ }^{\circ} \mathrm{C}$ (M80C86)
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C86-2)

## MINIMUM COMPLEXITY SYSTEM



[^3]
## Waveforms

BUS TIMING - MINIMUM MODE SYSTEM


NOTE: 1. Signals at 82C84A are shown for reference only. RDY is sampled near the end of T2, T3, TW to determine if TW machine states are to be inserted.

## Waveforms

BUS TIMING - MINIMUM MODE SYSTEM (Continued)


NOTE: 1. Two $\overline{\operatorname{INTA}}$ cycles run back-to-back. The $80 C 86$ local ADDR/DATA bus is floating during both INTA cycles. Control Signals are shown for the second INTA cycle.

Specifications 80C86
A.C. Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=00 \mathrm{C}$ to $+700^{\circ} \mathrm{C}$ (C80C86, C80C86-2)
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ ( $180 \mathrm{C} 86, \mathrm{C} 80 \mathrm{C} 86-2$ )
$V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-550^{\circ} \mathrm{C}$ to $+125{ }^{\circ} \mathrm{C}$ (M80C86)
$V_{C C}=5.0 \mathrm{~V} \pm 5 \% ; T A=-55{ }^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C86-2)

## MAX MODE SYSTEM (USING 82C88 BUS CONTROLLER)

| TIMING REQUIREMENTS |  | 80C86-2 |  | $80 \mathrm{C86}$ |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | MIN | MAX |  |  |
| (1) TCLCL | CLK Cycle Period | 125 |  | 200 |  | ns |  |
| (2) TCLCH | CLK Low Time | 68 |  | 118 |  | ns |  |
| (3) TCHCL | CLK High Time | 44 |  | 69 |  | ns |  |
| (4) TCH 1 CH 2 | CLK Rise Time |  | 10 |  | 10 | ns | From 1.0 V to 3.5 V |
| (5) TCL2CL1 | CLK Fall Time |  | 10 |  | 10 | ns | From 3.5V to 1.0 V |
| (6 TDVCL | Data in Setup Time | 20 |  | 30 |  | ns |  |
| (7) TCLDX1 | Data In Hold Time | 10 |  | 10 |  | ns |  |
| (8) TR1VCL | RDY Setup Time into 82C84A (Notes 1, 2) | 35 |  | 35 |  | ns |  |
| (9) TCLR1X | RDY Hold Time into 82C84A <br> (Notes 1, 2) | 0 |  | 0 |  | ns |  |
| (10)TRYHCH | READY Setup Time into 80C86 | 68 |  | 118 |  | ns |  |
| (11)TCHRYX | READY Hold Time into 80C86 | 20 |  | 30 |  | ns |  |
| (12)TRYLCL | READY Inactive to CLK (Note 3) | -8 |  | -8 |  | ns |  |
| (13)TINVCH | Setup Time for Recognition (INTR,NMI, TEST) (Note 2) | 15 |  | 30 |  | ns |  |
| (14)TGVCH | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | 15 |  | 30 |  | ns |  |
| (15)TCHGX | $\overline{\mathrm{RQ}}$ Hold Time into 80C86 (Note 4) | 30 | $\begin{gathered} \hline \text { TCHCL+ } \\ 10 \\ \hline \end{gathered}$ | 40 | $\begin{array}{\|c\|} \hline \text { TCHCL+ } \\ 10 \\ \hline \end{array}$ | ns |  |
| (16) TILIH | Input Rise Time (Except CLK) |  | 15 |  | 15 | ns | From 0.8 V to 2.0 V |
| (17) TIHIL | Input Fall Time (Except CLK) |  | 15 |  | 15 | ns | From 2.0 V to 0.8 V |
| TIMING RESPONSES |  |  |  |  |  |  |  |
| (18)TCLML | Command Active Delay (Note 1) | 5 | 35 | 5 | 35 | ns |  |
| (19) TCLMH | Command Inactive (Note 1) | 5 | 35 | 5 | 35 | ns |  |
| (20)TRYHSH | READY Active to Status Passive (Notes 3, 5) |  | 65 |  | 110 | ns |  |
| (21)TCHSV | Status Active Delay | 10 | 60 | 10 | 110 | ns |  |
| (22) TCLSH | Status Inactive Delay (Note 5) | 10 | 70 | 10 | 130 | ns |  |
| (23) TCLAV | Address Valid Delay | 10 | 60 | 10 | 110 | ns |  |
| (24) TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| (25) TCLAZ | Address Float Delay | TCLAX | 50 | TCLAX | 80 | ns |  |
| (26) TCHSZ | Status Float Delay |  | 50 |  | 80 | ns |  |
| (27) TSVLH | Status Valid to ALE High (Note 1) |  | 20 |  | 20 | ns |  |
| (28)TSVMCH | Status Valid to MCE High (Note 1) |  | 30 |  | 30 | ns | $C L=100 \mathrm{pF}$ |
| (29) TCLLH | CLK low to ALE Valid (Note 1) |  | 20 |  | 20 | ns | for all 80C86 |
| (30)TCLMCH | CLK low to MCE High (Note 1) |  | 25 |  | 25 | ns | to 80C86 self-load) |
| (31) TCHLL | ALE Inactive Delay (Note 1) | 4 | 18 | 4 | 18 | ns |  |
| (32)TCLMCL | MCE Inactive Delay (Note 1) |  | 15 |  | 15 | ns |  |
| (33) TCLDV | Data Valid Delay | 10 | 60 | 10 | 110 | ns |  |
| (34)TCLDX2 | Data Hold Time | 10 |  | 10 |  | ns |  |
| (35) TCVNV | Control Active Delay (Note 1) | 5 | 45 | 5 | 45 | ns |  |


| TIMING REQUIREMENTS |  | 80C86-2 |  | $80 \mathrm{C86}$ |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN | MAX | MIN | MAX |  |  |
| TIMING RESPONSES |  |  |  |  |  |  |  |
| (36)TCVNX | Control Inactive Delay (Note 1) | 10 | 45 | 10 | 45 | ns | 1 |
| (37)TAZRL | Address Float to Read Active | 0 |  | 0 |  | ns |  |
| (38)TCLRL | RD Active Delay | 10 | 100 | 10 | 165 | ns | $C L=100 \mathrm{pF}$ |
| (39)TCLRH | RD Inactive Delay | 10 | 80 | 10 | 150 | ns |  |
| (40)TRHAV | RD Inactive to Next Address Active | $\begin{gathered} \text { TCLCL } \\ \hline-40 \\ \hline \end{gathered}$ |  | $\begin{array}{\|c\|} \hline \text { TCLCL } \\ -45 \\ \hline \end{array}$ |  | ns |  |
| $\begin{gathered} \text { TCHDTL } \\ \hline \end{gathered}$ | Direction Control Actıve Delay (Note 1) |  | 50 |  | 50 | ns |  |
| $\underset{(42)}{\text { TCHDTH }}$ | Direction Control Inactive Delay (Note 1) |  | 30 |  | 30 | ns |  |
| (43)TCLGL | GT Active Delay | 0 | 50 | 10 | 85 | ns |  |
| (44)TCLGH | GT Inactive Delay | 0 | 50 | 10 | 85 | ns |  |
| (45)TRLRH | RD Width | $\begin{array}{\|c} 2 \mathrm{TCLCL} \\ -50 \end{array}$ |  | $\begin{array}{\|c\|} \hline 2 \text { TCLCL } \\ -75 \end{array}$ |  | ns | $1$ |
| (46)TOLOH | Output Rise Time |  | 15 |  | 20 | ns | From 0.8 V to 2.0 V |
| (47)TOHOL | Output Fall Tıme |  | 15 |  | 20 | ns | From 2.0 V to 08 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 T2 state (8 nanoseconds into T3)
4 The 80 C 86 actively pulls the $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ pin to a logic one on the following clock low time
5 Status lines return to their inactive (logic one) state after CLK goes low and READY goes high

## Waveforms

BUS TIMING - MINIMUM MODE SYSTEM (Using 82C88)


NOTE: 1. Signals at 82 C 84 A or 82 C 88 are shown for reference only. RDY is sampled near the end of T2, T3, TW to determine if TW machine states are to be inserted.
2. The issuance of the 82 C 88 command and control signals (MRDC, $\overline{\text { MWTC }}, \overline{\text { AMWC }}, \overline{\text { IORC }}, \overline{\overline{O W C}}, \overline{\mathrm{AIOWC}}$, INTA, and DEN) lags the active high 82C88 CEN.
3. Status inactive in state just prior to T4.

## Waveforms (Continued)

BUS TIMING - MAXIMUM MODE (USING 82C88) (Continued)


NOTES 1 Signals at 82C84A or 82C88 are shown for reference only.
2 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{\text { IORC }}, \overline{\text { IOWC }}$, $\overline{A I O W C}, \overline{\operatorname{NNTA}}$ and $\overline{\mathrm{DEN}}$ ) lags the active high 82C88 CEN.
3 Status inactive in state just prior to T4
4. Cascade address is valid between first and second INTA cycles

5 Two $\overline{I N T A}$ cycles run back-to-back. The $80 C 86$ local ADDR/DATA bus is floating during both $\overline{\text { INTA }}$ cycles Control for pointer address is shown for second INTA cycle

## Waveforms (Continued)

REQUEST/GRANT SEQUENCE TIMING (MAXIMUM MODE ONLY)


NOTE: The coprocessor may not drive the busses outside the region shown without risking contention

HOLD/HOLD ACKNOWLEDGE TIMING (MINIMUM MODE ONLY)


ASYNCHRONOUS SIGNAL RECOGNITION


NOTE: Setup requirements for asynchronous signals only to guarantee recognition at next CLK

BUS LOCK SIGNAL TIMING (MAXIMUM MODE ONLY)


## Waveforms (Continued)



*Includes stay and jig capacitance
A.C. Testing Input, Output Waveform


VIL - 50\% VIL
VOL
A.C. Testing: All input signals (other than CLK) must switch between VILmax $-50 \%$ VIL and VIHmın $+20 \%$ VIH. CLK must switch between 0.4 V and VCC -0.4. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{N}$.

## Burn-In Circuits

MD80C86 CERAMIC DIP


NOTES:

1. $\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=\mathrm{OV}$
2. Input Voltage Limits (Except Clock): VIL (Maximum) $=0.4 \mathrm{~V}$ $\mathrm{VIH}($ Minimum $)=2.6 \mathrm{~V}, \mathrm{VIH}_{(\text {Clock })}=(\mathrm{VCC}-0.4 \mathrm{~V}) \mathrm{Min}$
3. $\mathrm{VCC} / 2$ is external supply set to $2.7 \mathrm{~V} \pm 10 \%$
4. VCL is generated on program card (VCC -0.65 V )
5. Pins 13-16 input sequenced instructions from internal hold devices.
6. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
7. Node (A) $=$ a $40 \mu \mathrm{~s}$ pulse every 2.56 ms

COMPONENTS:

1. $\mathrm{RI}=10 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
2. $R O=1.2 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
3. $\mathrm{RIO}=2.7 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
4. $R C=1 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
5. $\mathrm{C}=0.01 \mu \mathrm{~F}$ (Minimum)

## Burn-In Circuits (Continued)

MR80C86 CERAMIC LCC


## NOTES:

1. $\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
2. Input Voltage Limits (Except Clock):

VIL (Maximum) $=04 \mathrm{~V}$
$\mathrm{VIH}($ Minimum $\left.)=2.6 \mathrm{~V}, \mathrm{VIH}_{\text {(Clock }}\right)=(\mathrm{VCC}-0.4 \mathrm{~V}) \mathrm{Min}$
3. $\mathrm{VCC} / 2$ is external supply set to $2.7 \mathrm{~V} \pm 10 \%$
4. VCL is generated on program card (VCC -0.65 V )
5. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
6. Node (A) $=$ a $40 \mu \mathrm{~s}$ pulse every 2.56 ms

COMPONENTS:

1. $\mathrm{RI}=10 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
2. $R O=1.2 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
3. $\mathrm{RIO}=2.7 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
4. $R C=1 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
5. $\mathrm{C}=0.01 \mu \mathrm{~F}$ (Mınimum)

## Metallization Topology

DIE DIMENSIONS:
$249.2 \times 290.9 \times 19 \pm 1$ mils
METALLIZATION:
Type: Silicon - Aluminum
Thickness: $11 \mathrm{kA} \pm 2 \mathrm{kA}$
GLASSIVATION:
Type: Nitrox
Thickness: 10kA $\pm 2 k A$
DIE ATTACH:
Material: Gold - Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)

$$
\text { Ceramic LCC }-420^{\circ} \mathrm{C}(\mathrm{Max})
$$

WORST CASE CURRENT DENSITY:
$1.5 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout


| Mnemonic and Description | Instruction Code |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER |  |  |  |  |
| MOV = Move: | 76543210 | 78543210 | 76543210 | 76543210 |
| Register/Memory to/from Register | 100010 dw | mod reg r/m |  |  |
| Immediate to Register/Memory | 1100011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if w 1 |
| Immediate to Register | 1011 wreg | data | data liw 1 |  |
| Memory to Accumulator | 1010000 w | add-low | addr-high |  |
| Accumulator to Memory | 1010001 w | addr-low | addr-high |  |
| Register/Memory to Segment Register* - | 10001110 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  |
| Segment Register to Register/Memory | 10001100 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  |
| PUSH = Push: |  |  |  |  |
| Register/Memory | 11111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  |
| Register | 01010 reg |  |  |  |
| Segment Register | 000 reg 110 |  |  |  |
| POP = Pop: |  |  |  |  |
| Register/Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |
| Register | 01011 reg |  |  |  |
| Segment Register | 000 reg 111 |  |  |  |
| XCHQ $=$ Exchange: |  |  |  |  |
| Register/Memory with Register | 1000011 w | mod reg r/m |  |  |
| Register with Accumulator | 10010 reg |  |  |  |
| IN = input from: |  |  |  |  |
| Fixed Port | 1110010 w | port |  |  |
| Variable Port | 1110110 w |  |  |  |
| OUT = Output to: |  |  |  |  |
| Fixed Port | 1110011 w | port |  |  |
| Variable Port | 1110111 w |  |  |  |
| XLAT $=$ Translate Byte to AL | 11010111 |  |  |  |
| LEA = Load EA to Register | 10001101 | mod regr $/ \mathrm{m}$ |  |  |
| LDS = Load Pointer to DS | 11000101 | $\mathrm{mod} \mathrm{regr} / \mathrm{m}$ |  |  |
| LES = Load Pointer to ES | 11000100 | $\bmod \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  |
| LAHF = Load AH with Flags | 10011111 |  |  |  |
| SAHF = Store AH into Flags | 10011110 |  |  |  |
| PUSHF = Push Flags | 10011100 |  |  |  |
| POPF $=$ Pop Flags | 10011101 |  |  |  |

## INSTRUCTION SET SUMMARY (Continued)

| Mnemonic and Description | Instruction Code |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC | 76543210 | 76543210 | 76543210 | 76543210 |
| ADD = Add: |  |  |  |  |
| Reg./Memory with Register to Either | 000000 dw | $\bmod \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  |
| Immediate to Register/Memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate to Accumulator | 0000010 w | data | data if $w=1$ |  |
| ADC = Add with Carry: |  |  |  |  |
| Reg /Memory with Register to Either | 000100 dw | mod regr/m |  |  |
| Immedıate to Register/Memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate to Accumulator | 0001010 w | data | data if $w=1$ |  |
| INC = Increment: |  |  |  |  |
| Register/Memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |
| Register | 01000 reg |  |  |  |
| AAA $=$ ASCII Adjust for Add | 00110111 |  |  |  |
| DAA = Decimal Adjust for Add | 00100111 |  |  |  |
| SUB = Subtract: |  |  |  |  |
| Reg./Memory and Register to Either | 001010 dw | mod reg r/m |  |  |
| Immediate from Register/Memory | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate from Accumulator | 0010110 w | data | data if $w=1$ |  |
| SBB $=$ Subtract with Borrow |  |  |  |  |
| Reg./Memory and Register to Either | 000110 dw | mod regr $/ \mathrm{m}$ |  |  |
| Immedıate from Register/Memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate from Accumulator | 0001110 w | data | data if $w=1$ |  |
| DEC $=$ Decrement: |  |  |  |  |
| Register/Memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  |
| Register | 01001 reg |  |  |  |
| NEG = Change Sign | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  |
| CMP = Compare: |  |  |  |  |
| Register/Memory and Register | 001110 dw | mod reg r/m |  |  |
| Immediate with Register/Memory | 100000sw | $\bmod 111 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate with Accumulator | 0011110 w | data | data if $w=1$ |  |
| AAS = ASCII Adjust for Subtract | 00111111 |  |  |  |
| DAS = Decimal Adjust for Subtract | 00101111 |  |  |  |
| MUL $=$ Multiply (Unsıgned) | 1111011 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |
| IMUL = Integer Multiply (Signed) | 1111011 w | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |  |
| AAM $=$ ASCII Adjust for Multiply | 11010100 | 00001010 |  |  |
| DIV = Divide (Unsigned) | 1111011 w | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  |
| IDIV $=$ Integer Divide (Signed) | 1111011 w | $\bmod 111 \mathrm{r} / \mathrm{m}$ |  |  |
| AAD $=$ ASCII Adjust for Divide | 11010101 | 00001010 |  |  |
| CBW = Convert Byte to Word | 10011000 |  |  |  |
| CWD = Convert Word to Double Word | 10011001 |  |  |  |


| Mnemonic and Description | Instruction Code |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| LOGIC | 76543210 | 76543210 | 76543210 | 76543210 |
| NOT = Invert | 1111011 w | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  |
| SHL/SAL $=$ Shift Logical/Arithmetic Left | 110100 vw | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |
| SHR = Shift Logical Rıght | 110100 vw | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |  |
| SAR $=$ Shift Arithmetic Right | 110100 vw | $\bmod 111 \mathrm{r} / \mathrm{m}$ |  |  |
| ROL $=$ Rotate Left | 110100 vw | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |
| ROR = Rotate Right | 110100 vw | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  |
| RCL $=$ Rotate Through Carry Flag Left | 110100 vw | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  |
| RCR = Rotate Through Carry Right | 110100 Vw | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  |
| AND = And: |  |  |  |  |
| Reg./Memory and Register to Either | 001000 dw | modregr/m |  |  |
| Immediate to Register/Memory | 1000000 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ |
| Immediate to Accumulator | 0010010 w | data | data if $w=1$ |  |
| TEST = And Function to Flags, No Result: |  |  |  |  |
| Register/Memory and Register | 1000010 w | mod reg r/m |  |  |
| Immediate Data and Register/Memory | 1111011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ |
| Immediate Data and Accumulator | 1010100 w | data | data if $w=1$ |  |
| $\mathbf{O R}=\mathbf{O r}:$ |  |  |  |  |
| Reg /Memory and Register to Either | 000010 dw | mod reg r/m |  |  |
| Immediate to Register/Memory | 1000000 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ | data | data if w $=1$ |
| Immedıate to Accumulator | 0000110 w | data | data if w=1 |  |
| XOR = Exclusive or: |  |  |  |  |
| Reg./Memory and Register to Either | 001100 dw | mod reg r/m |  |  |
| Immediate to Register/Memory | 1000000 w | $\bmod 110 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{w}=1$ |
| Immediate to Accumulator | 0011010 w | data | data if $w=1$ |  |
| STRING MANIPULATION |  |  |  |  |
| REP = Repeat | 11110012 |  |  |  |
| MOVS = Move Byte/Word | 1010010 w |  |  |  |
| CMPS = Compare Byte/Word | 1010011 w |  |  |  |
| SCAS = Scan Byte/Word | 1010111 w |  |  |  |
| LODS = Load Byte/Wd to AL/AX | 1010110 w |  |  |  |
| $\mathbf{S T O S ~ = ~ S t o r ~ B y t e / W d ~ f r o m ~ A L / A ~}$ | 1010101 w |  |  |  |
| CONTROL TRANSFER |  |  |  |  |
| CALL = Call: |  |  |  |  |
| Direct Within Segment | 11101000 | disp-low | disp-high |  |
| Indirect Within Segment | 11111111 | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  |
| Direct Intersegment | 10011010 | offset-low | offset-high |  |
|  |  | seg-low | seg-high |  |
| Indirect Intersegment | 11111111 | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  |

INSTRUCTION SET SUMMARY (Continued)

| Mnemonic and Description | Instruction Code |  |  |
| :---: | :---: | :---: | :---: |
| JMP = Unconditional Jump: | 76543210 | 76543210 | 76543210 |
| Direct Within Segment | 11101001 | disp-low | disp-high |
| Direct Within Segment-Short | 11101011 | disp |  |
| Indirect Within Segment | 11111111 | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |
| Direct Intersegment | 11101010 | offsel-low | offset-high |
|  |  | seg-low | seg-high |
| Indirect Intersegment | 11111111 | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |
| RET = Return from CALL: |  |  |  |
| Within Segment | 11000011 |  |  |
| Within Seg Adding Immed to SP | 11000010 | data-low | data-high |
| Intersegment | 11001011 |  |  |
| Intersegment Adding Immediate to SP | 11001010 | data-low | data-high |
| JE/JZ = Jump on Equal/Zero | 01110100 | disp |  |
| $\text { JL/JNGE }=\underset{\text { or Equal }}{\text { Jump on Less/Not Greater }}$ | 01111100 | disp |  |
| $\begin{aligned} \text { JLE/JNG }= & \text { Jump on Less or Equal/ } \\ & \text { Not Greater } \end{aligned}$ | 01111110 | disp |  |
| $\begin{aligned} \mathrm{JB} / \mathrm{JNAE}= & \text { Jump on Below/Not Above } \\ & \text { or Equal } \end{aligned}$ | 01110010 | disp |  |
| $\begin{gathered} \text { JBE/JNA }=\begin{array}{l} \text { Jump on Below or Equal/ } \\ \\ \text { Not Above } \end{array} \end{gathered}$ | 01110110 | disp |  |
| JP/JPE = Jump on Parity/Parity Even | 01111010 | disp |  |
| JO = Jump on Overflow | 01110000 | disp |  |
| JS = Jump on Sign | 01111000 | disp |  |
| JNE/JNZ = Jump on Not Equal/Not Zero | 01110101 | disp |  |
| $\text { JNL/JGE }=\underset{\text { or Equal }}{ }$ | 01111101 | disp |  |
| JNLE/JG = Jump on Not Less or Equal/ | 01111111 | disp |  |
| $\begin{aligned} \text { JNB/JAE }= & =\begin{array}{l} \text { Jump on Not Below/Above } \\ \\ \text { or Equal } \end{array} \end{aligned}$ | 01110011 | disp |  |
| $\begin{aligned} \text { JNBE/JA } & =\underset{\text { Equal/Above }}{\text { Jump on Not Below or }} \end{aligned}$ | 01110111 | disp |  |
| JNP/JPO = Jump on Not Par/Par Odd | 01111011 | disp |  |
| JNO = Jump on Not Overflow | 01110001 | disp |  |
| JNS = Jump on Not Sign | 01111001 | disp |  |
| LOOP = Loop CX Times | 11100010 | disp |  |
| LOOPZ/LOOPE $=$ Loop While Zero/Equal | 11100001 | disp |  |
| $\begin{aligned} & \text { LOOPNZ/LOOPNE }= \text { Loop While Not } \\ & \text { Zero/Equal } \end{aligned}$ | 11100000 | disp |  |
| JCXZ = Jump on CX Zero | 11100011 | disp |  |
| INT = Interrupt |  |  |  |
| Type Specified | 11001101 | type |  |
| Type 3 | 11001100 |  |  |
| INTO = Interrupt on Overilow | 11001110 |  |  |
| IRET $=$ Interrupt Return | 11001111 |  |  |

INSTRUCTION SET SUMMARY (Continued)


## NOTES:

AL $=8$-bit accumulator
$A X=16$-bit accumulator
$C X=$ 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 instruc-
tion
if $\mathrm{mod}=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 mod $=10$ then DISP $=$ disp-high: disp-low
if $\mathrm{r} / \mathrm{m}=000$ then $E A=(B X)+(S I)+$ DISP
if $\mathrm{r} / \mathrm{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)+$ DISP
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(\mathrm{DI})+\mathrm{DISP}$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then $E A=(\mathrm{DI})+$ DISP
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 2nd byte of instruction (before data if required)
*except if mod $=00$ and $\mathrm{r} / \mathrm{m}=110$ then EA $=$ disphigh: disp-low.
*"MOV CS, REG/MEMORY not allowed.
if $\mathrm{s}: \mathrm{w}=01$ then 16 bits of immediate data form the operand.
if $s: 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 ZF FLAG. SEGMENT OVERRIDE PREFIX

$$
001 \text { reg } 110
$$

REG is assigned according to the following table:

| 16-Bit (w $=1$ ) |  | 8-Bit (w = 0) |  | Segment |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 000 | $A X$ | 000 | AL | 00 |  |
| 001 | CX | 001 | CL | 01 | CS |
| 010 | DX | 010 | DL | 10 | SS |
| 011 | BX | 011 | BL | 11 |  |
| 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:
FLAGS =
$\mathrm{X}: \mathrm{X}: \mathrm{X}: \mathrm{X}:$ (OF):(DF):(IF):(TF):(SF):(ZF):X:(AF):X:(PF):X:(CF)
Mnemonics © Intel, 1978

## Features

- Compatible with NMOS 8088
- Direct Software Compatibility with 80C86, 8086, 8088
- 8 Bit Data Bus Interface; 16 Bit Internal Architecture
- Completely Static CMOS Design
- DC.

5 MHz (80C88)

- DC.
$8 \mathrm{MHz}(80 \mathrm{C} 88-2)$
- Low Power Operation
- ICCSB $500 \mu \mathrm{~A}$ Maximum
- ICCOP
$10 \mathrm{~mA} / \mathrm{MHz}$ Maximum
- 1 Megabyte 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
- Wide Operating Temperature Ranges
- C80C88 $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I80C88 . . . . . . . . . . . . . . . . . . . . . . . . . -4000 C to $+85^{\circ} \mathrm{C}$
- M80C88. . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 80 C88 high performance $8 / 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 multiprocessing, allow user configuration to achieve the highest performance level.

Full TTL compatibility (with the exception of CLOCK) and industry-standard operation allow use of existing NMOS 8088 hardware and Harris CMOS peripherals.

Complete software compatibility with the 80C86, 8086, and 8088 microprocessors allows use of existing software in new designs.

## Ordering Information

| PACKAGE | TEMP. RANGE | 5 MHz | 8MHz |
| :---: | :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP80C88 | CP80C88-2 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP80C88 | IP80C88-2 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS80C88 | CS80C88-2 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS80C88 | IS80C88-2 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD80C88 | CD80C88-2 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID80C88 | ID80C88-2 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD80C88/B | MD80C88-2/B |
| SMD\# |  | 5962-8601601QA | - |
| LCC SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR80C88/B | MR80C88-2/B |
|  |  | 5962-8601601XA | - |

Pinouts
40 LEAD DIP $\begin{array}{cc}\text { MIN } & \text { MAX } \\ \text { MODE } & \text { MODE }\end{array}$


TOP VIEW


Functional Diagram



## Pin Description

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

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| AD7-ADO | 9-16 | I/O | ADDRESS DATA BUS: These lines constitute the time multiplexed memory/IO address ( $T 1$ ) and data ( $\mathrm{T} 2, \mathrm{~T} 3, \mathrm{Tw}$ and T4) bus. These lines are active HIGH and are held at high impedance to the last valid level during interrupt acknowledge and local bus "hold acknowledge" or "grant sequence". |
| A15-A8 | 2-8,39 | 0 | ADDRESS BUS: These lines provide address bits 8 through 15 for the entire bus cycle (T1-T4). These lines do not have to be latched by ALE to remain valid. A15-A8 are active HIGH and are held at high impedance to the last valid logic level during interrupt acknowledge and local bus "hold acknowledge" or "grant sequence". |
| A19/S6, A18/S5, A17/S4 A16/S3 | $\begin{aligned} & 35 \\ & 36 \\ & 37 \\ & 38 \end{aligned}$ | $\begin{aligned} & \mathrm{O} \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | ADDRESS/STATUS: During T1, 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 $\mathrm{T} 2, \mathrm{~T} 3$, Tw and T4. 56 is always LOW. The status of the interrupt enable flag bit (S5) is updated at the beginning of each clock cycle. S4 and S3 are encoded as shown. <br> This information indicates which segment register is presently being used for data accessing. <br> These lines are held at high impedance to the last valid logic level during local bus "hold acknowledge" or "grant sequence". |
| $\overline{\mathrm{RD}}$ | 32 | 0 | READ: Read strobe indicates that the processor is performing a memory or I/O read cycle, depending on the state of the $1 O / \bar{M}$ pin or $\overline{\mathrm{S} 2}$. This signal is used to read devices which reside on the 80 C 88 local bus. $\overline{R D}$ is active LOW during T2, T3 and Tw of any read cycle, and is guaranteed to remain HIGH in T2 until the 80C88 local bus has floated. <br> This line is held at a high impedance logic one state during "hold acknowledge" or "grant sequence". |
| READY | 22 | 1 | READY: is the acknowledgement from the addressed memory or I/O device that it will complete the data transfer. The RDY signal from memory or I/O is synchronized by the 82C84A clock generator to form READY. This signal is active HIGH. The 80C88 READY input is not synchronized. Correct operation is not guaranteed if the set up and hold times are not met. |
| INTR | 18 | 1 | INTERRUPT REQUEST: is 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 acknowlege 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 for test" 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 | NONMASKABLE INTERRUPT: is 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 transition LOW to HIGH and remain 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: is the +5 V power supply pin. $\mathrm{A} 0.1 \mu \mathrm{~F}$ capacitor between pins 20 and 40 is recommended for decoupling. |
| GND | 1,20 |  | GND: are the ground pins (both pins must be connected to system ground). A $0.1 \mu \mathrm{~F}$ capacitor between pins 1 and 20 is recommended for decoupling. |
| MN/ $\overline{M X}$ | 33 | 1 | MINIMUM/MAXIMUM: indicates the mode in which the processor is to operate. The two modes are discussed in the following sections. |

## Pin Description

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

MINIMUM MODE SYSTEM

| SYMBOL | PIN <br> NUMBER | TYPE | DESCRIPTION |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $10 / \bar{M}$ | 28 | 0 | STATUS LINE: is an inverted maximum mode $\overline{\mathbf{S 2}}$. It is used to distinguish a memory access from an I/O access. $1 O / \bar{M}$ becomes valid in the T4 preceding a bus cycle and remains valid until the final T4 of the cycle ( $I / O=\mathrm{HIGH}, \mathrm{M}=\mathrm{LOW}$ ). IO/M is held to a high impedance logic one during local bus "hold acknowledge". |  |  |  |  |
| $\overline{W R}$ | 29 | 0 | Write: strobe indicates that the processor is performing a write memory or write l/O cycle, depending on the state of the $1 O / \bar{M}$ signal. $\overline{W R}$ is active for T2, T3 and Tw of any write cycle. It is active LOW, and is held to high impedance logic one during local bus "hold acknowledge". |  |  |  |  |
| $\overline{\text { INTA }}$ | 24 | 0 | INTA: is used as a read strobe for interrupt acknowledge cycles. It is active LOW during T2, T3 and Tw of each interrupt acknowledge cycle. Note that $\overline{\text { INTA }}$ is never floated. |  |  |  |  |
| ALE | 25 | 0 | ADDRESS LATCH ENABLE: is provided by the processor to latch the address into the 82C82/82C83 address latch. It is a HIGH pulse active during clock low of T1 of any bus cycle. Note that ALE is never floated. |  |  |  |  |
| DT/ $\bar{R}$ | 27 | 0 | DATA TRANSMIT/RECEIVE: is needed in a minimum system that desires to use an 82C86/82C87 data bus transceiver. It is used to control the direction of data flow through the transceiver. Logically, $D T / \bar{R}$ is equivalent to $\bar{S} 1$ in the maximum mode, and its timing is the same as for $1 O / \bar{M}(T=H I G H$, $R=L O W$ ). This signal is held to a high impedance logic one during local bus "hold acknowledge". |  |  |  |  |
| $\overline{\text { DEN }}$ | 26 | 0 | DATA ENABLE: is provided as an output enable for the $82 \mathrm{C} 86 / 82 \mathrm{C} 87$ in a minimum system which uses the transceiver. $\overline{\mathrm{DEN}}$ is active LOW during each memory and I/O access, and for INTA cycles. For a read or $\overline{N T A}$ cycle, it is active from the middle of T2 until the middle of T4, while for a write cycle, it is active from the beginning of T2 until the middle of T4. $\overline{\mathrm{DEN}}$ is held to high impedance logic one during local bus "hold acknowledge". |  |  |  |  |
| HOLD, HLDA | $\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 acknowledged, HOLD must be active HIGH. The processor receiving the "hold" request will issue HLDA (HIGH) as an acknowledgment, in the middle of a T4 or TI 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 lowers HLDA, and when the processor needs to run another cycle, it will again drive the local bus and control lines. <br> Hold is not an asynchronous input. External synchronization should be provided if the system cannot otherwise guarantee the set up time. |  |  |  |  |
| $\overline{\mathrm{SSO}}$ | 34 | 0 | STATUS LINE: is logically equivalent to $\overline{\mathrm{SO}}$ in the maximum mode. The combination of $\overline{S S O}, 10 / \bar{M}$ and $D T / \bar{R}$ allows the system to completely decode the current bus cycle status. $\overline{\text { SSO }}$ is held to high impedance logic one during local bus "hold acknowledge". | $10 / \bar{M}$ <br> 1 <br> 1 <br> 1 <br> 1 <br> 0 <br> 0 <br> 0 <br> 0 | DT/R <br> 0 <br> 0 <br> 1 <br> 1 <br> 0 <br> 0 <br> 1 <br> 1 | $\mathbf{S S O}$ <br> 0 <br> 1 <br> 0 <br> 1 <br> 0 <br> 1 <br> 0 <br> 1 | CHARACTERISTICS <br> Interrupt Acknowledge <br> Read I/O Port <br> Write I/O Port <br> Halt <br> Code Access <br> Read Memory <br> Write Memory <br> Passive |

## Pin Description

The following pin descriptions are for the 80C88 system in maximum mode (i.e., MN/MX = GND). Only the
pin functions which are unique to maximum mode are described; all other pin functions are as described above.

## MAXIMUM MODE SYSTEM



## Functional Description

## Static Operation

All 80 C 88 circuitry is static in 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 80C88 can operate from DC to the specified upper frequency limit. The processor clock may be stoped in either state (high/low) and held there indefinitely. This type of operation is especially useful for system debug or power critical applications.

The 80C88 can be single stepped using only the CPU clock. This state can be maintained as long as is necessary. Single step clock operation allows simple interface circuitry to provide critical information for start-up.

Static design also allows very low frequency operation (as low as DC). In a power critical situation, this can provide extremely low power operation since 80C88 power dissipation is directly related to operation frequency. As the system frequency is reduced, so is the operating power until, at a DC input frequency, the power requirement is the 80 C 88 standby current.

## Internal Architecture

The internal functions of the 80C88 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 block diagram.

These units can interact directly but for the most part perform as separate asynchronous 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 4 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 1 byte in the queue, the BIU will attempt a byte 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 unrelocated 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, and stack segments of up to 64 K bytes
each, with each segment falling on 16 byte boundaries. (See Figure 1).


FIGURE 1. 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 as shown in Table A. 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.
table A

| MEMORY <br> REFERENCE <br> NEED | SEGMENT <br> REGISTER <br> USED | SEGMENT <br> SELECTION RULE |
| :--- | :--- | :--- |
| Instructions | CODE (CS) | Automatic with all instruction <br> prefetch. |
| Stack | STACK (SS) | All stack pushes and pops. <br> Memory references relative to <br> BP base register except data <br> references. |
| Local Data | DATA (DS) | Data references when: relative to <br> stack, destination of string oper- <br> ation, or explicitly overridden. |
| External Data <br> (Global) | EXTRA (ES) | Destination of string operations: <br> Explicitly selected using a <br> segment override. |

Word (16 bit) operands can be located on even or odd address boundaries. For address and data operands, the least significant byte of the word is stored in the lower valued address location and the most significant byte in the next higher address location.

The BIU will automatically execute two fetch or write cycles for 16 bit operands.

Certain locations in memory are reserved for specific CPU operations. (See Figure 2). Locations from addresses FFFFFOH through FFFFFH are reserved for operations including a jump to the initial system initialization routine. Following RESET, the CPU will always begin execution at location FFFFOH where the jump must be located. Locations 00000 H through 003FFH are reserved for interrupt operations. Each of the 256 possible interrupt service routines is accessed through its own pair of 16 bit pointers - segment address pointer and offset address pointer. The first pointer, used as the offset address, is loaded into the IP, and the second pointer, which designates the base address, is loaded into the CS. At this point program control is transferred to the interrupt routine. The pointer elements are assumed to have been stored at their respective places in reserved memory prior to the occurrence of interrupts.

## Minimum and Maximum Modes

The requirements for supporting minimum and maximum 80 C 88 systems are sufficiently different that they cannot be done efficiently with 40 uniquely defined pins. Consequently, the $80 C 88$ 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 80 C 88 defines pins 24 through 31 and 34 in maximum mode. When the MN/MX pin is strapped to VCC, the $80 C 88$ generates bus control signals itself on pins 24 through 31 and 34.

The minimum mode 80C88 can be used with either a multiplexed or demultiplexed bus. This architecture provides the 80 C 88 processing power in a highly integrated form.


FIGURE 2. RESERVED MEMORY LOCATIONS
The demultiplexed mode requires one latch (for 64 K addressability) or two latches (for a full megabyte of addressing). An 82C86 or 82C87 transceiver can also be used if data bus buffering is required. (See Figure 3). The 80 C 88 provides $\overline{\mathrm{DEN}}$ and $\mathrm{DT} / \overline{\mathrm{R}}$ to control the transceiver, and ALE to latch the addresses. This configuration of the minimum mode provides the standard demultiplexed bus structure with heavy bus buffering and relaxed bus timing requirements.


FIGURE 3. DEMULTIPLEXED BUS CONFIGURATION

The maximum mode employs the 82 C 88 bus controller (See Figure 4). The 82C88 decodes status lines S0, S1 and S 2 , and provides the system with all bus control signals. Moving the bus control to the 82 C 88 provides better source and sink current capability to the control lines, and frees the
$80 C 88$ pins for extended large system features. Hardware lock, queue status, and two request/grant interfaces are provided by the 80 C 88 in maximum mode. These features allow coprocessors in local bus and remote bus configurations.


FIGURE 4. FULLY BUFFERED SYSTEM USING BUS CONTROLLER

## Bus Operation

The 80C88 address/data bus is broken into three parts: the lower eight address/data bits (ADO-AD7), the middle eight address bits (A8-A15), and the upper four address bits (A16-A19). The address/data bits and the highest four adddress bits are time multiplexed. This technique provides the most efficient use of pins on the processor, permitting the use of a standard 40 lead package. The middle eight address bits are not multiplexed, i.e., they remain valid throughout each bus cycle. In addition, the bus can be demultiplexed at the processor with a single address latch if a standard, nonmultiplexed bus is desired for the system.

Each processor bus cycle consists of at least four CLK cycles. These are referred to as T1, T2, T3 and T4. (See Figure 5). The address is emitted from the processor during

T1 and data transfer occurs on the bus during T3 and T4. T2 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 T3 and T4. Each inserted "wait" state is of the same duration as a CLK cycle. Periods can occur between 80C88 driven bus cycles. These are referred to as "idle" states (Ti), or inactive CLK cycles. The processor uses these cycles for internal housekeeping.

During T1 of any bus cycle, the ALE (Address latch enable) signal is emitted (by either the processor or the 82C88 bus controller, depending on the MN/MX strap). At the trailing edge of this pulse, a valid address and certain status information for the cycle may be latched.


FIGURE 5. BASIC SYSTEM TIMING

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

TABLE B.

| $\overline{\mathbf{S 2}}$ | $\overline{\mathbf{S 1}}$ | $\overline{\mathbf{S 0}}$ | CHARACTERISTICS |
| :--- | :---: | :---: | :--- |
| 0 | 0 | 0 | Interrupt Acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| 1 | 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) |

Status bits S3 through S6 are multiplexed with high order address bits and are therefore valid during T2 through T4. S3 and S4 indicate which segment register was used for this bus cycle in forming the address according to Table C .

S5 is a reflection of the PSW interrupt enable bit. S6 is always equal to 0 .
table C.

| S4 | S3 | CHARACTERISTICs |
| :---: | :---: | :--- |
| 0 | 0 | Alternate Data (Extra Segment) |
| 0 | 1 | Stack |
| 1 | 0 | Code or None |
| 1 | 1 | Data |

## I/O Addressing

In the 80C88, I/O operations can address up to a maximum of $64 \mathrm{~K} \mathrm{I/O} \mathrm{registers} .\mathrm{The} \mathrm{I/O} \mathrm{address} \mathrm{appears} \mathrm{in} \mathrm{the} \mathrm{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 I/O byte locations in page 0 of the I/O address space. I/O ports are addressed in the same manner as memory locations.
Designers familiar with the 8085 or upgrading an 8085 design should note that the 8085 addresses I/O with an 8 bit address on both halves of the 16 bit address bus. The 80 C 88 uses a full 16 bit address on its lower 16 address lines.

## External Interface

## Processor Reset and Initialization

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The 80 C 88 RESET is required to be HIGH for greater than four clock cycles. The 80C88 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 for approximately 7 clock cycles. After this interval the 80C88 operates normally, beginning with the instruction in absolute location FFFFOH (see Figure 2). 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}$ after power up, to allow complete initialization of the 80 C 88 .

NMI will not be recognized if 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 and to eliminate the need for pull-up/ down resistors, "bus-hold" circuitry has been used on 80 C 88 pins 2-16, 26-32 and 34-39 (see Figure 6a and 6b). These circuits maintain a valid logic state if no driving source is present (i.e., an unconnected pin or a driving source which goes to a high impedance state).
To override the "bus hold" circuits, an external driver must be capable of supplying $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. 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 instruc-
tion set description. Hardware interrupts can be classified as nonmaskable 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 (see Figure 2), 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.

## Non-maskable Interrupt (NMI)

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

NMI is required to have a duration in the HIGH state of greater than two clock cycles, but is not required to be synchronized to the clock. Any high going transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves (2 bytes in the case of word moves) of a block type 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 high-going 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.


FIGURE 6A. BUS HOLD CIRCUITRY PIN 2-16, 35-39


FIGURE 6B. BUS HOLD CIRCUITRY PIN 26-32, 34

## Maskable Interrupt (INTR)

The 80C88 provides a single interrupt request input (INTR) which can be masked internally by software with the resetting of the interrupt enable (IF) flag 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 block type instruction. INTR may be removed anytime after the falling edge of the first $\overline{I N T A}$ signal. During 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). The FLAGS register, which is automatically pushed onto the stack, reflects the state of the processor prior to the interrupt. The enable bit will be zero until the old FLAGS register is restored, unless specifically set by an instruction.

During the response sequence (see Figure 7), the processor executes two successive (back-to-back) interrupt acknowledge cycles. The 80 C 88 emits the $\overline{\mathrm{LOCK}}$ signal (maximum mode only) from T2 of the first bus cycle until T2 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 fetched from the external interrupt system (e.g., 82C59A PIC) which identifies the source (type) of the interrupt. This byte is multiplied by four and used as a pointer into the interrupt vector lookup table.

An INTR signal left HIGH will be continually responded to within the limitations of the enable bit and sample period. INTR may be removed anytime after the falling edge of the first INTA signal. 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 ALE, delayed by one clock cycle, to allow the system to latch the halt status. Halt status is available on $10 / \bar{M}, D T / \bar{R}$, and $\overline{S S O}$. In maximum mode, the processor issues appropriate HALT status on $\overline{\mathrm{S} 2}$,
$\overline{\mathrm{S} 1}$ and $\overline{\mathrm{So}}$, and the $82 \mathrm{C88}$ bus controller issues one ALE. The 80 C 88 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 at the end of the local bus hold. An interrupt request or RESET will force the 80 C 88 out of the HALT state.

## Read/Modify/Write (Semaphore) Operations Via $\overline{\text { LOCK }}$

The $\overline{\text { LOCK }}$ status information is provided by the processor when consecutive bus cycles are required during the execution of an instruction. This allows the processor to perform read/modify/write operations on memory (via the "exchange register with memory" instruction), without another system bus master receiving intervening memory cycles. This is useful in multiprocessor system configurations to accomplish "test and set lock" operations. The $\overline{\text { LOCK }}$ signal is activated (LOW) in the clock cycle following decoding of the $\overline{\text { LOCK }}$ prefix instruction. It is deactivated at the end of the last bus cycle of the instruction following the $\overline{\text { LOCK }}$ prefix. While $\overline{\text { LOCK }}$ is active, a request on a $\overline{R Q} / \overline{G T}$ pin will be recorded, and then honored at the end of the $\overline{\text { LOCK. }}$

## External Synchronization Via TEST

As an alternative to interrupts, the 80C88 provides a single software-testable input pin (TEST). This input is utilized by executing a WAIT instruction. The single WAIT instruction is repeatedly executed until the TEST input goes active (LOW). The execution of WAIT does not consume bus cycles once the queue is full.
If a local bus request occurs during WAIT execution, the 80 C 88 three-states all output drivers while inputs and I/O pins are held at valid logic levels by internal bus-hold circuits. If interrupts are enabled, the 80C88 will recognize interrupts and process them when it regains control of the bus.

## Basic System Timing

In minimum mode, the MN/ $\overline{M X}$ pin is strapped to VCC and the processor emits bus control signals ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, 10 / \overline{\mathrm{M}}$, 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 82C88 bus controller uses to generate MULTIBUS ${ }^{m}$ compatible bus control signals.


FIGURE 7. INTERRUPT ACKNOWLEDGE SEQUENCE

## System Timing - Minimum System

The read cycle begins in T1 with the assertion of the address latch enable (ALE) signal (See Figure 5). The trailing (low going) edge of this signal is used to latch the address information, which is valid on the address data bus (ADO-AD7) at this time, into the 82C82/82C83 latch. Address lines A8 through A15 do not need to be latched because they remain valid throughout the bus cycle. From T1 to T4 the $10 / \bar{M}$ signal indicates a memory or I/O operation. At T2 the address is removed from the address data bus and the bus is held at the last valid logic state by internal bus-hold devices. The read control signal is also asserted at T2. 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 three-state its bus drivers. If a transceiver $(82 \mathrm{C} 86 / 82 \mathrm{C} 87)$ is required to buffer the local bus, signals DT//R and $\overline{\mathrm{DEN}}$ are provided by the 80 C 88.
A write cycle also begins with the assertion of ALE and the emission of the address. The $10 / \bar{M}$ signal is again asserted to indicate a memory or I/O write operation. In T2, immediately following the address emission, the processor emits the data to be written into the addressed location. This data remains valid until at least the middle of T4. During T2, T3, and Tw, the processor asserts the write control signal. The write ( $\overline{\mathrm{WR}}$ ) signal becomes active at the beginning of T2, as opposed to the read, which is delayed somewhat into T2 to provide time for output drivers to become inactive.
The basic difference between the interrupt acknowledge cycle and a read cycle is that the interrupt acknowledge
( $\overline{\mathrm{NTA}}$ ) signal is asserted in place of the read ( $\overline{\mathrm{RD}}$ ) signal and the address bus is held at the last valid logic state by internal bus-hold devices (see Figure 6). In the second of two successive INTA cycles, a byte of information is read from the data bus, 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 the interrupt vector lookup table, as described earlier.

## Bus Timing - Medium Complexity Systems

For medium complexity systems, the $M N / \overline{M X}$ pin is connected to GND and the 82 C 88 bus controller is added to the system, as well as an $82 \mathrm{C} 82 / 82 \mathrm{C} 83$ latch for latching the system address, and an 82C86/82C87 transceiver to allow for bus loading greater than the 80 C 88 is capable of handling (see Figure 8). Signals ALE, $\overline{\mathrm{DEN}}$, and DT/R are generated by the 82C88 instead of the processor in this configuration, although their timing remains relatively the same. The 80C88 status outputs ( $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}$ and $\overline{\mathrm{SO}}$ ) provide type of cycle information and become 82C88 inputs. This bus cycle information specifies read (code, data or I/O), write (data or I/O), interrupt acknowledge, or software halt. The 82C88 thus issues control signals specifying memory read or write, I/O read or write, or interrupt acknowledge. 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 as read strobes, and hence, data is not valid at the leading edge of write. The 82C86/82C87 tranceiver receives the usual T and $\overline{\mathrm{OE}}$ inputs from the $82 \mathrm{C} 88 \mathrm{DT} / \overline{\mathrm{R}}$ and $\overline{\mathrm{DEN}}$ outputs.


FIGURE 8. MEDIUM COMPLEXITY SYSTEM TIMING

The pointer into the interrupt vector table, which is passed during the second INTA cycle, can derive 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, the 82C86/82C87 transceiver must be disabled when reading from the master 82C59A during the interrupt acknowledge sequence and software "poll".

## The 80C88 Compared To The 80C86

The 80 C 88 CPU is an 8 bit processor designed around the 8086 internal structure. Most internal functions of the 80 C 88 are identical to the equivalent 80 C 86 functions. The 80 C 88 handles the external bus the same way the 80C86 does with the distinction of handling only 8 bits at a time. Sixteen-bit operands are fetched or written in two consecutive bus cycles. Both processors will appear identical to the software engineer, with the exception of execution time. The internal register structure is identical and all instructions have the same end result. Internally, there are three differences between the $80 C 88$ and the $80 C 86$. All changes are related to the 8 bit bus interface.

- The queue length is 4 bytes in the 80 C 88 , whereas the 80C86 queue contains 6 bytes, or three words. The queue was shortened to prevent overuse of the bus by the BIU when prefetching instructions. This was required because of the additional time necesssary to fetch instructions 8 bits at a time.
- To further optimize the queue, the prefetching algorithm was changed. The 80 C 88 BIU will fetch a new instruction to load into the queue each time there is a 1 byte space available in the queue. The 80 C 86 waits until a 2 byte space is available.
- The internal execution time of the instruction set is affected by the 8 bit interface. All 16 bit fetches and writes
from/to memory take an additional four clock cycles. The CPU is also limited by the speed of instruction fetches. This latter problem only occurs when a series of simple operations occur. When the more sophisticated instructions of the 80 C 88 are being used, the queue has time to fill and the execution proceeds as fast as the execution unit will allow.

The 80 C 88 and 80 C 86 are completely software compatible by virtue of their identical execution units. Software that is system dependent may not be completely transferable, but software that is not system dependent will operate equally as well on an 80 C 88 or an 80 C 86 .
The hardware interface of the 80 C 88 contains the major differences between the two CPUs. The pin assignments are nearly identical, however, with the following functional changes:

- A8-A15: These pins are only address outputs on the 80C88. These address lines are latched internally and remain valid throughout a bus cycle in a manner similar to the 8085 upper address lines.
- $\overline{\mathrm{BHE}}$ has no meaning on the 80 C 88 and has been eliminated.
- $\overline{\mathrm{SSO}}$ provides the $\overline{\mathrm{SO}}$ status information in the minimum mode. This output occurs on pin 34 in minimum mode only. DT/ $\overline{\mathrm{R}}, \mathrm{IO} / \overline{\mathrm{M}}$ and $\overline{\mathrm{SSO}}$ provide the complete bus status in minimum mode.
- $10 / \bar{M}$ has been inverted to be compatible with the 8085 bus structure.
- ALE is delayed by one clock cycle in the minimum mode when entering HALT, to allow the status to be latched with ALE.

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output or I/O Voltage Applied | GND-0.5V to VCC+0.5V |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $\ldots .+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10 sec ) | .$+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

## Absolute Maximum Ratings


Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $27.5^{\circ} \mathrm{C} / \mathrm{W}$ | $5.9{ }^{\circ} \mathrm{C}$ |
| Ceramic LCC Package | $62.2{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $8.6^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | .1.82 |
| Ceramic LCC Package |  | 806m |
| ate Coun |  |  |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

| Operating Voltage Range | +4.5 V to +5.5 V | Operating Temperature Range |  |
| :---: | :---: | :---: | :---: |
| M80C88-2 Only | +4.75 V to +5.25 V | C80C88/-2 . | . $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
|  |  | 180C88/-2 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
|  |  | M80C88/-2. | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

D.C. Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 80 \mathrm{C} 88)(\mathrm{C} 80 \mathrm{C} 88-2)$
$V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=-40{ }^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ ( 180 C 88 ) ( $180 \mathrm{C} 88-2$ )
$V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C88)
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C88-2)

| 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 { C80C88, I80C88 (Note 4) } \\ & \text { M80C88 (Note 4) } \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 \\ \operatorname{VCC}-0.4 \end{gathered}$ |  | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & 10 H=-2.5 \mathrm{~mA} \\ & 1 O H=-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | Output Low Voltage |  | 0.4 | V | $1 \mathrm{OL}=+2.5 \mathrm{~mA}$ |
| 11 | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | VIN $=0 \mathrm{~V}$ or VCC, DIP Pins 17-19, 21-23, 33 |
| IBHH | Input Current Bus Hold High | -40 | -400 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN = 3.0V } \\ & \text { (Note 1) } \end{aligned}$ |
| IBHL | Input current Bus Hold Low | 40 | 400 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VIN}=0.8 \mathrm{~V} \\ & \text { (Note 2) } \end{aligned}$ |
| 10 | Output Leakage Current |  | -10.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=0 \mathrm{~V}$ (Note 5) |
| ICCSB | Standby Power Supply Current |  | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} \\ & \text { (Note 3) } \end{aligned}$ |
| ICCOP | Operatıng Power Supply Current |  | 10 | $\mathrm{mA} / \mathrm{MHz}$ | $\begin{aligned} & \text { Freq = max, } \\ & \text { VIN = GND or VCC, } \\ & \text { Outputs Open } \end{aligned}$ |

NOTES 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 2 IBHL should be measured after lowering VIN to GND and then raising to 08 V on the following pins 2-16, 35-39 3 ICCSB tested during clock high time after HALT instruction execution VIN = VCC or GND VCC $=55 \mathrm{~V}$ outputs unloaded $4 \mathrm{MN} / \mathrm{MX}$ is a strap option and should be held to VCC or GND
5 IO should be measured by putting the pin in a high impedance state and then driving $V_{\text {OUT }}$ to GND on the following pins 26-29 and 32

Capacitance $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | 25 | pF | FREQ $=1 \mathrm{MHz}$ <br> All measurements are <br> referenced to device GND |
| COUT | Output Capacitance |  |  | pF |
| $\mathrm{CI} / \mathrm{O}$ | I/O Capacitance | 25 | pF |  |

A.C. Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=00 \mathrm{C}$ to +700 C (Cl C88) (C80C88-2)
$V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{A}=-40{ }^{\circ} \mathrm{C}$ to $+850^{\circ} \mathrm{C}(180 \mathrm{C} 88)(180 \mathrm{C} 88-2)$
$\mathrm{V}_{\mathrm{C}} \mathrm{C}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C88)
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C88-2)

## MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| SYMBOL | PARAMETER | 80C88-2 |  | $80 \mathrm{C88}$ |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) TCLCL | CLK Cycle Period | 125 |  | 200 |  | ns |  |
| (2) TCLCH | CLK Low Time | 68 |  | 118 |  | ns |  |
| (3) TCHCL | CLK High Time | 44 |  | 69 |  | ns |  |
| (4) $\mathrm{TCH1CH} 2$ | CLK Rise Time |  | 10 |  | 10 | ns | From 1.0V to 3.5V |
| (5)TCL2CL1 | CLK Fall Tıme |  | 10 |  | 10 | ns | From 3.5V to 1.0 V |
| (6) TDVCL | Data in Setup Time | 20 |  | 30 |  | ns |  |
| (7) TCLDX1 | Data in Hold Time | 10 |  | 10 |  | ns |  |
| (8) TR1VCL | RDY Setup Time into 82C84A (See Notes 1, 2) | 35 |  | 35 |  | ns |  |
| (9)TCLR1X | RDY Hold Time into 82C84A (See Notes 1, 2) | 0 |  | 0 |  | ns |  |
| $\underset{(10)}{\text { TRYHCH }}$ | READY Setup Time into 80C88 | 68 |  | 118 |  | ns |  |
| TCHRYX <br> (11) | READY Hold Time into 80C88 | 20 |  | 30 |  | ns |  |
| $\begin{gathered} \text { TRYLCL } \end{gathered}$ | READY Inactive to CLK (See Note 3) | -8 |  | -8 |  | ns |  |
| (13)THVCH | HOLD Setup Time | 20 |  | 35 |  | ns |  |
| TINVCH <br> (14) | INTR, NMI, TEST Setup Time (See Note 2) | 15 |  | 30 |  | ns |  |
| (15) TILIH | Input Rise Time (Except CLK) |  | 15 |  | 15 | ns | From 0.8 V to 2.0 V |
| (16) TIHIL | Input Fall Time (Except CLK) |  | 15 |  | 15 | ns | From 2.0 V to 0.8 V |

A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C80C88) (C80C88-2)
$V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ ( 180 C 88 ) ( $180 \mathrm{C} 88-2$ )
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C88)
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C88-2)

## MINIMUM COMPLEXITY SYSTEM TIMING RESPONSES

| SYMBOL | PARAMETER | MIN | 80C88-2 |  | 80 C 88 |  | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MAX | MIN | MAX | UNITS |  |
| (17)TCLAV | Address Valıd Delay | 10 | 60 | 10 | 110 | ns | $C_{L}=100 \mathrm{pF}$ for all 80C88 Outputs in addition to internal loads |
| (18)TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| (19)TCLAZ | Address Float Delay | TCLAX | 50 | TCLAX | 80 | ns |  |
| (20)TCHSZ | Status Float Delay |  | 50 |  | 80 | ns |  |
| (21)TCHSV | Status Active Delay | 10 | 60 | 10 | 110 | ns |  |
| (22) TLHLL | ALE WIdth | TCLCH-10 |  | TCLCH-20 |  | ns |  |
| (23)TCLLH | ALE Active Delay |  | 50 |  | 80 | ns |  |
| (24)TCHLL | ALE Inactive Delay |  | 55 |  | 85 | ns |  |
| (25) TLLAX | Address Hold Time to ALE Inactive | TCHCL-10 |  | TCHCL-10 |  | ns |  |
| (26)TCLDV | Data Valıd Delay | 10 | 60 | 10 | 110 | ns |  |
| (27) TCLDX2 | Data Hold Time | 10 |  | 10 |  | ns |  |
| $\underset{(28)}{\text { TWHDX }}$ | Data Hold Time After WR | TCLCL-30 |  | TCLCL-30 |  | ns |  |
| (29)TCVCTV | Control Active Delay 1 | 10 | 70 | 10 | 110 | ns |  |
| (30)TCHCTV | Control Active Delay 2 | 10 | 60 | 10 | 110 | ns |  |
| (31)TCVCTX | Control Inactive Delay | 10 | 70 | 10 | 110 | ns |  |
| (32)TAZRL | Address Float to READ Active | 0 |  | 0 |  | ns |  |
| (33)TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 100 | 10 | 165 | ns |  |
| (34)TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 80 | 10 | 150 | ns |  |
| (35)TRHAV | $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-40 |  | TCLCL-45 |  | ns |  |
| (36)TCLHAV | HLDA Valid Delay | 10 | 100 | 10 | 160 | ns |  |
| (37)TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-50 |  | 2TCLCL-75 |  | ns |  |
| (38)TWLWH | $\overline{\text { WR Width }}$ | 2TCLCL-40 |  | 2TCLCL-60 |  | ns |  |
| (39) TAVAL | Address Valid to ALE Low | TCLCH-40 |  | TCLCH-60 |  | ns |  |
| (40)TOLOH | Output Rise Tıme |  | 15 |  | 15 | ns | From 08 V to 2.0 V |
| (41)TOHOL | Output Fall Tıme |  | 15 |  | 15 | ns | From 20 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 clock
3 Applies only to T2 state (8 nanoseconds into T3)

## Waveforms

BUS TIMING - MINIMUM MODE SYSTEM


NOTES: 1. RDY is sampled near the end of $T 2, T 3, T w$ to determine if $T w$ machine states are to be inserted.
2. Signals at 82C84A are shown for reference only.

## Waveforms (Continued)

BUS TIMING - MINIMUM MODE SYSTEM (Continued)


NOTES: 1. Two $\overline{\text { INTA }}$ cycles run back-to-back. The $80 \mathrm{C88}$ local ADDR/DATA bus is floating during both $\overline{\mathbb{N T A}}$ cycles. Control Signals are shown for the second INTA cycle.
2. Signals at 82 C 84 A are shown for reference only.

$$
\begin{aligned}
& \text { A.C. Electrical Specifications } V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; T_{A}=0{ }^{\circ} \mathrm{C} \text { to }+70{ }^{\circ} \mathrm{C}(\mathrm{C} 80 \mathrm{C} 88)(\mathrm{C} 80 \mathrm{C} 88-2) \\
& \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(180 \mathrm{CB88})(\mathrm{I} 80 \mathrm{C} 88-2) \\
& \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-550^{\mathrm{C}} \text { to }+1250^{\circ} \mathrm{C}(\mathrm{M} 80 \mathrm{C} 88) \\
& \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to }+125{ }^{\circ} \mathrm{C}(\mathrm{M} 80 \mathrm{C} 88-2)
\end{aligned}
$$

## MAX MODE SYSTEM (USING $82 C 88$ BUS CONTROLLER) TIMING REQUIREMENTS

| SYMBOL | PARAMETER | 80C88-2 |  | $80 \mathrm{C88}$ |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) TCLCL | CLK Cycle Period | 125 |  | 200 |  | ns |  |
| (2) TCLCH | CLK Low Time | 68 |  | 118 |  | ns |  |
| (3) TCHCL | CLK High Time | 44 |  | 69 |  | ns |  |
| (4) TCH 1 CH 2 | CLK Rise Time |  | 10 |  | 10 | ns | From 1.0V to 3.5 V |
| (5) ${ }^{\text {TCL2CL1 }}$ | CLK Fall Time |  | 10 |  | 10 | ns | From 3.5 V to 1.0 V |
| (6) TDVCL | Data in Setup Time | 20 |  | 30 |  | ns |  |
| (7) TCLDX1 | Data in Hold Time | 10 |  | 10 |  | ns |  |
| (8)TR1VCL | RDY Setup Time into 82 C 84 (See Notes 1, 2) | 35 |  | 35 |  | ns |  |
| (9)TCLR1X | RDY Hold Time into 82 C 84 (See Notes 1, 2) | 0 |  | 0 |  | ns |  |
| (10)TRYHCH | READY Setup Time into 80C88 | 68 |  | 118 |  | ns |  |
| (11)TCHRYX | $\begin{aligned} & \text { READY Hold Time } \\ & \text { into } 80 \mathrm{C} 88 \\ & \hline \end{aligned}$ | 20 |  | 30 |  | ns |  |
| (12)TRYLCL | READY Inactive to CLK (See Note 3) | -8 |  | -8 |  | ns |  |
| (13)TINVCH | Setup Time for Recognition (INTR, NMI, TEST) (See Note 2) | 15 |  | 30 |  | ns |  |
| (14)TGVCH | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | 15 |  | 30 |  | ns |  |
| (15)TCHGX | $\overline{\mathrm{RQ}}$ Hold Time into 80 C 88 (See Note 4) | 30 | TCHCL + 10 | 40 | TCHCL + 10 | ns |  |
| (16) TILIH | Input Rise Time (Except CLK) |  | 15 |  | 15 | ns | From 08 V to 2.0 V |
| (17) TIHIL | input Fall Time (Except CLK) |  | 15 |  | 15 | ns | From 2.0 V to 0.8 V |

A.C. Electrical Specifications $V_{C C}=50 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C80C88) (C80C88-2)
$V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+850^{\circ} \mathrm{C}$ ( 180 C 88 ) ( $180 \mathrm{C} 88-2$ )
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125{ }^{\circ} \mathrm{C}$ (M80C88)
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M80C88-2)
MAX MODE SYSTEM (USING $82 C 88$ BUS CONTROLLER) TIMING RESPONSES

| SYMBOL | PARAMETER | 80C88-2 |  | 80 C 88 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (18)TCLML | Command Active Delay (See Note 1) | 5 | 35 | 5 | 35 | ns |  |
| (19)TCLMH | Command Inactive Delay (See Note 1) | 5 | 35 | 5 | 35 | ns |  |
| (20) ${ }^{\text {TRYHSH }}$ | READY Active to Status Passive (See Notes 3, 5) |  | 65 |  | 110 | ns |  |
| (21)TCHSV | Status Active Delay | 10 | 60 | 10 | 110 | ns |  |
| (22)TCLSH | Status Inactive Delay (See Note 5) | 10 | 70 | 10 | 130 | ns |  |
| (23) TCLAV | Address Valıd Delay | 10 | 60 | 10 | 110 | ns |  |
| (24)TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| (25) TCLAZ | Address Float Delay | TCLAX | 50 | TCLAX | 80 | ns |  |
| (26)TCHSZ | Status Float Delay |  | 50 |  | 80 | ns |  |
| (27)TSVLH | Status Valid to ALE High (See Note 1) |  | 20 |  | 20 | ns |  |
| $\begin{array}{\|l} \mathbf{n}^{\text {T }} \text { TSVMCH } \\ \hline \end{array}$ | Status Valid to MCE High (See Note 1) |  | 30 |  | 30 | ns |  |
| (29) TCLLH | CLK Low to ALE Valid (See Note 1) |  | 20 |  | 20 | ns |  |
| (30)TCLMCH | CLK Low to MCE High (See Note 1) |  | 25 |  | 25 | ns |  |
| (31)TCHLL | ALE Inactive Delay (See Note 1) | 4 | 18 | 4 | 18 | ns |  |
| ${ }_{(32)^{\text {TCLMCL }}}$ | MCE Inactive Delay (See Note 1) |  | 15 |  | 15 | ns | $C_{L}=100 \mathrm{pF}$ for all 80C88 Outputs in |
| (33)TCLDV | Data Valıd Delay | 10 | 60 | 10 | 110 | ns | addition to internal loads |
| (34)TCLDX2 | Data Hold Time | 10 |  | 10 |  | ns |  |
| (35)TCVNV | Control Active Delav (See Note 1) | 5 | 45 | 5 | 45 | ns |  |
| (36)TCVNX | Control Inactıve Delay (See Note 1) | 10 | 45 | 10 | 45 | ns |  |
| (37) TAZRL | Address Float to Read Active | 0 |  | 0 |  | ns |  |
| (38)TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 100 | 10 | 165 | ns |  |
| (39)TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 80 | 10 | 150 | ns |  |
| (40)TRHAV | $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-40 |  | TCLCL-45 |  | ns |  |
| (41)TCHDTL | Direction Control Active Delay (See Note 1) |  | 50 |  | 50 | ns |  |
| (42)TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 |  | 30 | ns |  |
| (43)TCLGL | $\overline{\mathrm{GT}}$ Active Delay | 0 | 50 | 0 | 85 | ns |  |
| (44)TCLGH | $\overline{\mathrm{GT}}$ Inactive Delay | 0 | 50 | 0 | 85 | ns |  |
| (45)TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-50 |  | 2TCLCL-75 |  | ns | 1 |
| $(46){ }^{\text {TOLOH }}$ | Output Rise Time |  | 15 |  | 15 | ns | From 0.8V to 2.0 V |
| (47) TOHOL | Output Fall Time |  | 15 |  | 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 clock
3. Applies only to T2 state (8 nanoseconds into T3)

4 The 80 C 88 actively pulls the $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ pin to a logic one on the following clock low tıme.
5 Status lines return to their inactive (logic one) state after CLK goes low and READY goes high.

## Waveforms

BUS TIMING - MAXIMUM MODE (USING 82C88)


NOTES. 1 RDY is sampled near the end of T2, T3, Tw to determine if Tw machine states are to be inserted
2 Signals at 82C84A or 82C88 are shown for reference only.
3 Status inactive in state fust prior to T4.
4 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{\text { IORC }}, \overline{\text { IOWC }}, \overline{\mathrm{AIOWC}}$, $\overline{\text { INTA }}$ and $\overline{\text { DEN }}$ ) lags the active high 82 C 88 CEN

## Waveforms (Continued)

BUS TIMING - MAXIMUM MODE SYSTEM (USING 82C88) (Continued)


## Waveforms (Continued)

REQUEST/GRANT SEQUENCE TIMING (MAXIMUM MODE ONLY)


NOTE: The coprocessor may not drive the busses outside the region shown without risking contention

HOLD/HOLD ACKNOWLEDGE TIMING (MINIMUM MODE ONLY)


NOTE: Setup requirements for asynchronous signals only to guarantee recognition at next CLK

ASYNCHRONOUS SIGNAL RECOGNITION


NOTE: Setup requirements for asynchronous signals only to guarantee recognition at next CLK

BUS LOCK SIGNAL TIMING (MAXIMUM MODE ONLY)


## Waveforms (Continued)

RESET TIMING


## A.C. Test Circuit

OUTPUT FROM
DEVICE UNDER TEST
*Includes stay and jig capacitance
A.C. Testing Input, Output Waveform


## 3



NOTES:

1. $\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
2. Input Voltage Limits (Except Clock):

VIL (Maximum) $=0.4 \mathrm{~V}$
$\mathrm{VIH}($ Minimum $)=2.6 \mathrm{~V}, \mathrm{VIH}_{\text {(Clock) }}=(\mathrm{VCC}-0.4 \mathrm{~V}) \mathrm{Min}$
3. $\mathrm{VCC} / 2$ is external supply set to $2.7 \mathrm{~V} \pm 10 \%$
4. VCL is generated on program card (VCC -0.65 V )
5. Pins 13-16 input sequenced instructions from internal hold devices,

MPONENTS:

1. $\mathrm{RI}=10 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
(DIP Only).
2. $R O=12 k \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
3. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
4. $\mathrm{RIO}=2.7 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
5. Node (A) $=\mathrm{a} 40 \mu \mathrm{~s}$ pulse every 2.56 ms
6. $R C=1 \mathrm{k} \Omega \pm 5 \%, 1 / 4 \mathrm{~W}$
7. $\mathrm{C}=0.01 \mu \mathrm{~F}$ (Minimum)

## Metallization Topology

DIE DIMENSIONS:
$249.2 \times 290.9 \times 19 \pm 1$ mils
METALLIZATION:
Type: Silicon - Aluminum
Thickness: $11 \mathrm{k} \AA \pm 2 k \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold - Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)

$$
\text { Ceramic LCC }-420^{\circ} \mathrm{C}(\mathrm{Max})
$$

WORST CASE CURRENT DENSITY:
$1.5 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout
$80 C 88$


## Instruction Set Summary

| Mnemonic and Description | Instruction Code |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER |  |  |  |  |
| MOV = Move: | 76543210 | 76543210 | 76543210 | 76543210 |
| Register/Memory to/from Register | 100010 dw | mod reg r/m |  |  |
| Immediate to Register/Memory | 1100011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if w 1 |
| Immediate to Register | 1011 wreg | data | data if w 1 |  |
| Memory to Accumulator | 1010000 w | add-low | addr-high |  |
| Accumulator to Memory | 1010001 w | addr-low | addr-high |  |
| Register/Memory to Segment Register** | 10001110 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  |
| Segment Register to Register/Memory | 10001100 | mod 0 reg r/m |  |  |
| PUSH = Push: |  |  |  |  |
| Register/Memory | 11111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  |
| Register | 01010 reg |  |  |  |
| Segment Register | 000 reg 110 |  |  |  |
| POP = Pop: |  |  |  |  |
| Register/Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |
| Register | 01011 reg |  |  |  |
| Segment Register | 000 reg 111 |  |  |  |
| XCHG = Exchange: |  |  |  |  |
| Register/Memory with Register | 1000011 w | mod reg r/m |  |  |
| Register with Accumulator | 10010 reg |  |  |  |
| IN = Input from: |  |  |  |  |
| Fixed Port | 1110010 w | port |  |  |
| Variable Port | 1110110 w |  |  |  |
| OUT = Output to: |  |  |  |  |
| Fixed Port | 1110011 w | port |  |  |
| Variable Port | 1110111 w |  |  |  |
| XLAT $=$ Translate Byte to AL | 11010111 |  |  |  |
| LEA = Load EA to Register | 10001101 | mod reg r/m |  |  |
| LDS = Load Pointer to DS | 11000101 | mod regr/m |  |  |
| LES = Load Pointer to ES | 11000100 | mod reg r/m |  |  |
| LAHF = Load AH with Fiags | 10011111 |  |  |  |
| SAHF = Store AH into Flags | 10011110 |  |  |  |
| PUSHF = Push Flags | 10011100 |  |  |  |
| POPF = Pop Flags | 10011101 |  |  |  |

## Instruction Set Summary (Continued)

| Mnemonic and Description | Instruction Code |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC | 76543210 | 76543210 | 76543210 | 76543210 |
| ADD = Add: |  |  |  |  |
| Reg / Memory with Register to Either | 000000 dw | mod regr $/ \mathrm{m}$ |  |  |
| Immediate to Register/Memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate to Accumulator | 0000010 w | data | data if $w=1$ |  |
| ADC $=$ Add with Carry: |  |  |  |  |
| Reg / Memory with Register to Either | 000100 dw | mod reg r/m |  |  |
| Immedıate to Register/Memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immedıate to Accumulator | 0001010 w | data | data if $w=1$ |  |
| INC = Increment: |  |  |  |  |
| Register/Memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |
| Register | 01000 reg |  |  |  |
| AAA = ASCII Adjust for Add | 00110111 |  |  |  |
| DAA $=$ Decimal Adjust for Add | 00100111 |  |  |  |
| SUB = Subtract: |  |  |  |  |
| Reg./Memory and Register to Elther | 001010 dw | $\mathrm{modregr} \mathrm{r} / \mathrm{m}$ |  |  |
| Immediate from Register/Memory | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if s:w $=01$ |
| Immediate from Accumulator | 0010110 w | data | data if $w=1$ |  |
| SBB $=$ Subtract with Borrow |  |  |  |  |
| Reg./Memory and Register to Either | 000110 dw | mod reg r/m |  |  |
| Immediate from Register/Memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $s: w=01$ |
| Immediate from Accumulator | 0001110 w | data | data if $w=1$ |  |
| DEC $=$ Decrement: |  |  |  |  |
| Register/Memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  |
| Register | 01001 reg |  |  |  |
| NEG $=$ Change Sign | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  |
| CMP = Compare: |  |  |  |  |
| Register/Memory and Register | 001110 dw | mod reg r/m |  |  |
| Immediate with Register/Memory | 100000 sw | $\bmod 111 \mathrm{r} / \mathrm{m}$ | data | data if $s: w=01$ |
| Immediate with Accumulator | 0011110 w | data | data if $w=1$ |  |
| AAS = ASCII Adjust for Subtract | 00111111 |  |  |  |
| DAS = Decimal Adjust for Subtract | 00101111 |  |  |  |
| MUL - = Multiply (Unsıgned) | 1111011 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |
| IMUL = Integer Multiply (Signed) | 1111011 w | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |  |
| AAM = ASCII Adjust for Multiply | 11010100 | 00001010 |  |  |
| DIV $=$ Divide (Unsigned) | 1111011 w | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  |
| IDIV $=$ Integer Divide (Signed) | 1111011 w | $\bmod 111 \mathrm{r} / \mathrm{m}$ |  |  |
| AAD $=$ ASCII Adjust for Divide | 11010101 | 00001010 |  |  |
| CBW = Convert Byte to Word | 10011000 |  |  |  |
| CWD = Convert Word to Double Word | 10011001 |  |  |  |

## Instruction Set Summary (Continued)

| Mnemonic and Description | Instruction Code |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| LOGIC | 76543210 | 76543210 | 76543210 | 76543210 |
| NOT $=$ Invert | 1111011 w | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  |
| SHL/SAL $=$ Shift Logical/Arithmetic Left | 110100 Vw | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |
| SHR $=$ Shift Logıcal Right | 110100 vw | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |  |
| SAR $=$ Shift Arithmetic Right | 110100 vw | $\bmod 111 \mathrm{r} / \mathrm{m}$ |  |  |
| ROL $=$ Rotate Left | 110100 vw | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |
| ROR $=$ Rotate Rıght | 110100 vw | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  |
| RCL $=$ Rotate Through Carry Flag Left | 110100 vw | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  |
| RCR $=$ Rotate Through Carry Right | 110100 vw | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  |
| AND = And: |  |  |  |  |
| Reg / Memory and Register to Either | 001000 dw | mod reg r/m |  |  |
| Immediate to Register/Memory | 1000000 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ |
| Immediate to Accumulator | 0010010 w | data | data if $w=1$ |  |
| TEST = And Function to Flags, No Result: |  |  |  |  |
| Register/Memory and Register | 1000010 w | mod reg r/m |  |  |
| Immediate Data and Register/Memory | 1111011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ |
| Immediate Data and Accumulator | 1010100 w | data | data if $w=1$ |  |
| $\mathrm{OR}=\mathrm{Or}$ : |  |  |  |  |
| Reg / Memory and Register to Elther | 000010 dw | mod reg r/m |  |  |
| Immediate to Register/Memory | 1000000 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ |
| Immediate to Accumulator | 0000110 w | data | data if $w=1$ |  |
| XOR = Exclusive or: |  |  |  |  |
| Reg / Memory and Register to Either | 001100 dw | mod reg r/m |  |  |
| Immediate to Register/Memory | 1000000 w | $\bmod 110 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ |
| Immediate to Accumulator | 0011010 w | data | data if $w=1$ |  |
| STRING MANIPULATION |  |  |  |  |
| REP = Repeat | 11110012 |  |  |  |
| MOVS = Move Byte/Word | 1010010 w |  |  |  |
| CMPS = Compare Byte/Word | 1010011 w |  |  |  |
| SCAS = Scan Byte/Word | 1010111 w |  |  |  |
| LODS = Load Byte/Wd to AL/AX | 1010110 w |  |  |  |
| $\mathbf{S T O S ~ = ~ S t o r ~ B y t e / W d ~ f r o m ~ A L / A ~}$ | 1010101 w |  |  |  |
| CONTROL TRANSFER |  |  |  |  |
| CALL = Call: |  |  |  |  |
| Direct Within Segment | 11101000 | disp-low | disp-high |  |
| Indirect Within Segment | 11111111 | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  |
| Direct Intersegment | 10011010 | offset-low | offset-high |  |
|  |  | seg-low | seg-high |  |
| Indirect Intersegment | 11111111 | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  |

## Instruction Set Summary (Continued)

| Mnemonic and Description | Instruction Code |  |  |
| :---: | :---: | :---: | :---: |
| JMP = Unconditional Jump: | 76543210 | 76543210 | 76543210 |
| Direct Within Segment | 11101001 | disp-low | dısp-high |
| Direct Within Segment-Short | 11101011 | dısp |  |
| Indirect Within Segment | 11111111 | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |
| Direct Intersegment | 11101010 | offset-low | offset-high |
|  |  | seg-low | seg-high |
| Indirect Intersegment | 11111111 | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |
| RET = Return from CALL: |  |  |  |
| Within Segment | 11000011 |  |  |
| Within Seg Adding Immed to SP | 11000010 | data-low | data-high |
| Intersegment | 11001011 |  |  |
| Intersegment Addıng Immediate to SP | 11001010 | data-low | data-high |
| JE/JZ = Jump on Equal/Zero | 01110100 | dısp |  |
| $\begin{aligned} \text { JL/JNGE } & =\underset{\text { or Equal }}{\text { Jump on Less/Not Greater }} \end{aligned}$ | 01111100 | disp |  |
| $\begin{aligned} \text { JLE/JNG }= & \text { Jump on Less or Equal/ } \\ & \text { Not Greater } \end{aligned}$ | 01111110 | dısp |  |
| $\begin{aligned} & \text { JB/JNAE }= \text { Jump on Below/Not Above } \\ & \text { or Equal } \end{aligned}$ | 01110010 | disp |  |
| $\begin{aligned} \text { JBE/JNA }= & \text { Jump on Below or Equal/ } \\ & \text { Not Above } \end{aligned}$ | 01110110 | disp |  |
| JP/JPE = Jump on Parity/Parity Even | 01111010 | disp |  |
| JO $=$ Jump on Overflow | 01110000 | dısp |  |
| JS = Jump on Sign | 01111000 | disp |  |
| JNE/JNZ = Jump on Not Equal/Not Zero | 01110101 | disp |  |
| $\begin{gathered} \text { JNL./JGE }=\underset{\text { or Equal }}{\text { Jump on }} \text { Not Less/Greater } \end{gathered}$ | 01111101 | disp |  |
| JNLE/JG = Jump on Not Less or Equal/ | 01111111 | disp |  |
| $\begin{aligned} & \text { JNB } \\ & \text { JAE }=\underset{\text { or Equal }}{\text { Jump on Not Below/Above }} \end{aligned}$ | 01110011 | disp |  |
| $\begin{aligned} \text { JNBE/JA }= & \text { Jump on Not Below or } \\ & \text { Equal/Above } \end{aligned}$ | 01110111 | disp |  |
| JNP/JPO = Jump on Not Par/Par Odd | 01111011 | dısp |  |
| JNO = Jump on Not Overflow | 01110001 | disp |  |
| JNS = Jump on Not Sign | 01111001 | disp |  |
| LOOP = Loop CX Times | 11100010 | disp |  |
| LOOPZ/LOOPE = Loop While Zero/Equal | 11100001 | disp |  |
| $\begin{aligned} \text { LOOPNZ/LOOPNE }= & \text { Loop While Not } \\ & \text { Zero/Equal } \end{aligned}$ | 11100000 | disp |  |
| JCXZ = Jump on CX Zero | 11100011 | disp |  |
| INT = interrupt |  |  |  |
| Type Specified | 11001101 | type |  |
| Type 3 | 11001100 |  |  |
| INTO = Interrupt on Overflow | 11001110 |  |  |
| IRET $=$ Interrupt Return | 11001111 |  |  |

Instruction Set Summary (Continued)


## NOTES:

AL $=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 $\mathbf{w}=\mathbf{1}$ then word instruction; if $\mathbf{w}=\mathbf{0}$ then byte instruction
if $\mathrm{mod}=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
if mod $=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 $\mathrm{r} / \mathrm{m}=001$ then $E A=(B X)+(D I)+$ DISP
if $\mathrm{r} / \mathrm{m}=010$ then $E A=(B P)+(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+$ DISP
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then EA $=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+\mathrm{DISP}^{*}$
if $\mathrm{r} / \mathrm{m}=111$ then $E A=(B X)+$ DISP
DISP follows 2nd byte of instruction (before data if required)
*except if $\mathrm{mod}=00$ and $\mathrm{r} / \mathrm{m}=110$ then EA $=$ disp-
high: disp-low.
**MOV CS, REG/MEMORY not allowed.
if $\mathrm{s}: \mathrm{w}=01$ then 16 bits of immediate data form the operand.
if s: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 ZF FLAG. SEGMENT OVERRIDE PREFIX

001 reg 110
REG is assigned according to the following table:

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

Instructions which reference the flag register file as a 16-bit object use the symbol FLAGS to represent the file: FLAGS =
$\mathrm{X}: \mathrm{X}: \mathrm{X}: \mathrm{X}:(\mathrm{OF}):(\mathrm{DF}):(I F):(\mathrm{TF}):(\mathrm{SF}):(\mathrm{ZF}): \mathrm{X}:(\mathrm{AF}): \mathrm{X}:(\mathrm{PF}): \mathrm{X}:(\mathrm{CF})$
Mnemonics © Intel, 1978

## CMOS PERIPHERALS

PAGEINDUSTRY CMOS PERIPHERAL CROSS REFERENCE. ..... 4-3
CMOS PERIPHERAL DATASHEETS
CDP1851, C Programmable I/O Interface ..... 4-5
CDP1852, C Byte-Wide I/O Port ..... 4-17
CDP1852/3, C/3 High-Reliability Byte-Wide I/O Port ..... 4-25
CDP1853, C N -Bit 1 of 8 Decoder ..... 4-30
CDP1853/3, C/3 High-Reliability N-Bit 1 of 8 Decoder ..... 4-34
CDP1854A, AC Programmable UART ..... 5-41
CDP1855, C 8-Bit Programmable Multiply/Divide Unit ..... 4-38
CDP1857, C 4-Bit Bus Buffer/Separator ..... 4-51
CDP1871A, AC Keyboard Encoder ..... 4-55
CDP1872C High Speed 8-Bit Input Port ..... 4-64
CDP1874C High Speed 8-Bit Input Port ..... 4-64
CDP1875C High Speed 8-Bit Output Port ..... 4-64
CDP1877, C Programmable Interrupt Controller (PIC) ..... 4-69
CDP1878, C Dual Counter-Timer ..... 4-78
CDP1879, C-1 Real-Time Clock ..... 4-91
CDP1881, C 6-Bit Latch and Decoder Memory Interface ..... 4-107
CDP1882, C 6-Bit Latch and Decoder Memory Interface ..... 4-107
CDP1883, C 7-Bit Latch and Decoder Memory Interface ..... 4-113
ICM7170 Microprocessor Compatible Real-Time Clock ..... 4-118
82C237 Enhanced Programmable DMA Controller ..... 4-131
82C284 Clock Generator and Ready Interface for 80C286 Processors ..... 4-15782C284/883
Clock Generator and Ready Interface for 80C286 Processors ..... 4-167
82C37A Programmable DMA Controller ..... 4-176
82C50A Asynchronous Communications Element. ..... 5-3
82C52 Serial Controller Interface. ..... 5-23
82C54 Programmable Interval Timer ..... 4-198
82C55A Programmable Peripheral Interface ..... 4-215
82C59A Priority Interrupt Controller ..... 4-237
82C82 Octal Latching Bus Driver. ..... 4-256
82C83H
82C84A Clock Generator Driver ..... 4-270
82C85 Static Clock Controller/Generator ..... 4-280
82C86H Octal Bus Transceiver ..... 4-299
82C87H Octal Inverting Bus Transceiver ..... 4-306
82C88 Bus Controller ..... 4-313
82 C 89 Bus Arbiter ..... 4-322
RELATED APPLICATION NOTES
App Note 109 82C59A Priority Interrupt Controller ..... 7-15
App Note 7275 User's Guide to the CDP1879 and CDP1879C1 CMOS Real-Time Clocks. ..... 7-70
App Note 7374 The CDP1871A Keyboard Encoder ..... 7-88

## CDP1800-Series CMOS Peripherals

Can be used with CMOS and NMOS Processors

| RCA I/O TYPE | DESCRIPTION AND FUNCTION | RCA | MICROPROCESSOR BUS |  |  |  |  | INPUT <br> LEVELS | (NOTE 2) <br> FANOUT <br> (TTL <br> LOADS) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MULTIPLEXED |  |  | NONMULTIPLEXED |  |  |  |
|  |  |  | RCAMO- TOROLA | INTEL | $\begin{aligned} & \text { INTEL } \\ & \text { NSC } \end{aligned}$ | ZILOG | ROCKWELL |  |  |
|  |  | $\begin{aligned} & 1800 \\ & \text { SERIES } \end{aligned}$ | $\begin{gathered} 68 \mathrm{HCO5} \\ 6805 \end{gathered}$ | 8048, 8051 80C48, 80C51 $8049,80 C 49$ 8088 | $\begin{gathered} 8085 \\ 80 C 85 \\ \text { NSC800 } \end{gathered}$ | Z80 | $\begin{gathered} 6502 \\ 65 C 02 \end{gathered}$ |  |  |
| VOPORTS |  |  |  |  |  |  |  |  |  |
| CDP1851 | Programmable I/O Port | Yes | Note 1 | Note 1 | Note 1 | Yes | Yes | CMOS | 1 |
| CDP1852 | Byte-Wide I/O Port | Yes | Yes | Yes | Yes | Yes | Yes | CMOS | 1 |
| CDP1857 | 4-Bit Bus Buffer/ Separator | Yes | Yes | Yes | Yes | Yes | Yes | CMOS | 1 |
| CDP1872 | 8-Bit Input Port | Yes | Yes | Yes | Yes | Yes | Yes | cmos | 3 |
| CDP1874 | 8-Bit Input Port | Yes | Yes | Yes | Yes | Yes | Yes | CMOS | 3 |
| CDP1875 | 8-Bit Input Port | Yes | Yes | Yes | Yes | Yes | Yes | CMOS | 3 |
| MEMORY HO DECODERS |  |  |  |  |  |  |  |  |  |
| CDP1853 | N -Bit 1 of 8 Decoder | Yes | Yes | Yes | Yes | Yes | Yes | CMOS | 1 |
| CDP1881 | 6-Bit Latch/Decoder | Yes | Yes | Yes | Yes | Yes | Yes | CMOS | 1 |
| CDP1882 | 6-Bit Latch/Decoder | Yes | Yes | Yes | Yes | Yes | Yes | CMOS | 1 |
| CDP1883 | 7-Bit Latch/Decoder | Yes | Yes | Yes | Yes | Yes | Yes | CMOS | 1 |
| SERIAL 10 |  |  |  |  |  |  |  |  |  |
| $\begin{array}{\|l} \hline \text { CDP1854A } \\ \text { (Note 3) } \\ \hline \end{array}$ | UART | Yes | Note 1 | Note 1 | Note 1 | Note 1 | Note 1 | CMOS | 1 |
| CDP6402 | UART | Note 1 | Note 1 | Note 1 | Note 1 | Note 1 | Note 1 | CMOS | 1 |
| MULTIPLYIDIVIDE |  |  |  |  |  |  |  |  |  |
| CDP1855 | 8-Bit Programmable MDU | Yes | Note 1 | Note 1 | Note 1 | Note 1 | Note 1 | CMOS | 1 |
| KEYBOARD NTTERFACE |  |  |  |  |  |  |  |  |  |
| CDP1871A | Keyboard Encoder | Yes | Note 1 | Note 1 | Note 1 | Note 1 | Note 1 | CMOS |  |
| TIMEA FUNCTIONS |  |  |  |  |  |  |  |  |  |
| CDP1878 | Dual Counter-Timer | Yes | Note 1 | Note 1 | Note 1 | Yes | Yes | CMOS | 1 |
| CDP1879 | Real-Time Clock | Yes | $\begin{array}{c\|} \hline \text { Use } 6818, \\ A \\ \hline \end{array}$ | Use 6818, A | Use6818, A | Yes | Yes | CMOS | 1 |
| INTERRUPT CONTROL |  |  |  |  |  |  |  |  |  |
| CDP1877 | Programmable Interrupt Controller | Yes | No | No | No | No | No | CMOS | 1 |

NOTES:

1. Yes but requires additional "glue parts".
2. 1 TLL load, i.e., $\leq 0.4 \mathrm{~V}$ at 1.6 mA
3. Operating in 1800 compatible mode (mode 1). Otherwise see CDP6402 for mode 0 information.

# 80CXXX Family <br> Peripheral Cross Reference 

| HARRIS | INTEL | NEC | OKI | MITSUBISHI | VLSI | OTHER |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PERIPHERALS |  |  |  |  |  |  |
| 82C37A-5 | 82C37A-5 | $\mu$ PD71037 <br> $\mu$ PD8237A-5 | MSM82C37A-5 | M5M82C37A-4, -5 | $\begin{aligned} & \text { VL82C37A-4 } \\ & \text { VL82C37A-5 } \end{aligned}$ | $\begin{aligned} & \text { TMP82C37A-5 } \\ & \text { CA82C37A-5 } \end{aligned}$ |
| $\begin{aligned} & 82 C 37 A \\ & 82 \mathrm{C} 237 \end{aligned}$ |  |  | MSM82C37A |  | VL82C37A-8 | $\begin{aligned} & \text { KS82C37A } \\ & \text { SMC82C37A } \end{aligned}$ |
| $\begin{aligned} & 82 \mathrm{C} 37 \mathrm{~A}-12 \\ & 82 \mathrm{C} 237-12 \end{aligned}$ |  |  |  |  |  |  |
| 82C54 | 82C54 | $\mu$ PD71054 | MSM82C54 | $\begin{aligned} & \text { M5M82C54-6 } \\ & \text { M5M82C54 } \end{aligned}$ | VL82C54-8 | AM82C54 <br> KS82C54 <br> CA82C54 <br> TMP82C54 |
| 82C54-10 | 82C54-2 |  | MSM82C54-2 |  |  | AM82C54-2 <br> KS82C54-10 <br> TMP82C54-2 |
| 82C55A-5 |  | $\mu$ PD82C56A-5 | MSM82C55A-5 | M5M82C55A-5 |  |  |
| 82C55A | 82C55A-2 | $\mu$ PD71055 <br> $\mu$ PD8255A-2 | MSM82C55A-2 |  |  | AM82C55A <br> KS82C55A <br> CA82C55A <br> UM82C55A |
| 82C59A-5 |  |  |  | M5M82C59A |  |  |
| 82C59A | 82C59A-2 | $\mu$ PD71059 $\mu$ PD8259A | MSM82C59-2 |  | VL82C59A-8 | AM82C59A-2 <br> CA82C59A <br> KS82C59A <br> TMP82C59 |
| 82C59A-12 |  |  |  |  |  |  |
| UAFITS |  |  |  |  |  |  |
| 82C50A |  |  |  |  | VL82C50A | $\begin{aligned} & \text { INS82C50A } \\ & \text { CA82C50A } \\ & \text { WD82C50A } \\ & \text { KS82C50A } \end{aligned}$ |
| 82C52 |  |  |  |  |  | $\begin{aligned} & \text { CA82C52 } \\ & \text { KS82C52 } \end{aligned}$ |
| BUS SUPPORT |  |  |  |  |  |  |
| 82C284-10 | 82C284-10 |  |  |  |  | KS82C284-10 |
| 82C284-12 | 82C284-12 |  |  |  |  | KS82C284-12 |
| 82C82 |  | $\mu$ PD71082 |  |  |  |  |
| 82 C 83 H |  | $\mu$ PD7 1083 |  |  |  |  |
| 82C84A | $\begin{aligned} & 82 \mathrm{C} 84 \mathrm{~A} \\ & 82 \mathrm{C} 84 \mathrm{~A}-5 \end{aligned}$ | $\mu$ PD7 1084 | MSM82C84A MSM82C84A-5 MSM82C84A-2 |  | VL82C84A-8 | $\begin{aligned} & \text { CA82C84A } \\ & \text { KS82C84A } \end{aligned}$ |
| $82 \mathrm{C85}$ |  |  |  |  |  |  |
| 82 C 86 H |  | $\mu$ PD71086 |  |  |  | MM182C86 |
| 82C87H |  | $\mu$ PD71087 |  |  |  | MM182C87 |
| 82C88 | 82C88 | $\mu \text { PD71088 }$ $\mu \text { PD8288 }$ | MSM82C88 MSM82C88-2 |  | VL82C88-8 | $\begin{aligned} & \text { CA82C88 } \\ & \text { KS82C88 } \end{aligned}$ |
| 82C89 |  |  |  |  |  |  |

HARRIS

# CMOS Programmable VO Interface 

## Features

- 20 Programmable VO Lines
- Programmable for Operation in Four Modes:
- Input
- Output
- Bidirectional
- Bit-programmable
- Operates in Either VO or Memory Space


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 5V | 10V |
| :---: | :---: | :--- | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1851CE | CDP1851E |
| Burn-in |  | CDP1851CEX | - |
| Ceramic DIP <br> Burn-ın | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1851CD | CDP1851D |
|  |  | CDP1851CDX | CDP1851DX |

## Description

THE CDP1851 and CDP1851C are CMOS programmable two-port I/Os designed for use as general-purpose I/O devices. They are directly compatible with CDP1800-series microprocessors functioning at maximum clock frequency. Each port can be programmed in either byte-I/O or bit-programmable modes for interfacing with peripheral devices such as printers and keyboards.

Both ports A and B can be separately programmed to be 8 bit input or output ports with handshaking control lines, RDY and STROBE. Only port A can be programmed to be a bidirectional port. This configuration provides a means for communicating with a peripheral device or microprocessor system on a single 8 bit bus for both transmitting and receiving data. Handshaking signals are provided to maintain proper bus access control. Port A handshaking lines are used for input control and port $B$ handshaking lines are used for output; therefore port B must be in the bit-programmable mode where handshaking is not used.

Ports A and B can be separately bit programmed so that each individual line can be designated as an input or output line. The handshaking lines may also be individually programmed as input or output when port $\mathbf{A}$ is not in bidirectional mode.

The CDP1851 has a supply-voltage range of 4 V to 10.5 V , and the CDP1851C has a range of 4 V to 6.5 V . Both types are supplied in 40 -lead dual-in-line plastic ( E suffix) or hermetic ceramic (D suffix) packages. The CDP1851C is also available in chip form ( H suffix).

CDP1851 Programming Modes

| MODE | (8) <br> PORT A DATA PINS | (2) PORT A HANDSHAKING PINS | (8) <br> PORT B DATA PINS | (2) PORT B HANDSHAKING PINS |
| :---: | :---: | :---: | :---: | :---: |
| Input | Accept Input Data | READY, STROBE | Accept Input Data | READY, STROBE |
| Output | Output Data | READY, STROBE | Output Data | READY, STROBE |
| Bidirectional (Port A Only) | Transfer Input/ Output Data | Input Handshaking for Port A | Must be Previously Set to Bit-Programmable Mode | Output Handshaking for Port A |
| Bit-Programmable | Programmed Individually as In puts or Outputs | Programmed Individually as Inputs or Outputs | Programmed Individually as Inputs or Outputs | Programmed Individually as Inputs or Outputs |

## Specifications CDP1851, CDP1851C

| MAXIMUM RATINGS, Absolute-Maximum Values: |  |
| :---: | :---: |
| DC SUPPLY-VOLTAGE RANGE, (VDD) (Voltage referenced to $\mathrm{V}_{\text {SS }}$ Terminal) |  |
|  |  |
| CDP1851 .................................................................................................. 0.0 .5 to 0.11 V |  |
| CDP1851C | -0.5 to +7 V |
|  |  |
|  |  |
| POWER DISSIPATION PER PACKAGE (PD): |  |
|  |  |
| For TA $=+60$ to $+85^{\circ} \mathrm{C}$ (PACKA ЗE TYPE E) .................................. Derate Lineary at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |  |
|  |  |
| For $T_{A}=+100$ to $+125^{\circ} \mathrm{C}$ (PACK IGE TYPE D) $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . \ldots \ldots . .$. |  |
| DEVICE DISSIPATION PER OUTP'JT TRANSISTOR |  |
| For TA = FULL PACKAGE-TEMPERATURE RANGE (All Package Type) | 40 mW |
| OPERATING-TEMPERATURE RANGE ( $T_{A}$ ) : |  |
| PACKAGE TYPE D, H | -55 to $+125^{\circ} \mathrm{C}$ |
| PACKAGE TYPE E | . -40 to $+85^{\circ} \mathrm{C}$ |
|  LEAD TEMPERATURE (DURING SOLDERING): |  |
|  |  |
|  |  |

OPERATING CONDITIONS at TA = Full Package-Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1851 |  | CDP1851C |  |  |
|  | MIN. | MAX. | MIN. | MAX. |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | VSS | VDD | VSS | VDD |  |



Fig. 1 - Functional diagram for CDP1851 and CDP1851C.

STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm \mathbf{5 \%}$, Except as noted

| CHARACTERISTIC |  | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \mathrm{vo}_{0} \\ & \text { (v) } \end{aligned}$ | $\mathrm{V}_{\mathrm{IN}}$ <br> (V) | VDD <br> (V) | CDP1851 |  |  | CDP1851C |  |  |  |
|  |  | Min. |  |  | Typ. ${ }^{\text {¢ }}$ | Max. | Min. | Typ. ${ }^{\bullet}$ | Max. |  |
| Quiescent Device Current | IDD |  | - | 0,5 | 5 | - | 0.01 |  | - | 0.02 | 200 | $\mu \mathrm{A}$ |
|  |  | - | 0, 10 | 10 | - | 1 | 200 | - | - | - |  |  |
| Output Low Drive |  | 0.4 | 0,5 | 5 | 1.6 | 3.2 | - | 1.6 | 3.2 | - | mA |  |
| (Sink) Current | lOL | 0.5 | 0,10 | 10 | 2.6 | 5.2 | - | - | - | - |  |  |
| Output High Drive (Source) Current |  | 4.6 | 0,5 | 5 | -1.15 | -2.3 | - | -1.15 | -2.3 | - |  |  |
|  | 1 OH | 9.5 | 0, 10 | 10 | -2.6 | -5.2 | - | - | - | - |  |  |
| Output Voltage |  | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | v |  |
| Low-Level | VOL $\ddagger$ | - | 0, 10 | 10 | - | 0 | 0.1 | - | - | - |  |  |
| Output Voltage |  | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - |  |  |
| High Level | $\mathrm{V}_{\mathrm{OH}} \ddagger$ | - | 0, 10 | 10 | 9.9 | 10 | - | - | - | - |  |  |
| Input Low Voltage | VIL | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 |  |  |
|  |  | 0.5, 9.5 | - | 10 | - | - | 3 | - | - | - |  |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 4.5 | - | 5 | 3.5 | - | - | 3.5 | - | - |  |  |
|  |  | 0.5, 9.5 | - | 10 | 7 | - | - | - | - | - |  |  |
| Input Leakage Current | IN | Any | 0,5 | 5 | - | - | $\pm 1$ | - | - | $\pm 1$ | $\mu \mathrm{A}$ |  |
|  |  | Input | 0, 10 | 10 | - | - | $\pm 2$ | - | - | - |  |  |
| 3-State Output Leakage |  | 0,5 | 0,5 | 5 | - | - | $\pm 1$ | - | - | $\pm 1$ |  |  |
| Current | Iout | 0, 10 | 0, 10 | 10 | - | - | $\pm 1$ | - | - | - |  |  |
| Operating Current | $\mathrm{IDD1}^{\text {a }}$ | - | 0,5 | 5 | - | 1.5 | 3 | - | 1.5 | 3 | mA |  |
|  |  | - | 0, 10 | 10 | - | 6 | 12 | - | - | - |  |  |
| Input Capacitance | $\mathrm{CIN}^{\text {N }}$ | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |  |
| Output Capacitance | Cout | - | - | - | - | 10 | 15 | - | 10 | 15 |  |  |

${ }^{-}$Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$.
$\ddagger \mathrm{I}_{\mathrm{OL}}=\mathrm{I}_{\mathrm{OH}}=1 \mu \mathrm{~A}$.
$\Delta$ Operating current is measured at 200 kHz for $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ and 400 kHz for $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}$, with open outputs (worst-case frequencies for CDP1802A system operating at maximum speed of 3.2 MHz ).

## FUNCTIONAL DESCRIPTION

The CDP1851 has four modes of operation: input, output, bidirectional, and bit-programmable. Port A is programmable in all modes; port $B$ is programmable in all but the bidirectional mode. A control byte must be loaded into the control register to program the ports. In the input and output modes, each port has two handshaking signals, STROBE and RDY. In the bidirectional mode, port A has four handshaking signals: A RDY and A STROBE for input, $B$ RDY and BSTROBE for output. If port $A$ is programmed in the bidirectional mode, port $B$ must be programmed in the bit-programmable mode. Each terminal of port A or B may be individually programmed for input or output in the bitprogrammable mode. Since handshaking is not used in this mode, the RDY and STROBE lines may also be used for bit-programming if port A is not in the bidirectional mode.
Input Mode
When a peripheral device has data to input, it sends a

STROBE pulse to the PIO. The leading edge of this pulse clears the RDY line, inhibiting further transmission from the peripheral. The trailing edge of the STROBE pulse latches the data into the PIO buffer register and also activates the $\mathbb{N T}$ line to signal the CPU to read this data. The INT pin can be wired to the $\overline{N^{\prime} T}$ pin of the CPU or the $\overline{E F}$ lines for polling. The CPU then executes an input or a load instruction, depending on the mapping technique used. In either case the proper code must be asserted on the RAO, RA1, and CS lines to read the buffer register (see Table VI).
The $\overline{\mathbf{I N T}}$ line is deactivated on the leading edge of TPB. The trailing edge of TPB sets the RDY line to signal the peripheral that the port is ready to be loaded with new data. If RDY is low when the input mode is entered (i.e. after a reset), a "dummy" read must be done to set RDY high and signal the peripheral device that the port is ready to be loaded.

## CDP1851, CDP1851C

## FUNCTIONAL DESCRIPTION (Cont'd)

## Output Mode

A peripheral STROBE pulse sent to the PIO generates an interrupt to signal the CPU that the peripheral device is ready for data. The CPU executes the proper output or store instruction. Data are than read from memory and placed on the bus. The data are latched into the port buffer at the end of the window when RE/WE $=0$ and $W R / R E=1$. The RDY line is also set at this time, indicating to the peripheral that there is data in the port buffer. The INT line is deactivated at the beginning of the window. After the peripheral reads valid port data, it can send another STROBE pulse, clearing the RDY line and activating the INT line as in the input mode.

## Bidirectional Mode

This mode programs port A to function as both an input and output port. The bidirectional feature allows the peripheral to control port direction by using both sets of handshake signals. The port A handshaking pins are used to control input data from peripheral to PIO, while the port B handshaking pins are used to control output data from PIO to peripheral. Data are transferred in the same manner as the input and output modes. Since A INT is used for both
input and output, the status register must be read to determine what condition caused A INT to be activated (see Table V).

## Bit-Programmable Mode

This mode allows individual bits of port A or port B to be programmed as inputs or outputs. To output data to bits programmed as outputs, the CPU loads a data byte into the 8 bit port as in the output mode (no handshaking). Only bits programmed for outputs latch this data. Data must be stable when reading from bits programmed as inputs, since the input bits do not latch. When the CDP1851 inputs data to the CPU the CPU also reads the output bits latched during the last output cycle. The RDY and STROBE lines may be used for I/O by using the STROBE/RDY I/O control byte in table II. An additional feature available in the bit-programmable mode is the ability to generate interrupts based on input/output byte combinations. These interrupts can be programmed to occur on logic conditions (AND, OR, NAND, and NOR) generated by the eight I/O lines of each port (The STROBE and RDY lines cannot generate interrupts).


Fig. 2 - Memory space I/O. This configuration allows up to four CDP1851s to occupy memory space 8XXX with no additional hardware (A4-A5 and A6-A7 are used as RAO and RA1 on the third and fourth PIO's).

## CDP1851, CDP1851C

## PROGRAMMING

1. Initialization and Controls

The CDP1851 PIO must be cleared by a low on the CLEAR input during power-on to set it for programming. Once programmed, modes can be changed without clearing except when exiting the bit-programmable mode. A low on the CLEAR input sets both ports to the input modes, disables interrupts, unmasks all bitprogrammed interrupt bits, and resets the status register, A RDY, and B RDY.

## 2. Mode Setting

The control register must be sequentially loaded with the appropriate mode set control bytes in order as shown in table I (i.e. input mode then output mode, etc.). Port A is set with the SET A bit = 1 and port $B$ is set with the SET B bit = 1. If a port is set to the bitprogrammable mode, the bit-programming control byte from table II must be loaded. A bit is programmed for output with the I/O bit = 1 and for input with the I/O bit = 0 . The STROBE and RDY lines may be programmed for input or output with the STROBE/RDY control byte of
table II. Input data on the STROBE and RDY lines is detected by reading the status register. When using the STROBE or RDY lines for output, the control byte must be loaded every time output data is to be changed. To program logical conditions that will generate an interrupt, the interrupt control byte of table III must be loaded. An interrupt mask of the eight I/O lines may be loaded next, if bit D4 (mask follows) of the interrupt control byte $=1$. The I/O lines are masked if the corresponding bit of the interrupt mask register is 1 , otherwise it is monitored. Any combination of masked bits are permissable, except all bits masked (mask $=$ FF).
3. INT Enable/Disable

To enable or disable the $\overline{\mathrm{NT}}$ line in all modes, the interrupt ENABLE/DISABLE byte must be loaded (see Table IV). Interrupts can also be detected by reading the status register see table V. All interrupts should be disabled when programming or false interrupts may occur. The INT outputs are open drain NMOS devices that allow wired ORing (use 10K pull-up registers).

## A FLOW CHART GUIDE TO CDP1851 MODE PROGRAMMING



TABLE I [RA1 $=0$, RA $0=1]$

| MODE SET * | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input | 0 | 0 | X | $\operatorname{Set} \mathrm{B}$ | $\operatorname{Set} \mathrm{A}$ | X | 1 | 1 |
| Output | 0 | 1 | X | $\operatorname{Set} \mathrm{B}$ | $\operatorname{Set} \mathrm{A}$ | X | 1 | 1 |
| Bit-Programmable | 1 | 1 | X | $\operatorname{Set} \mathrm{B}$ | $\operatorname{Set} \mathrm{A}$ | X | 1 | 1 |
| Bidirectional | 1 | 0 | X | X | $\operatorname{Set} \mathrm{A}$ | X | 1 | 1 |

* Modes should be set in order as shown in Table I

If either port is set for bit-programmable mode, the two following control bytes should immediately follow:

## TABLE II [RA1=0, RA0=1]

| Bit-Programming | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $1 / O 7$ | $\mathrm{I} / \mathrm{O} 6$ | $\mathrm{I} / \mathrm{O} 5$ | $\mathrm{I} / \mathrm{O} 4$ | $\mathrm{I} / \mathrm{O} 3$ | $\mathrm{I} / \mathrm{O} 2$ | $\mathrm{I} / \mathrm{O} 1$ | $1 / \mathrm{O}$ |
| STROBE/RDY I/O Control $\triangle$ | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |

$\Delta$ Output $=1$
$\Delta$ Input $=0$
(D1) $0=$ Port A, $1=$ Port B
(D2) $0=$ No change to RDY line function, $1=$ Change per bit (D6)
(D3) $0=$ No change to STROBE line function, $1=$ Change per bit (D7)
(D4) RDY line output data
(D5) STROBE line output data
(D6) RDY line used as:
Output = 1
Input = 0
(D7) STROBE line used as:
Output = 1
Input = 0
If interrupts will be used for either bit-programmed port, the following control bytes should be loaded:

TABLE III [RA1=0, RA0=1]

| INTERRUPT CONTROL | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Logical Conditions and Mask | 0 | D 6 | D 5 | D 4 | D 3 | 1 | 0 | 1 |

(D3) $0=$ Port A, $1=$ Port B
(D4) $0=$ No change in mask, $1=$ Mask follows (See TABLE IIla)
(D5) (D6) $0,0=$ NAND; $1,0=O R ; 0,1=$ NOR; $1,1=$ AND
TABLE IIIa [RA1=0, RA0=1]

| INTERRUPT CONTROL | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mask Register <br> (II D4 $=1$ ) | B7 <br> Mask | B6 <br> Mask | B5 <br> Mask | B4 <br> Mask | B3 <br> Mask | B2 <br> Mask | B1 <br> Mask | B0 <br> Mask |

If Bn Mask = 1 then mask. Bit (for $\mathrm{n}=0$ to 7 )

TABLEIV [RA1 $=0$, RA $0=1]$

| Interrupt <br> Enable/Disable | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbb{N T}}$ |  |  |  |  |  |  |  |
|  | $X$ | $X$ | $X$ | $A / B$ | 0 | 0 | 1 |  |

$\overline{\mathbb{I N T}}$ Enable $=1, \overline{\mathrm{INT}}$ Enabled

$$
A / B=0, \text { Port } A
$$

$$
=0, \overline{\mathrm{INT}} \text { Disabled }
$$

$=1$, Port B
TABLE V
[RA1=0, RAO $=1$ ]

| Status Register |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| (D0) | $\overline{\text { B INT }}$ status (1 means set) |  | All Modes |  |  | A RDY input data |  | Bit-Programmable Mode |  |
| (D1) | $\overline{\mathrm{A} \text { INT }}$ status (1 means set) |  |  |  | (D5) | A STRO | ut d |  |  |
| (D2) 1 | $1=\overline{\text { AINT }}$ was caused by A STROBE $\}$ |  | Bidirectional Mode |  |  | $B$ RDY input data |  |  |  |
| (D3) | $1=\overline{\text { AINT }}$ was caused by B STROBE |  | Only |  |  | B STROBE input data |  |  |  |

TABLE VI - CPU CONTROLS

| CS * | RA1 | RAO | RD/WE | WR/RE | Action |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | X | X | X | X | No-op bus 3-stated |
| X | 0 | 0 | X | X | No-op bus 3-stated |
| X | X | X | 0 | 0 | No-op bus 3-stated |
| X | X | X | 1 | 1 | No-op bus 3-stated |
| X | X | X | 1 | 1 | No-op bus 3-stated |
| 1 | 0 | 1 | 1 | 0 | Read * status register |
| 1 | 0 | 1 | 0 | 1 | Load control register |
| 1 | 1 | 0 | 1 | 0 | Read * port A |
| 1 | 1 | 0 | 0 | 1 | Load port A |
| 1 | 1 | 1 | 1 | 0 | Read * port B |
| 1 | 1 | 1 | 1 | Load port B |  |

* Read $=\mathrm{RD} / \overline{\mathrm{WE}}=1$ and $\mathrm{WR} / \overline{\mathrm{RE}}=0$ is latched on trailing edge of CLOCK.

TABLE VII - MEMORY I/O USE

| I/O Space <br> Memory Space | RD/产E Input | WR/ $\overline{R E}$ Input | TPB Input |
| :--- | :---: | :---: | :---: |
|  | $\overline{\overline{M R D}}$ | $\overline{T P B}$ | TPB |
|  |  |  |  |
| CPU Terminals |  |  |  |

## FUNCTION PIN DEFINITION

## CLOCK (Input):

Positive input pulse that latches READ and CS on its trailing edge.

## CS - CHIP SELECT (Input)

A high-level voltage at this input selects the CDP1851 PIO.
RAO - REGISTER ADDRESS 0 (Input):
This input and RA1 are used to select either the ports or the control/status registers.
RA1 - REGISTER ADDRESS 1 (Input):
See RAO

## BUS 0 - BUS 7:

Bidirectional CPU data bus.

## CLEAR (Input)

A low-level voltage at this input resets both ports to the input mode, and also resets the status register. A RDY, B RDY, and interrupt enable (disabling interrupts).

## $\overline{\text { AINT }}$ - $\overline{\text { A INTERRUPT }}$ (Output):

A low-level voltage at this output indicates the presence of one of the interrupt conditions listed in Table III. This output is an open-drain NMOS device (to allow wired ORing) and must be tied to a pullup resistor, normally 10 $\mathrm{k} \Omega$.

## CDP1851, CDP1851C

## FUNCTION PIN DEFINITION (Cont'd)

## $\overline{\text { BINT }}$ - $\overline{\text { BINTERRUPT }}$ (Output):

A low-level voltage at this output indicates the presence of one of the interrupt conditions listed in Table III. This output is also an open-drain NMOS device and must be tied to a pullup resistor.

## B RDY - B READY (Output):

This output is a handshaking or data bit I/O line in the bit-programmable mode.

## B STROBE (Input):

An input handshaking line for port $B$ in the input and output modes, and for port A when it is in the bidirectional mode. It can be used as a data bit I/O line in the bit-programmable mode except when port $A$ is not programmed as bidirectional.

## B 0-B7:

Data input or output lines for port B.

## VSS:

Ground

## AO-A 7:

Data input or output lines for port A.

## A STROBE (Input):

An input handshaking line for port $A$ in the input, output, and bidirectional modes. It can also be used as a data bit I/O line when port $A$ is in the bit-programmable mode.

## A RDY - A READY (Output):

A output handshaking line or data bit I/O line.
TPB (Input):
A positive input pulse used as a data load, set, or reset strobe.

## WR/ $\overline{\operatorname{RE}}$ - WRITE/READ ENABLE (Input):

A positive input used to write data from the CDP1851 to the CPU bus.

## RD/WE - READ/WRITE ENABLE (Input):

A positive input used to read data from the CPU bus to the CDP1851 bus.

## VD:

Positive supply voltage.


Fig. 3-1/O space I/O.

DYNAMIC ELECTRICAL CHARACTERISTICS at TA $=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$, $t_{r}, t_{f}=\mathbf{2 0} \mathbf{n s}, V_{I H}=0.7 \mathrm{VDD}_{\text {D }}, V_{\text {IL }}=0.3 \mathrm{~V}_{\mathrm{DD}}, C_{L}=100 \mathrm{pF}$

| CHARACTERISTIC |  | VDD <br> (V) | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1851 |  |  | CDP1851C |  |  |  |
|  |  |  | Min. | Typ.* | Max. ${ }^{+}$ | Min. | Typ. ${ }^{-}$ | Max. ${ }^{+}$ |  |
| Input Mode see Figs. 4 and 5 |  |  |  |  |  |  |  |  |  |
| Minimum Setup Times: <br> Chip Select to CLOCK | tcSCL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 50 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | - | $\begin{aligned} & 50 \\ & - \end{aligned}$ | 75 - | ns |
| RD/ $\overline{W E}$ to CLOCK | trwCL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} 120 \\ 60 \\ \hline \end{gathered}$ | - | 75 - | 120 <br> - |  |
| WR/RE to CLOCK | tWRCL | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 120 \\ & 60 \\ & \hline \end{aligned}$ | - | $75$ | 120 - |  |
| Data in to STROBE | tDIST | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | $\begin{gathered} 120 \\ 60 \end{gathered}$ | - | $75$ | 120 - |  |
| Minimum Hold Times: Chip Select After CLOCK | thCSCL | $\begin{gathered} \hline 5 \\ 10 \\ \hline \end{gathered}$ | $-$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | $\begin{gathered} \hline 120 \\ 60 \\ \hline \end{gathered}$ | - | $75$ | 120 - |  |
| Address After TPB | THATPB | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & -50 \\ & -25 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | - | -50 | 0 |  |
| Data In After STROBE | tHSTDI | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 50 \\ & 25 \end{aligned}$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | - | 50 | 75 |  |
| Data Bus Out After Address | ${ }_{\text {thadOH }}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 50 \\ & 25 \end{aligned}$ | $\begin{aligned} & 325 \\ & 165 \end{aligned}$ | $\begin{aligned} & 500 \\ & 250 \end{aligned}$ | 50 | 325 - | 500 - |  |
| Propagation Delay Times: TPB to $\overline{\mathrm{NT}}$ | tPINT | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 200 \\ & 100 \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | - | 200 | 300 - |  |
| STROBE to INT | tsTINT | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & \hline 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | - | 200 | 300 - |  |
| TPB to RDY | tTPRDY | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 250 \\ & 125 \end{aligned}$ | $\begin{aligned} & 375 \\ & 200 \end{aligned}$ | - | 250 | 375 - |  |
| STROBE to RDY | tSTRDY | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 260 \\ & 130 \end{aligned}$ | $\begin{aligned} & 400 \\ & 200 \end{aligned}$ | - | 260 | 400 - |  |
| Minimum Pulse Widths: CLOCK | tWCL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | $\begin{aligned} & 120 \\ & 60 \end{aligned}$ | - | 75 | 120 - |  |
| TPB | tWTPB | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 120 \\ & 60 \end{aligned}$ | - | 75 | 120 - |  |
| STROBE | tWST | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{gathered} 100 \\ 50 \\ \hline \end{gathered}$ | $\begin{gathered} 150 \\ 75 \\ \hline \end{gathered}$ | - | 100 | 150 - |  |
| Access Time, Address to Data Bus Out | ${ }^{\text {t }}$ ADA | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 325 \\ & 165 \end{aligned}$ | $\begin{aligned} & 500 \\ & 250 \end{aligned}$ | $-$ | 325 - | 500 |  |

[^4]
## CDP1851, CDP1851C




92CS-31927

Fig. 4 - Interrupt signal propagation delay time test circuit and waveforms.


Fig. 5 - Input mode timing waveforms.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$, $t_{\text {r }}, t_{f}=\mathbf{2 0} \mathrm{ns}, \mathrm{V}_{\mathrm{IH}}=\mathbf{0 . 7} \mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, C_{\mathrm{L}}=\mathbf{1 0 0} \mathrm{pF}$

| CHARACTERISTIC |  | VDD (V) | Min. | Limits |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | CDP1851 |  | CDP1851C |  |  |  |
|  |  |  |  | Typ. ${ }^{\bullet}$ | Max. ${ }^{+}$ | Min. | Typ. ${ }^{\circ}$ | Max. ${ }^{+}$ |  |
| Output Mode see Figs. 4 and 6 |  |  |  |  |  |  |  |  |  |
| Minimum Setup Times: Chip Select to CLOCK | ${ }^{\text {t }} \mathrm{CSCL}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{array}{r} 50 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | $-$ | $50$ | $75$ | ns |
| RD/WE to CLOCK | tRWCL | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} 120 \\ 60 \\ \hline \end{gathered}$ | $-$ | $\begin{aligned} & 75 \\ & - \end{aligned}$ | 120 - |  |
| WR/RE to CLOCK | tWRCL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} \hline 120 \\ 60 \\ \hline \end{gathered}$ | - | $75$ | 120 - |  |
| Address to WRITE * | ${ }^{\text {t }}$ AW | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 50 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | - | 50 | 75 |  |
| Data Bus to WRITE * | tDW | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 80 \\ & 40 \end{aligned}$ | $\begin{gathered} 120 \\ 60 \end{gathered}$ | $-$ | $80$ | 120 - |  |
| Minimum Hold Times: Chip Select After CLOCK | $t^{\mathrm{H}} \mathrm{HCSCL}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | $\begin{gathered} 120 \\ 60 \end{gathered}$ | - | $75$ | 120 - |  |
| Address After WRITE * | thaw | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 50 \\ & 25 \end{aligned}$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | $-$ | 50 | 75 |  |
| Data Bus After WRITE * | thDW | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 50 \\ & 25 \end{aligned}$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | $-$ | $50$ | 75 |  |
| Propagation Delay Times: <br> WRITE * to Data Out | tWDO | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 225 \\ & 125 \end{aligned}$ | $\begin{aligned} & 350 \\ & 200 \end{aligned}$ | $-$ | $225$ | $350$ |  |
| WRITE * to INT | tWINT | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | $\begin{aligned} & 450 \\ & 225 \\ & \hline \end{aligned}$ | $-$ | 300 - | 450 - |  |
| WRITE * to RDY | tWRDY | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 350 \\ & 175 \end{aligned}$ | $\begin{aligned} & 525 \\ & 275 \\ & \hline \end{aligned}$ | $-$ | 350 - | $525$ |  |
| STROBE to TNT | tstint | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 200 \\ & 100 \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | - | $200$ | $300$ |  |
| STROBE to RDY | tSTRDY | $\begin{gathered} \hline 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 260 \\ & 130 \end{aligned}$ | $\begin{aligned} & 400 \\ & 200 \\ & \hline \end{aligned}$ | - | $260$ | $400$ |  |
| Minimum Pulse Widths: CLOCK | tWCL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | $\begin{aligned} & 120 \\ & 60 \end{aligned}$ | - | $75$ | $120$ |  |
| STROBE | tWST | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{gathered} 100 \\ 50 \end{gathered}$ | $\begin{aligned} & 150 \\ & 75 \end{aligned}$ | $-$ | 100 | 150 - |  |
| WRITE * | twW | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{gathered} 175 \\ 90 \end{gathered}$ | $\begin{aligned} & 275 \\ & 150 \end{aligned}$ | - | $\overline{175}$ | $275$ |  |

* WRITE is the overlap of RD/ $/ \overline{W E}=0$ and $W R / \overline{R E}=1$.
- Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages.
${ }^{+}$Maximum limits of minimum characteristics are the values above which all devices function.


Fig. 6 - Output mode timing waveforms.

HARRIS
SEMICONDUCTOR

## Byte-Wide Input/Output Port

## Features

- Static Silicon-Gate CMOS Circuitry
- Parallel 8 Bit Data Register and Buffer
- Handshaking Via Service Request Flip-Flop
- Low Quiescent and Operating Power
- Interfaces Directly with CDP1800-Series Microprocessors
- Single Voltage Supply
- Full Military Temperature Range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | $\mathbf{5 V}$ | 10V |
| :--- | :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1852CE | CDP1852E |
| Burn-in |  | CDP1852CEX | CDP1852EX |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1852CD | CDP1852D |
| * 883B | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | CDP1852CD3 | CDP1852D3 |

* Respective specifications are included at the end of this data sheet.


## Description

The CDP1852 and CDP1852C are parallel, 8 bit, mode-programmable input/output ports. They are compatible and will interface directly with CDP1800-series microprocessors. They are also useful as 8 bit address latches when used with the CDP1800 multiplexed address bus and as I/O ports in generalpurpose applications.

The mode control is used to program the device as an input port ( mode $=0$ ) or as an output port ( $\operatorname{mode}=1$ ). The $\overline{S R} /$ SR output can be used as a signal to indicate when data is ready to be transferred. In the input mode, a peripheral device can strobe data into the CDP1852, and microprocessor can read that data by device selection. In the output mode, a microprocessor strobes data into the CDP1852, and handshaking is established with a peripheral device when the CDP1852 is deselected.

In the input mode, data at the data-in terminals (D10-D17) is strobed into the port's 8 bit register by a high (1) level on the clock line. The negative high-to-low transition of the clock latches the data in the register and sets the service request output low ( $\overline{\mathrm{SR}} / \mathrm{SR}=0$ ). When CS1/ $\overline{\mathrm{CS} 1}$ and CS2 are high (CS1/ CS1 and CS2 = 1), the 3-state output drivers are enabled and data in the 8 -bit register appear at the data-out terminals (DOOD07). When either CS1/CS1 or CS2 goes low (CS1/CS1 or CS2 $=0$ ), the data-out terminals are tristated and the service request output returns high $(\overline{S R} / S R=1)$.
In the output mode, the output drivers are enabled at all times. Data at the data-in terminals (D10-D17) is strobed into the 8 bit register when $\mathrm{CS} 1 / \overline{\mathrm{CS1}}$ is low $(\mathrm{CS} 1 / \overline{\mathrm{CS1}}=0)$ and CS 2 and the clock are high (1), and are present at the data-out terminals (D00-D07). The negative high-to-low transition of the clock latches the data in the register. The $\overline{\mathrm{SR}} / \mathrm{SR}$ output goes high $(\overline{S R} / S R=1)$ when the device is deselected (CS1/CS1 $=1$ or $\mathrm{CS} 2=0)$ and returns low $(\overline{S R} / \mathrm{SR}=0)$ on the following trailing edge of the clock.

Typical CDP1802 Microprocessor System


FIGURE 1.

## Specifications CDP1852, CDP1852C

A $\overline{\text { CLEAR }}$ control is provided for resetting the port's register (D00-D07 $=0$ ) and service request flip-flop (input mode: $\overline{\mathrm{SR}} /$ $\mathrm{SR}=1$ and output mode. $\overline{\mathrm{SR}} / \mathrm{SR}=0$ )
The CDP1852 is functionally identical to the CDP1852C. The CDP1852 has a recommended operating voltage range of 4 to 10.5 volts, and the CDP1852C has a recom-
mended operating voltage range of 4 to 6.5 volts.
The CDP1852 and CDP1852C are supplied in 24-lead, hermetic, dual-in-line ceramic packages ( $D$ suffix), in 24-lead dual-in-line plastic packages (E suffix). The CDP1852C is also available in chip form ( H suffix).

MAXIMUM RATINGS, Absolute-Maximum Values:


RECOMMENDED OPERATING CONDITIONS at $T_{A}=$ Full Package Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | CDP1852 |  | CDP1852C |  |  |
|  | Min. | Max. | Min. | Max. |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | $\mathrm{V}_{\text {ss }}$ | $\mathrm{V}_{\text {DD }}$ | $\mathrm{V}_{\mathrm{ss}}$ | $\mathrm{V}_{\text {DD }}$ |  |



Fig 2 - Block diagram of CDP1852.


STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}$

| CHARACTERISTIC | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Vo <br> (V) | $V_{\text {in }}$ <br> (V) | $V_{D D}$ <br> (V) | CDP1852 |  |  | CDP1852C |  |  |  |
|  |  |  |  | Min. | Typ.* | Max. | Min. | Typ.* | Max. |  |
| Quiescent Device Current, lod | - | 0,5 | 5 | - | - | 10 | - | - | 50 | $\mu \mathrm{A}$ |
|  | - | 0,10 | 10 | - | - | 100 | - | - | - |  |
| Output Low Drive (Sink) Current, loL | 0.4 | 0,5 | 5 | 1.6 | 3.2 | - | 1.6 | 3.2 | - | mA |
|  | 0.5 | 0,10 | 10 | 3 | 6 | - | - | - | - |  |
| Output High Drive (Source) Current, Іон | 4.6 | 0,5 | 5 | -1.15 | -2.3 | - | -1.15 | -2.3 | - |  |
|  | 9.5 | 0,10 | 10 | -3 | -6 | - | - | - | - |  |
| Output Voltage Low Level, Vout | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  | - | 0,10 | 10 | - | 0 | 0.1 | - | - | - |  |
| Output Voltage High Level, VOH | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - |  |
|  | - | 0,10 | 10 | 9.9 | 10 | - | - | - | - |  |
| Input Low Voltage, VIL | 0.5,4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 |  |
|  | 0.5,9.5 | - | 10 | - | - | 3 | - | - | - |  |
| Input High Voltage, $V_{I H}$ | 0.5,4.5 | - | 5 | 3.5 | - | - | 3.5 | - | - |  |
|  | 0.5,9.5 | - | 10 | 7 | - | - | - | - | - |  |

STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}$ (Cont'd)

| CHARACTERISTIC | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Vo <br> (V) | VIN <br> (V) | $V_{D D}$ <br> (V) | CDP1852 |  |  | CDP1852C |  |  |  |
|  |  |  |  | Min. | Typ.* | Max. | Min. | Typ.* | Max. |  |
| Input Current, In | - | 0,5 | 5 | - | - | $\pm 1$ | - | - | $\pm 1$ | $\mu \mathrm{A}$ |
|  | - | 0,10 | 10 | - | - | $\pm 2$ | - | - | - |  |
| 3-State Output Leakage Current, lour | 0,5 | 0,5 | 5 | - | - | $\pm 1$ | - | - | $\pm 1$ |  |
|  | 0,10 | 0,10 | 10 | - | - | $\pm 2$ | - | - | - |  |
| Operating Current, loDi $\ddagger$ | - | 0,5 | 5 | - | 130 | 300 | - | 150 | 300 |  |
|  | - | 0,10 | 10 | - | 550 | 800 | - | - | - |  |
| Input Capacitance, $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance, Cout | - | - | - | - | 5 | 7.5 | - | - | - |  |

*Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$.
$\dagger_{\text {lot }}=l_{\text {OH }}=1 \mu \mathrm{~A}$
$\ddagger$ Operating current is measured at 2 MHz in an CDP1802 system with open outputs and a program of 6N55, 6NAA, 6N55, 6NAA, …--

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}= \pm 5 \%$,
$\mathrm{t}_{\mathrm{t}}, \mathrm{t}_{\mathrm{I}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$, and 1 TTL Load

| CHARACTERISTIC | $V_{D D}$ <br> (V) | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ.* | Max. |  |
| MODE 0 - Input Port (Fig. 4) |  |  |  |  |  |
| Minimum Select Pulse Width, ${ }_{\text {sw }}$ | 5 | - | 180 | 360 | ns |
|  | 10 | - | 90 | 180 |  |
| Minimum Write Pulse Width, ${ }_{\text {tww }}$ | 5 | - | 90 | 180 |  |
|  | 10 | - | 45 | 90 |  |
| Minimum Clear Pulse Width, tcle | 5 | - | 80 | 160 |  |
|  | 10 | - | 40 | 80 |  |
| Minimum Data Setup Time, tos | 5 | - | -10 | 0 |  |
|  | 10 | - | -5 | 0 |  |
| Mininum Data Hold Time, $\mathrm{t}_{\mathrm{OH}}$ | 5 | - | 75 | 150 |  |
|  | 10 | - | 35 | 75 |  |
| Data Out Hold Time, tooh $\dagger$ | 5 | 30 | 185 | 370 |  |
|  | 10 | 15 | 100 | 200 |  |
| Propagation Delay Times, $\mathrm{t}_{\text {FLH }}, \mathrm{t}_{\text {PHL }}$ : Select to Data Out $\dagger$, tsoo | 5 | 30 | 185 | 370 |  |
|  | 10 | 15 | 100 | 200 |  |
| Clear to SR, Trse | 5 | - | 170 | 340 |  |
|  | 10 | - | 85 | 170 |  |
| Clock to SR, tcse | 5 | - | 110 | 220 |  |
|  | 10 | - | 55 | 110 |  |
| Select to SR, tssR | 5 | - | 120 | 240 |  |
|  | 10 | - | 60 | 120 |  |

$\dagger$ Minimum value is measured from CS2, maximum value is measured from CS1/ $\overline{\mathrm{CS1}}$
*Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$

## INPUT PORT MODE 0 - TYPICAL OPERATION

## General Operation

When the mode control is tied to VSS, the CDP1852 becomes an input port. In this mode, the peripheral device places data into the CDP1852 with a strobe pulse and the CDP1852 signals the microprocessor that data is ready to be transferred on the
strobe's trailing edge via the $\overline{\mathrm{SR}}$ output line. The CDP1802 then issues an input instruction that enables the CDP1852 to place the information from the peripheral device on the data bus to be entered into a memory location and the accumulator of the microprocessor.


Fig 4 －MODE 0 input port timing waveforms and truth tables．


Fig 5 －Input port mode 0 functıonal diagram and waveforms－typical operation．

## Detailed Operation（See Fig 5）

The STROBE from the peripheral device places DATA into the 8 －bit register of the CDP1852 when it goes high and latches the DATA on its trailing edge The $\overline{S R}$ output is set low on the strobe＇s trailing edge This output is connected to a flag line of the CDP1802 microprocessor and software polling will determine that the flag line has gone low and peripheral data is ready to be transferred．The CDP1802 then issues an input instruction that places an $N_{x}$ line high． With the MRD line also high，the CDP1852 is selected and its output drivers place the

DATA from the peripheral device on the DATA BUS When the CDP1802 selected the CDP1852，it also selected and ad－ dressed the memory via one of the 16 inter－ nal address registers selected by an inter－ nal＂ X ＂regıster The data from the CDP1852 is therefore entered into the memory［Bus $\rightarrow M(R(X))]$ The data is also transferred to the $D$ register（accumulator）in the micro－ processor（Bus $\rightarrow$ D）．When the CDP1802＇s execute cycle is completed，the CDP1852 is deselected by the $N_{x}$ line returning low and its data output pins are tri－stated The $\overline{\mathrm{SR}}$ output returns high

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}= \pm 5 \%$,
$\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$, and 1 TTL Load

*Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$

## OUTPUT PORT MODE 1 - TYPICAL OPERATION

## General Operation

Connecting the mode control to $V_{D D}$ configures the CDP1852 as an output port. The output drivers are always on in this mode, so any data in the 8-bit register will be present at the data-out lines when the CDP1852 is selected. The N line and MRD connections between the CDP1852 and CDP1802 remain the same as in the input mode configuration, but now the clock input of the CDP1852 is tied to the TPB output of the

CDP1802 and the SR output of the CDP1852 will be used to signal the peripheral device that valid data is present on its input lines The microprocessor issues an output instruction, and data from the memory is strobed into the CDP1852 with the TPB pulse When the CDP1852 is deselected, the SR output goes high to signal the peripheral device.


Fig 6 - MODE 1 output port timing waveforms and truth tables


Fig 7 - Output port mode 1 functıonal dıagram and waveforms - typical operation

## Detailed Operation (See Fig 7)

The CDP1802 issues an output instruction The $N_{x}$ line goes high and the MRD line goes low. The memory is accessed $M(R(X)$ ) $\rightarrow$ BUS and places data on the DATA BUS. This data are strobed into the 8-bit register of the CDP1852 when TPB goes high and latched on the TPB's trailing edge. The
valid data thus appears on the CDP1852 output lines When the CDP1802 output instruction cycle is complete, the $\mathrm{N}_{\mathrm{x}}$ line goes low and the SR output goes high. SR will remain high until the trailing edge of the next TPB pulse, when it will return low.


Fig. 8 - Execution of a " 65 " output instruction showing momentary selection of input port "D".

## Application Information

In a CDP1800 series microprocessor-based system where MRD is used to distinguish between INP and OUT instructions, an INP instruction is assumed to occur at the beginning of every I/O cycle because MRD starts high. Therefore, at the start of an OUT instruction, which uses the same 3-bit N code as that used for selection of an input port, the input device is selected for a short time (see Fig. 8). This condition forces SR low and sets the internal SR latch (see Fig. 3 ). In a small system with unique $N$ codes


[^5]Fig. 9-CDP1853 tıming waveforms.
for inputs and outputs, this situation does not arise. Using the CDP1853 N-bit decoder or equivalent logic to decode the N lines after TPA prevents dual selection in larger systems (see Fig. 9 and Fig. 10).


Fig. 10-CDP1853 functional diagram.

CDP1852/3 CDP1852C/3

## Features

- Static Silicon-Gate CMOS Circuitry
- Parallel 8-Bit Data Register and Buffer
- Handshaking Via Service Request Flip-Flop
- Low Quiescent and Operating Power
- Interfaces Directly with CDP1800Series Microprocessors
- Single Voltage Supply
- Full Military Temperature Range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$


## Description

The CDP1852/3 and CDP1852C/3 are parallel, 8 -bit, mode-programmable inputoutput ports. They are compatible and will interface directly with CDP1800-series microprocessors. They are also useful as $\mathbf{8}$ bit address latches when used with the CDP1800 multiplexed address bus and as I/O ports in general-purpose applications.

The mode control is used to program the device as an input port ( $\operatorname{mode}=0$ ) or as an output port (mode $=1$ ). The $\overline{\text { SR/SR output can be used as a signal to indicate when data is }}$ ready to be transferred. In the input mode, a peripheral device can strobe data into the CDP1852/3, and microprocessor can read that data by device selection. In the output mode, a microprocessor strobes data into the CDP1852/3, and handshaking is established with a peripheral device when the CDP1852/3 is deselected.

In the input mode, data at the data-in terminals (D10-D17) is strobed into the port's 8 -bit register by a high (1) level on the clock line. The negative high-to-low transition of the clock latches the data in the register and sets the service request output low ( $\overline{\mathrm{SR}} / \mathrm{SR}=$ 0 ). When CS1/ $\overline{\mathrm{CS} 1}$ and CS2 are high (CS1/CS1 and CS2 $=1$ ), the 3 -state output drivers are enabled and data in the 8-bit register appear at the data-out terminals (D00-D07). When either CS1/ $\overline{\mathrm{CS} 1}$ or CS2 goes low (CS1/ $\overline{\mathrm{CS1}}$ or $\mathrm{CS} 2=0$ ), the data-out terminals are tristated and the service request output returns high $(\overline{\mathrm{SR}} / \mathrm{SR}=1)$.

In the output mode, the output drivers are enabled at all times. Data at the data-in terminals (D10-D17) is strobed into the 8 bit register when CS1/CS1 is low (CS1/CS1 $=0$ ) and CS2 and the clock are high (1), and are present at the data-out terminals (D00-D07). The negative high-to-low transition of the clock latches the data in the register. The SR/SR output goes high $\overline{S R} / S R=1$ ) when the device is deselected (CS1/ $\overline{C S 1}=1$ or $C S 2=0$ ) and returns low $(\overline{S R} / S R=0)$ on the following trailing edge of the clock.
A CLEAR control is provided for resetting the port's register (DOO-DO7 $=0$ ) and service request flip-flop (input mode: $\overline{\mathrm{SR}} / \mathrm{SR}=1$ and output mode: $\overline{\mathrm{SR}} / \mathrm{SR}=0$ ).

The CDP $1852 / 3$ is functionally identical to the CDP1852C/3. The CDP1852/3 has a recommended operating voltage range of 4 to 10.5 volts, and the CDP1852C/3 has a recommended operating voltage range of 4 to 6.5 volts.

The CDP $1852 / 3$ and CDP1852C/3 are supplied in 24-lead, dual-in-line side-brazed ceramic packages ( D suffix) that conforms to the requirements and dimensions specified in MIL-38510 Case Outline D-3.

| Pinout |
| :--- | :--- |
| 24-LEAD DIP |
| TOP VIEW |

Block Diagram of CDP1852/3



FIGURE 2. CDP1852/3 LOGIC DIAGRAM

## Absolute Maximum Ratings

| DC Supply Voltage Range, (VD): <br> (All Voltages Referenced to $\mathrm{V}_{\mathrm{SS}}$ Terminal) |  |
| :---: | :---: |
| CDP1852/3 | -0.5 V to +11 V |
| CDP1852C/3 | -0.5V to +7V |
| Input Voltage Range, All Inputs | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, any One Input. | .$\pm 10 \mathrm{~mA}$ |
| Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ ) |  |
| $\mathrm{T}_{\text {A }}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (Package Type D) . . . . . . . . . . . . 500mW |  |
| $\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Package Type D). | Derate Linearly at |
|  | mW/ ${ }^{\circ} \mathrm{C}$ to 200 mW |

Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range (All Package Types).

100 mW
Operating Temperature Range ( $T_{A}$ ): Package Type D $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stq }}$ ) $\ldots \ldots . . . . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{In}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10s max
$+265^{\circ} \mathrm{C}$
$12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW
Recommended Operating Conditions $T_{A}=$ Full-Package Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges.

| CHARACTERISTIC | LImis |  |  |  | UNTTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1852/3 |  | CDP1852C/3 |  |  |
|  | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | $\mathrm{V}_{\text {Ss }}$ | $V_{D D}$ | $\mathrm{V}_{\mathrm{ss}}$ | $V_{D D}$ | V |

Specifications CDP1852/3, CDP1852C/3
Static Electrical Characteristics $\mathrm{V}_{\mathbb{N}}=0$ or $\mathrm{V}_{\mathrm{DD}}$, Except as Noted

| CHARACTERISTIC | SYMBOL | TEST CONDITIONS | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Quiescent Device Current (Note 1) | IDD | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | - | 10 | - | 100 | $\mu \mathrm{A}$ |
|  |  | $V_{D D}=10 \mathrm{~V}$ | - | 20 | - | 300 | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | 1 OL | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.4 \mathrm{~V}$ | 2.6 | - | 1.9 | - | mA |
|  |  | $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V}$ | 6.1 | - | 4.1 | - | mA |
| Output High Drive (Source) Current | ${ }^{\text {IOH }}$ | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=4.6 \mathrm{~V}$ | -1.8 | - | -1.3 | - | mA |
|  |  | $V_{D D}=10 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=9.5 \mathrm{~V}$ | -4.4 | - | -2.9 | - | mA |
| Output Voitage Low Level | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=0 \mu \mathrm{~A}$ | - | 0.1 | - | 0.2 | V |
|  |  | $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=0 \mu \mathrm{~A}$ | - | 0.1 | - | 0.2 | V |
| Output Voltage High Level | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=0 \mu \mathrm{~A}$ | 4.9 | - | 4.8 | - | V |
|  |  | $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{l}_{\mathrm{OL}}=0 \mu \mathrm{~A}$ | 9.9 | - | 9.8 | - | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.2,4.8 \mathrm{~V}$ | - | 1.5 | - | 1.5 | V |
|  |  | $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.2,9.8 \mathrm{~V}$ | - | 3 | - | 3 | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.2,4.8 \mathrm{~V}$ | 3.5 | - | 3.5 | - | V |
|  |  | $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.2,9.8 \mathrm{~V}$ | 7 | - | 7 | - | V |
| Input Leakage Low | IIL | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ | - | -1 | - | -5 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=0 \mathrm{~V}$ | - | -1 | - | -5 | $\mu \mathrm{A}$ |
| Input Leakage High | $\mathrm{I}_{\mathrm{H}}$ | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=5 \mathrm{~V}$ | - | 1 | - | 5 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=10 \mathrm{~V}$ | - | 1 | - | 5 | $\mu \mathrm{A}$ |
| 3-State Output Leakage Low | lozı | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}$ | - | -1 | - | -5 | $\mu \mathrm{A}$ |
|  |  | $V_{D D}=10 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}$ | - | -1 | - | -5 | $\mu \mathrm{A}$ |
| 3-State Output Leakage High | $\mathrm{I}_{\text {OZH }}$ | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=5 \mathrm{~V}$ | - | 1 | $\cdot$ | 5 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=10 \mathrm{~V}$ | - | 1 | - | 5 | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | Note 2 | - | 10 | - | 10 | pF |
| Output Capacitance | Cout | Note 2 | - | 15 | - | 15 | pF |

NOTES:

1. The CDP $1852 \mathrm{C} / 3$ meets all 5 volt Static Electrical Characteristics of the CDP1852/3 except $+125^{\circ} \mathrm{C}$ Quiescent Device Current for which the limit is $\mathrm{I}_{\mathrm{DD}}=300 \mu \mathrm{~A}$.
2. Input and Output Capacitance are guaranteed but not tested.

## Static Burn-in Circuit

| TYPE NO. | $V_{D D}$ | TEMPERATURE | TIME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CDP1852 $/ 3$ | 11 V | $+125^{\circ} \mathrm{C}$ | 160 Hrs . Min. |
| CDP1852C $/ 3$ | 7 V | $+125^{\circ} \mathrm{C}$ | 160 Hrs . Min. |

Dynamic Electrical Characteristics Mode $=0$ Input Port, See Figure 3, Input tr, tf $\leq 15 \mathrm{~ns} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | $\begin{gathered} V_{D D} \\ \text { vOLTS } \end{gathered}$ | LIMITS* |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | (Note 1) MIN | MAX | (Note 1) MIN | MAX |  |
| Select Duration | $t_{\text {sw }}$ | 5 | 250 | - | 360 | - | ns |
|  |  | 10 | 150 | $\cdot$ | 180 | - | ns |
| Clock Pulse Width | ${ }^{\text {tww }}$ | 5 | 150 | - | 200 | - | ns |
|  |  | 10 | 90 | - | 110 | - | ns |
| Clear Pulse Width | $\mathrm{t}_{\text {cLR }}$ | 5 | 110 | - | 160 | - | ns |
|  |  | 10 | 50 | $\cdot$ | 80 | $\cdot$ | ns |
| Data-In to Clock Fall Setup Time | $\mathrm{t}_{\mathrm{DS}}$ | 5 | -10 | $\bullet$ | -10 | - | ns |
|  |  | 10 | -5 | - | -5 | - | ns |
| Data-In After Clock Fall Hold Time | $\mathrm{t}_{\mathrm{DH}}$ | 5 | 150 | - | 170 | - | ns |
|  |  | 10 | 70 | $\bullet$ | 100 | $\bullet$ | ns |
| Propagation Delay Times: Clear to $\overline{\mathrm{SR}}$ | $t_{\text {RSR }}$ | 5 | - | 200 | - | 340 | ns |
|  |  | 10 | - | 110 | - | 170 | ns |
| Clock to $\overline{\mathrm{SR}}$ | $\mathrm{t}_{\text {CSR }}$ | 5 | - | 175 | - | 220 | ns |
|  |  | 10 | - | 110 | $\cdot$ | 130 | ns |
| Deselect to $\overline{\mathrm{SR}}$ | $\mathrm{t}_{\text {SSR }}$ | 5 | - | 175 | $\bullet$ | 240 | ns |
|  |  | 10 | - | 110 | $\cdot$ | 120 | ns |

NOTE: 1. Time required by a device to allow for the indicated function.


| MODE $=0$ TRUTH TABLE |  |  |  |
| :---: | :---: | :---: | :--- |
| CLOCK | CS1-CS2 (Note 1) | $\overline{\text { CLEAR }}$ | DATA OUT EQUALS |
| X | 0 | X | High Impedance |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | Data Latch |
| 1 | 1 | X | Data In |



NOTE: 1. CS1 - CS2 $=C S 1=1, C S 2=1$
FIGURE 3. MODE $=0$ INPUT PORT TIMING WAVEFORMS AND TRUTH TABLES

Dynamic Electrical Characteristics Mode $=1$ Output Port, See Figure 4, Input tr, tf $\leq 15 \mathrm{~ns} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | $\begin{gathered} \mathbf{v}_{\mathrm{DD}} \\ \text { vOLTS } \end{gathered}$ | LIMITS* |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | (Note 1) MIN | MAX | (Note 1) MIN | MAX |  |
| Clock Pulse Width | $\mathrm{t}_{\text {cle }}$ | 5 | 170 | - | 260 | - | ns |
|  |  | 10 | 90 | - | 130 | - | ns |
| Write Width Duration | ${ }^{\text {tww }}$ | 5 | 200 | - | 260 | - | ns |
|  |  | 10 | 110 | - | 130 | - | ns |
| Clear Pulse Width | $\mathrm{t}_{\text {CLR }}$ | 5 | 110 | - | 135 | $\cdot$ | ns |
|  |  | 10 | 60 | - | 75 | - | ns |
| Data-In to Clock Fall Setup Time | $\mathrm{t}_{\mathrm{DS}}$ | 5 | -10 | - | -10 | - | ns |
|  |  | 10 | -5 | - | -5 | - | ns |
| Data Hold from Write Termination | $\mathrm{t}_{\mathrm{DH}}$ | 5 | 130 | - | 170 | $\cdot$ | ns |
|  |  | 10 | 70 | - | 90 | - | ns |
| Select-After Clock-Fall Hold Time | ${ }^{\text {s }}$ H | 5 | 0 | - | 0 | $\cdot$ | ns |
|  |  | 10 | 0 | - | 0 | - | ns |
| Propagation Delay Times: Clear to Data | $t_{\text {RDO }}$ | 5 | - | 215 | - | 290 | ns |
|  |  | 10 | - | 140 | - | 190 | ns |
| Write to Data Out | twoo | 5 | - | 250 | - | 350 | ns |
|  |  | 10 | - | 130 | - | 190 | ns |
| Data In to Data Out | $\mathrm{t}_{\text {DOO }}$ | 5 | - | 150 | $\cdot$ | 200 | ns |
|  |  | 10 | - | 80 | $\cdot$ | 100 | ns |
| Clear to SR | $t_{\text {RSA }}$ | 5 | - | 175 | - | 240 | ns |
|  |  | 10 | - | 120 | $\cdot$ | 160 | ns |
| Clock to SR | ${ }^{\text {ctsR }}$ | 5 | - | 170 | $\cdot$ | 240 | ns |
|  |  | 10 | - | 90 | - | 120 | ns |
| Deselect to SR | ${ }_{\text {tss }}$ | 5 | - | 170 | - | 240 | ns |
|  |  | 10 | - | 90 | - | 120 | ns |

NOTE: 1. Time required by a device to allow for the indicated function.


| MODE $=1$ TRUTH TABLE |  |  |  | SERVICE REQUEST TRUTH TABLE |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CLOCK | $\overline{\text { CS1-CS2 }}$ (Note 1) | CLEAR | DATA OUT EQUALS |  |  |
| 0 | X | 0 | 0 | $\overline{\mathrm{CS1}} \sim$ | Clock |
| 0 | X | 1 | Data Latch |  |  |
| X | 0 | 1 | Data Latch | CS2 | $\overline{\text { CLEAR }}$ |
| 1 | 1 | X | Data In | $\overline{\mathrm{SR}} / \mathrm{SR}=1$ | $\overline{\mathrm{SP}} / \mathrm{SR}=0$ |

NOTE: 1. $\overline{\mathrm{CS} 1}-\mathrm{CS} 2=\overline{\mathrm{CS} 1}=0, \mathrm{CS} 2=1$
FIGURE 4. MODE $=1$ OUTPUT PORT TIMING WAVEFORMS AND TRUTH TABLES

HARRIS
SEMICONDUCTOR

# CDP1853 CDP1853C 

N-Bit 1 of 8 Decoder

## Features

- Provides Direct Control of Up to 7 Input and 7 Output Devices
- CHIP ENABLE (CE) Allows Easy Expansion for Multilevel VO Systems


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 5V | 10V |
| :---: | :---: | :--- | :---: |
| Plastic DIP <br> Burn-in | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1853CE | CDP1853E |
|  |  | CDP1853CEX | - |
| Ceramic DIP <br> Burn-in <br> * 883B | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1853CD | CDP1853D |
|  |  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | CDP1853 1853 CDX |

* Respective specifications are included at the end of this data sheet.


## Description

The CDP1853 and CDP1853C are 1 of 8 decoders designed for use in general purpose microprocessor systems. These devices, which are functionally identical, are specifically designed for use as gated N -bit decoders and interface directly with the 1800-series microprocessors with out additional components. The CDP1853 has a recommended operating voltage range of 4 to 10.5 volts, and the CDP1853C has a recommended operating voltage range of 4 to 6.5 volts.
When CHIP ENABLE (CE) is high, the selected output will be true (high) from the trailing edge of CLOCK A (high-to-low transition) to the trailing edge of CLOCK B (high-to-low transition). All outputs will be low when the device is not selected ( $C E=0$ ) and during conditions of CLOCK A and CLOCK B as shown in Figure 2. The CDP1853 inputs NO, N1, N2, CLOCK A, and CLOCK B are connected to an 1800-series microprocessor outputs NO, N1, N2, TPA, and TPB respectively, when used to decode I/O commands as shown in Figure 5. The CHIP ENABLE (CE) input provides the capability for multiple levels of decoding as shown in Figure 6.

The CDP1853 can also be used as a general 1 of 8 decoder for I/O and memory system applications as shown in Figure 4.

The CDP1853 and CDP1853C are supplied in hermetic 16 -lead dual-in-line ceramic (D suffix) and plastic (E suffix) packages.


CDP1853 Functional Diagram


FIGURE 1.

TRUTH TABLE

| CE | CL A | CL B | EN |
| :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | Qn-1* |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |
| 0 | X | X | 0 |


| N2 | N1 | N0 | EN | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ | $\mathbf{4}$ | $\mathbf{5}$ | $\mathbf{6}$ | $\mathbf{7}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| $\mathbf{X}$ | X | X | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

1 = High level, $0=$ Low level, $X=$ Don't care

* Qn-1 = Enable remains in previous state.

MAXIMUM RATINGS, Absolute-Maximum Values:
DC SUPPLY-VOLTAGE RANGE, (VDD)
(All voltage values referenced to $\mathrm{V}_{\mathrm{SS}}$ terminal
CDP $1853 \quad \ldots . . . . . . . . . .$.
-0.5 to +11 V
CDP1853C
-0.5 to +7 V
INPUT VOLTAGE RANGE, ALL INPUTS -0.5 to $V_{D D}+0.5 \mathrm{~V}$
DC INPUT CURRENT, ANY ONE INPUT $\pm 10 \mathrm{~mA}^{\prime}$
OPERATING-TEMPERATURE RANGE ( $T_{A}$ ):
CER AMIC PACKAGES (D SUFFIX TYPES) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-\mathbf{5 5}$ to + $\mathbf{1 2 5}{ }^{\circ} \mathrm{C}$
PLASTIC PACKAGES (E SUFFIX TYPES) -40 to $+85^{\circ} \mathrm{C}$
STORAGE TEMPERATURE RANGE ( $T_{\text {stg }}$ ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 to $+150^{\circ} \mathrm{C}$ LEAD TEMPERATURE (DURING SOLDERING).

At distance $1 / 16 \pm 1 / 32$ inch ( $1.59 \pm 0.79 \mathrm{~mm}$ ) from case for 10 s max. $+265^{\circ} \mathrm{C}$

STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}$. Except as noted

| CHARACTERISTIC | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { Vo } \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & \text { VIN } \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & \text { VDD } \\ & \text { (V) } \end{aligned}$ | CDP1853 |  |  | CDP1853C |  |  |  |
|  |  |  |  | Min. | $\text { Typ. }{ }^{\dagger}$ | Max. | Min. | Typ. ${ }^{\dagger}$ | Max. |  |
| Quiescent Device Current, IL | - | - | 5 | - | 1 | 10 | - | 5 | 50 | $\mu \mathrm{A}$ |
|  | - | - | 10 | - | 10 | 100 | - | - | - |  |
| Output Low Drive (Sink) Current, ${ }^{1} \mathrm{OL}$ | 0.4 | 0,5 | 5 | 1.6 | 3.2 | - | 1.6 | 3.2 | - | mA |
|  | 0.5 | 0,10 | 10 | 2.6 | 5.2 | - | - | - | - |  |
| Output High Drive (Source Current) ${ }^{1} \mathrm{OH}$ | 4.6 | 0,5 | 5 | -1.15 | -2.3 | - | -1.15 | -2.3 | - | mA |
|  | 9.5 | 0,10 | 10 | -2.6 | -5.2 | - | - | - | - |  |
| Output Voltage Low-Level $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  | - | 0,10 | 10 | - | 0 | 0.1 | - | - | - |  |
| Output Voltage High Level $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - |  |
|  | - | 0,10 | 10 | 9.9 | 10 | - | - | - | - |  |
| Input Low Voltage$v_{I L}$ | 0.5,4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  | 1,9 | - | 10 | - | - | 3 | - | - | - |  |
| Input High Voltage$v_{I H}$ | 0.5,4.5 | - | 5 | 3.5 | - | - | 3.5 | - | - |  |
|  | 1,9 | - | 10 | 7 | - | - | - | - | - |  |
| Input Leakage Current IIN | Any Input | 0,5 | 5 | - | - | $\pm 1$ | - | - | $\pm 1$ | $\mu \mathrm{A}$ |
|  |  | 0,10 | 10 | - | - | $\pm 1$ | - | - | - |  |
| Operatıng Current 'DD1 ${ }^{*}$ | 0,5 | 0,5 | 5 | - | 50 | 100 | - | 50 | 100 | $\mu \mathrm{A}$ |
|  | 0,10 | 0,10 | 10 | - | 150 | 300 | - | - | - |  |
| Input Capacitance $C_{I N}$ | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | $\rho \mathrm{F}$ |
| Output Capacitance $\mathrm{C}_{\text {OUT }}$ | - | - | - | - | 10 | 15 | - | 10 | 15 | $\rho \mathrm{F}$ |

$\dagger$ Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltage.

* Operating current measured in a CDP1802 system at 2 MHz with outputs floating.
- $\mathrm{I}_{\mathrm{OL}}=\mathrm{I}_{\mathrm{OH}}=1_{\mu} \mathrm{A}$

OPERATING CONDITIONS at $T_{A}=$ Full Package-Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | CDP1853 | CDP1853C |  | UNITS |  |
|  | Min. | Max. | Min. |  |  |
| Supply-Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Recommended Input Voltage Range | $V_{S S}$ | $V_{D D}$ | $V_{S S}$ | $V_{D D}$ | V |

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\text {DD }}= \pm 5 \%$,
$V_{\text {IH }}=0.7 \mathrm{~V}_{D D}, V_{\text {IL }}=0.3 \mathrm{~V}_{D D}, t_{r}, t_{f}=20 \mathrm{~ns}, C_{L}=100 \mathrm{pF}$

| CHARACTERISTIC | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1853 |  | CDP1853C |  |  |
|  |  | Typ. | Max. | Typ. | Max. |  |
| Propagation Delay Time: CE to Output, ${ }^{\text {t EOH }}$, ${ }^{\text {t }}$ EOL | 5 | 175 | 275 | 175 | 275 | ns |
|  | 10 | 90 | 150 | - | - |  |
| N to Outputs, ${ }^{\text {NOH }}$, ${ }^{\text {N }} \mathrm{NOL}$ | 5 | 225 | 350 | 225 | 350 | ns |
|  | 10 | 120 | 200 | - | - |  |
| Clock A to Output, $\mathrm{t}_{\text {AO }}$ | 5 | 200 | 300 | 200 | 300 | ns |
|  | 10 | 100 | 150 | - | - |  |
| Clock B to Output, $\mathrm{t}_{\mathrm{BO}}$ | 5 | 175 | 275 | 175 | 275 | ns |
|  | 10 | 90 | 150 | - | - |  |
| Minimum Pulse Widths: Clock A, t CACA | 5 | 50 | 75 | 50 | 75 | ns |
|  | 10 | 25 | 50 | - | - |  |
| Clock B, ${ }^{\text {c }}$ CBCB | 5 | 50 | 75 | 50 | 75 |  |
|  | 10 | 25 | 50 | - | - |  |

Note 1: Maximum limits of minimum characteristics are the values above which all devices function.
Note 2: Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages.

c) CLOCK A TO OUTPUT (0-7) DELAY TIME


92 CM 29023 B
Fig. 2 - Propagation delay time diagrams.


Fig. 3 - Timing dıagram.

-2:5-29C20
Fig. 4 - N-bit decoder used as a 1 of 8 decoder.


Fig. 5 - N-bit decoder in a one-level I/O system


Fig. 6 - Two-level I/O using CDP1853 and CDP1852.

## Features

- Provides Direct Control of Up to 7 Input and 7 Output Devices When used with a CDP1800-Series Microprocessor
- CHIP ENABLE (CE) Allows Easy Expansion for Multi-level VO Systems


## Pinout



## Description

The CDP1853/3 and CDP1853C/3 are high-reliability 1 of 8 decoders designed for use in general purpose microprocessor systems. These devices, which are functionally identical, are specifically designed for use as gated N -bit decoders and interface directly with the 1800-series microprocessors without additional components. The CDP1853/3 has a recommended operating voltage range of 4 to 10.5 volts, and the CDP $1853 \mathrm{C} / 3$ has a recommended operating voltage range of 4 to 6.5 volts.

When CHIP ENABLE (CE) is high, the selected output will be true (high) from the trailing edge of CLOCK A (high-to-low transition) to the trailing edge of CLOCK $\mathbf{B}$ (high-to-low transition). All outputs will be low when the device is not selected ( $C E=0$ ) and during conditions of CLOCK A and CLOCK B as shown in Figure 2 when used with the 1800-series microprocessor. The CDP1853/3 inputs NO, N1, N2, CLOCK A, and CLOCK B are connected to outputs NO, N1, N2, TPA, and TPB respectively, when used to decode I/O commands as shown in Figure 5. The CHIP ENABLE (CE) input provides the capability for multiple levels of decoding as shown in Figure 6.
The CDP1853/3 can also be used as a general purpose 1 of 8 decoder for I/O and memory system applications as shown in Figure 4.

The CDP1853/3 and CDP1853C/3 are supplied in hermetic 16-lead dual-in-line ceramic packages ( $D$ suffix) .

## CDP1853/3 Functional Diagram



FIGURE 1.

TRUTH TABLE

| CE | CL A | CL B | EN |
| :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | Qn-1* |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |
| 0 | $X$ | $X$ | 0 |


| N2 | N1 | N0 | EN | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ | $\mathbf{4}$ | $\mathbf{5}$ | $\mathbf{6}$ | $\mathbf{7}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| $\mathbf{1}$ | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| $\mathbf{X}$ | $\mathbf{X}$ | $\mathbf{X}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

1 = High level, $0=$ Low level, $X=$ Don't care

* $Q_{n-1}=$ Enable remains in previous state.

Specifications CDP1853/3, CDP1853C/3

## Static Electrical Characteristics

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{0} \\ & (V) \end{aligned}$ | $\mathbf{V}_{\mathbb{N}}$(V) | $V_{D D}$ <br> (V) | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Quiescent Device Current | Iss (Note 1) | - | 0,5 | 5 | -50 | - | -100 | - | $\mu \mathrm{A}$ |
|  |  | - | 0,10 | 10 | -500 | - | -1000 | - | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | ${ }_{\mathrm{OL}}$ | 0.4 | - | 5 | 2.3 | - | 1.6 | - | mA |
|  |  | 0.5 | - | 10 | 3.7 | - | 2.6 | - | mA |
| Output High Drive (Source) Current | IOH | 4.6 | - | 5 | - | -1.7 | - | -1.2 | mA |
|  |  | 9.5 | - | 10 | - | -3.7 | - | -2.6 | mA |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ (Note 2) | - | 0,5 | 5 | - | 0.1 | - | 0.2 | V |
|  |  | - | 0,10 | 10 | - | 0.1 | - | 0.2 | V |
| Output Voltage High-Level | $\mathrm{V}_{\mathrm{OH}}$ <br> (Note 2) | - | 0,5 | 5 | 4.9 | - | 4.8 | - | V |
|  |  | - | 0,10 | 10 | 9.9 | - | 9.8 | - | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | 0.8,4.2 | - | 5 | - | 1.5 | - | 1.5 | V |
|  |  | 1,9 | - | 10 | - | 3 | - | 3 | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.8, 4.2 | - | 5 | 3.5 | - | 3.5 | - | V |
|  |  | 1, 9 | - | 10 | 7 | - | 7 | - | V |
| Input Leakage Low | IIL | - | 0 | 5 | -1 | - | -5 | - | $\mu \mathrm{A}$ |
|  |  | - | 0 | 10 | -1 | - | -5 | - | $\mu \mathrm{A}$ |
| Input Leakage High | $\mathrm{I}_{\mathrm{H}}$ | - | 5 | 5 | - | 1 | - | 5 | $\mu \mathrm{A}$ |
|  |  | - | 10 | 10 | - | 1 | - | 5 | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ (Note 2) | - | - | - | - | 10 | - | 10 | pF |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ (Note 2) | - | - | - | - | 15 | - | 15 | pF |

NOTES:

1. The CDP 1853 C meets all 5 -volt static electrical characteristics of
the CDP1853 except quiescent device current for which the limits are: $\mathrm{I}_{\mathrm{SS}}=-500 \mu \mathrm{~A}$ © $-55^{\circ} \mathrm{C}$ and $+25^{\circ} \mathrm{C}$ and $\mathrm{I}_{\mathrm{SS}}=-1000 \mu \mathrm{~A}$ © $+125^{\circ} \mathrm{C}$.

Dynamic Electrical Characteristics See Figure 2, $C_{L}=100 \mathrm{pF}, \mathrm{tr}, \mathrm{tt}=15 \mathrm{~ns}$

| CHARACTERISTIC |  | $\begin{aligned} & V_{D D} \\ & (\mathrm{~V}) \end{aligned}$ | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | -55 | $5^{\circ} \mathrm{C}$ |  |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Propagation Delay Time:Chip Enable (CE) to Output High | $\mathrm{t}_{\text {toh }}$ | 5 | - | 175 | - | 275 | ns |
|  | ${ }_{\text {teOH }}$ | 10 | - | 90 | - | 150 | ns |
| Disable to Output Low | $\mathrm{t}_{\text {EOL }}$ | 5 | - | 295 | $\cdot$ | 400 | ns |
|  |  | 10 | - | 200 | - | 250 | ns |
| N Input to Output | $\mathrm{t}_{\mathrm{NO}}$ | 5 | - | 225 | - | 315 | ns |
|  |  | 10 | - | 120 | - | 165 | ns |
| Clock A to Output Low | $\mathrm{t}_{\mathrm{AO}}$ | 5 | - | 210 | - | 300 | ns |
|  |  | 10 | - | 110 | - | 150 | ns |
| Clock B to Output Low | $\mathrm{t}_{\mathrm{BO}}$ | 5 | - | 295 | - | 400 | ns |
|  |  | 10 | - | 200 | - | 250 | ns |
| $\begin{array}{\|c} \hline \text { Pulse Width: } \\ \text { Clock A } \\ \hline \text { Clock B } \end{array}$ | $\mathrm{t}_{\text {caca }}$ | 5 | 50 | - | 75 | - | ns |
|  |  | 10 | 25 | - | 50 | - | ns |
|  | $\mathrm{t}_{\text {cbib }}$ | 5 | 50 | - | 75 | - | ns |
|  |  | 10 | 25 | - | 50 | - | ns |

Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1853/3 |  | CDP1853C/3 |  |  |
|  | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input voltage Range | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |

```
Absolute Maximum Ratings
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|l|}{\begin{tabular}{l}
DC Supply Voltage Range, ( \(V_{D D}\) ): \\
(All Voltages Referenced to \(\mathrm{V}_{\mathrm{ss}}\) Terminal)
\end{tabular}} \\
\hline CDP1853/3 & -0.5V to +11V \\
\hline CDP1853C/3 & -0.5 V to +7V \\
\hline Input Voltage Range, All Inputs & -0.5 V to \(\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}\) \\
\hline DC Input Current, Any One Input. & . \(\pm 10 \mathrm{~mA}\) \\
\hline \multicolumn{2}{|l|}{Power Dissipation Per Package ( \(\mathrm{P}_{\mathrm{D}}\) )} \\
\hline \(\mathrm{T}_{A}=-55^{\circ} \mathrm{C}\) to \(+100^{\circ} \mathrm{C}\) (Package Type D) & 500 mW \\
\hline \(\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}\) to \(+125^{\circ} \mathrm{C}\) (Package Type D) & Derate Linearly at \\
\hline & mW/ \({ }^{\circ} \mathrm{C}\) to 200 mW \\
\hline
\end{tabular}
```

Device Dissipation Per Output Transistor $\mathrm{T}_{\mathrm{A}}$ = Full Package Temperature Range (All Package Types) 100 mW
Operating Temperature Range ( $\mathrm{T}_{\mathrm{A}}$ ):
Package Type D
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature Range ( $T_{\text {stg }}$ ).
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{In}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10s max $+265^{\circ} \mathrm{C}$

## Timing Diagrams


(a) N-INPUTS TO OUTPUTS DELAY TIME

(b) Ce to output delay time

(c) CLOCK B TO OUTPUT DELAY time

(d) CLOCK A TO OUTPUT DELAY TIME

FIGURE 2. PROPAGATION DELAY TIME DIAGRAMS


FIGURE 3. TIMING DIAGRAM


FIGURE 4. N-BIT DECODER USED AS A 1 OF 8 DECODER


Figure 4. N-BIT DECODER IN A ONE-LEVEL VO SYSTEM

Bias/Static Burn-in Circuit


All Resistors are $47 \mathrm{k} \Omega \pm 20 \%$


# 8-Bit Programmable Multiply/Divide Unit 

## Features

- Cascadable Up to 4 Units for 32-Bit by 32-Bit Multiply or 64ㄴ32 Bit Divide
- 8-Bit by 8 -Bit Multiply or $16 \div 8$ Bit Divide in $5.6 \mu \mathrm{~s}$ at 5 V or $2.8 \mu \mathrm{~s}$ at 10 V
- Direct Interface to CDP1800-Series Microprocessors
- Easy Interface to Other 8-Bit Microprocessors
- Significantly Increases Throughput of Microprocessor Used for Arithmetic Calculations


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 5V | 10V |
| :---: | :---: | :--- | :---: |
| Plastic DIP <br> Burn-in | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1855CE | CDP1855E |
|  |  | CDP1855CEX | - |
| Ceramic DIP <br> Burn-in | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1855CD | CDP1855D |
|  |  | CDP1855CDX | - |

## Description

The CDP1855 and CDP1855C are CMOS 8-bit multiply/ divide units which can be used to greatly increase the capabilities of 8 -bit microprocessors. They perform multiply and divide operations on unsigned, binary operators. In general, microprocessors do not contain multiply or divide instructions and even efficiently coded multiply or divide subroutines require considerable memory and execution time. These multiply/divide units directly interface to the CDP1800-series microprocessors via the N -lines and can easily be configured to fit in either the memory or I/O space of other 8 -bit microprocessors.
The multiple/divide unit is based on a method of multiplying by add and shift right operations and dividing by subtract and shift left operations. The device is structured to permit cascading identical units to handle operands up to 32 bits.
The CDP1855 and CDP1855C are functionally identical. They differ in that the CDP1855 has a recommended operating voltage range of 4 V to 10.5 V , and the CDP1855C, a recommended operating voltage range of 4 V to 6.5 V .
The CDP1855 and CDP1855C types are supplied in a 28lead hermetic dual-in-line ceramic package (D suffix) and in a 28 lead dual-in-line plastic package ( E suffix). The CDP1855C is also available in chip form (H suffix).

Pinout


## Circuit Configuration



## MAXIMUM RATINGS, Absolute-Maximum Values:

```
DC SUPPLY-VOLTAGE RANGE, (VDD)
    (Voltage referenced to VSS Terminal)
        CDP1855.
                                -0.5 to +11 V
        CDP1855C
                                -0.5 to +7 V
INPUT VOLTAGE RANGE, ALL INPUTS
                0.5 to VDD +0.5 V
DC INPUT CURRENT, ANY ONE INPUT
                \pm10 mA
POWER DISSIPATION PER PACKAGE (PD):
```




```
    For TA = -55 to 100}\mp@subsup{}{}{\circ}\textrm{C}\mathrm{ (PACKAGE TYPE D).
                                ............................. . 500 mW
    For TA}=+100\mathrm{ to +125}\mp@subsup{}{}{\circ}\textrm{C}\mathrm{ (PACKAGE TYPE D)
                                Derate Lineary at 12 mW/ }\mp@subsup{}{}{\circ}\textrm{C}\mathrm{ to }200\textrm{mW
DEVICE DISSIPATION PER OUTPUT TRANSISTOR
    For TA = FULL PACKAGE-TEMPERATURE RANGE (All Package Types)
        100 mW
OPERATING-TEMPERATURE RANGE (TA):
    PACKAGE TYPE D
        -55 to +125 ' C
    PACKAGE TYPE E. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -40 to +850
STORAGE TEMPERATURE RANGE (TStg) ........................................................................ . 65 to +150
LEAD TEMPERATURE (DURING SOLDERING):
    At distance 1/16\pm1/32 inch ( }1.59\pm0.79\textrm{mm})\mathrm{ from case for 10 s max.
+265 C
```

STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm \mathbf{1 0 \%}$, Except as noted

| CHARACTERISTIC |  | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{V}_{0}$ <br> (V) | VIN <br> (V) | VDD <br> (V) | CDP1855 |  |  | CDP1855C |  |  |  |
|  |  | Min. |  |  | Typ.॰ | Max. | Min. | Typ.॰ | Max. |  |
| Quiescent Device |  |  | - | 0,5 | 5 | - | 0.01 | 50 | - | 0.02 | 200 | $\mu \mathrm{A}$ |
| Current | IDD | - | 0, 10 | 10 | - | 1 | 200 | - | - | - |  |  |
| Output Low Drive |  | 0.4 | 0,5 | 5 | 1.6 | 3.2 | - | 1.6 | 3.2 | - | mA |  |
| (Sink) Current | IOL | 0.5 | 0, 10 | 10 | 2.6 | 5.2 | - | - | - | - |  |  |
| Output High Drive (Source) Current |  | 4.6 | 0, 5 | 5 | -1.15 | -2.3 | - | 1-1.15 | 1-2.3 | - |  |  |
|  | IOH | 9.5 | 0, 10 | 10 | -2.6 | -5.2 | - | - | - | - |  |  |
| Output Voltage |  | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |  |
| Low-Level | $\mathrm{V}_{\text {OL } \pm}$ | - | 0, 10 | 10 | - | 0 | 0.1 | - | - | - |  |  |
| Output Voltage |  | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - |  |  |
| High Level | $\mathrm{VOH}_{\mathrm{O}} \pm$ | - | 0, 10 | 10 | 9.9 | 10 | - | - | - | - |  |  |
| Input Low Voltage |  | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 |  |  |
|  | $\mathrm{V}_{\text {IL }}$ | 0.5, 9.5 | - | 10 | - | - | 3 | - | - | - |  |  |
| Input High |  | 0.5, 4.5 | - | 5 | 3.5 | - | - | 3.5 | - | - |  |  |
| Voltage | $\mathrm{V}_{\text {IH }}$ | 0.5, 9.5 | - | 10 | 7 | - | - | - | - | - |  |  |
| Input Leakage |  | - | 0,5 | 5 | - | - | $\pm 1$ | - | - | $\pm 1$ | $\mu \mathrm{A}$ |  |
| Current | INN | - | 0, 10 | 10 | - | - | $\pm 1$ | - | - | - |  |  |
| 3-State Output Leakage Current |  | 0,5 | 0,5 | 5 | - | - | $\pm 1$ | - | - | $\pm 1$ |  |  |
|  | IOUT | 0, 10 | 0, 10 | 10 | - | - | $\pm 10$ | - | - | - |  |  |
| Operating Current | IDD1\# | - | 0,5 | 5 | - | 1.5 | - | - | 1.5 | 3 | mA |  |
|  | IDDI\# | - | 0, 10 | 10 | - | 6 | 12 | - | - | - |  |  |
| Input Capacitance | CIN | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |  |
| Output Capacitance | COUT | - | - | - | - | 10 | 15 | - | 10 | 15 |  |  |

- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$.
\#Operating current is measured at 3.2 MHz with open outputs.
$\ddagger \mathrm{IOL}^{\mathrm{I}} \mathrm{IOH}=1 \mu \mathrm{~A}$.

OPERATING CONDITIONS at $T_{A}=$ Full Package-Temperature Range. For maximum rellability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | CONDITIONS | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | VDD <br> (V) | CDP1855 |  | CDP1855C |  |  |
|  |  | Min. | Max. | Min. | Max. |  |
| DC Operating Voltage Range | - | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | - | VSS | VDD | VSS | VDD |  |
| Maximum Input Clock Frequency | 5 | 3.2 | - | 3.2 | - | MHz |
|  | 10 | 6.4 | - | - | - |  |
| Minimum $8 \times 8$ Multiply (16 $\div 8$ Divide) Time | 5 | - | 5.6 | - | 5.6 | $\mu \mathrm{s}$ |
|  | 10 | - | 2.8 | - | - |  |



Fig. 2 - Block diagram of CDP1855 and CDP1855C.

## CDP1855, CDP1855C

## FUNCTIONAL DESCRIPTION

The CDP1855 is a multıply-dıvide unit (MDU) designed to be compatible with CDP1800 series microprocessor systems. It can, in fact, be interfaced to most 8-bit microprocessors (see Fig. 5) The CDP1855 performs binary multiply or divide operations as directed by the microprocessor it can do a 16 N -bit by 8 N -bit divide yieldıng ab 8 N -bit result plus and 8 N -bit remainder The multiply is an 8 N -bit by 8 N -bit operation with a 16 N -bit result The " N " represent the number of cascaded CDP1855's and can be 1, 2 , 3 or 4 All operations require $8 N+1$ shift pulses (See "DELAY NEEDED WITH AND WITHOUT PRESCALER" Pg 7)

The CDP1855 contaıns three registers, $X, Y$, and $Z$, which are loaded with the operands prior to an operation and contain the results at the completion in addition, the control register must be loaded to initiate a multiply or divide There is also a status register which contains an overflow flag as shown in the "CONTROL REGISTER BIT ASSIGNMENT TABLE" The register address lines (RAORA1) are used to select the appropriate register for loading or reading The RD/ $\bar{W} \bar{E}$ and STB lines are used in conjunction with the RA lines to determine the exact MDU response (See "CONTROL TRUTH TABLE")

## 1. Initialization and Controls

The CDP1855 must be cleared by a low on pin 2 during power-on which prevents bus contention problems at the $Y_{L}, Y_{R}$ and $Z_{L}, Z_{R}$ terminals and also resets the sequence counters and the shift pulse generator
Prıor to loadıng any other registers the control register must be loaded to specify the number of MDU's being used (See "CONTROL REGISTER BIT ASSIGNMENT TABLE")

Once the number of devices has been specified and the sequence counters cleared with a clear pulse or bit 6 of the control word, the $X, Y$, and $Z$ registers can be loaded as defined in the "CONTROL TRUTH TABLE" All bytes of the $X$ register can be loaded, then all bytes of the $Y$, and then all bytes of the $Z$, or they can be loaded randomly Succcessive loads to a given register will always proceed sequentially from the most significant byte to the least signıficant byte, as previously described Resetting the sequence counters select the most significant MDU In a four MDU system, loadıng all MDU's results in the sequence counter pointing to the first MDU again in all other configurations (1, 2, or 3 MDU's), the sequence counter must be reset prior to each series of register reads or writes

## 2. Divide Operation

For the divide operation, the divisor is loaded in the $X$ register The dividend is loaded in the $Y$ and $Z$ registers with the more significant half in the $Y$ register and the less significant half in the $Z$ register These registers may be loaded in any order, and after loading is completed, a control word is loaded to specify a divide operation and the number of MDU's and also to reset the sequence counters and $Y$ or $Z$ register and select the clock option if desired Clearing the sequence counters with bit 6 will set the MDU's up for reading the results
The $X$ register will be unaltered by the operation The quotient will be in the $Z$ register while the remainder will be in the $Y$ register An overflow will be indicated by the C.O./O.F. of the most significant MDU and can also be determined by reading the status byte
While the CDP1855 is specified to perform 16 by 8 -bit divides, if the quotient of a divide operation exceeds the size of the $Z$ register(s) ( 8 N -bits - where N is the number of

When multıple MDU's are cascaded, the loading of each register is done sequentially. For example, the first selection of regıster X for loadıng loads the most significant CDP1855, the second loads the next significant, and so on. Registers are also read out sequentially This is accomplished by internal counters on each MDU which are decremented by STB during each register selection. When the counter matches the chip number (CN1, CNO lines), the device is selected. These counters must be cleared with a clear on pin 2 or with bit 6 in the control word (See "CONTROL REGISTER BIT ASSIGNMENT TABLE") in order to start each sequence of accesses with the most significant device.

The CDP1855 has a built in clock prescaler which can be selected via bit 7 in the control register. The prescaler may be necessary in cascaded systems operating at high frequencies or in systems where a suitable clock frequency is not readily available. Without the prescaler select, the shift frequency is equal to the clock input frequency With the prescaler selected, the rate depends on the number of MDU's as defined by bits 4 and 5 of the control word (See "CONTROL REGISTER BIT ASSIGNMENT TABLE")

For one MDU, the clock frequency is divided by 2 For two MDU's the clock frequency is divided by 4 For 3 or 4 MDU's, the clock frequency is divided by 8

## OPERATION

cascaded CDP1855's) the overflow bit in the Status Register will be set Neither the quotient in $Z$ nor the remainder in $Y$ will represent a valid answer This will always be the result of a division performed when the divisor $(X)$ is equal to or less than the most significant 8 N -bits of the dividend $(\mathrm{Y})$
The MDU can still be used for such computations if the divide is done in two steps The dividend is split into two parts-the more significant 8 N -bits and the less significant 8 N -bits-and a divide done on each part Each step yields an 8 N -bit result for a total quotient of 16 N -bits

The first step consists of dividing the more significant 8 N bits by the divisor This is done by clearing the Y register(s), loading the $Z$ register(s) with the more significant 8 N -bits of the dividend, and loading the $X$ register (s) with the divisor. A division is performed and the resultant value in $Z$ represents the more significant 8 N -bits of the final quotient The $Z$ register(s) value must be unloaded and saved by the processor
A second division is performed using the remainder from the first division (in Y ) as the more significant 8 N -bits of the dividend and the less significant half of the origınal dividend loaded into the $Z$ register The divisor in $X$ remains unaltered and is, by definition, larger than the remainder from the first division which is in $Y$ The resulting value in $Z$ becomes the less significant 8 N -bits of the final quotient and the value in $Y$ is, as usual, the remainder.
Extending this technique to more steps allows division of any size number by an 8 N -bit divisor.

Note that division by zero is never permitted and must be tested for and handled in software
The following example illustrates the use of this algorithm

## Example:

Assume three MDU's capable of a by 24-bit division. The problem is to divide $00 \mathrm{~F} 273,491 \mathrm{C} 06 \mathrm{H}$ by 0003 B 4 H

| Step 1 | $\begin{gathered} 000000 \\ Y \end{gathered}$ | $\begin{gathered} \text { 00F273 } \\ \text { Z(MS) } \end{gathered}$ |  | $\begin{gathered} 0003 B 4 \\ X \end{gathered}$ | = | $\begin{gathered} 000041 \\ \text { Z1 } \end{gathered}$ | $\begin{gathered} R=0001 B F \\ Y 1 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Step 2. | $\begin{gathered} 0001 \mathrm{BF} \\ \mathrm{Y} 1 \end{gathered}$ | $\begin{gathered} 491 \mathrm{C} 06 \\ \mathrm{Z}(\mathrm{LS}) \end{gathered}$ | 1 | $\begin{gathered} 0003 B 4 \\ X \end{gathered}$ | $=$ | $\begin{gathered} 78 \mathrm{C} 936 \\ \mathrm{Z} 2 \end{gathered}$ | $\begin{gathered} R=00000 E \\ Y 2 \end{gathered}$ |
| Result | $\begin{gathered} 000041 \\ \text { Z1 } \end{gathered}$ | $\begin{gathered} \text { 78C936 } \\ \text { Z2 } \end{gathered}$ |  | $\begin{gathered} R=00000 E \\ Y 2 \end{gathered}$ |  |  |  |

## CDP1855, CDP1855C

## OPERATION (Cont'd)

The $Z$ register can simply be reset using bit 2 of the control word and another divide can be done in order to further divide the remainder.

## 3. Multiply Operation

For a multiply operation the two numbers to be multiplied are loaded in the $X$ and $Z$ registers. The result is in the $Y$ and
$Z$ register with $Y$ being the more significant half and $Z$ the less significant half The $X$ register will be unchanged after the operation is completed
The original contents of the Y register are added to the product of $X$ and $Z$ Bit 3 of the control word will reset register Y to 0 if desired

## FUNCTIONAL DESCRIPTION OF CDP1855 TERMINALS

## CE - CHIP ENABLE (Input):

A high on this pin enables the CDP1855 MDU to respond to the select lines. All cascaded MDU's must be enabled together. CE also controls the tristate C.O./O.F., output of the most significant MDU.

## CLEAR (Input):

The CDP1855 MDU(s) must be cleared upon power-on with a low-on this pin. The clear signal resets the sequence counters, the shift pulse generator, and bits 0 and 1 of the control register.

## CTL - CONTROL (Input):

This is an input pin. All CTL pins must be wired together and to the $Y_{L}$ of the most significant CDP1855 MDU and to the $Z_{R}$ of the least significant CDP1855 MDU. This signal is used to indicate whether the registers are to be operated on or only shifted.

## C.O./O.F. - CARRY OUT/OVER FLOW (Output):

This is a tristate output pin. It is the CDP1855 Carry Out signal and is connected to Cl (CARRY-IN) of the next more significant CDP1855 MDU, except for on the most significant MDU. On that MDU it is an overflow indicator and is enabled when chip enables is true. A low on this pin indicates that an overflow has occured. The overflow signal is latched each time the control register is loaded, but is only meaningful after a divide command.

## $\mathbf{Y}_{\mathbf{L}}, \mathbf{Y}_{\mathbf{R}}$ - Y-LEFT, Y-RIGHT:

These are tristate bi-directional pins for data transfer between the Y registers of cascaded CDP1855 MDU's. The $Y_{R}$ pin is an output and $Y_{L}$ is an input during a multiply and the reverse is true at all other times. The $Y_{L}$ pin must be connected to the $Y_{R}$ pin of the next more significant MDU. An exception is that the $Y_{L}$ pin of the most significant CDP1855 MDU must be connected to the $Z_{R}$ pin of the least significant MDU and to the CTL pins of all MDU's. Also the $Y_{R}$ pin of the least significant MDU is tiexd to the $Z_{L}$ pin of the most significant MDU.

## $\mathbf{Z}_{\mathbf{L}}, \mathbf{Z}_{\mathbf{R}}$ - Z-LEFT, Z-RIGHT:

These are tristate bi-directional pins for data transfers between the " $Z$ " registers of cascaded MDU's. The $Z_{R}$ pin is an output and $Z_{L}$ is an input during a multiply and the reverse is true at all other times. The $Z_{L}$ pin must be tied to the $Y_{R}$ pin of the next more significant MDU. An exception is that the $Z_{L}$ pin of the most significant MDU must be connected to the $Y_{R}$ pin of the least significant MDU. Also, the $Z_{R}$ pin of the least significant MDU is tied to the $Y_{L}$ of the most significant MDU.

## $\overline{\text { SHIFT }}$ — SHIFT CLOCK:

This is a tristate bi-directional pin. It is an output on the most significant MDU. And an input on all other MDU's. It provides the MDU system timing pulses. All SHIFT pins must be connected together for cascaded operation. A maximum of the $8 \mathrm{~N}+1$ shifts are required for an operation where " $N$ " equals the number of MDU devices that are cascaded.

## CLK - CLOCK (Input):

This pin should be grounded on all but the most significant MDU. There is an optional reduction of clock frequency available on this pin if so desired, controlled by bit 7 of the control byte

## STB - STROBE (Input):

When RD/WE is low data is latched from bus lines on the falling edge of this signal It may be asynchronous to the clock. Strobe also increments the selected register's sequence counter during reads and writes TPB would be used in CDP1800 systems

## RD/ $\overline{\text { WE }}$ - READ/WRITE ENABLE (Input):

This signal defines whether the selected register is to be read from or written to. In 1800 systems use MRD if MDU's are addressed as I/O devices, MWR is used if MDU's are addressed as memory devices

## RA2, RA1, RAO - REGISTER ADDRESS (Input):

These input signals define which register is to be read from or written to It can be seen in the "CONTROL TRUTH TABLE" that RA2 can be used as a chip enable it is identifical to the CE pin, except only CE controls the tristate $\overline{\mathrm{CO} O . F}$. on the most significant MDU. In 1800 systems use N lines if MDU's are used as I/O devices, use address lines or function of address lines if MDU's are used as memory devices.

## BUS 0 - BUS 7 - BUS LINES:

Tristate bi-directıonal bus for direct interface with CDP1800 series and other 8-bit microprocessors.
$\mathbf{Z}_{\mathbf{R}}$ - Z-RIGHT:
See Pin 6.
$\mathbf{Y}_{\mathbf{R}}-\mathbf{Y - R I G H T}$ :
See Pin 5.
$\overline{\mathrm{CI}}-\overline{\text { CARRY }} \mathbf{I N}$ (Input):
This is an input for the carry from the next less significant MDU. On the least significant MDU it must be high (VDD) on all others it must be connected to the CO pin of the next less significant MDU.

## CN1, CNO - CHIP NUMBER (Input):

These two input pıns are wired high or low to indicate the MDU position in the cascaded chain. Both are high for the most significant MDU regardless of how many CDP1855 MDU's are used Then CN1 = high and CNO = low for the next MDU and so forth.

VSS - GROUND:
Power supply line.
VDD - V+•
Power supply line.

CONTROL TRUTH TABLE

| INPUTS* |  |  |  |  |  | RESPONSE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CE | $\begin{aligned} & \text { RA2 } \\ & \text { (N2) } \\ & \hline \end{aligned}$ | RA1 <br> (N1) | RAO <br> (NO) | RD/WE <br> (MRD) | $\begin{gathered} \text { STB } \\ \text { (TPB) } \end{gathered}$ |  |
| 0 | X | X | X | X | X | NO ACTION (BUS FLOATS) |
| X | 0 | X | X | X | X | NO ACTION (BUS FLOATS) |
| 1 | 1 | 0 | 0 | 1 | $x$ | $x$ TO BUS 7 INCREMENT SEQUENCE |
| 1 | 1 | 0 | 1 | 1 | $x$ | $z$ TO BUS $\}$ COUNTER WHEN |
| 1 | 1 | 1 | 0 | 1 | X | $Y$ TO BUS STB AND RD $=1$ |
| 1 | 1 | 1 | 1 | 1 | X | STATUS TO BUS |
| 1 | 1 | 0 | 0 | 0 | 1 | LOAD X FROM BUS $\}$ INCREMENT |
| 1 | 1 | 0 | 1 | 0 | 1 | LOAD $Z$ FROM BUS $\}$ SEQUENCE |
| 1 | 1 | 1 | 0 | 0 | 1 | LOAD Y FROM BUS $\int$ COUNTER |
| 1 | 1 | 1 | 1 | 0 | 1 | LOAD CONTROL REGISTER |
| 1 | 1 | X | X | 0 | 0 | NO ACTION (BUS FLOATS) |

* ( ) = 1800 system signals. $1=$ High Level, $0=$ Low Level, $X=$ High or Low Level.

CONTROL REGISTER BIT ASSIGNMENT TABLE


B2 = 1, RESET Z REGISTER
B3 $=1$, RESET Y REGISTER

| B5 | B4 | \# of MDU's |
| :---: | :---: | :--- |
| 1 | 1 | ONE MDU |
| 1 | 0 | TWO MDU's |
| 0 | 1 | THREE MDU's |
| 0 | 0 | FOUR MUD's |

B6 = 1, RESET SEQUENCE COUNTER

B7 = 1, SELECT SHIFT RATE OPTIONS:


B7 = 0, SHIFT = CLOCK FREQUENCY RATE

| \# OF MDU's | SHIFT RATE |
| :---: | :---: |
| 1 | CLOCK $\div 2$ |
| 2 | CLOCK $\div 4$ |
| 3 | CLOCK $\div 8$ |
| 4 | CLOCK $\div 8$ |

STATUS REGISTER


NOTE. Bits $1-7$ are read as 0 always

## delay needed with and without prescaler

8N+1 Shifts/Operation at 1 Clock Cycle/Shift
$\mathbf{N}=$ Number of MDU's
S = Shift Rate

| Number <br> of <br> MDU's | No Prescaler <br> Shifts = 8N+1 <br> Needed | Machine <br> Cycles <br> Needed* | Shifts = <br> N (8N+1) <br> Needed | Machine <br> Cycles <br> Needed* | Shift <br> Rate |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 9 | $2(1$ NOP) | 18 | $3(1$ NOP) | 2 |
|  | 17 | $2(1 \mathrm{NOP})$ | 68 | $9(3 \mathrm{NOPs})$ | 4 |
| 3 | 25 | $3(1$ NOP) | 200 | $25(9 \mathrm{NOPs})$ | 8 |
| 4 | 33 | $4(2 \mathrm{NOPs})$ | 264 | $33(11 \mathrm{NOPs})$ | 8 |

*NOP instruction is shown for machine cycles needed (3/NOP). Other instructions may be used.

CDP1855 INTERFACING SCHEMES


Fig. 3 - Required connection for memory mapped addressing of the MDU.


Fig. 4 - Interfacing the CDP1855 to an 8085 microprocessor as an I/O device.

## CDP1855，CDP1855C

## PROGRAMMING EXAMPLE FOR MULTIPLICATION

For a 24－bit x 24－bit multiply using the system shown in Figure 5，the following is an assembly listing of a program to multiply 201F7C ${ }_{16}$ by 723C0916：

| MEMORY LOCATION | $\begin{aligned} & \text { OP } \\ & \text { CODE } \end{aligned}$ | $\begin{aligned} & \text { LINE } \\ & \text { NO. } \end{aligned}$ | ASSEMBLY <br> LANGUAGE |  |
| :---: | :---: | :---: | :---: | :---: |
| 0000） | F8＊O； | 0001 | LDI $0 \geq 0 \mathrm{H}$ |  |
| 0002 | Aこ： | 0002 | FLO F＇2 | ．LOAD SO INTO R2．0 |
| 000 | $\mathrm{FBOO}_{4}$ | （0）こ． | LDI ${ }^{\text {（OH }}$ |  |
| 0005 | B＇\％ | 0004 | FHI R2＇ | ．．LDAD OO INTO F＇2． 1 （ $22=00 \% 0)$ |
| 0006 | ¢758： | 0005 | OUT 7：DC OS8H | ．．LOAD CONTROL REGISTERS |
| 0008 | ； | 0006 |  | ．．SFECIFYING THREE MDU＇S． |
| 0008 | ； | 0007 |  | ．．FiESET THE Y FEGISTER AND |
| 0008 | ； | 0008 |  | ．SEOUENCE COUNTEF |
| 0008 | 6420： | 0009 | OUT 4；DC OIOH | ．．LUAD MSE OF $\times$ FEGISTER |
| 000 A | ； | 0010 |  | ．WITH 20 |
| OOOA | 641F： | 0011 | OUT \＆：DC 11 FH | ．L LOAD NEXT MSE DF $\times$ REG |
| טOOC | ； | 001： |  | ．WITH 1F |
| Owoc | 647C： | 001？ | OUT 4；DC O7CH | ．LDAD LSE OF $\times$ REGISTEF |
| OOOE | ； | 0014 |  | ．W1TH 7C |
| OUOE | 6572： | 0015 | OUT 5：DC O7H | ．．LOAD MSB OF Z FEGISTEFi |
| 0010 | ： | 0016 |  | ．WJTH 72 |
| 0010 | 65\％C： | 0017 | OUT 5：DC wご心 | ．Lluad next mse of z FEg |
| 0012 | ： | 0018 |  | ．WlTH $\therefore$ C |
| 012 | 6509： | 0019 | UHT 5：DC＠OH | ．．LOAD LSH OF $Z$ HEGISTEF |
| 0014 | ： | いいO |  | ．WJTH OG |
| 0014 | 6759： | OO． 1 | OUT 7；DC．059H | ．L LOAD CONTFOL FEEISTEFS |
| OU16 | ； | い0ここ |  | ．．RESETTING Y REGISTEFS |
| 0016 | \＃ | 1025 |  | ．AND SEOUENCE COUNTEFS |
| 001 ¢ | ； | $00^{\circ} 4$ |  | ．．AND STAFITING MULTIFLY |
| 0116 | ； | 1025 |  | －OFEEATION |
| DELAY FOR MULTIPLY TO FINISH |  |  |  |  |
| 0016 | E： | 0026 | SEX Fin |  |
| 0017 | GE60： | 0いこ7 | 1NF 6：IFX | ．MSB OF KESULTS IS STOFED |
| 0014 | ； | 0098 |  | ＊AT LOCATION OOSO |
| 1019 | 6E60\％ | 0129 | ［NF 6：1Fix |  |
| 01 E | 6E6O： | 0070 | INF S：IFiX |  |
| Oい1D | 6D6\％： | 0031 | INF S：IFiX |  |
| 01 F | 6D60； | 003 | INF 5：IFiX |  |
| 0021 | 6D： | O053 | INF 5 | ．．COMFLETE LOADING FiESUL T |
| 0以2土 | \％ | 0034 |  | ．．INTO MEMOFIY LOCATIONS |
| めけご | ； | 0055 |  | ．－OOSO TO OOJ5 |
| 002\％ | ； | 0036 |  | ．．FESULTS＝OE558DBA2B5C |
| 0022 | 3022： | 0037 STOF | BR STOF |  |
| 004 | － | 0098 | END |  |
| unou |  |  |  |  |

The result of $201 \mathrm{~F} 7 \mathrm{C}_{16} \times 723 \mathrm{C} 09_{16}$ is 0E558DBA2B5C $=$ 1576061279727610．It will be stored in memory as follows：

| LOC | BYTE |
| :---: | :---: |
| 0030 | $0 E$ |
| 31 | 55 |
| 32 | $8 D$ |
| 33 | $B A$ |
| 34 | $2 B$ |
| 35 | $5 C$ |

## BEFORE MULTIPLY

|  | MDU1 | MDU2 | MDU3 |
| :--- | :---: | :---: | :---: |
| Register $X$ | 20 | 1 F | 7 C |
| Register $Y$ | 00 | 00 | 00 |
| Register $Z$ | 72 | 3 C | 09 |
|  |  |  |  |

## AFTER MULTIPLY

Register $X$
Register $Y$
Register $\mathbf{Z}$
MDU1

| 20 | MDU2 | MDU3 |
| :---: | :---: | :---: |
| $0 E$ | 55 | 7 F |
| BA | 2 B | 5 C |

## CDP1855, CDP1855C

## PROGRAMMING EXAMPLE FOR DIVISION

| MEMORY LOCATION | $\begin{aligned} & \text { OP } \\ & \text { CODE } \end{aligned}$ | LINE NO. | ASSEMBLY LANGUAGE |  |
| :---: | :---: | :---: | :---: | :---: |
| 0000 | ; | 0001 | Program example for a 16 bit by 8 bit divide using 1 CDP 1855 MDU |  |
| 0000 | ; | 0002 | . . Gives a 16 bit answer with 8 bit remainder |  |
| 0000 | ; | 0003 |  |  |
| 0000 | 68C22000; | 0004 | RLDI R2,2000H | . Answer is stored at 2000 hex |
| 0004 | ; | 0005 |  | Register 2 points to it |
| 0004 | 68C33000; | 0006 | RLDI R3,3000H | Dividend is stored at 3000 hex |
| 0008 | ; | 0007 |  | Register 3 points to it |
| 0008 | 68C44000; | 0008 | RLDI R4,4000H | . Divisor is stored at 4000 hex |
| 000C | ; | 0009 |  | . Register 4 points to it |
| 000C | ; | 0010 |  |  |
| 000C | E067F0; | 0011 | SEX RO; OUT 7; DC OFOH | Write to the control register to use |
| 000F | ; | 0012 |  | clock / 2; 1 MDU; reset sequence |
| 000F | , | 0013 |  | . . counter; and no operation |
| 000F | ; | 0014 |  |  |
| 000F | E464; | 0015 | SEX R4; OUT 4 | . Load the divisor into the X register |
| 0011 | , | 0016 |  |  |
| 0011 | E06600; | 0017 | SEX RO, OUT 6; DC 0 | . . Load 0 into the Y register |
| 0014 | E365, | 0018 | SEX R3; OUT 5 | . Load the most signıficant 8 bits of |
| 0016 | ; | 0019 |  | the dividend into the $Z$ register |
| 0016 | ; | 0020 |  |  |
| 0016 | E067F2; | 0021 | SEX RO, OUT 7; DC OF2H | . Do the first divide, also resets the |
| 0019 | , | 0022 |  | . sequence counter |
| 0019 |  | 0023 |  |  |
| 0019 | E26D60; | 0024 | SEX R2; INP 5; IRX | Read and store the most signıficant |
| 001C | , | 0025 |  | 8 bits of the answer at 2000 hex |
| 001C |  | 0026 |  |  |
| 001C | E067F0, | 0027 | SEX RO; OUT 7, DC OFOH | Reset the sequence counter |
| 001F | ; | 0028 |  |  |
| 001F | E365; | 0029 | SEX R3, OUT 5 | Load the 8 least significant 8 bits |
| 0021 | , | 0030 |  | of the original dividend into the $Z$ |
| 0021 | , | 0031 |  | . register |
| 0021 |  | 0032 |  |  |
| 0021 | E067F2, | 0033 | SEX RO; OUT 7; DC OF2H | . . Do the second division |
| 0024 | , | 0034 |  |  |
| 0024 | E26D60, | 0035 | SEX R2; INP 5; IRX | . Read and store the least significant |
| 0027 | ; | 0036 |  | . 8 bits of the answer at 2001 hex |
| 0027 | 6E; | 0037 | INP 6 | . Read and store the remainder at 2002 |
| 0028 | ; | 0038 |  | hex |
| 0000 |  |  |  |  |

For the divide operation (Fig. 5), the formula is:

$$
\frac{Y_{3} Y_{2} Y_{1} Z_{3} Z_{2} Z_{1}}{X_{3} X_{2} X_{1}}=Z_{3} Z_{2} Z_{1}+\frac{Y_{3} Y_{2} Y_{1}}{X_{3} X_{2} X_{1}}
$$



92CM-31850
Fig. 5 - Cascading three MDU's (CDP1855) in an 1800 system with MDU's being accessed as I/O ports in programming example.


Fig. 6 - Cascading four MDU's (CDP1 855).

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \% \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L}=100 \mathrm{pF}$ (See Fig. 7)

| CHARACTERISTIC• | VDD <br> (V) | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1855 |  |  | CDP1855C |  |  |  |
|  |  | Min. | Typ.* | Max. | Min. | Typ.* | Max. |  |



- Maximum limits of minimum characteristics are the values above which all devices function.
*Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages.
+Clock frequency and pulse width are given for systems using the internal clock option of the CDP1855. Clock frequency equals shift frequency for systems not using the internal clock option.
$\Delta$ Shift period for cascading of devices is increased by an amount equal to the $\overline{\mathrm{C} .1} . \operatorname{to} \overline{\mathrm{C} . O}$. Prop. Delay for each device added.


Fig. 7 - Operation timing diagram.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \% \mathrm{t}_{\mathrm{r}}, \mathrm{iff}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$ ， $C_{L}=100 \mathrm{pF}$（See Fig．8）

| CHARACTERISTIC• | VDD <br> （V） | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1855 |  |  | CDP1855C |  |  |  |
|  |  | Min． | Typ．＊ | Max． | MIn． | Typ．＊ | Max． |  |

Write Cycle

| Minimum Clear Pulse Width | t $\overline{C L R}$ | 5 | － | 50 | 75 | － | 50 | 75 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 10 | － | 25 | 40 | － | － | － |  |
| Minimum Write Pulse Width | twW | 5 | － | 150 | 225 | － | 150 | 225 |  |
|  |  | 10 | － | 75 | 115 | － | － | － |  |
| Minimum Data－In Setup | tDSU | 5 | － | －75 | 0 | － | －75 | 0 |  |
|  |  | 10 | － | －40 | 0 | － | － | － |  |
| Minimum Data－In－Hold | ${ }^{\text {t }}$ D | 5 | － | 50 | 75 | － | 50 | 75 |  |
|  |  | 10 | － | 25 | 40 | － | － | － |  |
| Minimum Address to Write Setup | ${ }^{\text {t }}$ ASU | 5 | － | 50 | 75 | － | 50 | 75 |  |
|  |  | 10 | － | 25 | 40 | － | － | － |  |
| Minimum Address after Write Hold | ${ }^{\text {t }}$ AH | 5 | － | 50 | 75 | 二 | 50 | 75 |  |
|  |  | 10 | － | 25 | 40 | － | － | － |  |

－Maximum limits of minimum characteristics are the values above which all devices function．
＊Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages．


Fig． 8 －Write timing diagram．

## Specifications CDP1855, CDP1855C

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \% \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L}=100 \mathrm{pF}$ (See FIg. 9)


Read Cycle


- Maximum limits of minimum characteristics are the values above which all devices function.
*Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages.


Fig. 9 - Read timing diagram.

## Features

- Provides Easy Connection of VO to CDP1800Series Microprocessor Data Bus.
- Non-Inverting Fully Buffered Data Transfer


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 5V | 10V |
| :--- | :---: | :--- | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP 1857 CE | - |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP 1857 CD | - |

TABLE 1. CDP1857 FUNCTION FOR I/O BUS SEPARATOR OPERATION

| CS | $\overline{\text { MRD }}$ | DATA BUS OUT <br> DB0-DB3 | DATA OUT <br> DO0-DO3 |
| :---: | :---: | :--- | :--- |
| 0 | X | High Impedance | High Impedance |
| 1 | 0 | High Impedance | Data Bus |
| 1 | 1 | Data In | High Impedance |

## Description

The CDP1857 and CDP1857C are 4 bit CMOS non-inverting bus separators designed for use in CDP1800-series microprocessor systems. They can be controlled directly by a 1800 -series microprocessor without the use of additional components.

The CDP1857 is designed for use as a bus buffer or separator between the 1800 -series microprocessor data bus and I/O devices. It provides a chip-select (CS) input signal which, when high (1), enables the bus-separator three-state output drivers. The direction of data flow, when enabled, is controlled by the $\overline{M R D}$ input signal.

In the CDP1857, when $\overline{M R D}=1$, it enables the three-state bus drivers (DB0-DB3) and transfers data from the DATA-IN lines onto the data bus. When $\overline{M R D}=0$, it disables the three-state bus drivers (DBO-DB3) and enables the three-state data output drivers (DOO-DO3), thus transferring data from the data bus to the DATA-OUT terminals.

The CDP1857 can be used as a bi-directional bus buffer by connecting the corresponding DI and DO terminals (Figure 1). The MRD output signal from the 1800 -series microprocessor has the correct polarity to control the CDP1857 when it is used as I/O bus buffer/separator. Therefore, the 1800 -series microprocessor $\overline{M R D}$ signal can be connected directly to the $\overline{M R D}$ input of CDP1857. See Function Table 1 for use of the CDP1857 as an I/O bus buffer/separator.

The CDP1857 is functionally identical to the CDP1857C. The CDP1857 has a recommended operating-voltage range of 4 to 10.5 volts, and the CDP1857C has recommended operating-voltage range of 4 to 6.5 volts. The CDP1857 and CDP1857C are supplied in 16-lead hermetic, dual-in-line ceramic packages ( $D$ suffix), and in 16-lead plastic packages ( $E$ suffix).

Functional Diagram for CDP1857


## Specifications CDP1857, CDP1857C

Static Electrical Characteristics At $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Except as Noted:

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & v_{0} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1857 |  |  | CDP1857C |  |  |  |
|  |  |  |  |  | MIN | $\begin{array}{\|c\|} \text { TYP } \\ \text { (Note 1) } \end{array}$ | MAX | MIN | $\begin{array}{\|c\|} \hline \text { TYP } \\ \text { (Note 1) } \\ \hline \end{array}$ | MAX |  |
| Quiescent Device Current | IDD | - | 0, 5 | 5 | - | 1 | 10 | - | 5 | 50 | $\mu \mathrm{A}$ |
|  |  | - | 0, 10 | 10 | - | 10 | 100 | - | - | - | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | lOL | 0.4 | 0,5 | 5 | 1.6 | 3.2 | - | 1.6 | 3.2 | - | mA |
|  |  | 0.5 | 0, 10 | 10 | 2.6 | 5.2 | - | - | - | - | mA |
| Output High Drive (Source) Current | $\mathrm{IOH}^{\text {O}}$ | 4.6 | 0,5 | 5 | -1.15 | -2.3 | - | -1.15 | -2.3 | - | mA |
|  |  | 9.5 | 0, 10 | 10 | -2.6 | -5.2 | - | - | - | - | mA |
| Output Voltage Low-Level (Note 3) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  |  | - | 0, 10 | 10 | - | 0 | 0.1 | - | - | - | V |
| Output Voltage High-Level (Note 3) | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - | V |
|  |  | - | 0, 10 | 10 | 9.9 | 10 | - | - | - | - | V |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 0.5, 9.5 | - | 10 | - | - | 3 | - | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 9.5 | - | 5 | 3.5 | - | - | 3.5 | - | - | V |
|  |  | 0.5, 9.5 | - | 10 | 7 | - | - | - | - | - | V |
| Input Leakage Current | IN | Any Input | 0,5 | 5 | - | - | 1 | - | - | 1 | $\mu \mathrm{A}$ |
|  |  |  | 0, 10 | 10 | - | - | 1 | $\cdot$ | - | - | $\mu \mathrm{A}$ |
| Operating Current (Note 2) | $\mathrm{I}_{\mathrm{DD} 1}$ | 0,5 | 0,5 | 5 | - | 50 | 100 | - | 50 | 100 | $\mu \mathrm{A}$ |
|  |  | 0,10 | 0,10 | 10 | - | 150 | 300 | - | - | - | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | $\cdot$ | 5 | 7.5 | pF |
| Output Capacitance | Cout | - | - | - | - | 10 | 15 | - | 10 | 15 | pF |

NOTES:

1. Typical values are for $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and nominal voltage.
2. $\mathrm{I}_{\mathrm{OL}}=\mathrm{I}_{\mathrm{OH}}=1 \mu \mathrm{~A}$.
3. Operating current measured in a CDP 1802 system at 3.2 MHz with outputs floating.
Dynamic Electrical Characteristics At $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \%, \mathrm{~V}_{I H}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD},} \mathrm{t}_{\mathrm{F}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1857 |  | CDP1857C |  |  |
|  |  |  | $\begin{gathered} \hline \text { TYP } \\ \text { (Note 1) } \\ \hline \end{gathered}$ | MAX | $\begin{gathered} \text { TYP } \\ \text { (Note 1) } \end{gathered}$ | MAX |  |
| Propagation Delay Time: $\overline{M R D}$ or CS to DO | $\mathrm{t}_{\mathrm{ED}}$ | 5 | 150 | 225 | 150 | 225 | ns |
|  |  | 10 | 75 | 125 | - | - | ns |
| $\overline{M R D}$ or CS to DB | $t_{E B}$ | 5 | 150 | 225 | 150 | 225 | ns |
|  |  | 10 | 75 | 125 | - | - | ns |
| DI to DB | $\mathrm{t}_{18}$ | 5 | 100 | 150 | 100 | 150 | ns |
|  |  | 10 | 50 | 75 | - | - | ns |
| DB to DO | $\mathrm{t}_{\mathrm{BO}}$ | 5 | 100 | 150 | 100 | 150 | ns |
|  |  | 10 | 50 | 75 | - | - | ns |

NOTE: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal voltages.
Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1857 |  | CDP1857C |  |  |
|  | MIN | MAX | MIN | MAX |  |
| Supply-Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Recommended Input voltage Range | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {SS }}$ | $V_{\text {DD }}$ | V |

## Specifications CDP1857, CDP1857C

## Absolute Maximum Ratings

| DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ): <br> (All Voltages Referenced to $\mathrm{V}_{\mathrm{SS}}$ Terminal) |  |
| :---: | :---: |
| CDP1857 | -0.5V to +11 V |
| CDP1857C. | -0.5V to +7V |
| Input Voltage Range, All Inputs | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, Any One Input. | . $\pm 10 \mathrm{~mA}$ |
| Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ ) |  |
| $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (Package Type E) | 500 mW |
| $\mathrm{T}_{\mathrm{A}}=+60^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type E) | . . . Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |
| $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (Package Type D) | 500 mW |
| $T_{A}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Package Type D). | Searly at |

Device Dissipation Per Output Transistor$T_{A}=$ Full Package Temperature Range(All Package Types).100 mWOperating Temperature Range $\left(T_{A}\right)$ :Package Type D
$\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Package Type E. . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Storage Temperature Range ( $\mathrm{T}_{\text {stq }}$ ) $\ldots . . . . . . . . .{ }^{-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}}$ Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{ln}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10 s max $+265^{\circ} \mathrm{C}$

Timing Diagrams


FIGURE 2. TIMING DIAGRAMS FOR CDP1857

## Typical Applications



FIGURE 3. CDP1857 BIDIRECTIONAL BUS BUFFER OPERATION


FIGURE 4. CDP1857 BUS SEPARATOR OPERATION

HARRIS CDP1871AC

## Features

- Directly Interfaces with CDP1800-Series Microprocessor
- Low Power Dissipation
- 3-State Outputs
- Scans and Generates Code for 53 Key ASCII Keyboard Plus 32 HEX Keys (SPST Mechanical Contact Switches)
- Shift, Control, and Alpha Lock Input
- RC-Controlled Debounce Circuitry
- Single Supply 4 V to 10.5 V
(CDP1871A)
4 V to 6.5 V
(CDP1871AC)
- N-Key Lockout


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | $\mathbf{5 V}$ | 10V |
| :--- | :---: | :--- | :--- |
| Plastic DIP <br> Burn-in | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1871ACE | CDP1871AE |
|  |  | CDP1871ACEX | CDP1871AEX |
| PLCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1871ACQ | CDP1871AQ |
| Ceramic DIP <br> Burn-in | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1871ACD | CDP1871AD |
|  |  | CDP1871ACDX | CDP1871ADX |

## Description

The CDP1871A is a keyboard encoder designed to directly interface between a CDP1800-series microprocessor and a mechanical keyboard array, providing up to 53 ASCII coded keys and 32 HEX coded keys, as shown in the system diagram (Figure 1).

The keyboard may consist of simple single-pole sin-gle-throw (SPST) mechanical switches. Inputs are provided for alpha-lock, control, and shift functions, allowing 160 unique codes. An external R-C input is available for user-selectable debounce times. The N key lock-out feature prevents unwanted key codes if two or more keys are pressed simultaneously.

The CDP1871A and CDP1871AC are functionally identical. They differ in that the CDP1871A has a recommended operating voltage range of 4 V to 10.5 V , and the CDP8171AC has a recommended operating voltage range 4 V to 6.5 V . These types are supplied in 40 lead dual-in-line ceramic packages (D suffix), and 40 lead dual-in-line plastic packages ( $E$ suffix), and 44 lead plastic chip-carrier packages ( $Q$ suffix).

## Pinouts




FIGURE 1. TYPICAL CDP1800 SERIES MICROPROCESSOR SYSTEM USING THE CDP1871A


FIGURE 2. CDP1871A BLOCK DIAGRAM


NOTE: 1: Printed-circuit board mount: $57 \mathrm{~mm} \times 57 \mathrm{~mm}$ minimum area $\times 1.6 \mathrm{~mm}$ thick G10 epoxy glass, or equivalent.

Recommended Operating Conditions at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}$. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1871AD, CDP1871AE |  | CDP1871ACD, CDP1871ACE |  |  |
|  |  | MIN | MAX | MIN | MAX |  |
| Supply Voltage Range |  | 4 | 10.5 | 4 | 6.5 | V |
| Recommended Input Voltage Range |  | $\mathrm{V}_{\text {ss }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {ss }}$ | $V_{D D}$ | V |
| Clock Input Frequency, TPB | 5 | DC | 0.4 | DC | 0.4 |  |
| (Keyboard Capacitance $=200 \mathrm{pF}$ ) | 10 | DC | 0.8 | - | - | z |

STATIC ELECTRICAL CHARACTERISTIC at $\mathrm{T}_{\mathrm{A}}=-40$ to $+85^{\circ} \mathrm{C}$, except as noted


[^6]
## CDP1871A, CDP1871AC

## FUNCTIONAL DESCRIPTION OF CDP1871A TERMINALS

D1 - D11 (Outputs):
Drive lines for the $11 \times 8$ keyboard switch matrix. These outputs are connected through the external switch matrix to the sense lines (S1 - S8).

## S1 - S8 (Inputs):

Sense lines for the $11 \times 8$ keyboard maxtrix. These inputs have internal pull-down resistors and are driven high by appropriate drive line when a keyboard switch is closed.

## $\overline{\text { CS1 }}, \mathbf{C S 2}, \mathrm{CS3}, \mathrm{CS} 4$ (Inputs):

Chip select inputs, which are used to enable the tri-state data bus outputs (BUS $0-\operatorname{BUS} 7$ ) and to enable the resetting of the status flag ( $\overline{\mathrm{DA}}$ ), which occurs on the low-to-high transition of TPB. These four inputs are normally connected to the N -lines (NO-N2) and MRD output of the CDP1800-series mıcroprocessor. (Table 2)

## BUS 0 - BUS 7 (Outputs):

Tri-state data bus outputs which provide the ASII and HEX codes of the detected keys. The outputs are normally connected to the BUS 0 - BUS 7 termınals of the CDP1800series microprocessor.

## $\overline{\text { DA }}$ (Output):

The data available output flag which is set low when a valid key closure is detected. It is reset high by the low-to-high transition of TPB when data is read from the CDP1871A. This output is normally connected to a flag input (EF1-EF4) of the CDP1800-series microprocessor.

## TPB (Input):

The input clock used to drive the scan generator and reset
the status flag ( $\overline{\mathrm{DA}})$. This input is normally connected to the TPB output of the CDP1800-series microprocessor.

## $\overline{\text { RPT }}$ (Output):

The repeat output flag which is used to indicate that a key is still closed after data has been read from the CDP1871A ( $\overline{D A}=$ high). It remains low as long as the key is closed and is used for an autorepeat function, under CPU control. This output is normally connected to a flag input (EF1-EF4) of the CDP1800-series microprocessor.

## DEBOUNCE(Input):

This input is connected to the junction of an external resistor to $\mathrm{V}_{\mathrm{DD}}$ and capacitor to $\mathrm{V}_{\mathrm{Ss}}$. It provides a debounce time delay ( $t \cong R C$ ) after the release of a key. If a debounce is not desired, the external pull-up resistor is still required.

## ALPHA, SHIFT, CONTROL (Inputs):

A high on the SHIFT or CONTROL inputs will be internally latched (after the debounce time) and the drive and sense line decoding will be modified as shown in Table 3. They are normally connected to the keyboard, but produce no code by themselves The SHIFT and CONTROL inputs have internal pull-down resistors to simplify use with momentary contact switches. The ALPHA input is not latched and is designed for a standard SPDT switch to provide an alphalock function. When ALPHA $=1$ the drive and sense line decoding will be modified as shown in Table 3.
$V_{D D}, V_{s s}:$
$V_{D D}$ is the positive supply voltage input. $V_{s s}$ is the most negative supply voltage terminal and is normal connected to ground. All outputs swing from $V_{s s}$ to $V_{D D}$. The recommended input voltage swing is from $V_{\text {ss }}$ to $V_{D D}$.

TABLE 1 - SWITCH INPUT FUNCTIONS

| CONTROL | SHIFT | ALPHA | KEY FUNCTION |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | NORMAL |
| 1 | $X$ | $X$ | CONTROL |
| 0 | 1 | $X$ | SHIFT |
| 0 | 0 | 1 | ALPHA |

X = DON'T CARE

TABLE 2 - VALID N-LINE CONNECTIONS

| CPU | CDP1871A SIGNAL |  |  |  | CPU INPUT <br> INSTRUCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CS4 | CS3 | CS2 | $\overline{\text { CS1 }}$ |  |
| CDP1800- <br> SERIES <br> SIGNAL | $\overline{M R D}$ | $N 2$ | $N 0$ | $N 1$ | INP5 |
|  | $\overline{M R D}$ | $N 0$ | $N 1$ | $N 2$ | INP3 |
|  | $\overline{M R D}$ | $N 2$ | $N 1$ | N0 | INP6 |

TABLE 3 - DRIVE AND SENSE LINE KEYBOARD CONNECTIONS $\ddagger$

| SENSE <br> LINES | DRIVE LINES |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{1}$ |  | $\mathrm{D}_{2}$ |  | $\mathrm{D}_{3}$ |  | $\mathrm{D}_{4}$ |  | $\mathrm{D}_{5}$ |  | $\mathrm{D}_{6}$ |  | $\begin{gathered} \mathbf{D}_{7} \\ \hline \hline \text { SPACE } \end{gathered}$ | $\begin{aligned} & \underline{D_{8} \dagger} \\ & 80_{16} \end{aligned}$ | $\begin{aligned} & \mathbf{D}_{9} \dagger \\ & \hline 88_{16} \end{aligned}$ | $\xlongequal[90_{16}]{\mathbf{D}_{10} \dagger}$ | $\begin{aligned} & \mathbf{D}_{11} \dagger \\ & \hline \hline 98_{16} \end{aligned}$ |
| $\mathrm{S}_{1}$ | SP | 0 | 1 | 8 |  | @ | H | H | P | P | X | X |  |  |  |  |  |
|  | 0 | \%, \% | 8 | - | @ | NUL | h | BS | p | DLE | x | CAN |  |  |  |  |  |
| $\mathrm{S}_{2}$ | ! | 1 | ) | 9 | A | A | 1 | 1 | Q | Q | $Y$ | $Y$ |  | 8116 | $89_{16}$ | $91_{16}$ | $99_{16}$ |
|  | 1 | \% | 9 | \% | a | SOH | i | HT | q | DC1 | y | EM |  |  |  |  |  |
| $S_{3}$ | " | 2 | * | : | B | B | J | $J$ | R | R | Z | Z | LINE <br> FEED | $82_{16}$ | $8 \mathrm{~A}_{16}$ | $92{ }_{16}$ | $9 \mathrm{~A}_{16}$ |
|  | 2 | \% | : | $\cdots$ | b | STX | J | LF | r | DC2 | z | SUB |  |  |  |  |  |
| $\mathrm{S}_{4}$ | \# | 3 | + | ; | C | C | K | K | S | S | \{ | [ | ESCAPE | $83_{16}$ | $8 \mathrm{~B}_{16}$ | $93_{16}$ | $9 B_{16}$ |
|  | 3 | + | ; |  | c | ETX | k | VT | s | DC3 | [ | ESC |  |  |  |  |  |
| $\mathrm{S}_{5}$ | \$ | 4 | < |  | D | D | L | L | T | T | ; | 1 |  | $84_{16}$ | $8 C_{16}$ | $94{ }_{16}$ | $9 \mathrm{C}_{16}$ |
|  | 4 |  | , |  | d | EOT | I | FF | t | DC4 | $\backslash$ | FS |  |  |  |  |  |
| $\mathrm{S}_{6}$ | \% | 5 | = | - | E | E | M | M | U | U | \} | 1 | CARRAIGE RETURN | $85_{16}$ | $8 \mathrm{D}_{16}$ | $95_{16}$ | $9 \mathrm{D}_{16}$ |
|  | 5 | $\because$ | - |  | e | ENQ | m | CR | u | NAK | ] | GS |  |  |  |  |  |
| $S_{7}$ | \& | 6 | $>$ |  | F | F | N | N | V | V | $\sim$ | 1 |  | $86_{16}$ | $8 \mathrm{E}_{16}$ | $96_{16}$ | $9 \mathrm{E}_{16}$ |
|  | 6 |  | . |  | f | ACK | n | SO | v | SYN | 1 | RS |  |  |  |  |  |
| $\mathrm{S}_{8}$ |  | 7 | ? | 1 | G | G | 0 | 0 | W | W | DEL | - | DELETE | $87_{16}$ | $8 \mathrm{~F}_{16}$ | 9716 | $9 \mathrm{~F}_{16}$ |
|  | 7 | $\cdots$ | 1 |  | g | BEL | 0 | SI | w | ETB | - | US |  |  |  |  |  |

KEY:

| SHIFT* | ALPHA* |
| :--- | :--- |
| NORMAL | CONTROL* |

*CONTROL overrides SHIFT and ALPHA = NO RESPONSE
$\ddagger$ Showing ASCII outputs for all combinations with and without SHIFT, ALPHA LOCK and CONTROL
$\dagger$ Drive lines 8, 9, 10, and 11 generate non-ASCII hex values which can be used for special codes.

TABLE 4 - HEXIDECIMAL VALUES OF ASCII CHARACTERS

|  | b4 | BITS |  |  |  | MSD |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{array}{ll}0 & \\ 0 \\ & 0\end{array}$ |  | $\begin{aligned} & 0 \\ & \\ & \\ & \\ & 1 \end{aligned}$ | $\begin{array}{lll}0 & & \\ & 1 & \\ & 0\end{array}$ | $\begin{array}{lll}0 & & \\ & 1 \\ & \\ & 1\end{array}$ | $\begin{array}{lll}1 & & \\ & 0 & \\ & 0\end{array}$ | $\begin{array}{ll} 1 \\ & \\ & \\ & 1 \end{array}$ | ${ }^{1}$ | ${ }^{1}$ |
|  |  | b3 | b2 |  |  | b1 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| LSD | 0 | 0 | 0 | 0 | 0 | NUL | DLE | SP | 0 | @ | P | 1 | p |
|  | 0 | 0 | 0 | 1 | 1 | SOH | DC1 | $!$ | 1 | A | Q | a | q |
|  | 0 | 0 | 1 | 0 | 2 | STX | DC2 | " | 2 | B | R | b | r |
|  | 0 | 0 | 1 | 1 | 3 | ETX | DC3 | \# | 3 | C | S | c | S |
|  | 0 | 1 | 0 | 0 | 4 | EOT | DC4 | \$ | 4 | D | T | d | t |
|  | 0 | 1 | 0 | 1 | 5 | ENQ | NAK | \% | 5 | E | U | e | u |
|  | 0 | 1 | 1 | 0 | 6 | ACK | SYN | \& | 6 | F | V | $f$ | v |
|  | 0 | 1 | 1 | 1 | 7 | BEL | ETB | 1 | 7 | G | W | g | w |
|  | 1 | 0 | 0 | 0 | 8 | BS | CAN | $($ | 8 | H | X | h | X |
|  | 1 | 0 | 0 | 1 | 9 | HT | EM | $)$ | 9 | 1 | Y | i | $y$ |
|  | 1 | 0 | 1 | 0 | A | LF | SUB | * | : | $J$ | Z | $j$ | $z$ |
|  | 1 | 0 | 1 | 1 | B | VT | ESC | + | ; | K | [ | k | \{ |
|  | 1 | 1 | 0 | 0 | C | FF | FS | , | < | L | 1 | 1 | I |
|  | 1 | 1 | 0 | 1 | D | CR | GS | - | = | M | ] | m | \} |
|  | 1 | 1 | 1 | 0 | E | SO | RS | . | $\geq$ | N | $\dagger$ | n | $\sim$ |
|  | 1 | 1 | 1 | 1 | F | SI | US | 1 | ? | 0 | - | 0 | DEL |

## OPERATION

The CDP1871A is made up of two major sections: the counter/scan-selection logic and the control logic (Fig. 2). The counter and scan-selection logic scans the keyboard array using the drive lines (D1-D11) and the sense lines (S1-S8). The outputs of the internal 5 -stage scancounter are conditionally encoded by the ALPHA, SHIFT, and CONTROL inputs (Table 1, Table 3) and are used to drive the D1-D11 output lines high one at a time. Each D1-D11 output may drive up to eight keys, which are sampled by the sense line inputs ( $\mathrm{S} 1-\mathrm{S} 8$ ). The $\mathrm{S} 1-\mathrm{S} 8$ inputs are enabled by the internal 3-stage scancounter.
The control logic interfaces with the CDP1800-series I/O and timing signals to establish tıming and status conditions for the CDP1871A.
The TPB input clocks the scancounters and is also used to reset the Data Available output (DA). When a valid keydown condition is detected on a sense line, the control logic inhibits the clock to the scancounters on the next low-tohigh transition of TPB and the $\overline{D A}$ output is set low. The scancounter outputs (C1-C8) represent the ASCII and HEX key codes and are used to drive the BUS 0-BUS 7 outputs, which interface directly to the CDP1800-Series data bus. The BUS 0 - BUS 7 outputs, which are normally tri-stated, are enabled by decoding the CS inputs during a CPU input instruction (Table 2). The low-to-high transition of TPB during the input instruction resets the $\overline{D A}$ output high. Once the DA output has been reset, it cannot go low again until the present key is released and a new keydown condition is detected. (This prevents unwanted repeated keycode outputs which may be caused by fast software routines).
After the depressed key is released and the debounce delay (determined by RX, CX) has occurred, the scan clock inhibit
is removed, allowing the scancounters to advance on the following high-to-low transitions of TPB. This provides an N -key lockout feature, which prevents the entry of erroneous codes when two or more keys are pressed simultaneously. The first key pressed in the scanning order is recognized, while all other keys pressed are ignored until the first key is released and read by the CPU, at which time the next key pressed in the scanning order is detected. If the first key remains closed after the CPU reads the data and resets the $\overline{D A}$ output, on the low-to-high transition of TPB, an auxiliary signal (RPT) is generated and is available to the CPU to indicate an auto-repeat condition. The RPT output is reset high at the end of the debounce delay after the depressed key is released.

The DEBOUNCE input provides a terminal connection for an external user-selected RC circuit to eliminate false detection of a keydown condition caused by keyboard noise. The operation of the DEBOUNCE circuit is shown in Fig. 2 (Pin 36). When a valid keydown is detected, the on-chip active-resistor device $\left(R_{N}\right)$ is enabled and the external capacitor ( $\mathrm{C}_{\mathrm{x}}$ ) is discharged, providing a key closure debounce time $\cong R_{N} C_{x}$. This discharge is sensed by the Schmitt-tigger inverter, which clocks the $\overline{D A}$ flip-flop (latching the $\overline{D A}$ output low and inhibiting the scan clock). (The DA F/F is reset by the low-to-high transition of TPB when the CS inputs are enabled). When a valid key-release is detected $R_{N}$ is disabled and $C_{x}$ begins to charge through the external resistor ( $R_{x}$ ), providing a key-release debounce time $\cong R_{x} C_{x}$. This charge time is again sensed by the Schmitt-trigger inverter, enabling the scan clock to continue on the next high-to-low transitions of TPB, after the current keycode data is read by the CPU.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}-40$ to $+85^{\circ} \mathrm{C}, V_{D D} \pm 5 \%$

| CHARACTERISTIC |  | $V_{D D}$ <br> (V) | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1871AD CDP1871AE |  |  | CDP1871ACD CDP1871ACE |  |  |  |
|  |  |  | MIN. | TYP.* | MAX. | MIN. | TYP.* | MAX. |  |
| Clock Cycle Time |  | 5 | - | - | - | - | - | - | NOTE$1$ |
|  | $\mathrm{t}_{\mathrm{cc}}$ | 10 | - | - | - | - | - | - |  |
| Clock Pulse Width High |  | 5 | 100 | 40 | - | 100 | 40 | - | ns |
|  | $t_{\text {cwh }}$ | 10 | 50 | 20 | - | - | - | - |  |
| Data Available Valid Delay |  | 5 | - | 260 | 500 | - | 260 | 500 | ns |
|  | $t_{\text {daL }}$ | 10 | - | 130 | 250 | - | - | - |  |
| Data Available Invalid Delay |  | 5 | - | 70 | 150 | - | 70 | 150 | ns |
|  | $t_{\text {DAH }}$ | 10 | - | 35 | 75 | - | - | - |  |
| Scan Count Delay(Non-Repeat) |  | 5 | - | 850 | 1900 | - | 850 | 1900 | ns |
|  | $\mathrm{t}_{\text {CD1 }}$ | 10 | - | 425 | 950 | - | - | - |  |
| Data Out Valid Delay |  | 5 | - | 120 | 250 | - | 120 | 250 | ns |
|  | $t_{\text {cov }}$ | 10 | - | 60 | 125 | - | - | - |  |
| Data Out Hold Tıme |  | 5 | - | 100 | 200 | - | 100 | 200 | ns |
|  | $\mathrm{t}_{\mathrm{CDH}}$ | 10 | - | 50 | 100 | - | - | - |  |
| Repeat Valid Delay |  | 5 | 二 | 150 | 400 | - | 150 | 400 | ns |
|  | $\mathrm{t}_{\text {PPL }}$ | 10 | - | 75 | 200 | - | - | - |  |
| Repeat Invalid Delay |  | 5 | - | 350 | 700 | - | 350 | 700 | ns |
|  | $\mathrm{t}_{\text {RPH }}$ | 10 | - | 170 | 350 | - | - | - |  |

*Typical Values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$
Note 1. $\mathrm{t}_{\mathrm{cc}}=\mathrm{t}_{\mathrm{cwH}}+\mathrm{t}_{\mathrm{cw}}$
$\mathrm{tcw}_{\mathrm{cw}}=\mathrm{t}_{\mathrm{cD} 1}+\mathrm{KC}$
$\mathrm{k}=0.9 \mathrm{~ns}$ per pF
$\mathrm{c}=$ keyboard capacıtance $(\mathrm{pF})$


Fig 3 - CDP1871A dynamıc tımıng dıagram (non-repeat)


Fig 4 - CDP1871A dynamıc tıming dıagram (repeat)

## CDP1871A, CDP1871AC



Fig 5 - Typical system software flowchart for CDP1871A, CDP1871AC

# CDP1874C, CDP1875C 

## Features

- Parallel 8-Bit Input/Output Register with Buffered Outputs
- High-Speed Data-In to Data-Out . . . .85ns (Max.) at $V_{D D}=5 V$
- Flexible Applications In Microprocessor Systems as Buffers and Latches
- High Order Address-Latch Capability in CDP1800-Series Microprocessor Systems
- Output Sink Current $=5 \mathrm{~mA}$ (Min.) at VDD $=5 \mathrm{~V}$
- 3-State Output - CDP1872C and CDP1874C


## Ordering Information

| PKG | TEMP. RANGE | CDP1872C | CDP1874C | CDP1875C |
| :---: | :---: | :---: | :---: | :---: |
| Plastic DIP | $\begin{gathered} -40^{\circ} \mathrm{C} \text { to } \\ +85^{\circ} \mathrm{C} \end{gathered}$ | CDP1872CE | CDP1874CE | CDP1875CE |
| Burn-in |  | CDP1872CEX | - | - |
| Ceramic DIP | $\begin{gathered} -40^{\circ} \mathrm{C} \text { to } \\ +85^{\circ} \mathrm{C} \end{gathered}$ | CDP1872CD | $\bullet$ | CDP1875CD |
| Burn-in |  | - | - | CDP1875CDX |

## Description

The CDP1872C, CDP1874C and CDP1875C devices are high-speed 8 -bit parallel input and output ports designed for use in the CDP1800 microprocessor system and for general use in other microprocessor systems. The CDP1872C and CDP1874C are 8-bit input ports; the CDP1875C is an 8-bit output port.

These devices have flexible capabilities as buffers and data latches and are reset by CLR input when the data strobe is not active.

The CDP1872C and CDP1874C are functionally identical except for device selects. The CDP1872C has one active low and one active high select; the CDP1874C has two active high device selects. These devices also feature 3 -state outputs when deselected. Data is strobed into the register on the leading edge of the CLOCK and latched on the trailing edge of the CLOCK.

The CDP1875C is an output port with data latched into the registers when the device selects are active. There are two active high and one active low selects. The output buffers are enabled at all times.
These devices are supplied in 22-lead hermetic, dual-in-line side-brazed ceramic packages (D suffix) and in 22-lead dual-in-line plastic package ( E suffix).

## Pinouts



## MAXIMUM RATINGS, Absolute-Maximum Values:

| DC SUPPLY-VOLTAGE RANGE, (VDo ... <br> (Voltage referenced to $\mathrm{V}_{\text {ss }}$ Termınal) | $-0.5 \text { to }+7 \mathrm{~V}$ |
| :---: | :---: |
| INPUT VOLTAGE RANGE, ALL INPUTS | -0.5 to $V_{D D}+0.5 \mathrm{~V}$ |
| DC INPUT CURRENT, ANY ONE INPUT | $\pm 10 \mathrm{~mA}$ |
| POWER DISSIPATION PER PACKAGE (PD) |  |
| For $T_{A}=-40^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (PACKAGE TYPE E) | 500 mW |
| For $\mathrm{T}_{\mathrm{A}}=+60^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (PACKAGE TYPE E) | Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |
| For $T_{A}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (PACKAGE TYPE D) | . 500 mW |
| For $\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (PACKAGE TYPE D) | Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |
| DEVICE DISSIPATION PER OUTPUT TRANSISTOR |  |
| FOR $\mathrm{T}_{\text {A }}$ - FULL PACKAGE-TEMPERATURE RANGE (All Package Types) | . 100 mW |
| OPERATING-TEMPERATURE RANGE ( $T_{A}$ ) |  |
| PACKAGE TYPE D | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| PACKAGE TYPE E | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| STORAGE TEMPERATURE RANGE ( $\mathrm{T}_{\text {stg }}$ ) | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| LEAD TEMPERATURE (DURING SOLDERING) |  |
|  |  |

RECOMMENDED OPERATING CONDITIONS at $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.
For maximum rellability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS <br> ALL TYPES | UNITS |
| :--- | :---: | :---: |
| DC Operating-Voltage Range | 4 to 6.5 |  |
| Input Voltage Range | $V_{\text {Ss }}$ to $V_{D D}$ |  |

STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{D D} \pm 5 \%$, except as noted

| CHARACTERISTIC |  | TEST CONDITIONS |  |  | LIMITS ALL TYPES |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Vo <br> (V) | $V_{\text {IN }}$ <br> (V) | $V_{D D}$ <br> (V) | MIN. | TYP. ${ }^{\circ}$ | MAX. |  |
| Quiescent Device Current | ldo | - | 0,5 | 5 | - | 25 | 50 | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | loL | 0.4 | 0,5 | 5 | 5 | 10 | - | mA |
| Output High Drive (Source) Current | l о | 4.6 | 0,5 | 5 | -4 | -7 | - |  |
| Output Voltage Low-Level * | VoL | - | 0,5 | 5 | - | 0 | 0.1 | V |
| Output Voltage High-Level * | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5,4.5 | - | 5 | 3.5 | - | - |  |
| Input Leakage Current | In | - | 0,5 | 5 | - | - | $\pm 1$ | $\mu \mathrm{A}$ |
| 3-State Output Leakage Current \# | lout | 0, 5 | 0,5 | 5 | - | - | $\pm 5$ |  |
| Input Capacitance | $\mathrm{Cin}^{\text {IN }}$ | - | - | - | - | 15 | - | pF |
| Output Capacitance \# | Cout | - | - | - | - | 15 | - |  |

- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{DD}} \pm 5 \%$.
* $\mathrm{l}_{\mathrm{OL}}=\mathrm{I}_{\text {OH }}=1 \mu \mathrm{~A}$.
\# For CDP1872C and CDP1874C only.


Fig. 1 - Equivalent logic diagram (1 of 8 latches shown) for CDP1872C.


Fig. 2 - Equivalent logic diagram (1 of 8 latches shown) for CDP1874C.


Fig. 3 - Equivalent logic diagram (1 of 8 latches shown) for CDP1875C.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{t}}=10 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}$, $V_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$

| CHARACTERISTIC |  | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \hline \text { CDP1872C } \\ & \text { CDP1874C } \end{aligned}$ |  |  |
|  |  | TYP. - | MAX. $\dagger$ |  |
| Input Port (Fig. 4) |  |  |  |  |
| Output Enable | $t_{\text {EN }}$ | 45 | 90 | ns |
| Ourrat Disable | tois | 45 | 90 |  |
| Clock to Data Out | tclo | 45 | 90 |  |
| Clear to Output | tcRO | 80 | 160 |  |
| Data In to Data Out | toio | 50 | 85 |  |
| Minimum Data Setup Time | tosu | 10 | 30 |  |
| Data Hold Time | $t_{\text {DH }}$ | 10 | 30 |  |
| Minimum Clock Pulse Width | tcL | 30 | 60 |  |
| Minimum $\overline{\text { Clear }}$ Pulse Width | tcr | 30 | 60 |  |

- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $V_{D D} \pm 5 \% . \quad \dagger$ Maximum values are for $T_{A}=85^{\circ} \mathrm{C}$ and $V_{D D} \pm 5 \%$.


Fig. 4 - Timing waveforms for CDP1872C and CDP1874C (input-port types).

## Specifications CDP1872C, CDP1874C, CDP1875C

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{t}_{\mathrm{t}}, \mathrm{t}_{\mathrm{t}}=10 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}$, $V_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, C_{\mathrm{L}}=150 \mathrm{pF}$

| CHARACTERISTIC |  | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1875C |  |  |
|  |  | TYP. - | MAX. $\dagger$ |  |
| Output Port (Fig. 5) |  |  |  |  |
| Clock to Data Out | tclo | 50 | 100 | ns |
| $\overline{\text { Clear to Output }}$ | tcro | 80 | 160 |  |
| Data In to Data Out | toIo | 50 | 85 |  |
| Minimum Data Setup Time | tos | 10 | 30 |  |
| Data Hold Time | $\mathrm{t}_{\text {DH }}$ | 10 | 30 |  |
| Minimum Clear Pulse Width | $\mathrm{t}_{\mathrm{CR}}$ | 30 | 60 |  |

- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $V_{D D} \pm 5 \%$.
$\dagger$ Maximum values are for $T_{A}=85^{\circ} \mathrm{C}$ and $V_{D D} \pm 5 \%$.


Fig. 5 - Timing waveforms for CDP1875C (output port).


Fig. 6-CDP1874C used as an input port and address latch with CDP1875C used as an output port.


Fig. 7 - CDP1872C used as an input port and selected by CD74HC138.


Fig. 8-CDP1874C and CDP1875C used as input/output buffers.

## Features

- Compatible with CDP1800 Series
- Programmable Long Branch Vector Address and Vector Interval
- 8 Levels of Interrupt Per Chip
- Easily Expandable
- Latched Interrupt Requests
- Hard Wired Interrupt Priorities
- Memory Mapped
- Multiple Chip Select Inputs to Minimize Address Space Requirements


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | $\mathbf{5 V}$ | 10V |
| :--- | :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1877CE | CDP1877E |
| Ceramic <br> DIP <br> Burn-ın | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1877CD | CDP1877D |
|  |  | CDP1877CDX | - |

## Description

The CDP1877 and CDP1877C are programmable 8-level interrupt controllers designed for use in CDP1800 series microprocessor systems. They provide added versatility by extending the number of permissible interrupts from 1 to N in increments of 8 .
When a high to low transition occurs on any of the PIC interrupt lines ( $\overline{\mathrm{IRO}}$ to (1R7), it will be latched and, unless the request is masked, it will cause the INTERRUPT line on the PIC and consequently the INTERRUPT input on the CPU to go low.
The CPU accesses the PIC by having interrupt vector register R(1) loaded with the memory address of the PIC. After the interrupt S3 cycle, this register value will appear at the CPU address bus, causing the CPU to fetch an instruction from the PIC. This fetch cycle clears the interrupt request latch bit to accept a new high-to-low transition, and also causes the PIC to issue a long branch instruction (CO) followed by the preprogrammed vector address written into the PIC's address registers, causing the CPU to branch to the address corresponding to the highest priority active interrupt request.
If no other unmasked interrupts are pending, the INTERRUPT output of the PIC will return high. When an interrupt is requested on a masked interrupt line, it will be latched but it will not cause the PIC INTERRUPT output to go low. All pending interrupts, masked and unmasked, will be indicated by a "1" in the corresponding bit of the status register. Reading of the status register will clear all pending interrupt request latches.
Several PICs can be cascaded together by connecting the INTERRUPT output of one chip to the CASCADE input of another. Each cascaded PIC provides 8 additional interrupt levels to the system. The number of units cascadable depends on the amount of memory space and the extent of the address decoding in the system.
Interrupts are prioritized in descending order; $\overline{\mathbb{R} 7}$ has the highest and $\overline{\mathrm{IRO}}$ has the lowest priority.
The CDP1877 and CDP1877C are functionally identical. They differ in that the CDP1877 has a recommended operating voltage range of 4 V to 10.5 V , and the CDP1877C has a recommended operating voltage range of 4 V to 6.5 V . These types are supplied in 28 lead dual-in-line ceramic packages ( $D$ suffix), and 28 -lead dual-in-line plastic packages ( E suffix).

## Pinout



## Programming Model

PROGRAMMABLE INTERRUPT CONTROLLER (PIC)

MAXIMUM RATINGS, Absolute-Maximum Values:
DC SUPPLY-VOLTAGE RANGE, (VDD)
(Voltage referenced to $\mathrm{V}_{\text {SS }}$ terminal)
CDP1877 -0.5 to +11 V
CDP1877C ..... -0.5 to +7 V
INPUT VOLTAGE RANGE, ALL INPUTS -0.5 to $V_{D D}+0.5 \mathrm{~V}$$\pm 10 \mathrm{~mA}$
POWER DISSIPATION PER PACKAGE (PD):
For $\mathrm{T}_{\mathrm{A}}=-40$ to $+60^{\circ} \mathrm{C}$ (PACKAGE TYPE E) ..... 500 mW
For $T_{A}=+60$ to $+85^{\circ} \mathrm{C}$ (PACKAGE TYPE E) Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mWFor $T_{A}=-55$ to $+100^{\circ} \mathrm{C}$ (PACKAGE TYPE D)500 mW
For $T_{A}=+100$ to $125^{\circ} \mathrm{C}$ (PACKAGE TYPE D) Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW
DEVICE DISSIPATION PER OUTPUT TRANSISTORFOR $T_{A}=F U L L$ PACKAGE-TEMPERATURE RANGE (All Package Types)100 mW
OPERATING-TEMPERATURE RANGE ( $T_{A}$ ):
PACKAGE TYPE D ..... -55 to $+125^{\circ} \mathrm{C}$
PACKAGE TYPE E -40 to $+85^{\circ} \mathrm{C}$
STORAGE-TEMPERATURE RANGE ( $\mathrm{T}_{\text {stg }}$ ) ..... -65 to $+150^{\circ} \mathrm{C}$LEAD TEMPERATURE (DURING SOLDERING):At distance $1 / 16 \pm 1 / 32 \mathrm{in}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10 s max.$+265^{\circ} \mathrm{C}$

## STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $\mathbf{+ 8 5}{ }^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm \mathbf{5} \%$, Except as noted


-Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}} . \quad{ }_{{ }_{\mathrm{IOL}}}=\mathrm{IOH}_{\mathrm{OH}}=1 \mu \mathrm{~A}$.
\# Operating current measured under worst-case conditions in a $3.2-\mathrm{MHz}$ CDP1802A system: one PIC access per instruction cycle.

OPERATING CONDITIONS at TA $_{\mathbf{A}}=$ Full Package-Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1877 |  | CDP1877C |  |  |
|  | Min. | Max. | Min. | Max. |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | $v$ |
| Input Voltage Range | $\mathrm{v}_{\text {SS }}$ | VDD | VSS | VDD |  |



Functional Definitions for CDP1877 and CDP1877C Terminals

| TERMINAL | USAGE | TYPE |
| :---: | :---: | :---: |
| $\mathrm{V}_{\text {DD }}-\mathrm{V}_{\text {SS }}$ | Power |  |
| BUS0-BUS7 | Data bus-Communicates information to and from CPU | Bidirectional |
| IR0-IR7 | Interrupt Request Lines | Input |
| INTERRUPT | Interrupt to CPU | Output |
| $\overline{M R D}$, $\overline{M W R}$ | Read/Write controls from CPU | Input |
| TPA, TPB | Timing pulses from CPU | Input |
| CS, $\overline{\mathrm{CS}}$ | Chip selects, Enable Chip if valid during TPA | Input |
| CS/Ax, CS/Ay | Used as a Chip Select during TPA and as a Register address during Read/Write Operations | Input |
| CASCADE | Used for cascading several PIC units. The INTERRUPT output from a higher priority PIC can be tied to this input, or the input can be tied to Vdd if cascading is not used. | Input |

## PIC Programming Model

## INTERNAL REGISTERS

The PIC has three write-only programmable registers and two read-only registers.

## Page Register

This write only register contains the high order vector address the device will issue in response to an interupt request. This high-order address will be the same for any of

## BUS 7

the 8 possible interrupt requests; thus, interrupt vectoring differs only in location within a specified page.

| A15 | A14 | A13 | PAGE REGISTER BITS |  |  |  | A12 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

## Control Register

The upper nibble of this write-only register contains the low order vector address the device will issue in response to an
interrupt request. The lower nibble is used for a master interrupt reset, master mask reset and for interval select.


THE LOW ORDER VECTOR ADDRESS WILL BE SET ACCORDING TO THE TABLE BELOW:

| INTERVAL SELECTEDNO. OF BYTES | BIT B7 | $\begin{aligned} & \text { LOW A } \\ & \text { BIT B6 } \end{aligned}$ | BITS <br> BIT B5 | BIT B4 |
| :---: | :---: | :---: | :---: | :---: |
| 2 | SETS A7 | SETS A6 | SETS A5 | SET A4 |
| 4 | SETS A7 | SETS A6 | SETS A5 | X |
| 8 | SETS A7 | SETS A6 | X | X |
| 16 | SETS A7 | X | X | X |

X=DON'T CARE
NOTE: All DON'T CARE Addresses and Addresses A0-A3 are determined by interrupt request.

## Mask Register

A "1" written into any location in this write only register will mask the corresponding interrupt request line. All interrupt inputs (except CASCADE) are maskable.

BUS 7
BUS 0


## Status Register

In this read only register a " 1 " will be present in the corresponding bit location for every masked or unmasked pending interrupt.

BUS 7 BUS 0

|  |  | STATUS BITS |  |  |  |  |
| :--- | :--- | :--- | ---: | ---: | ---: | ---: |
| S 7 | S 6 | S 5 | S 4 | S 3 | S 2 | S 1 |

## Polling Register

This read only register provides the low order vector address and is used to identify the source of interrupt if a polling technique, rather than interrupt servicing, is used.


## RESPONSE TO INTERRUPT (AFTER S3 CYCLE)

The PIC's response to interrogation by the CPU is always 3 bytes long, placed on the data bus in consecutive bytes in the following format:
First (Instruction) Byte:
LONG BRANCH INSTRUCTION - CO (Hex)

BUS 7

| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## Second (High-Order Address) Byte

This byte is the High-Order vector Address that was written into the PIC's Page Register by the user. The PIC does not alter this value in any way.

High-Order Vector Address

$$
\text { BUS } 7
$$

BUS 0

| A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Third (Low-Order Address) Bytes
INTERVAL 2
BUS 7
BUS 0


INTERVAL 4


INTERVAL 8


INTERVAL 16
BUS 7 BUS 0


Indicates active interrupt input number (binary 0 to 7 ).

Bits indicated by $A x$ ( $x=4$ to 7 ) are the same as programmed into the Control Register. All other bits are generated by the PIC.

## REGISTER ADDRESSES

In order to read/write or obtain an interrupt vector from any PIC in the system, all chip selects (CS/Ax, CS/Ay, CS, $\overline{C S}$ ) must be valid during TPA.

CS/Ax and CS/Ay are multiplexed addresses; both must be high during TPA, and set according to this table during TPB to access the proper register.

| $\mathbf{C S} / \mathbf{A x}$ | $\mathbf{C S} / \mathbf{A y}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathrm{WR}}$ | ACTION TAKEN |
| :---: | :---: | :---: | :---: | :--- |
| 1 | 0 | 0 | 1 | READ Long Branch instruction and vector for highest priority unmasked <br> interrupt pending. |
| 1 | 0 | 1 | 0 | WRITE to Page Register |
| 0 | 1 | 1 | 0 | WRITE to Control Register |
| 0 | 0 | 0 | 1 | READ Status Register |
| 0 | 0 | 1 | 0 | WRITE to Mask Register |
| 0 | 1 | 0 | 1 | READ Polling Register (Used to identify INTERRUPT source if Polling tech- <br> nique rather than INTERRUPT service is used.) |
| 1 | 1 | X | X | Unused condition |

## PIC Application Examples

Example I-Single PIC Application
Fig. 2 shows all the connections required between CPU and PIC to handle eight levels of interrupt control.


Fig. 2 - PIC and CPU connection diagram.

## Programming

Programming the PIC consists of the following steps:

1. Disable interrupt at CPU.
2. Reset Master Interrupt Bit, B3, of Control Register.
3. Write a " 1 " into the Interrupt Input bit location of the Mask Register, if maskıng is desıred.
4. Write the High-Order Address byte into the Page Register.
5. Write the Low-Order Address and the vector interval into the Control Register.
6. Program $R(1)$ of the CPU to point to the PIC so that the Long Branch instruction can be read from the PIC during the Interrupt Service routine.

Values for Example I with LOCATION 84EO arbitrarily chosen as the Vector Address with interval of eight bytes, $\overline{\mathrm{R} 4}$ pending, is shown in Table I
In deriving the above addresses, all DON'T CARE bits are assumed to be 0 .
When an INTERRUPT ( $\overline{\mathrm{R} 4}$ ) is received by the CPU, it will address the PIC and will branch to the interrupt service routıne.
The three bytes generated by the PIC will be:
1st Byte $=\mathrm{CO}_{\mathrm{H}}$
2nd Byte $=84 \mathrm{H}$
3rd Byte $=E O_{H}$

Table I - Register Address Values

| REGISTER | REGISTER ADDRESS | OPERATION | DATA BYTE |
| :---: | :---: | :---: | :---: |
| MASK | EOOOH | WRITE | 00 H |
| CONTROL | EO40H | WRITE | CEH |
| PAGE | EO80H | WRITE | $84 H$ |
| STATUS | $E 000 H$ | READ | 10 H |
| POLLING | EO40H | READ | EOH |
| R(1) (IN CPU) | E08OH | - | - |

## CDP1877, CDP1877C

## Example II—Multi-PIC Application

Fig. 3 shows all the connections required between CPU and
PICs to handle sixteen levels of interrupt control.


Fig. 3 - PICs and CPU connection diagram.

## Register Address Assignments

The low-byte register address for any WRITE or READ operation is the same as shown in Table I.
The high-byte register differs for each PIC because of the linear addressing technique shown in the example:

$$
\begin{aligned}
& \text { PIC } 1=111 \times \times \times 01(E 1 H \text { FOR X=0) } \\
& \text { PIC } 2=111 \times X X 10(E 2 H \text { FOR X=0) }
\end{aligned}
$$

The $R(1)$ vector address is unchanged. This address will select both PICs simultaneously ( $\mathrm{R}(1) .1=111 \times \mathrm{XX00}=\mathrm{EOH}$ ). Internal CDP1877 logic controls which PIC will respond when an interrupt request is serviced.

## Additional PIC Application Comments

The interval select options provide significant flexibility for interrupt routine memory allocations:

- The 2-byte interval allows one to dedicate a full page to interrupt servicing, with variable space between routines, by specifying indirect vectoring with 2 byte short branch instructions on the current page.
- The 4-byte interval allows for a 3 byte long branch to any location in memory where the interrupt service
routine is located. The branch can be preceded by a Save Instruction to save previous contents of $X$ and $P$ on the stack.
- The 8 -byte and 16-byte intervals allow enough space to perform a service routine without indirect vectoring. The amount of interval memory can be increased even further if ali 8 INTERRUPTS are not required. Thus a 4level interrupt system could use alternate IR Inputs, and expand the interval to 16 and 32 bytes, respectively.
The 4 Chip Selects allow one to conserve total allotted memory space to the PIC. For one chip, a total of 4 address lines could be used to select the device, mapping it into as little as 4-K of memory space. Note that this selection technique is the only one that allows the PIC to work properly in the system: I/O mapping cannot be used because the PIC must work within the CDP1800 interrupt structure to define the vector address. Decoded signals also will not work because the chip selects must be valid on the trailing edge of TPA.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%, \mathrm{t}_{\mathrm{r}}, \mathrm{tf}_{\mathrm{f}}=20 \mathrm{~ns}$,


| CHARACTERISTIC |  | VDD <br> (V) | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1877 |  |  | CDP1877C |  |  |  |
|  |  |  | Min. | Typ. ${ }^{\circ}$ | Max. | Min. | Typ. ${ }^{\text {® }}$ | Max. |  |
| Address to TPA Setup Time | tas | 5 | 60 | - | - | 60 | - | - | ns |
| Address to TPA Setup Time | tas | 10 | 40 | - | - | - | - | - |  |
| Address to TPA Hold Time |  | 5 | 60 | - | - | 60 | - | - |  |
|  | H | 10 | 40 | - | - | - | - | - |  |
| Data Valid after TPB |  | 5 | 370 | - | - | 370 | - | - |  |
|  | t ${ }^{\text {DTPB }}$ | 10 | 210 | 310 | - | - | - | - |  |
| Data Hold Time from Write | W | 5 | 30 | - | - | 30 | - | - |  |
|  | W | 10 | 40 | - | - | - | - | - |  |
| Address to Valid Data Access Time |  | 5 | - | 340 | 490 | - | 340 | 490 |  |
|  | tor | 10 | - | 125 | 230 | - | - | - |  |
| Data Setup Time to Write | tDSU | 5 | 0 | - | - | 0 | - | - |  |
| Data Setup Time to Write | IDSU | 10 | 0 | - |  |  | - | - |  |
| Address Hold from TPB |  | 5 | 80 | - | - | 80 | - | - |  |
|  | TPB | 10 | 40 | - | - | - | - | - |  |
| Minimum $\overline{M W R}$ Pulse Width |  | 5 | 130 | - | - | 130 | - | - |  |
|  | tMWR | 10 | 60 | - | - | - | - | - |  |
| Minimum IR Pulse Width | t- | 5 | 130 | - | - | 130 | - | - |  |
| Minimum In Pulse Widn | TRX | 10 | 60 | - | - |  | - | - |  |

${ }^{-}$Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{DD}} \pm 5 \%$.


Fig. 4 - Timing waveforms for CDP1877.

## Features

- Compatible with General Purpose and CDP1800Series Microprocessor Systems
- Two 16-Bit Down Counters and Two 8-Bit Control Registers
- 5 Modes Including a Versatile Variable-Duty Cycle Mode
- Programmable Gate-Level Select
- Two-Complemented Output Pins for Each CounterTimer
- Software-Controlled Interrupt Output
- Addressable in Memory Space or CDP1800-Series VO Space


## Ordering Information

| PACKAGE | TEMP. |  |  |
| :---: | :---: | :---: | :---: |
| RANGE | 5V | 10V |  |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1878CE | CDP1878E |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1878CD | CDP1878D |
| Burn-In |  | CDP1878CDX | - |

## Description

The CDP1878 and CDP1878C are dual counter-timers consisting of two 16 -bit programmable down counters that are independently controlled by separate control registers. The value in the registers determine the mode of operation and control functions. Counters and registers are directly addressable in memory space by any general industry type microprocessors, in addition to input/output mapping with the CDP1800 series microprocessors.

Each counter-timer can be configured in five modes with the additional flexibility of gate-level control. The control registers in addition to mode formatting, allow software start and stop, interrupt enable, and an optional read control that allows a stable readout from the counters. Each countertimer has software control of a common interrupt output with an interrupt status register indicating which counter-timer has timed out.

In addition to the interrupt output, true and complemented outputs are provided for each counter-timer for control of peripheral devices.
The CDP1878 and CDP878C are functionally identical. They differ in that the CDP1878 has a recommended operating voltage range of 4 to 10.5 volts, and the CDP1878C has a recommended operating voltage range of 4 volts to 6.5 volts. These types are supplied in 28 -lead dual-in-line ceramic packages ( D suffix), and 28 -lead dual-in-line plastic packages (E suffix).

## Pinout

|  |  |
| :---: | :---: |
| INT 1 | ${ }^{28} \mathrm{~V}_{\mathrm{DD}}$ |
| TAO 2 | $27 \mathrm{DB7}$ |
| $\overline{T A O}$ | $26 \mathrm{DB6}$ |
| tag 4 | 25 dB5 |
| tacl 5 | 24 DB4 |
| 吅 6 | 23 DB3 |
| I-OMEM 7 | $22 \mathrm{DB2}$ |
| TPB $\overline{W R}$ | $21 \mathrm{DB1}$ |
| TPA 9 | 20 DB0 |
| cs 10 | 19 тво |
| ${ }^{\text {a }} 111$ | 18 TBO |
| ${ }^{4} 12$ | 17 TBG |
| A2 13 | 16 tBCL |
| $\mathrm{v}_{\text {ss }} 14$ | 13 RESET |

TABLE 1. MODE DESCRIPTION

| MODE | FUNCTION | APPLICATION |
| :--- | :--- | :--- |
| 1 Timeout | Outputs change when clock <br> decrements counter to "0" | Event counter |
| 2 Timeout Strobe | One clockwide output pulse when <br> clock decrements counter to "0" | Trigger pulse |
| 3 Gate-Controlled |  |  |
| One Shot | Outputs change when clock <br> decrements counter to "0". <br> Retriggerable | Time-delay <br> generation |
| 4 Rate Generator | Repetitive clockwide output pulse | Time-base <br> generator |
| 5 Variable-Duty | Repetitive output with <br> programmed duty cycle | Motor control |

## Absolute Maximum Ratings

| DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ): <br> (All Voltages Referenced to $\mathrm{V}_{\mathrm{SS}}$ Terminal) |  |
| :---: | :---: |
| CDP1878. | -0.5V to +11V |
| CDP1878C. | -0.5V to +7V |
| Input Voltage Range, All inputs | . 5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, Any One Input. | $\pm 10 \mathrm{~mA}$ |
| Power Dissıpation Per Package ( $\mathrm{P}_{\mathrm{D}}$ ) |  |
| $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (Package Type E) | 500 mW |
| $\mathrm{T}_{\mathrm{A}}=+60^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type E) | . . . Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |
| $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (Package Type D) | 500 mW |
| $\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Package Type D) | . . Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |

Device Dissipation Per Output Transistor $\mathrm{T}_{\mathrm{A}}=$ Full Package Temperature Range (All Package Types)

100 mW Operating Temperature Range $\left(T_{A}\right)$ :
Package Type D
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Package Type E. . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stg }}$ ) . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{In}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10s max.
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | SYMBOL | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1878 |  | CDP1878C |  |  |
|  |  | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range |  | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range |  | $\mathrm{V}_{\text {S }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{SS}}$ | $V_{D D}$ | V |
| Maxımum Clock Input Rise or Fall Time | $t_{r}, t_{\text {f }}$ | - | 5 | - | 5 | $\mu \mathrm{s}$ |
| Minimum Clock Pulse Width | $\mathrm{t}_{\text {WL }}, \mathrm{t}_{\text {WH }}$ | 200 | - | 200 | - | ns |
| Maximum Clock Input Frequency | $\mathrm{f}_{\mathrm{CL}}$ | DC | 1 | DC | 1 | MHz |

Static Electrical Characteristics At $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{VDD} \pm 5 \%$ Except as Noted:

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & v_{\mathrm{O}} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1878 |  |  | CDP1878C |  |  |  |
|  |  |  |  |  | MIN | (Note 1) TYP | MAX | MIN | (Note 1) TYP | MAX |  |
| Quiescent Device Current | $\mathrm{I}_{\mathrm{DD}}$ | - | 0,5 | 5 | - | . 01 | 50 | - | . 02 | 200 | $\mu \mathrm{A}$ |
|  |  | - | 0, 10 | 10 | $\bullet$ | 1 | 200 | - | - | - | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | $\mathrm{l}_{\mathrm{OL}}$ | 0.4 | 0, 5 | 5 | 1.6 | 3.2 | - | 1.6 | 3.2 | - | mA |
|  |  | 0.5 | 0, 10 | 10 | 2.6 | 5.2 | - | - | - | $\bullet$ | mA |
| Output High Drive (Source) Current | $\mathrm{I}_{\mathrm{OH}}$ | 4.6 | 0, 5 | 5 | -1.15 | -2.3 | - | -1.15 | -2.3 | - | mA |
|  |  | 9.5 | 0, 10 | 10 | -2.6 | -5.2 | - | - | - | - | mA |
| Output Voltage Low-Level (Note 2) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  |  | - | 0, 10 | 10 | - | 0 | 0.1 | $\cdot$ | - | - | V |
| Output Voltage High-Level (Note 2) | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | $\cdot$ | 4.9 | 5 | - | V |
|  |  | - | 0, 10 | 10 | 9.9 | 10 | - | - | - | - | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 0.5, 9.5 | - | 10 | - | - | 3 | - | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 9.5 | - | 5 | 3.5 | - | $\cdot$ | 3.5 | - | - | V |
|  |  | 0.5, 9.5 | - | 10 | 7 | - | $\cdot$ | - | - | - | V |
| Input Leakage Current | $\mathrm{I}_{\mathrm{IN}}$ | Any | 0,5 | 5 | - | - | $\pm 1$ | - | - | $\pm 1$ | $\mu \mathrm{A}$ |
|  |  | Input | 0, 10 | 10 | $\cdot$ | - | $\pm 2$ | $\cdot$ | - | $\cdot$ | $\mu \mathrm{A}$ |
| Operating Current (Note 3) | $\mathrm{I}_{\text {DD1 }}$ | - | 0, 5 | 5 | - | 1.5 | 3 | - | 1.5 | 3 | mA |
|  |  | - | 0, 10 | 10 | $\cdot$ | 6 | 12 | - | - | - | mA |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | $\bullet$ | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance | $\mathrm{C}_{\text {OUt }}$ | - | - | - | - | 10 | 15 | - | 10 | 15 | pF |

NOTES:

1. Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
2. $\mathrm{I}_{\mathrm{OL}}=\mathrm{I}_{\mathrm{OH}}=1 \mu \mathrm{~A}$.
3. Operating current measured at 200 kHz for $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ and 400 kHz for $V_{D D}=10 \mathrm{~V}$, with open outputs (worst-case frequencies for CDP1802A system operating at maximum speed of 3.2 MHz ).


Fig. 1 - Functional diagram CDP1878 and CDP1878C.

Functional Definitions for CDP1878 and CDP1878C Terminals

| TERMINAL | USAGE | TERMINAL | USAGE |
| :---: | :---: | :---: | :---: |
| VDD-VSS | Power |  |  |
| DB0-DB7 | Data to and from device | CS | Active high input that enables device |
| TPB/WR, $\overline{R D}$ | Directional control signals | INT | Low when counter is " 0 " |
| A0, A1, A2 | Addresses that select counters or registers | RESET | When active, TAO, TBO are low, $\overline{\mathrm{TAO}}, \overline{\mathrm{TBO}}$ are high. Interrupt stat |
| TACL, TBCL | Clocks used to decrement counters |  | register is cleared |
| TAG, TBG | Gate inputs that control counters | I-O/MEM | Tied high in CDP1800 input/output |
| TAO, $\overline{\text { TAO }}$ | Complemented outputs of Timer A |  | mode, otherwise tied low |
| TBO, $\overline{\text { TBO }}$ | Complemented outputs of Timer B |  |  |
| TPA | Used with CDP1800-series processors, tied high otherwise |  |  |

## REGISTER TRUTH TABLE

| ADDRESS |  |  | ACTIVE |  | REGISTER OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A2 | A1 | A0 | TPB/WR | $\overline{R D}$ |  |
| 1 | 1 | 0 | X |  | Write Counter A MSB |
| 1 | 1 | 0 |  | X | Read Counter A MSB |
| 0 | 1 | 0 | X |  | Write Counter A LSB |
| 0 | 1 | 0 |  | X | Read Counter A LSB |
| 1 | 0 | 0 | X |  | Control Register A |
| 1 | 1 | 1 | X |  | Write Counter B MSB |
| 1 | 1 | 1 |  | X | Read Counter B MSB |
| 0 | 1 | 1 | X |  | Write Counter B LSB |
| 0 | 1 | 1 |  | X | Read Counter B LSB |
| 1 | 0 | 1 | X |  | Control Register B |
| 1 | 0 | 0 |  | X |  |
| 1 | 0 | 1 |  | X | Interrupt Status Register |
| 0 | 0 | 0 |  |  | Not Used |
| 0 | 0 | 1 |  |  | Not Used |

PROGRAMMING MODEL


Counter B Registers


## Functional Description-See Fig. 1

The dual counter-timer consists of two programmable 16bit down counters, separately addressable and controlled by two independent 8 -bit control registers. The word in the control register determines the mode and type of operation that the counter-timer performs. Writing to or reading from a counter or register is enabled by selective addressing during a write or read cycle. The data is placed on the data bus by the microprocessor during the write cycle or read from the counter during the read cycle. Data to and from the counters and to the control registers is in binary format.
Each counter-timer consists of three parts. The first is the counter itself, a 16-bit down counter that is decremented on the trailing edge of the clock input. The second is the jam register that receives the data when the counter is written to. The word in the control register determines when the jam register value is placed into the counter. The third part is the holding register that places the counter value on the data bus when the counter is read.
When the counter has decremented to zero, three events occur. The first involves the common interrupt output pin that, if enabled, becomes active low. The second is the setting of a bit in the interrupt status register. This register can be read to determine which counter-timer has timed out. The third event is the logic change of the complemented output pins.
In addition to the clock input used to decrement the counter, a gate input is available to enable or initiate operation. The counter-timers are independent and can have different mode operations.

## Write Operation

The counters and registers are separately addressable and are programmed via the data bus when the chip is selected with the TPB/WR pin active. Normal sequencing requires that the counter jam register be loaded first with the required value (most significant and least significant byte
in any order), and then the control register be accessed and loaded with the control word. The trailing edge of the TPB/WR pulse will latch the control word into the control register. The trailing edge of the first clock to occur with gate valid will cause the counter to be jammed with its initial value. The counter will decrement on the trailing edge of succeeding clocks as long as the gate is valid, until it reaches zero. The output levels will then change, and if enabled, the interrupt output will become active and the appropriate timer bit will be set in the interrupt status register. The interrupt output and the interrupt status register can be cleared (to their inactive state) by addressing the control register with the TPB/WR line active. For example, if counter A tımes out, control register A must be accessed to reset the interrupt output high and reset the timer A bit in the status register low. Timer B bit in the status register will be unaffected.

## Read Operation

Each counter has a holding register that is continuously being updated by the counter and is accessed when the counter is addressed during read cycles. Counter reads are accomplished by halting the holding register and then reading it, or by reading the holding register directly. If the holding register is read directly, data will appear on the bus if the counters are addressed with the $\overline{R D}$ line active. However, if the clock decrements the counter between the two read operations (most and least significant byte), an inaccurate value will be read. To preclude this from happening, writing a " 1 " into bit 6 of the control register and then addressing and reading the counter will result in a stable reading. This operation prevents the holding register from being updated by the counter and does not affect the counter's operation.
The interrupt status register is read by addressing either control register with the $\overline{\mathrm{RD}}$ line active. A " 1 " in bit 7 indicates Timer $A$ has timed out and a " 1 " in bit 6 indicates Timer B has timed out. Bits 0-5 are zeros.

## Control Register



Bits 0, 1 and 2 - Mode Selects-See Mode Timing Diagrams (Figs. 2, 3, 4, 5 and 6).

|  | Bit 7 | Bit 2 | Bit 1 | Bit 0 |
| :--- | :---: | :---: | :---: | :---: |
| Mode 1 - Timeout | - | 0 | 0 | 1 |
| Mode 2 - Timeout Strobe | - | 0 | 1 | 0 |
| Mode 3 - Gate Controlled One Shot | 0 | 0 | 1 | 1 |
| Mode 4 - Rate Generator | - | 1 | 0 | 0 |
| Mode 5 - Variable-Duty Cycle | - | 1 | 0 | 1 |
| No Mode selected. Counter outputs unaffected | - | 0 | 0 | 0 |

Note: When selecting a mode, the timer outputs TAO and TBO are set low, and TAO and TBO are set high. If bits 0,1 and 2 are all zero's when the control register is loaded, no
mode is selected, and the counter-timer outputs are unaffected. Issuing mode 6 will cause an indeterminate condition of the counter, issuing mode 7 is equivalent to issuing mode 5.

Bit 3-Gate level select-All modes require an enabling signal on the gate to allow counter operation. This enabling signal is either a level or a pulse (edge). Positive gate level or edge enabling is selected by writing a " 1 " into this bit and negative (low) enabling is selected when bit 3 is " 0 ".
Bit 4-Interrupt enable-Settıng this bit to " 1 " enables the INT output, and setting it to " 0 " disables it When reset, the INT output is at a high level. If the interrupt enable bit in the control register is enabled and the counter decrements to zero, the INT output will go low and will not return high until the counter-timer is reset or the selected control register is written to Example: If timer B times out, control register B must be accessed to reset the $\overline{1 N T}$ output high. If the interrupt enable bit is set to " 0 ", the counter's timeout will have no effect on the INT output.
In mode 5, the variable-duty cycle mode, the $\overline{\mathrm{NT}}$ pin will become active low when the MSB in the counter has decremented to zero.
Bit 5-Start/stop control-This bit controls the clock input to the counter and must be set to " 1 " to enable it. Writing a " 0 " into this location will halt operation of the counter. Operation will not resume until the bit is set to " 1 "
Bit 6-Holding register control-Since the counter may be decrementing during a read cycle, writing a " 1 " into this location will hold a stable value in the hold register for
subsequent read operations. Rewriting a " 1 " into bit 6 will cause an update in the holding register on the next trailing clock edge. If this location contains a " 0 ", the holding register will be updated continuously by the value in the counter.

Bit 7-Jam enable-When this bit is set to " 1 " during a write to the control register, the 16 -bit value in the jam register will be avallable to the counter; TAO and TBO are reset low and TAO and TBO are set high. On the trailing edge of the first input clock signal with the gate valid this value will be latched in the counter, the counter outputs TAO and TBO will be set high and the TAO and TBO will be reset low. Settıng bit 7 to " 0 " will leave the counter value unaffected. This location should be set to " 0 " any time a write to the control register must be performed without changing the present counteb value. If the value in the jam register has not been changed, writing a " 1 " into bit 7 of the control register with zeros in bits 0,1 , and 2 (mode select) will reload the counter with the old value and leave the mode unchanged. If the value in the jam register is changed, then the next write to the control register (with bit 7 a " 1 ") must include a valid mode select (i.e., at least 1 of the bits 0,1 , or 2 must be a" 1 ").
In mode 3, the hardware start is enabled by writing a " 0 " into bit 7 If a " 1 " is written to bit 7 , the timeout will start immediately and mode 3 will resemble mode 1.

MODE DESCRIPTIONS


Mode 1:
After the count is loaded into the jam register and the control register is written to with the jam-enable bit high on the trailing edge of the first clock after the gate is valid, TXO goes high and TXO goes low. The input clock decrements the counter as long as the gate remains valid. When it reaches zero, TXO goes low and TXO goes high, and if
enabled, the interrupt output is set low. Writing to the counter while it is decrementing has no effect on the counter value unless the control register is subsequently written to with the jam-enable bit high. After timeout the counter remains at FFFF unless reloaded.


| Mode |  | Control Register |  |  |  | Gate Control <br> 2$\quad$Selectable <br> High or Low Level <br> Enables Operation |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Mode 2:
Operation of this mode is the same as mode 1, except the outputs will change for one clock period only and then
return to the condition of TXO high and TXO low, and the counter is reloaded.


Fig. 3 - Timeout strobe (mode 2) timing waveforms.


Mode 3:
After the jam register is loaded with the required value, the gate edge will initiate this mode. TXO will be set high, and TXO will be set low. The clock will decrement the counter. When zero is reached, TXO will go low and TXO will be high, and the interrupt output will be set low. The counter is
retriggerable: While the counter is decrementing, a gate edge or write to the control register with the jam-enable bit high, will load the counter with the jam register value and restart the one-shot operation.


Fig. 4 - Gate controlled one-shot (mode 3) timing waveforms.

| Mode |  | Control Register |  |  |  |  | Gate Control <br> 4$\quad$Selectable <br> Rate Generator or Low Level <br> Enables Operation |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## Mode 4:

A repetitive clock-wide output pulse will be output, with the time between pulses equal to the counter's value, (trailing edge to leadıng edge). This model is software started with a write to the control register if the gate level is valid if the counter is written to while decrementing, the new value will
not affect the counter's operation until the present timeout has concluded, unless the control register is written to with the jam-enable bit high if the gate input (TAG or TBG) is used to start this mode. The first cycle following the gate going true is indeterminate.


Fig. 5 - Rate generators (mode 4) timing waveforms. $\quad$ 92CM-34631R2

| Mode |  | Control Register |  |  |  |  | Gate Control <br> 5 | Velectable |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vigh or Low Level |  |  |  |  |  |  |  |  |
| Enables Operation |  |  |  |  |  |  |  |  |

## Mode 5:

After the mode is initiated, the outputs will remain at one level until the clock decrements the least significant byte of the counter to $\mathrm{N}+1$. The outputs will then change level and the counter decrements the most significant byte to $\mathrm{N}+1$. The process will then repeat, resulting in a repetitive output
with a duty cycle directly controlled by the value in the counter. The output period will be equal to LSB+MSB+2.
The interrupt output will become active after the MSB is loaded into the counter and decrements to zero.


Fig. 6 - Variable-duty cycle (mode 5) timing waveforms.

## Note:

In order to avoid unwanted starts when selecting mode 3 or 4 , the gate signal must be set to the opposite level that will be programmed.

## Setting the Control Register

The following will illustrate a counter write and subsequent reads that places stable, accurate values on the data bus from the counter-timer.

The counter is addressed and the required values are loaded with a write operation. The control register is addressed next and loaded with B9H.


The counter will now decrement with each input clock pulse while the gate is valıd Assuming the counter has not decremented to zero and its value is to be read without affecting the counter's operation, a write to the control register is performed. 78 H is loaded into the control register.


The counter is addressed and read operations are performed.

## Function Pin Definition

DB7-DB0-8-bit bidirectional bus used to transfer binary information between the microprocessor and the dual counter-timer.
VDD, VSS-Power and ground for device.
A0, A1, and A2-Addresses used to select counters or registers.
TPB/WR, $\overline{\mathbf{R D}}$-Directional signals that determine whether data will be placed on the bus from a counter or the interrupt status register ( $\overline{\mathrm{RD}}$ active) (memory mapped), or data on the bus will be placed into a counter or control register (TPB/WR active). The following connections are required between the microprocessor and the countertimer in the CDP1800-series input/output mapping mode.

| Microprocessor | Counter-Timer |
| :---: | :---: |
| $\overline{M R D}$ | $\overline{R D}$ |
| TPB | $T P B / \overline{W R}$ |
| TPA | TPA |
| N Lines | Address Lines |
| $\overline{M E M}$ to VDD. |  |

During an output instruction, data from the memory is strobed into the counter-timer during TPB when $\overline{R D}$ is active, and latched on TPB's trailing edge. Data is read from the counter-timer when $\overline{R D}$ is not active between the trailing edges of TPA and TPB. (See Figs. 10, 11, and 12.)

TACL, TBCL-Clocks used to decrement the counter.
TAG, TBG-Gate inputs used to control counter.
TAO, TAO-Complemented outputs of Timer A.
TBO, $\overline{\text { TBO}}$-Complemented outputs of Timer B.
INT-Common interrupt output. Active when counter decrements to zero.
RESET-Active low signal that resets counter outputs (TAO, TBO low, TAO, TBO high). The interrupt output is set high and the status register is cleared.
I-O/MEM-Tied high in CDP1800-series input/output mode, otherwise tied low.
TPA-Tied to TPA of the CDP1800-series microprocessors. During memory mapping, it is used to latch the high order address bit for the chip select. In the CDP1800 input/output mode, it is used to gate the N lines. When the counter-timer is used with other microprocessors, or when the high order address of the CDP1800-series microprocessors is externally latched, it is connected to $V_{D D}$.
CS-An active high signal that enables the device.


Fig. 7-Typical CDP1802 memory-mapped system.


Fig. 8 - CDP1800-series memory-mappıng write cycle tımıng waveforms.


Fig. 9 - CDP1800-series memory-mapping read cycle timing waveforms.


Fig. 10 - Typical CDP1802 input/output-mapped system.


N LINES


92CM-34637
Fig. 11 - CDP1800-series input/output-mapping timing waveforms with output instruction.


TPB/WR

n LINES


Fig. 12 - CDP1800-series input/output-mapping timing waveforms with input instruction.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$,
Input $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ and 1 TTL Load

| CHARACTERISTIC |  | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. $\dagger$ | Typ.* | Max. |  |
| Read Cycle Times (see Fig. 13) |  |  |  |  |  |
| Data Access from Address | tDA | - | 350 | - | ns |
| Read Pulse Width | $\mathrm{t}_{\mathrm{RD}}$ | 400 | - | - |  |
| Data Access from $\overline{\text { Read }}$ | tDR | - | 250 | - |  |
| Address Hold after $\overline{\text { Read }}$ | ${ }^{\text {t }} \mathrm{RH}$ | 0 | - | - |  |
| Output Hold after Read | tDH | 50 | - | - |  |
| Chıp Select Setup to TPA | tcs | 50 | - | - |  |

$\dagger$ Tıme required by a limit device to allow for the indicated function.

- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nomınal $V_{D D}$


Fig. 13 -Read cycle tıming waveforms.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$, Input $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ and 1 TTL Load

| CHARACTERISTIC | LIMITS |  |  | MNITS |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  | Min. ${ }^{\dagger}$ | Typ. | Max. |  |

Write Cycle Times (see Fig. 14)

| Address Setup to $\overline{\text { Write }}$ | tAS | 150 | - | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Write Pulse Width | tWR | 150 | - | - |  |
| Data Setup to Write | tDS | 200 | - | - |  |
| Address Hold after Write | ${ }_{\text {t }}$ AH | 50 | - | - |  |
| Data Hold after $\overline{\text { Write }}$ | tWH | 50 | - | - |  |
| Chip Select Setup to TPA | tcs | 50 | - | - |  |

$\dagger$ Time required by a limit device to allow for the indicated function

- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$.


Fig. 14 - Write cycle timing waveforms.

## REFERENCE APP NOTE 7275

February 1992

## Features

- CPU Interface for Use with General-Purpose Microprocessors
- Time Of Day/Calendar
- Reads Seconds, Minutes, Hours
- Reads Day of Month and Month
- Alarm Circuit With Seconds, Minutes or Hours Operation
- Power Down Mode
- Separate Clock Output Selects 1 of 15 Square Wave Signals
- Interrupt Output Activated By Clock Output and/or Alarm Circuit
- Date Integrity Sampling for Clock Rollover Eliminated
- On-Board Oscillator:
- Crystal Operation CDP1879 at 10V
............ 4.19MHz, 2.09 MHz or 1.048 MHz
- Crystal Operation CDP1879C-1 at 5V .............. 4.19 MHz ,
2.09 MHz or 1.048 or 32 kHz
- External Clock Operation at 10 V or 5 V . . . . . . . . . . . 4.19MHz, 2.09 MHz 1.048MHz or 32 kHz
- Addressable in Memory Space or CDP1800 Series VO Mode
- Low Standby (Timekeeping) Voltage with External Clock


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 5V | 10V |
| :--- | :---: | :--- | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1879CE1 | CDP1879E |
| Ceramic DIP <br> Burn-in | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1879CD1 | - |
|  |  | CDP1879CD1X | CDP1879DX |

## Description

The CDP1879 real-time clock supplies time and calendar information from seconds to months in BCD format. It consists of 5 separately addressable and programmable counters that divide down an oscillator input. The clock input can have any one of 4 possible frequencies, allowing flexibility in the choice of crystal or external clock sources. Using an external 32 kHz clock source, timekeeping can be performed down to 2.5 V (see Standby (Timekeeping) Voltage Operation).
The device can be memory-mapped for use with any gen-eral-purpose microprocessor and has the additional capability of operating in the CDP1800 series input/output mode.
The real-time clock functions as a time-of-day/calendar with an alarm capability that can be set for combinations of seconds, minutes or hours. Alarm time is configured by loading alarm latches that activate an interrupt output through a comparator when the counter and alarm latch values are equal.
Fifteen selectable square-wave signals are available as a separate clock output signal and can also activate the interrupt output. A status register is available to indicate the interrupt source. The value in an 8 bit control register determines the operational characteristics of the device, by selecting the prescaler divisor and the clock output, and controls the load and alarm functions.
A transparent "freeze" circuit preclude clock rollover during counter and latch access times to assure stable and accurate values in the counters and alarm latches.
The CDP1879 is functionally identical to the CDP1879C-1. The CDP1879 has a recommended operating voltage range of 4 V to 10.5 V , and the CDP1879C-1 has a recommended operating voltage range of 4 V to 6.5 V . The CDP1879 and the CDP1879C-1 are supplied in 24 lead hermetic dual-in-line side-brazed ceramic packages (D suffix) and 24 lead dual-inline plastic packages (E suffix).

## Pinout

|  |  |
| :---: | :---: |
| $\begin{array}{r} \text { INT } \\ \hline \text { RESET } \\ \hline 2 \\ \hline \end{array}$ | 24 ${ }^{2} \mathrm{v}_{\mathrm{DD}}$ |
| POWER DOWN 3 | 22 XTAL |
| $\overline{\text { RD }} 4$ | 21 CLK |
| 1-OMEM 5 | $20 \mathrm{DB7}$ |
| TPB/WR 6 | 10 DB6 |
| TPA 7 | 18 DB5 |
| cs 8 | 17 DB4 |
| A2 9 | $16 \mathrm{DB3}$ |
| A1 10 | $15 \mathrm{DB2}$ |
| AO 11 | $14 \mathrm{DB1}$ |
| $\mathrm{V}_{\text {ss }} 12$ | $13 \mathrm{DB0}$ |

## CDP1879 Modes of Operation

| OPERATION | FUNCTION |
| :--- | :--- |
| Read | 1. Seconds, minutes, hours, date and month counters <br> 2. Status register to identify interrupt source |
| Write | 1. Control register to set device operation <br> 2. Seconds, minutes, hours, date and month counters <br> 3. Alarm latches for alarm time |
| Power Down | 1. Tri-state interrupt output with active alarm or clock out circuitry <br> for wake-up control |
| Interrupt | 2. Clock out as source |

## MAXIMUM RATINGS, Absolute-Maximum Values:

DC SUPPLY-VOLTAGE RANGE, (VDD)(Voltage referenced to Vss Terminal)
CDP1879 ..... 0.5 to +11 V
CDP1879C-1 ..... -0.5 to +7 V
INPUT VOLTAGE RANGE, ALL INPUTS ..... 0.5 to Vod +0.5 V
DC INPUT CURRENT, ANY ONE INPUT ..... $\pm 10 \mathrm{~mA}$
POWER DISSIPATION PER PACKAGE (PD):
For $T A=-40$ to $+60^{\circ} \mathrm{C}$ (PACKAGE TYPE E) ..... 500 mW
For $\mathrm{TA}=+60$ to $+85^{\circ} \mathrm{C}$ (PACKAGE TYPE E) Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW
For TA $=-55$ to $+100^{\circ} \mathrm{C}$ (PACKAGE TYPE D) ..... 500 mW
For $\mathrm{TA}_{\mathrm{A}}=+100$ to $+125^{\circ} \mathrm{C}$ (PACKAGE TYPE D) Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW
DEVICE DISSIPATION PER OUTPUT TRANSISTOR
For TA = FULL PACKAGE-TEMPERATURE RANGE (All Package Types) ..... 40 mW
OPERATING-TEMPERATURE RANGE (TA)
-55 to $+125^{\circ} \mathrm{C}$
PACKAGE TYPE E ..... -40 to $+85^{\circ} \mathrm{C}$
STORAGE TEMPERATURE RANGE (Tstg) ..... -65 to $+150^{\circ} \mathrm{C}$
LEAD TEMPERATURE (DURING SOLDERING).
At distance $1 / 16 \pm 1 / 32 \mathrm{in}$. ( $159 \pm 0.79 \mathrm{~mm}$ ) from case for $10 \mathrm{~s} \max$ ..... $+265^{\circ} \mathrm{C}$

OPERATING CONDITIONS at TA $_{\mathbf{A}}=$ Full Package-Temperature Range, unless otherwise noted.
For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1879 |  | CDP1879C-1 |  |  |
|  | Min. | Max. | Min. | Max. |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | $\mathrm{V}_{\text {ss }}$ | $V_{D D}$ | $\mathrm{V}_{\text {ss }}$ | $V_{D D}$ | V |
| DC Standby (Timekeeping) Voltage* Vstay $T_{A}=-40^{\circ}$ to $+85^{\circ} \mathrm{C} \dagger$ | 3 | - | 3 | - |  |
| $\mathrm{T}_{\mathrm{A}}=0^{\circ}$ to $+70^{\circ} \mathrm{C}$ | 2.5 | - | 2.5 | - | V |
| Clock Input Rise or Fall Time $t_{r}, t_{f}$ <br> $V_{D D}=5 \mathrm{~V}$  | - | 10 | - | 10 |  |
| $V_{D D}=10 \mathrm{~V}$ | - | 1 | - | - | $\mu \mathrm{S}$ |

[^7]

TABLE II

| Addresses | A2 | A1 | A0 |
| :--- | :---: | :---: | :---: |
| Latch, Counter Seconds | 0 | 1 | 0 |
| Latch, Counter Minutes | 0 | 1 | 1 |
| Latch, Counter Hours | 1 | 0 | 0 |
| Counter, Day | 1 | 0 | 1 |
| Counter, Month | 1 | 1 | 0 |
| Control, Register | 1 | 1 | 1 |
| Status Register | 1 | 1 | 1 |


| MSB of hours counters (Bit 7 ) is an AM-PM bit. $0=A M ;$ |
| :--- |
| $1=$ PM. |
| Bit 6 of hours counter controls $12 / 24$ hr. $1=12 \mathrm{hr}$ : |
| $0=24 \mathrm{hr}$. |
| Status Register: Bit $7 \mathrm{MSB}=$ alarm |
| Interrupt Source: Bit $6=$ clock |
| MSB of Month Counter (Bit 7 ) is a Leap Year Bit $0=$ No, |
| $1=$ Yes. |

STATIC ELECTRICAL CHARACTERISTICS at TA $=-40$ to $\mathbf{+ 8 5}{ }^{\circ} \mathrm{C}$ VDD $\pm \mathbf{5 \%}$, Except as noted


- Typical values are for $\mathrm{TA}^{2}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
$\ddagger \mathrm{IOL}=\mathrm{IOH}=1 \mu \mathrm{~A}$.
*Operating current measured with clockout $=488.2 \mu \mathrm{~s}$ and no load;
** See Table III and Fig 6 for oscillator circuit information.


## PROGRAMMING MODEL

WRITE AND READ REGISTERS

## BCD FORMAT



SECONDS COUNTER (00-59)


MINUTES COUNTER (00-59)


HOURS COUNTER (01-12 or 00-23)
DB7 0=AM, 1=PM
DB6 0=24 HR, $1=12$ HR


## DAY OF MONTH COUNTER

(01-28, 29, 30, 31)
DB7
DB0

| $X$ | TENS 0 or 1 | UNITS $0-9$ |
| :---: | :---: | :---: | :---: |

MONTH COUNTER
(JAN=1 DEC=12)
DB7 0=NO LEAP YEAR 1=LEAP YEAR

WRITE ONLY REGISTERS


CONTROL REGISTER

DB0-DB1 - FREQUENCY SELECT
DB2-START/STOP
DB3 - COUNTER/ALARM LATCH CONTROL DB4-DB7-CLOCK OUTPUT SELECT

DB7


SECONDS ALARM LATCH (00-59)
DB7

| TENS 0-5 | UNITS 0-9 |
| :--- | :--- |
| UN |  |

MINUTES ALARM LATCH (00-59)
DB7 DB6
DB0

| $x$ | $x$ | TENS <br> $0-2$ | UNITS 0-9 |  |
| :---: | :---: | :---: | :---: | :---: | :---: |

HOURS ALARM LATCH (01-12 or 00-23)
$12 \mathrm{HR}, \mathrm{DB} 7=0 \mathrm{AM}, 1=\mathrm{PM}$
24 HR, DB7 $=X$

## READ ONLY REGISTER

| DB7 |
| :--- | |  |  |  | DB6 |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| X | x | 0 | 0 | 0 | 0 | 0 | 0 |

INTERRUPT STATUS REGISTER
DB7=1 ALARM CIRCUIT ACTIVATED $\overline{\operatorname{INT}}$
DB6=1 CLOCK OUTPUT ACTIVATED INT.

REGISTER TRUTH TABLE

| ADDRESS |  |  | ACtive signal |  | BIT 3 CONTROL REGISTER | REGISTER OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A2 | A1 | AO | TPB/WR | $\overline{\mathbf{R D}}$ |  |  |
| 0 | 1 | 0 | X | - | 0 | Write Seconds Counter |
| 0 | 1 | 0 | - | X | 0 | Read Seconds Counter |
| 0 | 1 | 1 | X | - | 0 | Write Minutes Counter |
| 0 | 1 | 1 | - | X | 0 | Read Mınutes Counter |
| 1 | 0 | 0 | X | - | 0 | Write Hours Counter |
| 1 | 0 | 0 | - | X | 0 | Read Hours Counter |
| 1 | 0 | 1 | $x$ | - | 0 | Write Date Counter |
| 1 | 0 | 1 | - | x | 0 | Read Date Counter |
| 1 | 1 | 0 | x | - | 0 | Write Month Counter |
| 1 | 1 | 0 | - | X | 0 | Read Month Counter |
| 0 | 1 | 0 | X | - | 1 | Write Seconds Alarm Latch |
| 0 | 1 | 1 | X | - | 1 | Write Minutes Alarm Latch |
| 1 | 0 | 0 | $x$ | - | 1 | Write Hours Alarm Latch |
| 1 | 1 | 1 | X | - | - | Write Control Register |
| 1 | 1 | 1 | - | X | - | Read Int. Status Register |

## GENERAL OPERATION

The real-time clock contains seconds, minutes, and hours, date and month counters that hold time of day/calendar information (see Fig. 2). The frequency of an intrinsic oscillator is divided down to supply a once-a-second signal to the counter series string. The counters are separately addressable and can be written to or read from.
The real-time clock contains seconds, minutes and hour write-only alarm latches that store the alarm time (see Fig. 3 ). When the value of the alarm latches and counters are equal, the interrupt output is activated. The interrupt output can also be activated by a clock output transition. The clock output is derived from the prescaler and counters and can be one of 15 square-wave signals. The value in the readonly interrupt status register identifies the interrupt source.

Operational control of the real-time clock is determined by the byte in a write-only control register. The 8-bit value in this register determines the correct divisor for the prescaler, a data direction and alarm enable bit, clock output select, and start/stop control (see Fig. 4).
Data transfer and addressing are accomplished in two modes of operation, memory mapping and I/O mapping using the CDP1800-series microprocessors. The mode is selected by the level on an input pin. (I-O/MEM). Memory mapping implies use of the address lines as chip selects and address inputs using linear selection or partial or full decoding methods. I/O mapping with the CDP1800-series microprocessors involves use of the N line outputs in conjunction with input and output instructions to transfer data to and from memory.


Fig. 2 - Functional diagram - time counters highlighted.


## OPERATIONAL SEQUENCE

Power is applied and the real-time clock is reset. This sets the interrupt output pin high. After the CS pin is set high and with address 7 on the address input lines, the control register is loaded via the data bus to configure the clock.

With selective addressing, the seconds through month counters are then written to and loaded to set the current time. The real-time clock will now hold the current "wall clock" time, with an accuracy determined by the crystal or external clock used. If the alarm function is desired, the control register is accessed and loaded again This new byte will allow subsequent time data to be entered into the seconds, minutes and hours alarm latches. This sequence is also used when selecting one of the 15 available clock-out signals.
If the alarm function was selected, the interrupt output pin will be set low when the values in the seconds, minutes and hour alarm latches match those in the seconds, minutes and hour counters
If one of the 15 sub second-to-day clock outputs is selected by the byte in the control register, the clock output pin toggles at that frequency ( $50 \%$ duty cycle). The interrupt
output will also be set low on the first clock out negative transition. The interrupt source (alarm or clock out) can be determined by reading the interrupt status register. The clock output can be deselected by placing zero in the upper nibble of the control register if the alarm function is selected as the only interrupt source.

## COUNTERS (See Fig. 2)

The counter section consists of an on-board oscillator, a prescaler and 5 counters that hold the time of day/calendar information.
1 of 4 possible external crystals determine the frequency of the on-board oscillator ( $32,768 \mathrm{~Hz}, 1048576 \mathrm{MHz}, 2.097152$ $\mathrm{MHz}, 4.194304 \mathrm{MHz}$ ). The oscillator output is divided down by a prescaler that supplies a once-a-second pulse to the counters. The seconds counter divides the pulse by 60 and its output clocks the minute counter every 60 seconds. Further division by the minutes, hours, day of month and month counters result in 5 counters holding data that reflects the time/calendar from seconds to months. The counters are addressed separately and BCD data is transferred to and from via the data bus. The most significant


Fig. 4 - Functional diagram - control regıster highlıghted.
bit of the hours counter (Bit 7) is user programmed to indicate AM or PM and will be inverted every 12th hour. ( $0=$ $A M, 1=P M$ ). Bit 6 of the hours counter is user programmed to enable the hours counter for 12 or 24 hour operation. ( $0=$ $24,1=12$ ). If 24 -hour operation is selected, the AM-PM bit is "don't care", but still toggles every 12th hour. Writing to the seconds counter resets the last 7 stages of the prescaler, allowing time accuracy to approximately $1 / 100$ of a second.
The most significant bit of the month counter is a Leap Year bit. If it is set to "1", the counter will count to February 29, then roll to March 1 . If set to " 0 " it will go to March 1st after February 28th.

## ALARM AND INTERRUPT STATUS REGISTER (See Fig. 3)

The alarm circuit consists of 1) seconds, mınutes and hour alarm latches that hold the alarm time, 2) the outputs of the seconds, minutes and hour counters, and 3) a comparator that drives an interrupt output. The comparator senses the counter and alarm latch values and activates the interrupt output (active low) when they are equal.
The write-only alarm latches have the same addresses as their comparable counters. Bit 3 in the control register
determines data direction to the latches or counters and alarm enabling. For example, during a write cycle, if bit 3 in the control register is a " 1 ", addressing the seconds counter or alarm latch will load the seconds alarm latch from the data bus and will enable the alarm function. Conversely, if bit 3 in the control register is a " 0 ", addressing the seconds counter or alarm latch during a write cycle will place the value on the data bus into the seconds counter and will disable the alarm function. The interrupt output can be activated by the alarm circuit or the clock output. When an interrupt occurs, the upper two bits of the interrupt status register identify the interrupt source. The interrupt status register has the same address as the control register. Addressing the interrupt status register with the $\overline{R D}$ line active will place these register bits on the data bus. Bits 0-5 are held low. A " 1 " in bit 6 represents a clock output transition as the interrupt source. A " 1 " in bit 7 will identify the alarm circuit as the interrupt source.
Activating the reset pin (active low) resets the hour latch to " 30 " which prevents a match between alarm and time registers during an initialization procedure. Activating the reset pin or writing to the control register resets the interrupt output (high) and clears the interrupt status register.

## CLOCK OUTPUT (See Table I and Fig. 3)

One of 15 counter and prescaler overflows can be selected as a $50 \%$ duty cycle output signal that is available at the "clock out" pin. The frequency is selected by the upper nibble in the control register. For example, selecting a onesecond clock output will result in a repetitive signal that will be high for 500 ms and low for the same period The high-tolow transition of the output signal will set the clock bit in the status register and activate the interrupt output. The level of the "clock out" signal is derived from the value in the counter Example if hours clock is selected and the minutes counter holds 4 minutes, the clock out will be low for 26 minutes and high for 30 minutes. Thereafter, the clock out will toggle at a $50 \%$ duty cycle rate

## CONTROL REGISTER (See Table I and Fig. 4) BIT

BIT

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## CONTROL REGISTER BYTE

The 8-bit value in the control register determines the following.

1. Bit 0 and 1 - Frequency Select - Since there are one of 4 possible crystals the oscillator in the real-time clock can operate with, these bit levels determıne the prescaler divisor so that an accurate one second pulse is supplied to the counter series string

| BIT 1 | BIT 0 | FREQUENCY |
| :---: | :---: | :---: |
| 0 | 0 | $32,768 \mathrm{~Hz}$ |
| 0 | 1 | 1.048576 MHz |
| 1 | 0 | 2097152 MHz |
| 1 | 1 | 4.194304 MHz |

2. Bit 2 - Start-Stop Control - Counter enabling is controlled by the value at this location $A$ " 1 " will allow the counters to function and a " 0 " in this location will disable the counters.
3 Bit 3 - Counter/Latch Control - The level at this location controls two functions. It is required since the counters and alarm latches have the same addresses
1) A " 0 " in bit 3 will direct subsequent data to or from the counter selected and the alarm function will be disabled.
2) A " 1 " in bit 3 will direct subsequent data to or from the alarm latch and will enable the alarm.
4. Bits $\mathbf{4}$ to $\mathbf{7 - C l o c k}$ Select - These bits select one of $\mathbf{1 5}$ square-wave signals that will be present at the "clockout" pin. If bits 4 to 7 are zero's, the clock output pin will be high. If a clock is selected, the first high-to-low clock out transition will activate the interrupt pin (active low) and place a " 1 " in bit 6 of the status register. Writing to the control register or activating the reset pin will set the interrupt pin high and reset the interrupt status register.

Normal operation requires the control register to be written to and loaded first with a control word. However, subsequent writing to a counter if a "clock out" is selected may cause an interrupt out signal. Therefore, "clock-out" should be deselected by writing zero's into bits 4 through 7 if the
interrupt is used. When the counters are loaded, the control register is again written to with the value in the upper nibble selecting the "clock out" signal. See Table I.

## READ AND WRITE SIGNALS

When the I-O/MEM pin is low, the real-time clock is enabled for memory mapped operation. Data on the bus is placed in, or read from a counter, alarm latch or register by 1) placing the CS pin high, 2) selective addressing, 3) placing the TPB/WR pin low during a write cycle with the $\overline{R D}$ pin high or 4) setting the $\overline{R D}$ pin low during a read cycle with the TPB/WR pin high.
The I/O mapping mode used with the CDP1800 series microprocessor is selected by setting the I-O/MEM pin high The TPB/WR pin on the real-tıme clock is connected to the TPB output pin of the microprocessor. Data on the bus is written to or read from the counters, latches and registers by 1) placıng the CS pin high, 2) selective addressing utilizing the microprocessor N lines and I/O instructions, 3) placing the TPB/WR pin high with the $\overline{R D}$ pin low during an output or write operation (data is latched on TPB's trailing edge), 4) setting the $\overline{\mathrm{RD}}$ line high during an input or read operation. Data is placed on the bus by the real-tıme clock between the trailing edges of TPA and TPB.

## FREEZE CIRCUIT

Since writing to or reading from the counters or alarm latches is performed asynchronously, the once-a-second signal from the prescaler may pulse the counter series string during these operations. This can result in erroneous data. To avoid this occurring, a transparent "freeze" cırcuit is incorporated into the real-tıme clock This circuit is designed to trap and hold the one-second input clock transition if it occurs during access times. When the operations are completed, it is inserted into the counter series string. To utilize the "freeze" circuit, address " 1 " (A0 = $1, A 1=0, A 2=0$ ) is selected first while performing a write operation. Read or write accesses may now be performed with assurance the data is stable. All operations must be concluded withın 250 ms of the address " 1 " access. If memory mapping any dummy write operation after selecting address " 1 " will set the "freeze" circuit. If using the I/O mode, a 61 output instruction will perform the same function. There is no tıme restriction on subsequent accesses as long as the read or write operations are preceded by selecting address " 1 ".

## POWER DOWN

Power down operation is initiated with a low signal on the "POWER DOWN" input pin. In conjunction with the interrupt output, it is used to supply external control circuits with a 3 level control signal. The operatıng current is not appreciably reduced during "POWER DOWN" operation. When power down is initiated, any inputs on the address or data bus are ignored. The clock output is set low. The interrupt output is tri-stated. If enabled previously, the alarm circuitry is active and will set the interrupt output pin low when alarm time occurs. The interrupt output will also go low if a clock was selected and an internal high-to-low transition occurs during power down The clock output pın will remain low. If power down is initiated in the middle of a read or write sequence, it will not become activated until the read or write cycle is completed.

## PIN FUNCTIONS

VDD, Vss - Power and ground for device.
DB0 - DB7 - DATA BUS - 8-bit bidirectional bus that transfers BCD data to and from the counters, latches and registers.
A0, A1, A2 - Address inputs that select a counter, latch or register to read from or write to.
TPA - Strobe input used to latch the value on the chip select pin. CS is latched on the trailing edge of TPA. During memory mapping, it is used to latch the high order address bit used for the chip select. When the real-time clock is used with other microprocessors, or when the high order address of the CDP1800 series microprocessor is externally latched, it is connected to VDD. In the input/output mode, it is used to gate the N lines.
I-O/ $\overline{\text { MEM }}$ - Tied low during memory mapping and high when the input/output mode of the CDP1800 series microprocessor is used.
$\overline{R D}$, TPB/WR - DIRECTION SIGNALS - Active signals that determine data direction flow. In the memory mapped mode, data is placed on the bus from the counters or status register when RD pin is active.
Data is transferred to a counter, latch or the control register when $\overline{\mathrm{RD}}$ is high and TPB/WR is active and latched on the trailing edge (low to high) of the TPB/WR signal.
In the input/output mode, data is placed on the bus from a counter or status register when $\overline{\mathrm{RD}}$ is not active between the trailing edges of TPA and TPB. Data on the bus is written to a counter, latch, or the control register during TPB when $\overline{\mathrm{RD}}$
is active and latched on TPB's trailing edge. The following connections are required between the microprocessor and real-time clock in the CDP1800 series I/O mode.

## MICROPROCESSOR REAL-TIME CLOCK

| $\overline{M R D}$ | $\overline{\mathrm{RD}}$ |
| :---: | :---: |
| TPB | .TPB/ $\overline{W R}$ |
| TPA | .TPA |
| N LINES | ADDRESS LINES |
| I-O/MEM | VDD |

CS - CHIP SELECT - Used to enable or disable the inputs and outputs. TPA is used to strobe and latch a positive level on this pin to enable the device.
XTAL AND $\overline{\text { XTAL }}$ - The frequency of the internal oscillator is determined by the value of the crystal connected to these pins. "XTAL" may be driven directly by an external frequency source.
CLOCK OUT - 1 of 15 square wave frequencies will appear at this pin when selected. During power down, this pin will be placed low, and will be high during normal operation when the clock is deselected.
POWER DOWN - POWER DOWN CONTROL - A low on this pin will place the device in the power down mode.
INT - Interrupt Output - A low on this pin indicates an active alarm time or high-to-low transition of the "clock out" signal.
$\overline{\text { RESET }}$ - A low on this pin clears the status register and places the interrupt output pin high.

## FREQUENCY INPUT REQUIREMENTS

The Real-Time Clock operates with the following frequency input sources:

1. An external crystal that is used with the on-board oscillator. The oscillator is biased by a large feedback resistor and oscillates at the crystal frequency (see Fig. 6, Table III).
2. An external frequency input that is supplied at the XTAL input. XTAL is left open (see Fig. 5). A typical external oscillator circuit is shown in Fig. 7 in section, "Standby (Timekeeping) VOLTAGE OPERATION".

TABLE III - Typical Oscillator Circuit Parameters for Suggested Oscillator Circuit, see Fig. 6

| PARAMETERS | $\mathbf{4 . 1 9 7} \mathbf{~ M H z}$ | $\mathbf{2 . 0 9 7} \mathbf{~ M H z}$ | $\mathbf{1 . 0 4 9 ~ M H z}$ | $\mathbf{3 2 7 6 8} \mathbf{~ H z}^{*}$ | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{R}_{\mathbf{t}}$ | 22 | 22 | 22 | 22 | $\mathrm{M} \Omega$ |
| $\mathrm{C}_{\mathrm{o}}$ | 39 | 39 | 39 | 39 | pF |
| $\mathrm{C}_{\mathbf{l}}$ | 5 | 5 | 5 | 5 | pF |
| $\mathrm{R}_{\mathbf{s}}$ | - | - | - | 200 | $\mathrm{~K} \Omega$ |
| $\mathrm{C}_{\mathrm{L}}$ | - | - | - | 91 | pF |
| Crystal Impedance | 73 | 200 | 200 | 50 K (max.) | $\Omega$ |

[^8]
## CDP1879, CDP1879C-1

## FREQUENCY INPUT REQUIREMENTS (Cont'd)

## Design Considerations for Stable Crystal Oscillation

1. Stray capacitances should be minimized for best oscillator performance. Circuit board traces should be kept to a maximum of 1 inch , and there should be no parallel traces.


92CS-36886

Fig. 5 - Connections for an external-frequency source applied to real-tıme clock.
2. A signal line or power source line must not cross or go near the oscillator circuit line.
3. It is advisable to put a 0.1-microfarad capacitor between VDD and VSS of the CDP1879.


Fig 6 - Suggested oscillator circuit applied to real-time clock (see Table III).

## STANDBY (TIMEKEEPING) VOLTAGE OPERATION

When any one of the four specified crystals is used with the on-board oscillator, the Real-Time Clock can operate at a minimum of 4 volts VDD. However, at 32 kHz the clock will run (timekeeping only, no device READ/WRITE accesses) down to 3 volts at $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ and 2.5 volts at $0^{\circ}$ to $+70^{\circ} \mathrm{C}$. To achieve this low voltage operation, an external $32-\mathrm{kHz}$
clock source must be supplied at the XTAL input (see Fig. 7). The standby requirements for CHIP SELECT/DESELECT are listed in Table IV, and Fig. 8 indicates the timing waveforms. Fig. 9 illustrates the typical timekeeping curve over the full temperature range.


Fig. 7 - Typıcal external clock-source circuit.

Table IV - Standby (Timekeeping) Characteristics at Full-Temperature Range

| CHARACTERISTIC |  | VDD <br> (V) | $V_{\text {Stby }}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | CDP1879 |  | CDP1879C-1 |  |  |
|  |  |  |  | Min. | Max. | Min. | Max. |  |
| Chip Deselect to Standby | tostar | 5 | 2.5, 3 | 2 | - | 2 | - |  |
| (Timekeeping) Voltage Time | lcstby | 10 | 2.5, 3 | 1 | - | - | - | $\mu \mathrm{s}$ |
| Recovery to Normal | tra | 5 | 2.5, 3 | 2 | - | 2 | - |  |
| Operation Time | tac | 10 | 2.5, 3 | 1 | - | - | - |  |

STANDBY (TIMEKEEPING) VOLTAGE OPERATION (Cont'd)


Fig. 8 - Standby (timekeepıng) voltage-and tımıng-waveforms.


Fig. 9 - Typıcal standby (tımekeepıng) voltage vs. full-temperature range.

## APPLICATIONS

A typical application for this real-time clock is as a wake-up control to a CPU to reduce total system power in inter-mittent-use systems. A hookup diagram iliustrating this feature is shown in Fig. 10. In this configuration, the alarm and power-down features of the CDP1879 are utilized in the control of the sleep and wake-up states of the CPU. A typical shut-down/start-up sequence for this system could proceed as follows:

1. The CPU has finıshed a current task and will be inactive for the next six hours.
2. The CPU loads the CDP1879 alarm registers with the desired wake-up time.
3. The CDP 1800 Q output is set high, which stops the CPU oscillator (as an alternative, in an NMOS system, power to all components except the clock chip could be shut off).
4. This Q output signal is received by the CDP1879 as a power-down signal.
5. The CDP1879 tri-states the interrupt output pin.
6. The CDP1879 eventually times out, and sets an alarm by driving the INT output low.
7. The alarm signal resets the CPU (to avoid oscillator start-up problems) and flags the processor for a warmstart routine.
8. The CPU, once into its normal software sequence, writes to the CDP1879 control register to reset the interrupt request.


Fig. 10 - CPU wake-up circuit using the CDP1879 real-time clock.

## CDP1879, CDP1879C-1

## APPLICATIONS (Cont'd)



Fig. 11 - Typical CDP1802 memory-mapped system


Fig 12 - CDP1800-series memory-mapped write-cycle tıming waveforms.


Fig 13-CDP1800-series memory-mapped read-cycle timing waveforms.

## CDP1879, CDP1879C-1



Fig. 14 - Typical CDP1802 input/output-mapped system.


92CM-34906
Fig. 15-CDP1800-series input/output-mapping tımıng waveforms with output instruction.


Fig. 16 - CDP1800-series input/output-mappıng timing waveforms with input instruction.

## Specifications CDP1879, CDP1879C-1

DYNAMIC ELECTRICAL CHARACTERISTICS at TA $_{A}=\mathbf{- 4 0}$ to $+85^{\circ} \mathrm{C}$, Input $t_{r}, \mathbf{t}_{f}=10 \mathrm{~ns}, \mathrm{C}_{\mathrm{L}}=\mathbf{5 0} \mathrm{pF}$

| CHARACTERISTIC <br> Read Cycle Times (see Fig. 17) |  | VD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1879 |  | CDP1879C-1 |  |  |
|  |  |  | Min. $\dagger$ | Max. | Min. $\dagger$ | Max. |  |
| Data Access from Address | tDA | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 400 \\ & 190 \end{aligned}$ | - | 400 - | ns |
| $\overline{\text { Read Pulse Width }}$ | tRD | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 270 \\ & 160 \end{aligned}$ | - | 270 <br> - |  |  |
| Data Access from $\overline{\text { Read }}$ | tDR | $\begin{gathered} \hline 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 375 \\ & 170 \end{aligned}$ | - | 375 <br> - |  |
| Address Hold after $\overline{\text { Read }}$ | tRH | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | - | - | - |  |
| Output Hold after $\overline{\text { Read }}$ | tDH | $\begin{gathered} \hline 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 50 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 230 \\ & 130 \\ & \hline \end{aligned}$ | 50 | 230 |  |
| Chip Select Setup to TPA | tCS | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 50 \\ & 30 \end{aligned}$ | - | $50$ | - |  |

$\dagger$ Time required by a limit device to allow for the indicated function


Fig. 17 - Read-cycle tıming waveforms.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=\mathbf{- 4 0}$ to $\mathbf{+ 8 5}^{\circ} \mathrm{C}$, Input $\mathbf{t}_{\mathbf{r}}, \mathrm{t}_{\mathbf{f}}=\mathbf{1 0} \mathbf{n s}, \mathrm{C}_{\mathbf{L}}=\mathbf{5 0} \mathbf{~ p F}$

†Time required by a limit device to allow for the indicated function.


Fig. 18 - Write-cycle timing waveforms.

## Features

- Performs memory address latch and decoder functions multiplexed or non-multiplexed
- Decodes up to 16 K bytes of memory
- Interfaces directly with CDP1800-series microprocessors at maximum clock frequency
- Can replace CDP1866 and CDP1867 (upward speed and function capability)


## Ordering Information

| PACKAGE | TEMP. <br> RANGE | 5V | 10V |
| :---: | :---: | :--- | :--- |
| Plastic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to <br> $+85^{\circ} \mathrm{C}$ | CDP1881CE <br> CDP1881CEX | CDP1881E <br> CDP1881EX |
| Plastic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to <br> $+85^{\circ} \mathrm{C}$ | CDP1882CE <br> CDP1882CEX | CDP1882E <br> - |
| Ceramic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to <br> $+85^{\circ} \mathrm{C}$ | CDP1882CD <br> CDP1882CDX | CDP1882D <br> - |

## Description

The CDP1881 and CDP1882 are CMOS 6 bit memory latch and decoder circuits intended for use in CDP1800 series microprocessor systems. They can interface directly with the multiplexed address bus of this system at maximum clock frequency, and up to four $4 \mathrm{~K} \times 8$ bit memories to provide a 16 K byte memory system. With four $2 \mathrm{~K} \times 8$ bit memories an 8 K byte system can be decoded.
The devices are also compatible with non-multiplexed address bus microprocessors. By connecting the clock input to $\mathrm{V}_{\mathrm{DD}}$, the latches are in the data-following mode and the decoded outputs can be used in general purpose memorysystem applications.

The CDP1881 and CDP1882 are intended for use with 2 K or 4 K byte RAMs and are identical except that in the CDP1882 $\overline{\mathrm{MWR}}$ and $\overline{\mathrm{MRD}}$ are excluded.

The CDP1881 and CDP1882 are functionally identical to the CDP1881C and the CDP1882C. They differ in that the CDP1881 and CDP1882 have recommended operating voltage range of 4 to 10.5 volts and their $C$ versions have a recommended operating voltage range of 4 to 6.5 volts.
The CDP1881 and CDP1882 are supplied in 20 lead and 18 lead packages, respectively. The CDP1881 is supplied only in a dual-in-line plastic package ( $E$ suffix). The CDP1882 is supplied in dual-in-line, hermetic side-brazed ceramic ( $D$ suffix) and in plastic (E suffix) packages.

## Pinouts



Absolute Maximum Ratings

| DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ): <br> (All Voltages Referenced to $\mathrm{V}_{\mathrm{SS}}$ Terminal) |  |
| :---: | :---: |
| CDP1881 and CDP1882 | . 5 V to +11 V |
| CDP1881C and CDP1882C. | -0.5V to +7V |
| Input Voltage Range, All Inputs | 0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, Any One Input. | 10 mA |
| Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ ) |  |
| $\mathrm{T}_{A}=-40^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (Package Type E) .............. 500 mW |  |
| $\mathrm{T}_{\mathrm{A}}=+60^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type E) | . . . Derate Linearly at $12 \mathrm{~mW}{ }^{\circ} \mathrm{C}$ to 200 mW |
| $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (Package Type D) |  |
| $\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Package Type D) | Linearly at |

Device Dissipation Per Output Transistor $\mathrm{T}_{\mathrm{A}}=$ Full Package Temperature Range (All Package Types).

100 mW
Operating Temperature Range $\left(\mathrm{T}_{\mathrm{A}}\right)$ :
Package Type D.
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Package Type E. . . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $T_{\text {stg }}$ ) $\ldots \ldots . . . . . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \ln .(1.59 \pm 0.79 \mathrm{~mm})$
from case for 10s max
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1881, CDP1882 |  | CDP1881C, CDP1882C |  |  |
|  | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | $\mathrm{V}_{\text {ss }}$ | $V_{D D}$ | $\mathrm{V}_{\mathrm{SS}}$ | $V_{D D}$ | V |

Static Electrical Characteristics At $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$, Except as Noted:

| ChARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & v_{0} \\ & (V) \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1878 |  |  | CDP1878C |  |  |  |
|  |  |  |  |  | MIN | (Note 1) TYP | MAX | MIN | (Note 1) TYP | MAX |  |
| Quiescent Device Current | $I_{D D}$ | - | 0,5 | 5 | - | 1 | 10 | - | 5 | 50 | $\mu \mathrm{A}$ |
|  |  | - | 0,10 | 10 | - | 10 | 100 | - | - | - | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | $\mathrm{l}_{\mathrm{OL}}$ | 0.4 | 0,5 | 5 | 1.6 | 3.2 | - | 1.6 | 3.2 | - | mA |
|  |  | 0.5 | 0,10 | 10 | 3.2 | 6.4 | - | - | - | - | mA |
| Output High Drive (Source) Current | IOH | 4.6 | 0,5 | 5 | -1.15 | -2.3 | - | -1.15 | -2.3 | - | mA |
|  |  | 9.5 | 0,10 | 10 | -2.3 | -4.6 | - | - | - | - | mA |
| Output Voltage Low-Level (Note 2) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  |  | - | 0, 10 | 10 | - | 0 | 0.1 | - | - | - | V |
| Output Voltage High-Level (Note 2) | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - | V |
|  |  | - | 0,10 | 10 | 9.9 | 10 | - | - | - | - | V |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 1,9 | - | 10 | - | - | 3 | - | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 9.5 | - | 5 | 3.5 | - | - | 3.5 | - | - | V |
|  |  | 1,9 | - | 10 | 7 | - | - | - | - | - | V |
| Input Leakage Current | $\mathrm{I}_{\mathrm{N}}$ | Any Input | 0,5 | 5 | - | - | $\pm 1$ | $\cdot$ | - | $\pm 1$ | $\mu \mathrm{A}$ |
|  |  |  | 0,10 | 10 | - | - | $\pm 2$ | $\bullet$ | - | $\cdot$ | $\mu \mathrm{A}$ |
| Operating Current (Note 3) | $\mathrm{I}_{\mathrm{DD1}}$ | 0,5 | 0,5 | 5 | - | - | 2 | - | - | 2 | mA |
|  |  | -0, 10 | 0,10 | 10 | - | - | 4 | $\bullet$ | - | - | mA |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | $\cdot$ | 5 | 7.5 | pF |
| Output Capacitance | $\mathrm{Cout}^{\text {O }}$ | $\bullet$ | $\bullet$ | - | $\bullet$ | 10 | 15 | - | 10 | 15 | pF |
| Minimum Data Retention Voltage | $\mathrm{V}_{\mathrm{DR}}$ | $\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{DR}}$ |  |  | - | 2 | 2.4 | - | 2 | 2.4 | V |
| Data Retention Current | $\mathrm{I}_{\mathrm{DR}}$ | $\mathrm{V}_{\mathrm{DD}}=2.4 \mathrm{~V}$ |  |  | - | 0.01 | 1 | - | 0.5 | 5 | $\mu \mathrm{A}$ |

NOTES:

1. Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$.
2. $\mathrm{I}_{\mathrm{OL}}=\mathrm{I}_{\mathrm{OH}}=1 \mu \mathrm{~A}$.
3. Operating current measured at 200 kHz for $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ and 400 kHz for $V_{D D}=10 \mathrm{~V}$, with outputs open circuits (Equivalent to typical CDP1800 system at $3.2 \mathrm{MHz}, 5 \mathrm{~V}$; and $6.4 \mathrm{MHz}, 10 \mathrm{~V}$ ).


Fig. 1 - Functional diagram for the CDP1881, CDP1881C.


Fig. 2 - Functional diagram for the CDP1882, CDP1882C.

TRUTH TABLES for the CDP1881, CDP1881C and CDP1882, CDP1882C.

| INPUTS |  |  |  |  |  | OUTPUTS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { MWR } \triangle}$ | $\overline{\text { MRD } \triangle}$ | $\overline{C E}$ | CLK | MA4 | MA5 | $\overline{\text { CSO }}$ | $\overline{\text { CS1 }}$ | $\overline{\text { CS2 }}$ | $\overline{\text { CS3 }}$ |
| 1 | 1 | X | $x$ | $x$ | X | 1 | 1 | 1 | 1 |
| X | X | 1 | X | X | X | 1 | 1 | 1 | 1 |
| 0 | X | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |
| 0 | X | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |
| 0 | x | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 |
| 0 | X | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 0 | X | 0 | 0 | X | X |  | PRE | ATE |  |
| X | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |
| $x$ | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |
| X | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 |
| X | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| X | 0 | 0 | 0 | X | X |  | PRE | ATE |  |

$\Delta$ CDP1881, CDP1881C Only

| INPUTS |  |  | OUTPUTS |
| :---: | :---: | :---: | :---: |
| $\overline{C E}$ | CLK | MA0, MA1, <br> MA2, MA3 | A8, A9, <br> A10, A11 |
| $X$ | 1 | 1 | 1 |
| $X$ | 1 | 0 | 0 |
| $X$ | 0 | $X$ | PREVIOUS |
|  |  |  | STATE |

Logic 1 = High, Logic $0=$ Low, $X=$ Don't Care

DYNAMIC ELECTRICAL CHARACTERISTICS at TA $=\mathbf{- 4 0}$ to $+\mathbf{8 5}{ }^{\circ} \mathrm{C}, \mathrm{VDD} \pm \mathbf{5} \%, \mathrm{tr}, \mathrm{tt}=\mathbf{2 0} \mathbf{n s}$, VIH = 0.7 VDd, VIL = 0.3 Vdd, CL = $\mathbf{1 0 0}$ pF, See Fig. 3.

| CHARACTERISTIC |  | Vod <br> (V) | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1881, CDP1882 |  |  | CDP1881C, CDP1882C |  |  |  |
|  |  |  | Min. | Typ.• | Max. $\Delta$ | Min. | Typ.^ | Max. $\Delta$ |  |
| Minimum Setup Time, <br> Memory Address to CLOCK, | tMACL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{gathered} 10 \\ 8 \\ \hline \end{gathered}$ | $\begin{aligned} & 35 \\ & 25 \\ & \hline \end{aligned}$ | $-$ | $10$ | $35$ | ns |
| Minımum Hold Tıme, <br> Memory Address After CLOCK, | tCLMA | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & 8 \\ & 8 \\ & \hline \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | - | $8$ | $25$ |  |
| Minımum CLOCK Pulse Width | tCLCL | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{array}{r} 50 \\ 25 \\ \hline \end{array}$ | $\begin{array}{r} 75 \\ 40 \\ \hline \end{array}$ | - | 50 <br> - | 75 <br> - |  |
| Propagation Delay Times $\overline{\text { Chip Enable to }} \overline{\text { Chip Select }}$ | tCECS | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & 75 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 100 \\ & \hline \end{aligned}$ | $-$ | $75$ | $150$ |  |
| $\overline{\text { MRD }}$ or $\overline{\text { MWR }}$ to $\overline{\text { Chip Select* }}$ | tmCs | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 100 \\ & \hline \end{aligned}$ | $-$ | 75 | 150 |  |
| CLOCK to $\overline{\text { Chip Select }}$ | tCLCS | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{gathered} 100 \\ 65 \\ \hline \end{gathered}$ | $\begin{aligned} & 175 \\ & 125 \\ & \hline \end{aligned}$ | - | 100 | 175 |  |
| CLOCK to Address | tCLA | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & 100 \\ & 65 \\ & \hline \end{aligned}$ | $\begin{aligned} & 175 \\ & 125 \\ & \hline \end{aligned}$ | - | 100 <br> - | 175 |  |
| Memory Address to $\overline{\text { Chip Select }}$ | tMACS | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{gathered} 100 \\ 75 \\ \hline \end{gathered}$ | $\begin{aligned} & 175 \\ & 125 \\ & \hline \end{aligned}$ | - | 100 | 175 <br> - |  |
| Memory Address to Address | tMAA | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{array}{r} 80 \\ 40 \\ \hline \end{array}$ | $\begin{aligned} & 125 \\ & 60 \end{aligned}$ | - | 80 | 125 <br> - |  |

- Typical values are for $\mathrm{TA}=25^{\circ} \mathrm{C}$.
$\Delta$ Maxımum limits of mınimum characterıstics are the values above which all devices function.
*For the CDP1881 and CDP1881C types only.

(a) CHIP ENABLE TO CHIP SELECT PROPAGATION DELAY

(b) MRD OR $\overline{M W R ~ T O ~ C H I P ~ S E L E C T ~ P R O P A G A T I O N ~ D E L A Y ~(C D P I B 8 I, C D P I B 8 I C ~ O N L Y) ~}$

MAO-MA5
clock
$\overline{\mathrm{csO}}, \overline{\mathrm{cs1}}, \overline{\mathrm{cs2}}, \overline{\operatorname{cs3}}$

A B-AII

(c) MEMORY ADDRESS SETUP AND HOLD TIME

[^9]Fig. 3-CDP1881 and CDP1882 tımıng waveforms.

## SIGNAL DESCRIPTIONS/PIN FUNCTIONS

CLOCK: Latch-Input Control - a high at the clock input will allow data to pass through the latch to the output pin. Data is latched on the high to low transition of the clock input This input is connected to TPA in CDP1800-series systems
MAO-MA3: Address inputs to the high-byte address latches
MA4, MA5: High-byte address inputs decoded to produce chip selects $\overline{\text { CSO }}-\overline{\mathrm{CS}}$
$\overline{\text { MRD }}, \overline{\text { MWR: }}$ : MEMORYREAD (MRD) and MEMORY WRITE (MWR) signal inputs on the CDP1881, CDP1881C A low at either input, when the $\overline{\mathrm{CE}}$ pin is low, will enable the decoder chip select outputs (CS0 - $\overline{\mathrm{CS} 3 \text { ) }}$
$\overline{C E}$ CHIP ENABLE input - a low at the $\overline{C E}$ input of CDP1882, CDP1882C will enable the chip select decoder A low at the $\overline{C E}$ input of CDP1881, CDP1881C, coincident with a low at either the $\overline{M R D}$ or MWR pin, will enable the chip select decoder. A high on this pin forces $\overline{\text { CSO }}, \overline{\mathrm{CS1}}$, $\overline{\mathrm{CS} 2}$, and $\overline{\mathrm{CS} 3}$ to a high (false) state
A8-A11: Latched high-byte address outputs
$\overline{\mathbf{C S O}}-\overline{\mathbf{C S 3}:}$ One of four latched and decoded Chip Select outputs
VoD, Vss: Power and ground pins, respectively

## APPLICATION INFORMATION

The CDP1881 and CDP1882 can interface directly with the multiplexed address bus of the CDP1800-series microprocessor family at maximum clock frequency. A single CDP1881 or CDP1882 is capable of decoding up to 16 K -bytes of memory
The CDP1881 is provided with $\overline{M R D}$ and $\overline{M W R}$ inputs for controlling bus contention, and is especially useful for interfacing with RAMs that do not have an output enable function (OE) Fig 4 shows the CDP1881 in a minimum system configuration which includes the CDP1833 ROM ( $1 \mathrm{~K} \times 8$ ) and two $2 \mathrm{~K} \times 8$ RAMS. The CDP1881, in this example performs the following functions:
(1) Latch and decode high-order address bits for use as chip selects
(2) Gate chip selects with $\overline{M R D}$ and $\overline{M W R}$ to prevent bus contention with the CPU
(3) Latch high-order address bits A8 to A11.

A system using the CDP1882 is shown in Fig 5. The CDP1882 performs the memory address latch and decoder functions Note that the RAM has an output enable ( $\overline{(O E)}$ pin which elımınates the need for $\overline{M R D}$ and $\overline{M W R}$ inputs on the latch/decoder Instead, the MRD line is connected directly to the RAM output enable ( $\overline{O E}$ ) pin
In Fig. 6 the CDP1882 is used to decode a 16K-byte ROM system consisting of four CDM5332s


Fig. 4 - Minimum 1800-system using the CDP1881


Fig. 5-CDP1800-series system using the CDP1 882.


Fig. 6-16K-byte ROM systems using the CDP1882.
$92 \mathrm{CM}-37293$

## CMOS 7-Bit Latch and Decoder <br> Memory Interfaces

February 1992

## Features

- Performs Memory Address Latch And Decoder Functions Multiplexed Or Non-multiplexed
- Interfaces Directly With the CDP1800-Series Mircoprocessors
- Allows Decoding for Systems Up To 32K Bytes


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 5 V | 10V |
| :---: | :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1883CE | CDP1883E |
| Burn- $n$ |  | CDP1883CEX | - |

## Description

The CDP1883 is a CMOS 7-bit memory latch and decoder circuit intended for use in CDP1800-series mircoprocessor systems. It can serve as a direct interface between the multiplexed address bus of this system and up to four $8 \mathrm{~K} \times 8$-bit memories to implement a 32K-byte memory system. With four $4 \mathrm{~K} \times 8$-bit memories, a 16 K -byte system can be decoded.

The device is also compatible with non-multiplexed address bus microprocessors. By connecting the clock input to VDD, the latches are in the data-following mode and the decoded outputs can be used in general-purpose memory-system applications.

The CDP1833 is compatible with CDP1800-series microprocessors operating at maximum clock frequency.

The CDP1883 and CDP1883C are functionally identical. They differ in that the CDP1883 has a recommended operating voltage range of 4 volts to 10.5 volts and the $C$ version has a recommended operating voltage range of 4 volt to 6.5 volts.

The CDP1883 and CDP1883C are supplied in 20-lead dual-in-line plastic packages (E suffix)

## Pinout



## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ):
(All Voltages Referenced to $\mathrm{V}_{\text {SS }}$ Terminal)
CDP1883
-0.5 V to +11 V

CDP1883C. | $\ldots .5-0.5 \mathrm{~V}$ to +7 V |
| :--- |
| 0.5 V |
| $\mathrm{DD}+0.5 \mathrm{~V}$ |

Input Voltage Range, All Inputs
DC Input Current, Any One Input.
Power Dissipation Per Package ( $P_{D}$ )
$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (Package Type E)
. . . . . . . . . . . . . . . . 500 mW Werate Linearly at

$$
\begin{array}{r}
\mathrm{T}_{\mathrm{A}}=+60^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \text { (Package Type E) } \ldots . \text { Derate Linearly at } \\
12 \mathrm{~mW} /{ }^{\circ} \mathrm{C} \text { to } 200 \mathrm{~mW}
\end{array}
$$

Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range
100 mW
Operating Temperature Range $\left(T_{A}\right)$ :
Package Type E.
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stg }}$ ) . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{In}$. ( $1.59 \pm 0.79 \mathrm{~mm}$ )
from case for 10s max. from case for 10s max $+265^{\circ} \mathrm{C}$

Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | SYMBOL | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1883 |  | CDP1883C |  |  |
|  |  | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range |  | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range |  | $\mathrm{V}_{\mathrm{SS}}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{ss}}$ | $V_{D D}$ | V |

Static Electrical Characteristics At $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$, Except as Noted:

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{0} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1883 |  |  | CDP1883C |  |  |  |
|  |  |  |  |  | MIN | $\begin{gathered} \text { (Note 1) } \\ \text { TYP } \end{gathered}$ | MAX | MIN | (Note 1) TYP | MAX |  |
| Quiescent Device Current | IDD | - | 0,5 | 5 | - | 1 | 10 | - | 5 | 50 | $\mu \mathrm{A}$ |
|  |  | - | 0,10 | 10 | - | 10 | 100 | - | - | - | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current | 1 OL | 0.4 | 0,5 | 5 | 1.6 | 3.2 | - | 1.6 | 3.2 | - | mA |
|  |  | 0.5 | 0,10 | 10 | 3.2 | 6.4 | - | - | - | - | mA |
| Output High Drive (Source) Current | $\mathrm{IOH}^{\text {O}}$ | 4.6 | 0,5 | 5 | -1.15 | -2.3 | - | -1.15 | -2.3 | - | mA |
|  |  | 9.5 | 0,10 | 10 | -2.3 | -4.6 | - | - | - | - | mA |
| Output Voltage Low-Level (Note 2) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | $\cdot$ | 0 | 0.1 | V |
|  |  | - | 0,10 | 10 | - | 0 | 0.1 | - | - | - | V |
| Output Voltage High-Level (Note 2) | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - | V |
|  |  | - | 0,10 | 10 | 9.9 | 10 | - | - | - | - | V |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 0.5, 9.5 | - | 10 | - | - | 3 | - | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 9.5 | - | 5 | 3.5 | - | - | 3.5 | - | - | V |
|  |  | 0.5, 9.5 | - | 10 | 7 | - | - | - | - | - | V |
| Input Leakage Current | $\mathrm{I}_{\mathrm{N}}$ | Any | 0,5 | 5 | - | - | $\pm 1$ | $\cdot$ | - | $\pm 1$ | $\mu \mathrm{A}$ |
|  |  | Input | 0,10 | 10 | - | - | $\pm 2$ | - | - | - | $\mu \mathrm{A}$ |
| Operating Current (Note 3) | $\mathrm{I}_{\mathrm{DD1}}$ | 0,5 | 0,5 | 5 | - | - | 2 | - | - | 2 | mA |
|  |  | 0,10 | 0,10 | 10 | - | - | 4 | - | - | - | mA |
| Minimum Data Retention Voltage | $\mathrm{V}_{\mathrm{DR}}$ | $\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{DR}}$ |  |  | - | 2 | 2.4 | - | 2 | 2.4 | V |
| Data Retention Current | $\mathrm{I}_{\mathrm{DR}}$ | $\mathrm{V}_{\mathrm{DD}}=2.4 \mathrm{~V}$ |  |  | - | 0.01 | 1 | - | 0.5 | 5 | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance | $\mathrm{C}_{\text {OUt }}$ | - | - | - | - | 10 | 15 | - | 10 | 15 | pF |

NOTES:

1. Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$.
2. Operating current measured at 200 kHz for $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ and 400 kHz for $V_{D D}=10 \mathrm{~V}$, with outputs open circuit.


Fig 1 - Functional diagram for the CDP1883, CDP1883C

## SIGNAL DESCRIPTIONS/PIN FUNCTIONS

CLOCK: Latch Input Control-a high on the clock input will allow data to pass through the latch to the output pin. Data is latched on the high-to-low transition of the clock input. This pin is connected to TPA in the CDP1800 system and tied to $V_{D D}$ for other applications.
MAO-MA4: address inputs to the high byte address latches.
MA5-MA6: high byte address inputs decoded to produce chip selects CSO-CS3.
$\overline{\mathbf{C E}}:$ CHIP ENABLE input. A low on this pin will enable the chip select decoder A high on this pin forces the $\overline{\mathrm{CSO}}, \overline{\mathrm{CS1}}$, $\overline{\mathrm{CS} 2}$, and CS3 outputs to a high (false) state.
A8-A12: latched high-byte address outputs.
$\overline{\mathbf{C S O}}-\overline{\mathbf{C S 3}}$ : one of four latched and decoded Chip Select outputs.
$\mathbf{V}_{\mathrm{DD}}, \mathbf{V}_{\mathrm{ss}}$ : power and ground pins, respectively.

TRUTH TABLES FOR CDP1883, CDP1833C

| INPUTS |  |  |  | OUTPUTS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { CE }}$ | CLK | MA5 | MA6 | CS0 | CST | CS2 | CS3 |  |
| 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |  |
| 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |  |
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 |  |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |  |
| 0 | 0 | X | X | PREVIOUS STATE |  |  |  |  |
| 1 | X | X | X | 1 | 1 | 1 | 1 |  |


| INPUTS |  |  | OUTPUTS |
| :---: | :---: | :---: | :---: |
| $\mathbf{C E}$ | CLK | MA0-4 | A8-A12 |
| $\mathbf{X}$ | 1 | 1 | 1 |
| $\mathbf{X}$ | 1 | 0 | 0 |
| $\mathbf{X}$ | 0 | X | PREVIOUS STATE |

X = DON'T CARE

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm \mathbf{5 \%} \% \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{r}}=20 \mathrm{~ns}$, $V_{\text {IH }}=0.7 V_{D D}, V_{\text {IL }}=0.3 V_{D D}, C_{L}=100 \mathrm{pF}$. See Fig. 2.

| CHARACTERISTIC |  | VDD <br> (V) | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1883 |  |  | CDP1883C |  |  |  |
|  |  |  | Min. | Typ.• | Max. $\Delta$ | Min. | Typ. ${ }^{\circ}$ | Max. $\triangle$ |  |
| Minimum Setup Time, |  | 5 | - | 10 | 35 | - | 10 | 35 |  |
| Memory Address to CLOCK | $\mathrm{t}_{\text {MACL }}$ | 10 | - | 8 | 25 | - | - | - |  |
| Minimum Hold Time, |  | 5 | - | 8 | 25 | - | 8 | 25 |  |
| Memory Address After CLOCK | tclma | 10 | - | 8 | 25 | - | - | - |  |
| Minimum CLOCK Pulse Width |  | 5 | - | 50 | 75 | - | 50 | 75 |  |
| Minimum CLOCK Pulse Width | tcLCL | 10 | - | 25 | 40 | - | - | - |  |
| Propagation Delay Times: |  | 5 | - | 75 | 150 | - | 75 | 150 |  |
| Chip Enable to Chip Select | $\mathrm{tcecs}^{\text {d }}$ | 10 | - | 45 | 100 | - | - | - | ns |
|  |  | 5 | - | 100 | 175 | - | 100 | 175 |  |
| CLOCK to Chip Select | tclcs | 10 | - | 65 | 125 | - | - | - |  |
| CLOCK to Address, |  | 5 | - | 100 | 175 | - | 100 | 175 |  |
| CLOCK to Address, | tcla | 10 | - | 65 | 125 | - | - | - |  |
| Memory Address to Chip Select |  | 5 | - | 100 | 175 | - | 100 | 175 |  |
| Memory Address to Chip Select | $t_{\text {macs }}$ | 10 | - | 75 | 125 | - | - | - |  |
| Memory Address to Address | $t_{\text {maA }}$ | 5 | - | 80 | 125 | - | 80 | 125 |  |
| Memory Address to Address | $t_{\text {MAA }}$ | 10 | - | 40 | 60 | - | - | - |  |

- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$
$\Delta$ Maximum limits of mınimum characterıstıcs are the values above which all devices function

(a) CHIP ENABLE TO CHIP SELECT PROPAGATION DELAY

(b) MEMORY ADDRESS SETUP AND HOLD TIME

Fig. 2 - CDP1883 timing waveforms.

## APPLICATION INFORMATION

The CDP1883 and CDP1883C can be interfaced, without external components, with CDP1800-series microprocessor systems. These microprocessors feature a multiplexed address bus and provide an address latch signal (TPA) that is used as the Clock input of the CDP1883.
This signal is used to latch 7 bits of the high-order address. The lower five high-order address inputs are latched and held to be used with the eight lower-order address inputs to
access an $8 \mathrm{~K} \times 8$-bit memory. The two upper high-order address inputs are latched and decoded for use as chip selects.
The latched address and decoding functions of the CDP1883 and CDP1883C allow them to operate with 32K-byte memory systems. In addition, smaller memory systems can be configured with $4 \mathrm{~K} \times 8$-bit or smaller memories, or a mix of memory sizes up to $8 \mathrm{~K} \times 8$-bit.


92CM-37281
Fig 3 - Minımum 1800-system using the CDP1883 to interface with an $8 K \times 8$-bit memory.


FIg 4-32K-byte ROM system using the CDP1883

HARRIS

## GENERAL DESCRIPTION

The ICM7170 real time clock is a microprocessor bus compatible peripheral, fabricated using Harris' silicon gate CMOS LSI process. An 8-bit bidirectional bus is used for the data I/O circuitry. The clock is set or read by accessing the 8 internal separately addressable and programmable counters from 1/100 seconds to years. The counters are controlled by a pulse train divided down from a crystal oscillator circuit, and the frequency of the crystal is selectable with the on-chip command register. An extremely stable oscillator frequency is achieved through the use of an on-chip regulated power supply.
The device access time ( tacc ) of 300 ns eliminates the need for wait states or software overhead with most microprocessors. Furthermore, an ALE (Address Latch Enable) input is provided for interfacing to microprocessors with a multiplexed address/data bus. With these two special features, the ICM7170 can be easily interfaced to any available microprocessor.
The ICM7170 generates two types of interrupts, periodic and alarm. The periodic interrupt ( $100 \mathrm{~Hz}, 10 \mathrm{~Hz}$, etc.) can be programmed by the internal interrupt control register to provide 6 different output signals. The alarm interrupt is set by loading an on-chip 51-bit RAM that activates an interrupt output through a comparator. The alarm interrupt occurs when the real time counter and alarm RAM time are equal. A status register is available to indicate the interrupt source.

An on-chip Power-Down Detector eliminates the need for external components to support the battery back-up function. When a power-down or power failure occurs, internal logic switches the on-chip counters to battery back-up operation. Read/write functions become disabled and operation is limited to time-keeping and interrupt generation, resulting in low power consumption.
Internal latches prevent clock roll-over during a read cycle. Counter data is latched on the chip by reading the 100th-seconds counter and is held indefinitely until the counter is read again, assuring a stable and reliable time value.

## ORDERING INFORMATION

| Part <br> Number | Temperature <br> Range | Package |
| :--- | :--- | :--- |
| ICM7170IPG | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 24-Pin Plastic Dip |
| ICM7170IDG | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 24-Pin Ceramic |
| ICM7170IBG | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 24-Pin SOIC |
| ICM7170MDG | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 24-Pin Ceramic |
| ICM7170AIPG | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 24-Pin Plastic Dip |
| ICM7170AIDG | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 24-Pin Ceramic |
| ICM7170AIBG | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 24-Pin SOIC |
| ICM7170AMDG | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 24-Pin Ceramic |

"A" Parts Screened to < $5 \mu \mathrm{~A}$ ISTBY @ 32 KHz

## FEATURES

- 8-Bit $\mu$ P Bus Compatible
-Multiplexed or Direct Addressing
- Regulated Oscillator Supply Ensures Frequency Stability and Low Power
- Time From 1/100 Seconds to 99 Years
- Software Selectable 12/24 Hour Format
- Latched Time Data Ensures No Roll-Over During Read
- Full Calendar With Automatic Leap Year Correction
- On-Chip Battery Backup Switchover Circuit
- Access Time Less Than 300ns
- 4 Programmable Crystal Oscillator Frequencies over Industrial Temp Range
- 3 Programmable Crystal Oscillator Frequencies over Military Temp Range
- On-Chip Alarm Comparator and RAM
- Interrupts from Alarm and 6 Selectable Periodic Intervals
- Standby Micro-Power Operation: $1.2 \mu \mathrm{~A}$ Typical at 3.0 V and 32 kHz Crystal


## APPLICATIONS

- Portable and Personal Computers • Data Logging - Industrial Control Systems - Point Of Sale



## ABSOLUTE MAXIMUM RATINGS

Supply Voltage ............................................. 8 V
Power Dissipation (Note 1) . . . . . . . . . . . . . . . . . . . . . . 500 mW
Input Voltage (Any Terminal)
(Note 2) $\ldots \ldots \ldots . \ldots . . . . . . V_{D D}+0.3 V$ to $V_{S S}-0.3 V$
NOTE 1: $T_{A}=25^{\circ} \mathrm{C}$.
NOTE 2: Due to the SCR structure inherent in the CMOS process, connecting any terminal at voltages greater than $V_{D D}$ or less than $V_{S S}$ may-cause destructive device latchup For this reason, it is recommended that no inputs from external sources not operating on the same power supply be applied to the device before its supply is established, and that in multiple supply systems, the supply to the ICM7170 be turned on first
NOTE: Stresses above those listed under "Absolute Maxımum Ratıngs" may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions above those indicated in the operational sectıons of the specificatıons is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

0372-2
Figure 2: Functional Diagram

## ELECTRICAL CHARACTERISTICS

DC CHARACTERISTICS

Operating Temperature $\ldots \ldots . . . . . . . . .-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature .................. $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering, 10 sec ) ............... $300^{\circ} \mathrm{C}$

$\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BACK}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$ unless otherwise specified)
All IDD specifications include all input and output leakages (7170 and 7170A)

| Symbol | Parameter | Test Conditions |  | Specification |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| $V_{\text {DD }}$ | $\mathrm{V}_{\mathrm{DD}}$ Supply Range | $F_{\mathrm{OSC}}=1,2,4 \mathrm{MHz}$ |  | 1.9 |  | 5.5 | V |
|  |  |  |  | 2.6 |  | 5.5 |  |
| IStBy(1) | Standby Current | $\begin{aligned} & \text { FOSC }=32 \mathrm{kHz} \\ & \text { Pins } 1-8,15-22 \& 24=V_{D D} \\ & V_{D D}=V_{S S} ; V_{B A C K U P}=V_{D D}-3.0 \mathrm{~V} \\ & \text { For } 7170 \mathrm{~S} \text { See General Note (5) } \end{aligned}$ | 7170 |  | 1.2 | 20.0 | $\mu \mathrm{A}$ |
|  |  |  | 7170A |  | 1.2 | 5.0 |  |
| $\mathrm{I} \mathrm{STBY}(2)$ | Standby Current | $\begin{aligned} & F_{O S C}=4 M H z \\ & \text { Pins } 1-8,15-22 \& 24=V_{D D} \\ & V_{D D}=V_{S S} ; V_{B A C K U P}=V_{D D}-3.0 V \end{aligned}$ |  |  | 20 | 150 | $\mu \mathrm{A}$ |
| ${ }^{\prime} \mathrm{DD}(1)$ | Operating Supply Current | $\text { FOSC }=32 \mathrm{kHz}$ <br> Read/Write Operation at 100 Hz |  |  | 0.3 | 1.2 | mA |
| $1 \mathrm{DD}(2)$ | Operating Supply Current | $\mathrm{F}_{\mathrm{OSC}}=32 \mathrm{kHz}$ <br> Read/Write Operation at 1 MHz |  |  | 1.0 | 2.0 | mA |

[^10]
## ELECTRICAL CHARACTERISTICS

 DC CHARACTERISTICS( $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{B A C K U P}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$ unless otherwise specified) (Continued)
All IDD specifications include all input and output leakages ( 7170 and 7170A)

| Symbol | Parameter | Test Conditions |  | Specification |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\text {IL }}$ | Input low voltage (Except Osc.) | $\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{~V}$ |  |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input high voltage (Except Osc.) | $\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{~V}$ |  | 2.4 |  |  | V |
| V OL | Output low voltage (Except Osc.) | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  |  |  | 0.4 | V |
| V OH | Output high voltage except INTERRUPT (Except Osc.) | $\mathrm{l}^{\text {OH }}=-400 \mu \mathrm{~A}$ |  | 2.4 |  |  | V |
| IIL | Input leakage current | $V_{I N}=V_{D D}$ or $V_{S S}$ |  | -10 | 0.5 | +10 | $\mu \mathrm{A}$ |
| $\mathrm{lOL}^{(1)}$ | Tristate leakage current ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | $\mathrm{V}_{0}=\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{S S}$ |  | -10 | 0.5 | +10 | $\mu \mathrm{A}$ |
| $V_{\text {BATTERY }}$ | Backup Battery Voltage | $\mathrm{F}_{\mathrm{OSC}}=1,2,4 \mathrm{MHz}$ |  | 2.6 |  | $\mathrm{V}_{\mathrm{DD}}-1.3$ | V |
| VBATTERY | Backup Battery Voltage | $\mathrm{F}_{\text {OSC }}=32 \mathrm{kHz}$ |  | 1.9 |  | $V_{D D}-1.3$ | V |
| $\mathrm{lOL}^{(2)}$ | Leakage current INTERRUPT | $\mathrm{V}_{0}=\mathrm{V}_{\mathrm{DD}}$ | INT SOURCE connected to $V_{S S}$ |  | 0.5 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{Cl}_{1 / \mathrm{O}}$ | CAPACITANCE $\mathrm{D}_{0}-\mathrm{D}_{7}$ |  |  |  | 8 |  | pF |
| CADDRESS | CAPACITANCE A0-A ${ }_{4}$ |  |  |  | 6 |  | pF |
| $\mathrm{C}_{\text {CONTROL }}$ | CAP. $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}$ ALE |  |  |  | 6 |  | pF |
| $\mathrm{C}_{\text {IN }}$ Osc. | Total Osc. Input Cap. |  |  |  | 3 |  | pF |

AC CHARACTERISTICS $\quad\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{D}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BACKUP}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{D}_{0}-\mathrm{D}_{7}$ Load
Capacitance $=150 \mathrm{pF}, \mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=2.8 \mathrm{~V}$ unless otherwise specified)

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| READ CYCLE TIMING |  |  |  |  |
| $\mathrm{t}_{\mathrm{rd}}$ | READ to DATA valid |  | 250 | ns |
| $\mathrm{t}_{\text {acc }}$ | ADDRESS valid to DATA valid |  | 300 | ns |
| $\mathrm{t}_{\text {cyc }}$ | READ cycle time | 400 |  | ns |
| $t_{\text {r }}$ | Read high time | 150 |  | ns |
| $\mathrm{t}_{\mathrm{x}}$ | $\overline{\mathrm{RD}}$ high to bus tristate |  | 25 | ns |
| $t_{\text {as }}$ | ADDRESS to READ set up time | 50 |  | ns |
| $\mathrm{tar}_{\text {ar }}$ | ADDRESS HOLD time after READ | 0 |  | ns |
| WRITE CYCLE TIMING |  |  |  |  |
| $t_{\text {ad }}$ | ADDRESS valid to WRITE strobe | 50 |  | ns |
| $t_{\text {wa }}$ | ADDRESS hold time for WRITE | 0 |  | ns |
| $t_{\text {wl }}$ | WRITE pulse width, low | 100 |  | ns |
| $t_{\text {wh }}$ | WRITE high time | 300 |  | ns |
| $t_{\text {dw }}$ | DATA IN to WRITE set up time | 100 |  | ns |
| $t_{\text {wd }}$ | DATA IN hold time after WRITE | 30 |  | ns |
| $\mathrm{t}_{\mathrm{cyc}}$ | WRITE cycle time | 400 |  | ns |
| MULTIPLEXED MODE TIMING |  |  |  |  |
| $t_{11}$ | ALE Pulse Width, High | 50 |  | ns |
| $\mathrm{tal}^{\text {a }}$ | ADDRESS to ALE set up time | 30 |  | ns |
| $t_{l a}$ | ADDRESS hold time after ALE | 30 |  | ns |




0372-6
NOTE: The A0 to A4 address inputs may be connected to the D0 to D4 data lines when a multiplexed bus is used.
Figure 4: Timing Diagrams - Multiplexed Bus

| Signal | Pin\# | SOIC Pin\# | Description |
| :---: | :---: | :---: | :---: |
| $\overline{\text { WR }}$ | 1 | 19 | $\overline{\text { Write input }}$ |
| ALE | 2 | 20 | Address latch enable input |
| $\overline{\text { CS }}$ | 3 | 21 | Chip select input |
| A4-A0 | 4-8 | 22-2 | Address inputs |
| OSC OUT | 9 | 3 | Oscillator output |
| OSC IN | 10 | 4 | Oscillator input |
| INT SOURCE | 11 | 5 | Interrupt source |
| INTERRUPT | 12 | 6 | Interrupt output |
| $\mathrm{V}_{\text {SS }}$ (GND) | 13 | 7 | Digital common |
| $\mathrm{V}_{\text {BACKUP }}$ | 14 | 8 | Battery negative side |
| D0-D7 | 15-22 | 9-16 | Data 1/O |
| $V_{\text {DD }}$ | 23 | 17 | Positive digital supply |
| $\overline{\mathrm{RD}}$ | 24 | 18 | $\overline{\text { Read input }}$ |

## DETAILED DESCRIPTION

## Oscillator

The ICM7170 has an onboard CMOS Pierce oscillator with an internally regulated voltage supply for maximum accuracy, stability, and low power consumption. It operates at any of four popular crystal frequencies: 32.768 kHz , $1.048576 \mathrm{MHz}, 2.097152 \mathrm{MHz}$, and 4.194304 MHz .* The crystal should be designed for the parallel resonant mode of oscillation. In addition to the crystal, 2 or 3 load capacitors are required, depending on the circuit topology used.

The oscillator output is divided down to 4000 Hz by one of four divider ratios, determined by the two frequency selection bits in the Command Register (D0 and D1 at address $\$ 11$ ). This 4000 Hz is then divided down to 100 Hz , which is used as the clock for the counters.

Time and calendar information is provided by 8 consecutive, programmable counters: 100ths of seconds, seconds, minutes, hours, day of week, date, month, and year. The data is in binary format with 8 bits per digit. See Table 4 for address information. Any unused bits are held to a logic " 0 " during a read and ignored during a write operation.
*NOTE: 4.194304 MHz is not avallable over military temperature range.

## Alarm Compare RAM

On the chip are 51 bits of Alarm Compare RAM grouped into words of different lengths. These are used to store the time, ranging from 100ths of seconds to years, for comparison to the real-time counters. Each counter has a corresponding RAM word. In the Alarm Mode an interrupt is generated when the current time is equal to the alarm time. The RAM contents are compared to the counters on a word by word basis. If a comparison to a particular counter is unnecessary, then the appropriate ' $M$ ' bit in Compare RAM should be set to logic " 1 ".

The ' $M$ ' bit, referring to Mask bit, causes a particular RAM word to be masked off or ignored during a compare. Table 4 shows addresses and Mask bit information.

## Periodic Interrupts

The interrupt output can be programmed for 6 periodic signals: $100 \mathrm{~Hz}, 10 \mathrm{~Hz}$, once per second, once per minute, once per hour, or once per day. The 100 Hz and 10 Hz interrupts have instantaneous errors of $\pm 2.5 \%$ and $\pm 0.15 \%$ respectively. This is because non-integer divider circuitry is used to generate these signals from the crystal frequency, which is a power of 2 . The time average of these errors over a 1 second period, however, is zero. Consequently, the 100 Hz or 10 Hz interrupts are not suitable as an aid in tuning the oscillator; the 1 second interrupt must be used instead.
See General Note (6).

The periodic interrupts can occur concurrently and in addition to alarm interrupts. The periodic interrupts are controlled by bits in the interrupt mask register, and are enabled by setting the appropriate bit to a " 1 " as shown in Table 5. Bits D1 through D6 in the mask register, in conjunction with bits D1 through D6 of the status register, control the generation of interrupts according to Figure 5.
The interrupt status register, when read, indicates the cause of the interrupt and resets itself on the rising edge of the RD signal. When any of the counters having a corresponding bit in the status register increments, that bit is set to a " 1 " regardless of whether the corresponding bit in the interrupt mask register is set or not.
Consequently, when the status register is read it will always indicate which counters have increments and if an alarm compare occurred, since the last time it was read. This requires some special software considerations. If a slow interrupt is enabled (i.e. hourly or daily), the program must always check the slowest interrupt that has been enabled first, because all the other lower order bits in the status register will be set to " 1 " as well.
Bit D7 is the global interrupt bit, and when set to a " 1 ", indicates that the 7170 did indeed generate a hardware interrupt. This is useful when other interrupting devices in addition to the 7170 are attached to the system microprocessor, and all devices must be polled to determine which one generated the interrupt.
See General Note (6).

Table 2: Command Register Format

| COMMAND REGISTER ADDRESS (10001b, 11h) WRITE-ONLY |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| n/a | n/a | Normal/Test <br> Mode | Interrupt <br> Enable | Run/Stop | $12 / 24$ Hour <br> Format | Crystal <br> Frequency | Crystal <br> Frequency |

Table 3: Command Register Bit Assignments

| D5 | Test Bit | D4 | Interrupt <br> Enable | D3 | Run/Stop | D2 | 24/12 Hour <br> Format | D1 | D0 | Crystal <br> Frequency |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{0}$ | Normal Mode | 0 | Interrupt disabled | 0 | Stop | 0 | 12 hour mode | 0 | 0 | 32.768 kHz |
| 1 | Test Mode | 1 | Interrupt enable | 1 | Run | 1 | 24 hour mode | 0 | 1 | 1.048576 MHz |
|  |  |  |  |  |  |  |  | 1 | 0 | 2.097152 MHz |
|  |  |  |  |  |  |  |  | 1 | 1 | 4.194304 MHz |

Table 4: Address Codes and Functions

| Address |  |  |  |  |  | Function | DATA |  |  |  |  |  |  |  | Value |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A4 | A3 | A2 | A1 | AO | HEX |  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
| 0 | 0 | 0 | 0 | 0 | 00 | Counter-1/100 seconds | - | . | . | . | . | . | . | . | 0-99 |
| 0 | 0 | 0 | 0 | 1 | 01 | Counter-hours | - | - | - | . | . | . | . |  | 0-23 |
|  |  |  |  |  |  | 12 Hour Mode | * | - | - | - | . | . | . |  | 1-12 |
| 0 | 0 | 0 | 1 | 0 | 02 | Counter-minutes | - | - | . | . | . | . | . |  | 0-59 |
| 0 | 0 | 0 | 1 | 1 | 03 | Counter-seconds | - | - | . | . | . | - | . | . | 0-59 |
| 0 | 0 | 1 | 0 | 0 | 04 | Counter-month | - | - | - | - | . | . | . | . | 1-12 |
| 0 | 0 | 1 | 0 | 1 | 05 | Counter-date | - | - | - | . | . | . | . | . | 1-31 |
| 0 | 0 | 1 | 1 | 0 | 06 | Counter-year | - | . | . | . | . | . | . | . | 0-99 |
| 0 | 0 | 1 | 1 | 1 | 07 | Counter-day of week | - | - | - | - | - | . | . |  | 0-6 |
| 0 | 1 | 0 | 0 | 0 | 08 | RAM-1/100 seconds | M | - | . | . | . | . | . |  | 0-99 |
| 0 | 1 | 0 | 0 | 1 | 09 | RAM-hours | - | M | - | . | . | . | - | . | 0-23 |
|  |  |  |  |  |  | 12 hour Mode | * | M | - | - | . | . | . |  | 1-12 |
| 0 | 1 | 0 | 1 | 0 | OA | RAM-minutes | M | - | . | . | . | . | . |  | 0-59 |
| 0 | 1 | 0 | 1 | 1 | OB | RAM-seconds | M | - | . | . | . | . | . |  | 0-59 |
| 0 | 1 | 1 | 0 | 0 | 0 C | RAM-month | M | - | - | - | . | . | . | . | 1-12 |
| 0 | 1 | 1 | 0 | 1 | OD | RAM-date | M | - | - | . | . | . | - | - | 1-31 |
| 0 | 1 | 1 | 1 | 0 | OE | RAM-year | M | . | . | . | . | . | . | . | 0-99 |
| 0 | 1 | 1 | 1 | 1 | OF | RAM-day of week | M | - | - | - | - | - | - | . | 0-6 |
| 1 | 0 | 0 | 0 | 0 | 10 | Interrupt Status and Mask Register | + | . | - |  | - | . |  |  |  |
| 1 | 0 | 0 | 0 | 1 | 11 | Command register | - | - | . | . | . | . | . | . |  |

NOTES: Addresses 10010 to 11111 ( 12 h to 1 Fh ) are unused
'+' Unused bit for Interrupt Mask Regıster, MSB bit for Interrupt Status Regıster.
'-' Indicates unused bits.
'*' AM/PM indicator bit in 12 hour format Logic " 0 " indicates AM, logic " 1 " indicates PM
' $M$ ' Alarm compare for particular counter will be enabled if bit is set to logic " 0 ".
Table 5: Interrupt and Status Registers Format


## ICM7170

## Interrupt Operation

The Interrupt Output N -channel MOSFET (Figure 5) is efiabled whenever both the Interrupt Enable bit (D4 of the Command Register) and a mask bit (D0-D6 of the Interrupt Mask Register) are set. The transistor is turned ON when a flag bit is set that corresponds to one of the set mask bits. this also sets the Global Interrupt Flag Bit (D7 of the Interrupt Status Register). It is turned OFF when the Interrupt Status Register is read. An interrupt can occur in both the operational and standby modes of operation.

Since system power is usually applied between $V_{D D}$ and $\mathrm{V}_{\mathrm{SS}}$, the user can connect the Interrupt Source (pin \#11) to $V_{\text {SS }}$. This allows the Interrupt Output to turn on only while system power is applied and will not be pulled to $\mathrm{V}_{\text {SS }}$ during standby operation. If interrupts are required only during standby operation, then the interrupt source pin should be connected to the battery's negative side (VBACKUP). In this configuration, for example, the interrupt could be used to turn on power for a cold boot.
the battery-backup switchover function, as shown in Figure 6. Whenever the voltage from the $V_{S S}$ pin to the $V_{\text {BACKUP }}$ pin is less than approximately 1.0 V (the $\mathrm{V}_{\text {th }}$ of the N -channel MOSFET), the data bus I/O buffers in the 7170 are automatically disabled and the chip cannot be read or written to. This prevents random data from the microprocessor being written to the clock registers as the power supply is going down.
Actual switchover to battery operation occurs when the voltage on the $\mathrm{V}_{\text {BACKUP }}$ pin is within $\pm 50 \mathrm{mV}$ of $\mathrm{V}_{\mathrm{SS}}$. This switchover uncertainty is due to the offset voltage of the CMOS comparator that is used to sense the battery voltage. During battery backup, device operation is limited to timekeeping and interrupt generation only, thus achieving micropower current drain. If an external battery-backup switchover circuit is being used with the 7170, or if standby battery operation is not required, the $\mathrm{V}_{\text {BACKUP }}$ pin should be pulled up to $\mathrm{V}_{\mathrm{DD}}$ through a 2 k resistor.

## Power-Down Detector

The ICM7170 contains an on-chip power-down detector that eliminates the need for external components to support


Figure 5: Interrupt Output Circuit

## Time Synchronization

Time synchronization is achieved through bit D3 of the Command Register, which is used to enable or disable the 100 Hz clock from the counters. A logic " 1 " allows the counters to function and a logic " 0 " disables the counters. To accurately set the time, a logic " 0 " should be written into D3 and then the desired times entered into the appropriate counters. The clock is then started at the proper time by writing a logic " 1 " into D3 of the Command Register.

## Latched Data

To prevent ambiguity while the processor is gathering data from the registers, the ICM7170 incorporates data latches and a transparent transition delay circuit.

By accessing the 100ths of seconds counter an internal store signal is generated and data from all the counters is transferred into a 36 -bit latch. A transition delay circuit will delay a 100 Hz transition during a READ cycle. The data stored by the latches is then available for further processing until the 100ths of seconds counter is read again. If a RD signal is wider than 0.01 sec ., 100 Hz counts will be ignored.

## Control Lines

The $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{CS}}$ signals are active low inputs. Data is placed on the bus from counters or registers when $\overline{\mathrm{RD}}$ is a logic " 0 ". Data is transferred to counters or registers when $\overline{W R}$ is a logic " 0 ". $\overline{R D}$ and $\overline{W R}$ must be accompanied by a logical " 0 " $\overline{\mathrm{CS}}$ as shown in Figures 3 and 4. The 7170 will also work satisfactorily with $\overline{\mathrm{CS}}$ grounded. In this mode, access to the 7170 is controlled by $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only.

With the ALE (Address Latch Enable) input, the ICM7170 can be interfaced directly to microprocessors that use a multiplexed address/data bus by connecting the address lines AO-A4 to the data lines DO-D4. To address the chip, the address is placed on the bus and ALE is strobed. On the falling edge, the address and $\overline{C S}$ information is read into the address latch and buffer. $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are used in the same way as on a non-multiplexed bus. If a non-multiplexed bus is used, ALE should be connected to $V_{D D}$.

## Test Mode

The test mode is entered by setting D5 of the Command Register to a logic " 1 ". This connects the 100 Hz counter directly to the oscillator's output.

## Oscillator Considerations

Load Design: A new oscillator load configuration, shown in Figure 7, has been found that eliminates startup problems sometimes encountered with 32 kHz tuning fork crystals.
Two conditions must be met for best oscillator performance: the capacitive load must be matched to both the inverter and crystal to provide the ideal conditions for oscillation, and the resonant frequency of the oscillator must be adjustable to the desired frequency. In the original design (Figure 8), these two goals were often at odds with each other; either the oscillator was trimmed to frequency by detuning the load circuit, or stability was increased at the expense of absolute frequency accuracy.


The new load configuration (Figure 7) allows these two conditions to be met independently. The two load capacıtors, $\mathrm{C}_{1}$ and $\mathrm{C}_{2}$, provide a fixed load to the oscillator and crystal. $\mathrm{C}_{3}$ adjusts the frequency that the circuit resonates at by reducing the effective value of the crystal's motional capacitance, $\mathrm{C}_{0}$. This minute adjustment does not apprecıably change the load of the overall system, therefore stabillty is no longer affected by tuning. Typical values for these capacitors are shown in Table 6. $\mathrm{C}_{1}$ and $\mathrm{C}_{2}$ must always be greater than twice the crystal's recommended load capacitance in order for $\mathrm{C}_{3}$ to be able to trim the frequency. Some experimentation may be necessary to determine the ideal values of $C_{1}$ and $C_{2}$ for a particular crystal.
This three capacitor tuning method will be more stable than the original design and is mandatory for 32 kHz tuning fork crystals: without it they may leap into an overtone mode when power is initially applied.

The original two-capacitor circuit (Figure 8) will continue to work as well as it always has, and may continue to be used in applications where cost or space is a critical consideration. It is also easier to tune to frequency since one end of the trimmer capacitor is fixed at the AC ground of the circuit $\left(V_{D D}\right)$, minimizing the disturbance cause by contact between the adjustment tool and the trimmer capacitor. Note that in both configurations the load capacitors are connected between the oscillator pins and $V_{D D}$-do not use $V_{S S}$ as an AC ground.

Table 6: Typical Load Capacitor Values

| Crystal <br> Frequency | Load Caps <br> $\left(\mathbf{C}_{1}, \mathbf{C}_{2}\right)$ | Trimmer Cap <br> $\left(\mathbf{C}_{3}\right)$ |
| :---: | :---: | :---: |
| 32 kHz | 33 pF | $5-50 \mathrm{pF}$ |
| 1 MHz | 33 pF | $5-50 \mathrm{pF}$ |
| 2 MHz | 25 pF | $5-50 \mathrm{pF}$ |
| 4 MHz | 22 pF | $5-100 \mathrm{pF}$ |

Layout: Due to the extremely low current (and therefore high impedance) design of the ICM7170's oscillator, special attention must be given to the layout of this section. Stray capacitance should be minimized. Keep the oscillator traces on a single layer of the PCB. Avoid putting a ground plane above or below this layer. The traces between the crystal, the capacitors, and the 7170 OSC pins should be as short as possible. Completely surround the oscillator components with a thick trace of $V_{D D}$ to minimıze coupling with any digital signals. The final assembly must be free from contaminants such as solder flux, moisture, or any other potential sources of leakage. A good solder mask will help keep the traces free of moisture and contamination over time.

## Oscillator Tuning

Trimming the oscillator should be done indirectly. Direct monitoring of the oscillator frequency by probing OSC IN or OSC OUT is not accurate due to the capacitive loading of most probes. One way to accurately trim the 7170 is by turning on the 1 second periodic interrupt and trimming the oscillator until the interrupt period is exactly one second. This can be done as follows:

1) Turn on the system. Write a $\$ 00$ to the Interrupt Mask Register (location \$10) to clear all interrupts.
2) Set the Command Register (location \$11) for the appropriate crystal frequency, set the Interrupt Enable and Run/Stop bits to 1 , and set the Test bit to 0 .
3) Write a $\$ 08$ to the Interrupt Mask Register to turn on the 1 second interrupt.
4) Write an interrupt handler to read the Interrupt Status Register after every interrupt. This resets the interrupt and allows it to be set again. A software loop that reads the Interrupt Status Register several times each second will accomplish this also.
5) Connect a precision period counter capable of measuring 1 second within the accuracy desired to the interrupt output. If the interrupt is configured as active low, trigger on the falling edge. If the interrupt is active high, trigger on the rising edge. Be sure to measure the period between when the transistor turns ON, and when the transistor turns ON a second later.
6) Adjust $\mathrm{C}_{3}\left(\mathrm{C}_{2}\right.$ for the two-capacitor load configuration) for an interrupt period of exactly 1.000000 seconds.


## APPLICATION NOTES

## Digital Input Termination During Backup

To ensure low current drain during battery backup operation, none of the digital inputs to the 7170 should be allowed to float. This keeps the input logic gates out of their transition region, and prevents crossover current from flowing which will shorten battery life. The address, data, $\overline{C S}$, and ALE pins should be pulled to either $V_{D D}$ or $V_{S S}$, and the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs should be pulled to $\mathrm{V}_{\mathrm{DD}}$. This is necessary whether the internal battery switchover circuit is used or not.

0372-13
Figure 7: New Oscillator Configuration


0372-14
Figure 8: Original Oscillator Configuration

## IBM/PC Evaluation Circuit

Figure 9 shows the schematic of a board that has been designed to plug into an IBM PC/XT* or compatible computer. In this example $\overline{\mathrm{CS}}$ is permanently tied low and access to the chip is controlled by the RD and WR pins. These signals are generated by U1, which gates the IBM's $\overline{\mathrm{IOR}}$ and IOW with a device select signal from U3, which is functioning as an I/O block address decoder. DS1 selects the interrupt priority.

U5 is used to isolate the ICM7170 from the PC databus for test purposes. It is only required on heavily-loaded TTL databusses-the ICM7170 can drive most TTL and CMOS databusses directly.

Since the IBM PC/XT* requires a positive interrupt transition, the 7170's interrupt output transistor has been configured as a source follower. As a source follower, the interrupt output signal will swing between OV and 2.5 V . When trimming the oscillator, the frequency counter must be triggered on the rising edge of the interrupt signal.

| Batteries | Crystals |  |  |
| :--- | :--- | :--- | :--- |
| Panasonic | Saronix | 32 kHz | NTF3238 |
| Rayovac | Statek | 32 kHz | CX-1V |
|  | Seiko | 2 MHz | GT-38 |


*IBM, IBM PC, and IBM XT are trademarks of IBM Corp.

## GENERAL NOTES:

(1) TIME ACCESS

To update the present time registers (Hex 00-07) the $1 / 100$ register must be read first. The 7 real time counter registers (Hours, Minutes, Seconds, Month, Date, Day, and Year) data are latched only if the $1 / 100$ second counter register is read. The $1 / 100$ seconds data itself is not latched. The real time data will be held in the latches until the $1 / 100$ seconds is read again. See the data sheet section on LATCHED DATA. None of the RAM data is latched since it is static by nature.
(2) REGULATED OSCILLATOR

The oscillator's power supply is voltage regulated with respect to $\mathrm{V}_{\mathrm{dd}}$. In the 32 kHz mode the regulator's amplitude is $\Sigma V \operatorname{tn}+V \operatorname{tp}(\cong 1.8)$. In the 1,2 , and 4 MHz mode the regulator's amplitude is $\Sigma V \operatorname{tn}+\mathrm{Vtn}+\mathrm{Vtp}$ ( $\cong 2.6 \mathrm{~V}$ ). As a result, signal conditioning is necessary to drive the oscillator with an external signal. In addition, it is also necessary to buffer the oscillator's signal to drive other external clocks because of its reduced amplitude and offset voltage.
(3) INTERNAL BATTERY BACKUP

When the 7170 is using its own internal battery backup circuitry, no other circuitry interfaced to the 7170 should be active during standby operation. When $V_{d d}$ $(+5 \mathrm{~V})$ is turned off (Standby operation), $\mathrm{V}_{\text {dd }}$ should equal $\mathrm{V}_{\mathrm{ss}}=0 \mathrm{~V}$. All $7170 \mathrm{I} / \mathrm{O}$ should also equal $\mathrm{V}_{\mathrm{SS}}$. At this time, the Vbackup pin should be 2.8 V to 3.5 V below $V_{\text {SS }}$ when using a Lithium battery.
(4) EXTERNAL BATTERY BACKUP

The 7170 may be placed on the same power supply as battery-backed up RAM by keeping the 7170 in its operational state and having an external circuit switch between system and backup power for the 7170 and the RAM. In this case $V_{B A C K U P}$ should be pulled up to $V_{D D}$ through a $2 k$ resistor. Although the 7170 is always "on" in this configuration, its current consumption will typically be less than a microamp greater than that of standby operation at the same supply voltage. (See Note 9.)

Proper consideration must be given to disabling the 7170's and the RAM's I/O before system power is removed. This is important because many microprocessors can generate spurious write signals when their supply falls below their specified operating voltage limits. NANDing CS (or WR) with a POWERGOOD signal will create a $\overline{\mathrm{CS}}$ (or $\overline{\mathrm{WR}}$ ) that is only valid when system power is within specifications. The POWERGOOD signal should be generated by an accurate supply monitor such as the ICL7665 under/over voltage detector.

An alternate method of disabling the 7170's I/O is to pull $\mathrm{V}_{\text {BACKUP }}$ down to under a volt above $\mathrm{V}_{\mathrm{SS}}\left(\mathrm{V}_{\mathrm{SS}}<\right.$ $V_{\text {BACKUP }}<1.0 \mathrm{~V}$ ). This will cause the 7170 to internally disable all I/O. Do not allow $V_{B A C K U P}$ to equal $V_{S S}$, since this could cause oscillation of the battery backup comparator (See Figure 6). $\mathrm{V}_{\text {BACKUP }}=\mathrm{V}_{\mathrm{SS}}+0.5 \mathrm{~V}$ will disable the I/O and provide enough overdrive for the comparator.
(5) 7170A PART

The 7170A part is binned at final test for a 32.768 kHz maximum current of $5 \mu \mathrm{~A}$. All other specifications remain the same.
(6) INTERRUPTS

The Interrupt Status Register (address \$10) always indicates which of the real time counters have been incremented since the last time the register was read. NOTE: This is independent of whether or not any mask bits are set.

The status register is always reset immediately after it is read. If an interrupt from the 7170 has occurred since the last time the status register was read, bit D7 of the register will be set. If the source was an alarm interrupt, bit DO will also be set. If the interrupt transistor has been turned on, reading the Interrupt Status Register will reset it.

To enable the periodic interrupt, both the Command Register's Interrupt Enable bit (D4) and at least one bit in the Interrupt Mask Register (D1-D6) must be set to a 1. The periodic interrupt is triggered when the counter corresponding to a mask bit that has been set is incremented. For example, if you enable the 1 second interrupt when the current value in the 100ths counter is 57 , the first interrupt will occur 0.43 seconds later. All subsequent interrupts will be exactly one second apart. The interrupt service routine should then read the Interrupt Status Register to reset the interrupt transistor and, if necessary, determine the cause of the interrupt (periodic, alarm, or non-7170 generated) from the contents of the status register.

To enable the alarm interrupts, both the Command Register's Interrupt Enable bit (D4) and the Interrupt Mask Register's Alarm bit (D0) must be set to a 1. Each time there is an exact match between the values in the alarm register and the values in the real time counters, bits D0 and D7 of the Interrupt Status Register will be set to a 1 and the N -channel interrupt transistor will be turned on. As with a periodic interrupt, the service routine should then read the Interrupt Status Register to reset the interrupt transistor and, since periodic and alarm interrupts may be simultaneously enabled, determine the cause of the interrupt if necessary.

Mask bits: The 7170 alarm interrupt compares the data in the alarm registers with the data in the real time registers, ignoring any registers with the mask bit set. For example, if the alarm register is set to 11-23-95 (Month-Day-Year), 10:59:00:00 (Hour-Minutes-Sec-onds-Hundredths), and DAY $=X X$ ( $X X=$ masked off), the alarm will generate a single interrupt at 10:59 on November 23, 1995. If the alarm register is set to 11-XX-95, 10:XX:00:00, and DAY $=2$ ( $2=$ Tuesday); the alarm will generate one interrupt every minute from 10:00-10:59 on every Tuesday in November, 1995.
NOTE: Masking off the 100ths of a second counter has the same effect as setting it to 00.
(7) RESISTOR IN SERIES WITH BATTERY

A $2 k$ resistor (R2) must be placed in series with the battery backup pin of the 7170 . The UL laboratories have requested the resistor to limit the charging and discharging current to the battery. The resistor also serves the purpose of degenerating parasitic SCR action. This SCR action may occur if an input is applied to the 7170 , outside of its supply voltage range, while it is in the standby mode.

## GENERAL NOTES: (Continued)

(8) VBACKUP DIODE

Lithium batteries may explode if charged or if discharged at too high a rate. These conditions could occur if the battery was installed backwards or in the case of a gross component failure. A 1N914-type diode placed in series with the battery as shown in Figure 9 will prevent this from occurring. A resistor of $2 \mathrm{M} \Omega$ or so should parallel the diode to keep the $\mathrm{V}_{\text {BACKUP }}$ terminal from drifting toward the $\mathrm{V}_{\mathrm{SS}}$ terminal and shutting off 7170 I/O during normal operation.
(9) SUPPLY CURRENT

7170 supply current is predominantly a function of oscillator frequency and databus activity. The lower the oscillator frequency, the lower the supply current. When there is little or no activity on the data, address or control lines, the current consumption of the 7170 in its operational mode approaches that of the backup mode.

HARRIS
SEMICONDUCTOR

# CMOS High Performance Programmable DMA Controller 

## Features

- Fully Compatible with Harris 82C37A
- 82C237 May be Used in 8MHz and 12.5MHz 82C37A Sockets
- Optimized for 10 MHz and 12.5 MHz 80C286 Systems
- Special Mode Permits 16-Bit, Zero Wait State DMA Transfers
- High Speed Data Transfers:
- Up to 6.25 MBytes/sec with 12.5MHz Clock in Normal Mode
- Up to 12.5 MBytes/sec with 12.5MHz Clock in 16-Bit Mode
- Compatible with the NMOS 8237 A
- Four Independent Maskable Channels with Autoinitialization Capability
- Cascadable to any Number of Channels
- Memory-to-Memory Transfers
- Static CMOS Design Permits Low Power Operation
- ICCSB $=10 \mu A$ Maximum
- ICCOP = 2mA/MHz Maximum
- Fully TTLCMOS Compatible
- Internal Registers may be Read from Software


## Description

The 82C237 is a modified version of the 82C37A. The 82C237 is fully software and pin for pin compatible with the 82C37A but provides an additional mode for 16-bit DMA transfers, as well as enhanced speed. Each channel may be individually programmed for 8-bit or 16-bit data transfers.

The 82C237 controller can improve system performance by allowing external devices to transfer data directly to or from system memory. Memory-to-memory transfer capability is also provided, along with a memory block initialization feature. DMA requests may be generated by either hardware or software, and each channel is independently programmable with a variety of features for flexible operation.

The 82C237 is designed to be used with an external address latch, such as the 82C82, to demultiplex the most significant 8 bits of address. An additional latch is required to temporarily store the most significant 8 bits of data if 16 -bit memory-to-memory transfers are desired. The 82C237 can be used with industry standard microprocessors such as 80C286, 80286, 80C86, 80C88, 8086, 8088, 8085, Z80, NSC800, 80186 and others. Multimode programmability allows the user to select from three basic types of DMA services, and reconfiguration under program control is possible even with the clock to the controller stopped. Each channel has a full 64 K address and word count range, and may be programmed to autoinitialize these registers following DMA termination (end of process).

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 8 MHz | 12.5MHz |
| :---: | :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C237 | CP82C237-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C237 | IP82C237-12 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C237 | CS82C237-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C237 | IS82C237-12 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C237 | CD82C237-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C237 | ID82C237-12 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C237/B | MD82C237-12/B |
| SMD\# |  | Pending | Pending |
| LCC <br> SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C237/B | MR82C237-12/B |
|  |  | Pending | Pending |

## Pinouts



Block Diagram


TABLE 1.

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| VCC | 31 |  | VCC: is the +5 V power supply pin. A 0.1 uF capacitor between pins 31 and 20 is recommended for decoupling. |
| GND | 20 |  | Ground |
| CLK | 12 | I | CLOCK INPUT: The Clock Input is used to generate the timing signals which control 82C237 operations. This input may be driven from DC to 12.5 MHz for the $82 \mathrm{C} 237-12$, or from DC to 8 MHz for the 82C237. The Clock may be stopped in either state for standby operation. |
| $\overline{\mathrm{CS}}$ | 11 | 1 | CHIP SELECT: Chip Select is an active low input used to enable the controller onto the data bus for CPU communications. |
| RESET | 13 | 1 | RESET: This is an active high input which clears the Command, Status, Request, and Temporary registers, the First/Last Flip-Flop, and the mode register counter. The Mask register is set to ignore requests. The Data-Width register is set to perform 8-bit transfers on all channels (82C237 only). Following a Reset, the controller is in an idle cycle. |
| READY | 6 | I | READY: This signal can be used to extend the memory read and write pulses from the 82C237 to accommodate slow memories or I/O devices. Ready must not make transitions during its specified set-up and hold times. See Figure 14 for timing. Ready is ignored in verify transfer mode. |
| HLDA | 7 | 1 | HOLD ACKNOWLEDGE: The active high Hold Acknowledge from the CPU indicates that it has relinquished control of the system busses. HLDA is a synchronous input and must not transition during its specified set-up time. There is an implied hold time (HLDA inactive) of TCH from the rising edge of clock, during which time HLDA must not transition. |
| DREQODREQ3 | 16-19 | I | DMA REQUEST: The DMA Request (DREQ) lines are individual asynchronous channel request inputs used by peripheral circuits to obtain DMA service. In Fixed Priority, DREQO has the highest priority and DREQ3 has the lowest priority. A request is generated by activating the DREQ line of a channel. DACK will acknowledge the recognition of a DREQ signal. Polarity of DREQ is programmable. Reset initializes these lines to active high. DREQ must be maintained until the corresponding DACK goes active. DREQ will not be recognized while the clock is stopped. Unused DREQ inputs should be pulled High or Low (inactive) and the corresponding mask bit set. In 16-bit Transfer mode (82C237 only), each DREQ channel may be programmed to perform either 8-bit or 16-bit DMA transfers. |
| $\begin{gathered} \text { DBO- } \\ \text { DB7 } \end{gathered}$ | $\begin{aligned} & 21-23 \\ & 26-30 \end{aligned}$ | 1/0 | DATA BUS: The Data Bus lines are bidirectional three-state signals connected to the system data bus. The outputs are enabled in the Program condition during the I/O Read to output the contents of a register to the CPU. The outputs are disabled and the inputs are read during an I/O Write cycle when the CPU is programming the 82 C 237 control registers. During DMA cycles, the most significant 8 bits of the address are output onto the data bus to be strobed into an external latch by ADSTB. In memory-to-memory operations, data from the memory enters the 82C237 on the data bus during the read-from-memory transfer, then during the write-to-memory transfer, the data bus outputs write the data into the new memory location. |
| $\overline{\mathrm{IOR}}$ | 1 | 1/0 | I/O READ: I/O Read is a bidirectional active low three-state line. In the Idle cycle, it is an input control signal used by the CPU to read the control registers. In the Active cycle, it is an output control signal used by the 82C237 to access data from a peripheral during a DMA Write transfer. |
| $\overline{\text { IOW }}$ | 2 | 1/0 | I/O WRITE: I/O Write is a bidirectional active low three-state line. In the Idle cycle, it is an input control signal used by the CPU to load information into the 82C237. In the Active cycle, it is an output control signal used by the 82C237 to load data to the peripheral during a DMA Read transfer. |
| $\overline{\text { EOP }}$ | 36 | 1/0 | END OF PROCESS: End of Process ( $\overline{E O P}$ ) is an active low bidirectional signal. Information concerning the completion of DMA services is available at the bidirectional $\overline{E O P}$ pin. <br> The 82C237 allows an external signal to terminate an active DMA service by pulling the $\overline{\mathrm{EOP}}$ pin low. A pulse is generated by the 82 C 237 when terminal count (TC) for any channel is reached, except for channel 0 in memory-to-memory mode. During memory-to-memory transfers, $\overline{\text { EOP }}$ will be output when the TC for channel 1 occurs. <br> The $\overline{E O P}$ pin is driven by an open drain transistor on-chip, and requires an external pull-up resistor to VCC. <br> When an $\overline{\text { EOP }}$ pulse occurs, whether internally or externally generated, the 82 C 237 will terminate the service, and if autoinitialize is enabled, the base registers will be written to the current registers of that channel. The mask bit and TC bit in the status word will be set for the currently active channel by $\overline{E O P}$ unless the channel is programmed for autoinitialize. In that case, the mask bit remains clear. |

## Pin Description

TABLE 1.

| SYMBOL | PIN <br> NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| AO-A3 | 32-35 | 1/0 | ADDRESS: The four least significant address lines are bidirectional three-state signals. In the Idle cycle, they are inputs and are used by the 82 C 237 to address the control register to be loaded or read. In the Active cycle, they are outputs and provide the lower 4 bits of the output address. When in 16-bit mode ( 82 C 237 only), and the active channel is a 16-bit channel (as defined by the DataWidth register), then AO will remain low during the entire transfer (i.e. an even word address will always be generated). |
| A4-A7 | 37-40 | 0 | ADDRESS: The four most significant address lines are three-state outputs and provide 4 bits of address. These lines are enabled only during the DMA service. |
| HRQ | 10 | 0 | HOLD REQUEST: The Hold Request (HRQ) output is used to request control of the system bus. When a DREQ occurs and the corresponding mask bit is clear, or a software DMA request is made, the 82C237 issues HRQ. The HLDA signal then informs the controller when access to the system busses is permitted. For stand-alone operation where the 82 C 237 always controls the busses, HRQ may be tied to HLDA. This will result in one SO state before the transfer. |
| DACKODACK 3 | $\begin{array}{r} 14,15 \\ 24,25 \end{array}$ | 0 | DMA ACKNOWLEDGE: DMA acknowledge is used to notify the individual peripherals when one has been granted a DMA cycle. The sense of these lines is programmable. Reset initializes them to active low. |
| AEN | 9 | 0 | ADDRESS ENABLE: Address Enable enables the 8-bit latch containing the upper 8 address bits onto the system address bus. AEN can also be used to disable other system bus drivers during DMA transfers. AEN is active HIGH. |
| ADSTB | 8 | 0 | ADDRESS STROBE: This is an active high signal used to control latching of the upper address byte. It will drive directly the strobe input of external transparent octal latches, such as the 82C82. During block operations, ADSTB will only be issued when the upper address byte must be updated, thus speeding operation through elimination of S 1 states. ADSTB timing is referenced to the falling edge of the 82C237 clock. |
| $\overline{\text { MEMR }}$ | 3 | 0 | MEMORY READ: The memory Read signal is an active low three-state output used to access data from the selected memory location during a DMA Read or a memory-to-memory transfer. |
| $\overline{\text { MEMW }}$ | 4 | 0 | MEMORY WRITE: The Memory Write is an active low three-state output used to write data to the selected memory location during a DMA Write or a memory-to-memory transfer. |
| DWLE | 5 | 0 | DATA-WIDTH, LATCH ENABLE: In normal 8-bit transfer mode (16-bit transfer mode not enabled), this output is always high impedance tri-stated. In 16-bit transfer mode ( 82 C 237 only), this output serves a dual purpose. During S1 cycles, the DWLE output indicates the data width ( $0=16$-bit, $1=8$-bit) of the active channel. During memory-to-memory transfers, the DWLE output is used to enable an external latch which temporarily stores the 8 most significant bits of data during the read-from-memory transfer. DWLE enables this byte of data onto the data bus during the write-to-memory transfer of a memory-to-memory operation. |

## Functional Description

The 82C237 is an improved version of the Harris 82C37A DMA controller and is fully software and pin for pin compatible with the 82 C 37 A . All operational and pin descriptions of the 82C37A apply to the 82C237 with additional features noted in the section titled 82 C 237 Operation.

The 82C237 direct memory access controller is designed to improve the data transfer rate in systems which must transfer data from an I/O device to memory, or move a block of memory to an I/O device. It will also perform memory-tomemory block moves, or fill a block of memory with data from a single location. Operating modes are provided to handle single byte transfers as well as discontinuous data streams, which allows the 82 C 237 to control data movement with software transparency.

The DMA controller is a state-driven address and control signal generator, which permits data to be transferred directly from an I/O device to memory or vice versa without ever being stored in a temporary register. This can greatly increase the data transfer rate for sequential operations, compared with processor move or repeated string instructions. Memory-to-memory operations require temporary internal storage of the data byte between generation of the source and destination addresses, so memory-to-memory transfers take place at less than half the rate of $1 / O$ operations, but still much faster than with central processor techniques. The maximum data transfer rates obtainable with the 82C237 are shown in Figure 1.

The block diagram of the 82C237 is shown on page 2. The timing and control block, priority block, and internal registers are the main components. Figure 2 lists the name and size of the internal registers. The timing and control block derives internal timing from the clock input, and generates external control signals. The Priority Encoder block resolves priority contention between DMA channels requesting service simultaneously.

| 82C237 <br> TRANSFER TYPE | 8 MHz |  | 12.5 MHz |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | $8-$ <br> BIT | $16-$ <br> BIT | $8-$ <br> BIT | $16-$ <br> BIT |  |
|  | 4.00 | 8.00 | 6.25 | 12.5 | MByte/sec |
| Normal I/O | 2.67 | 5.34 | 4.17 | 8.34 | MByte/sec |
| Memory-to- <br> Memory | 1.00 | 2.00 | 1.56 | 3.12 | MByte/sec |

FIGURE 1. DMA TRANSFER RATES

## DMA Operation

In a system, the 82C237 address and control outputs and data bus pins are basically connected in parallel with the system busses. An external latch is required for the upper address byte. While inactive, the controller's outputs are in a high impedance state. When activated by a DMA request and bus control is relinquished by the host, the 82 C 237 drives the busses and generates the control signals to
perform the data transfer. The operation performed by activating one of the four DMA request inputs has previously been programmed into the controller via the Command, Mode, Address, and Word Count registers.

For example, if a block of data is to be transferred from RAM to an I/O device, the starting address of the data is loaded into the 82C237 Current and Base Address registers for a particular channel, and the length of the block is loaded into that channel's Word Count register. The corresponding Mode register is programmed for a memory-to-1/O operation (read transfer), and various options are selected by the Command register and other Mode register bits. The channel's mask bit is cleared to enable recognition of a DMA request (DREQ). The DREQ can either be a hardware signal or a software command.

Once initiated, the block DMA transfer will proceed as the controller outputs the data address, simultaneous MEMR and $\overline{\mathrm{IOW}}$ pulses, and selects an I/O device via the DMA acknowledge (DACK) outputs. The data byte flows directly from the RAM to the I/O device. After each byte is transferred, the address is automatically incremented (or decremented) and the word count is decremented. The operation is then repeated for the next byte. The controller stops transferring data when the Word Count register underflows, or an external $\overline{\mathrm{EOP}}$ is applied.

| NAME | SIZE | NUMBER |
| :--- | :---: | :---: |
| Base Address Registers | 16 Bits | 4 |
| Base Word Count Registers | 16 Bits | 4 |
| Current Address Registers | 16 Bits | 4 |
| Current Word Count Registers | 16 Bits | 4 |
| Temporary Address Register | 16 Bits | 1 |
| Temporary Word Count Register | 16 Bits | 1 |
| Status Register | 8 Bits | 1 |
| Command Register | 8 Bits | 1 |
| Temporary Register | 8 Bits | 1 |
| Mode Registers | 6 Bits | 4 |
| Mask Register | 4 Bits | 1 |
| Request Register | 4 Bits | 1 |
| Data-Width Register* | 4 Blts | 1 |

*82C237 only

## FIGURE 2. 82C237 INTERNAL REGISTERS

To further understand 82C237 operation, the states generated by each clock cycle must be considered. The DMA controller operates in two major cycles, active and idle. After being programmed, the controller is normally idle until a DMA request occurs on an unmasked channel, or a software request is given. The 82C237 will then request control of the system busses and enter the active cycle. The active cycle is composed of several internal states, depending on what options have been selected and what type of operation has been requested.

The 82C237 can assume seven separate states, each composed of one full clock period. State I (SI) is the idle state. It is entered when the 82C237 has no valid DMA requests pending, at the end of a transfer sequence, or when a Reset or Master Clear has occurred. While in SI, the DMA controller is inactive but may be in the Program Condition (being programmed by the processor).

State $0(\mathrm{SO})$ is the first state of a DMA service. The 82C237 has requested a hold but the processor has not yet returned an acknowledge. The 82 C 237 may still be programmed until it has received HLDA from the CPU. An acknowledge from the CPU will signal that DMA transfers may begin. S1, S2, S3 and S4 are the working states of the DMA service. If more time is needed to complete a transfer than is available with normal timing, wait states (SW) can be inserted between S3 and S4 in normal transfers by the use of the Ready line on the 82C237. For compressed transfers, wait states can be inserted between S2 and S4. See timing Figures 14 and 15.
Note that the data is transferred directly from the I/O device to memory (or vice versa) with $\overline{\mathrm{IOR}}$ and $\overline{\text { MEMW (or MEMR }}$ and $\overline{\mathrm{OW}}$ ) being active at the same time. The data is not read into or driven out of the 82 C 237 in 1/O-to-memory or memory-to-I/O DMA transfers.

Memory-to-memory transfers require a read-from and a write-to memory to complete each transfer. The states, which resemble the normal working states, use two-digit numbers for identification. Eight states are required for a single transfer. The first four states (S11, S12, S13, S14 are used for the read-from-memory half and the last four states (S21, S22, S23, S24) for the write-to-memory half of the transfer.

## Idle Cycle

When no channel is requesting service, the 82 C 237 will enter the Idle cycle and perform "SI" states. In this cycle, the 82C237 will sample the DREQ lines on the falling edge of every clock cycle to determine if any channel is requesting a DMA service.

Note that for standby operation where the clock has been stopped, DMA requests will be ignored. The device will respond to $\overline{C S}$ (chip select), in case of an attempt by the microprocessor to write or read the internal registers of the 82C237. When $\overline{C S}$ is low and HLDA is low, the 82C237 enters the Program Condition. The CPU can now establish, change or inspect the internal definition of the part by reading from or writing to the internal registers.

The 82C237 may be programmed with the clock stopped, provided that HLDA is low and at least one rising clock edge has occurred after HLDA was driven low, so the controller is in an SI state. Address lines AO-A3 are inputs to the device and select which registers will be read or written. The $\overline{\mathrm{IOR}}$ and $\overline{\mathrm{IOW}}$ lines are used to select and time the read or write operations. Due to the number and size of the internal registers, an internal flip-flop called the First/Last Flip-Flop is used to generate an additional bit of address. The bit is used to determine the upper or lower byte of the 16-bit Address and Word Count registers. The flip-flop is reset by Master Clear or Reset. Separate software commands can also set or reset this flip-flop.

Special software commands can be executed by the 82C237 in the Program Condition. These commands are decoded as sets of addresses with $\overline{\mathrm{CS}}, \overline{\mathrm{IOR}}$, and $\overline{\mathrm{IOW}}$. The commands do not make use of the data bus. Instructions include Set and Clear First/Last Flip-Flop, Master Clear, Clear Mode Register Counter, and Clear Mask Register.

## Active Cycle

When the 82C237 is in the Idle cycle, and a software request or an unmasked channel requests a DMA service, the device will issue HRQ to the microprocessor and enter the Active cycle. It is in this cycle that the DMA service will take place, in one of four modes:
Single Transfer Mode - In single transfer mode, the device is programmed to make one transfer only. The word count will be decremented and the address decremented or incremented following each transfer. When the word count "rolls over" from zero to FFFFH, a terminal count bit in the status register is set, an $\overline{\mathrm{EOP}}$ pulse is generated, and the channel will autoinitialize if this option has been selected. If not programmed to autoinitialize, the mask bit will be set, along with the TC bit and $\overline{E O P}$ pulse.
DREQ must be held active until DACK becomes active. If DREQ is held active throughout the single transfer, HRQ will go inactive and release the bus to the system. It will again go active and, upon receipt of a new HLDA, another single transfer will be performed, unless a higher priority channel takes over. In 8080A, 8085A, 80C88, or 80C86 systems, this will ensure one full machine cycle execution between DMA transfers. Details of timing between the 82C237 and other bus control protocols will depend upon the characteristics of the microprocessor involved.

Block Transfer Mode - In Block Transfer mode, the device is activated by DREQ or software request and continues making transfers during the service until a TC, caused by word count going to FFFFH, or an external End of Process $(\overline{\mathrm{EOP}})$ is encountered. DREQ need only be held active until DACK becomes active. Again, an Autoinitialization will occur at the end of the service if the channel has been programmed for that option.

Demand Transfer Mode - In Demand Transfer mode the device continues making transfers until a TC or external $\overline{\mathrm{EOP}}$ is encountered, or until DREQ goes inactive. Thus, transfers may continue until the I/O device has exhausted its data capacity. After the I/O device has had a chance to catch up, the DMA service is reestablished by means of a DREQ. During the time between services when the microprocessor is allowed to operate, the intermediate values of address and word count are stored in the 82C237 Current Address and Current Word Count registers. Higher priority channels may intervene in the demand process, once DREQ has gone inactive. Only an $\overline{E O P}$ can cause an Autoinitialization at the end of the service. $\overline{\mathrm{EOP}}$ is generated either by TC or by an external signal.

Cascade Mode - This mode is used to cascade more than one 82C237 for simple system expansion. The HRQ and HLDA signals from the additional 82C237 are connected to the DREQ and DACK signals respectively of a channel for the initial 82C237. This allows the DMA requests of the additional device to propagate through the priority network
circuitry of the preceding device. The priority chain is preserved and the new device must wait for its turn to acknowledge requests. Since the cascade channel of the initial 82C237 is used only for prioritizing the additional device, it does not output an address or control signals of its own. These could conflict with the outputs of the active channel in the added device. The initial 82C237 will respond to DREQ and generate DACK but all other outputs except $H R Q$ will be disabled. An external $\overline{E O P}$ will be ignored by the initial device, but will have the usual effect on the added device.

Figure 3 shows two additional devices cascaded with an initial device using two of the initial device's channels. This forms a two-level DMA system. More 82C237s could be added at the second level by using the remaining channels of the first level. Additional devices can also be added by cascading into the channels of the second level devices, forming a third level.


FIGURE 3. CASCADED 82C237s
When programming cascaded controllers, start with the first level device (closest to the microprocessor). After RESET, the DACK outputs are programmed to be active low and are held in the high state. If they are used to drive HLDA directly, the second level device(s) cannot be programmed until DACK polarity is selected as active high on the initial device. Also, the initial device's mask bits function normally on cascaded channels, so they may be used to inhibit second-level services.

## Transfer Types

Each of the three active transfer modes can perform three different types of transfers. These are Read, Write and Verify. Write transfers move data from an I/O device to the memory by activating $\overline{\mathrm{MEMW}}$ and $\overline{\mathrm{OR}}$. Read transfers move data from memory to an I/O device by activating $\overline{\mathrm{MEMR}}$ and $\overline{\mathrm{OWW}}$.

Verify transfers are pseudo-transfers. The 82C237 operates as in Read or Write transfers generating
addresses and responding to $\overline{\mathrm{EOP}}$, etc., however the memory and $1 / \mathrm{O}$ control lines all remain inactive. Verify mode is not permitted for memory-to-memory operation. Ready is ignored during verify transfers.

Autoinitialize - By setting bit 4 in the Mode register, a channel may be set up as an Autoinitialize channel. During Autoinitialization, the original values of the Current Address and Current Word Count registers are automatically restored from the Base Address and Base Word Count registers of that channel following $\overline{\mathrm{EOP}}$. The base registers are loaded simultaneously with the current registers by the microprocessor and remain unchanged throughout the DMA service. The mask bit is not set when the channel is in Autoinitialize mode. Following Autoinitialization, the channel is ready to perform another DMA service, without CPU intervention, as soon as a valid DREQ is detected, or software request made.
Memory-to-Memory - To perform block moves of data from one memory address space to another with minimum of program effort and time, the 82C237 includes a memory-to-memory transfer feature. Setting bit 0 in the Command register selects channels 0 and 1 to operate as memory-tomemory transfer channels.
The transfer is initiated by setting the software or hardware DREQ for channel 0 . The 82C237 requests a DMA service in the normal manner. After HLDA is true, the device, using four-state transfers in Block Transfer mode, reads data from the memory. The channel 0 Current Address register is the source for the address used and is decremented or incremented in the normal manner. The data byte read from the memory is stored in the 82 C 237 internal Temporary register. Another four-state transfer moves the data to memory using the address in channel one's Current Address register and incrementing or decrementing it in the normal manner. The channel 1 Current Word Count is decremented.

When the word count of channel 1 decrements to FFFFH, a TC is generated causing an $\overline{\mathrm{EOP}}$ output, terminating the service, and setting the channel 1 TC bit in the Status register. The channel 1 mask bit will also be set, unless the channel 1 mode register is programmed for autoinitialization. Channel 0 word count decrementing to FFFFFH will not set the channel 0 TC bit in the status register or generate an $\overline{E O P}$, or set the channel 0 mask bit in this mode. It will cause an autoinitialization of channel 0 , if that option has been selected.

If full Autoinitialization for a memory-to-memory operation is desired, the channel 0 and channel 1 word counts must be set to equal values before the transfer begins. Otherwise, if channel 0 underflows before channel 1 , it will autoinitialize and set the data source address back to the beginning of the block. If the channel 1 word count underflows before channel 0 , the memory-to-memory DMA service will terminate, and channel 1 will autoinitialize but channel 0 will not.

In memory-to-memory mode, Channel 0 may be programmed to retain the same address for all transfers. This allows a single byte to be written to a block of memory. This channel 0 address hold feature is selected by setting bit 1 in the Command register.

The 82C237 will respond to external $\overline{\mathrm{EOP}}$ signals during memory-to-memory transfers, but will only relinquish the system busses after the transfer is complete (i.e., after an S24 state). It should be noted that an external EOP cannot cause the channel 0 Address and Word Count registers to autoinitialize, even if the Mode register is programmed for autoinitialization. An external EOP will autoinitialize the channel 1 registers, if so programmed. Data comparators in block search schemes may use the $\overline{\mathrm{EOP}}$ input to terminate the service when a match is found. The timing of memory-to-memory transfers is found in Figure 13. Memory-tomemory operations can be detected as an active AEN with no DACK outputs.

Priority - The 82C237 has two types of priority encoding available as software selectable options. The first is Fixed Priority which fixes the channels in priority order based upon the descending value of their numbers. The channel with the lowest priority is 3 followed by 2,1 and the highest priority channel, 0 . After the recognition of any one channel for service, the other channels are prevented from interfering with the service until it is completed.
The second scheme is Rotating Priority. The last channel to get service becomes the lowest priority channel with the others rotating accordingly. The next lower channel from the channel serviced has highest priority on the following request. Priority rotates every time control of the system busses is returned to the processor.

## Rotating Priority



With Rotating Priority in a single chip DMA system, any device requesting service is guaranteed to be recognized after no more than three higher priority services have occurred. This prevents any one channel from monopolizing the system.
Regardless of which priority scheme is chosen, priority is evaluated every time a HLDA is returned to the 82 C 237 .
Compressed Timing - In order to achieve even greater throughput where system characteristics permit, the 82C237 can compress the transfer time to two clock cycles. From Figure 12 it can be seen that state S3 is used to extend the access time of the read pulse. By removing state S3, the read pulse width is made equal to the write pulse width and a transfer consists only of state S2 to change the address and state S4 to perform the read/write. S1 states will still occur when A8-A15 need updating (see Address Generation). Timing for compressed transfers is found in Figure 15. $\overline{\text { EOP }}$ will be output in S 2 if compressed timing is selected. Compressed timing is not allowed for memory-to-memory transfers.
Address Generation - In order to reduce pin count, the 82C237 multiplexes the eight higher order address bits on
the data lines. State S1 is used to output the higher order address bits to an external latch from which they may be placed on the address bus. The falling edge of Address Strobe (ADSTB) is used to load these bits from the data lines to the latch. Address Enable (AEN) is used to enable the bits onto the address bus through a three-state enable. The lower order address bits are output by the 82 C 237 directly. Lines A0-A7 should be connected to the address bus. Figure 12 shows the time relationships between CLK, AEN, ADSTB, DBO-DB7 and AO-A7.

During Block and Demand Transfer mode service, which include multiple transfers, the addresses generated will be sequential. For many transfers the data held in the external address latch will remain the same. This data need only change when a carry or borrow from A7 to A8 takes place in the normal sequence of addresses. To save time and speed transfers, the 82 C 237 executes S1 states only when updating of A8-A15 in the latch is necessary. This means for long services, S1 states and Address Strobes may occur only once every 256 transfers, a savings of 255 clock cycles for each 256 transfers.

## Programming

The 82 C 237 will accept programming from the host processor anytime that HLDA is inactive, and at least one rising clock edge has occurred after HLDA went low. It is the responsibility of the host to assure that programming and HLDA are mutually exclusive.
Note that a problem can occur if a DMA request occurs on an unmasked channel while the 82 C 237 is being programmed. For instance, the CPU may be starting to reprogram the two byte Address register of channel 1 when channel 1 receives a DMA request. If the 82 C 237 is enabled (bit 2 in the Command register is 0 ), and channel 1 is unmasked, a DMA service will occur after only one byte of the Address register has been reprogrammed. This condition can be avoided by disabling the controller (setting bit 2 in the Command register) or masking the channel before programming any of its registers. Once the programming is complete, the controller can be enabled/unmasked.

After power-up it is suggested that all internal locations be loaded with some known value, even if some channels are unused. This will aid in debugging.

## Register Description

Current Address Register - Each channel has a 16-bit Current Address register. This register holds the value of the address used during DMA transfers. The address is automatically incremented or decremented by one after each transfer and the values of the address are stored in the Current Address register during the transfer. This register is written or read by the microprocessor in successive 8-bit bytes. See Figure 6 for programming information. It may also be reinitialized by an Autoinitialize back to its original value. Autoinitialize takes place only after an EOP. In memory-to-memory mode, the channel 0 Current Address register can be prevented from incrementing or decrementing by setting the address hold bit in the Command register.

Current Word Count Register - Each channel has a 16-Bit Current Word Count register. This register determines the number of transfers to be performed. The actual number of transfers will be one more than the number programmed in the Current Word Count register (i.e., programming a count of 100 will result in 101 transfers). The word count is decremented after each transfer. When the value in the register goes from zero to FFFFH, a TC will be generated. This register is loaded or read in successive 8-bit bytes by the microprocessor in the Program Condition. See Figure 6 for programming information. Following the end of a DMA service it may also be reinitialized by an Autoinitialization back to its original value. Autoinitialization can occur only when an EOP occurs. If it is not Autoinitialized, this register will have a count of FFFFH after TC.

Base Address and Base Word Count Registers - Each channel has a pair of Base Address and Base Word Count registers. These 16 -bit registers store the original value of their associated current registers. During Autoinitialize these values are used to restore the current registers to their original values. The base registers are written simultaneously with their corresponding current register in 8-bit bytes in the Program Condition by the microprocessor. See Figure 6 for programming information. These registers cannot be read by the microprocessor.

Command Register - This 8-bit register controls the operation of the 82C237. It is programmed by the microprocessor and is cleared by Reset or a Master Clear instruction. The following diagram lists the function of the Command register bits. See Figure 4 for Read and Write addresses.

## Command Register



Mode Register - Each channel has a 6-bit Mode register associated with it. When the register is being written to by the microprocessor in the Program Condition, bits 0 and 1 determine which channel Mode register is to be written. When the processor reads a Mode register, bits 0 and 1 will both be ones. See the following diagram and Figure 4 for Mode register functions and addresses.

## Mode Register



Request Register - The 82 C 237 can respond to requests for DMA service which are initiated by software as well as by a DREQ. Each channel has a request bit associated with it in the 4-bit Request register. These are non-maskable and subject to prioritization by the Priority Encoder network. Each register bit is set or reset separately under software control. The entire register is cleared by a Reset or Master Clear instruction. To set or reset a bit, the software loads the proper form of the data word. See Figure 4 for register address coding, and the following diagram for Request register format. A software request for DMA operation can be made in block or single modes. For memory-to-memory transfers, the software request for channel 0 should be set. When reading the Request register, bits 4-7 will always read as ones, and bits $0-3$ will display the request bits of channels 0-3 respectively.

## Request Register

| 7 6 5 4 3 | \begin{tabular}{\|l|l|l|}
\hline
\end{tabular} |  | Bit Number |
| :---: | :---: | :---: | :---: |
| Don't Care, Write |  |  |  |
|  |  | $\begin{aligned} & 0 \\ & 01 \end{aligned}$ | Select channel 0 Select channel 1 |
| Bits 4-7 |  | 10 | Select channel 2 |
| All Ones, |  | 11 | Select channel 3 |
|  |  | 0 | Reset request bit |
|  |  | , | Set request bit |

Mask Register - Each channel has associated with it a mask bit which can be set to disable an incoming DREQ. Each mask bit is set when its associated channel produces an EOP if the channel is not programmed to Autoinitialize. Each bit of the 4-bit Mask register may also be set or cleared separately or simultaneously under software control. The entire register is also set by a Reset or Master Clear. This disables all hardware DMA requests until a Clear Mask Register instruction allows them to occur. The instruction to separately set or clear the mask bits is similar in form to that used with the Request register. Refer to the following diagram and Figure 4 for details. When reading the Mask register, bits 4-7 will always read as logical ones, and bits 0-3 will display the mask bits of channels 0-3, respectively. The 4 bits of the mask register may be cleared simultaneously by using the Clear Mask Register command (see software commands section).

Mask Register


All four bits of the Mask register may also be written with a single command.


Status Register - The Status register is available to be read out of the 82 C 237 by the microprocessor. It contains information about the status of the devices at this point. This information includes which channels have reached a terminal count and which channels have pending DMA requests. Bits $0-3$ are set every time a TC is reached by that channel or an external EOP is applied. These bits are cleared upon Reset, Master Clear, and on each Status Read. Bits 4-7 are set whenever their corresponding channel is requesting service, regardless of the mask bit state. If the mask bits are set, software can poll the Status register to determine which channels have DREQs, and selectively clear a mask bit, thus allowing user defined service priority. Status bits 4-7 are updated while the clock is high, and latched on the falling edge. Status Bits 4-7 are cleared upon Reset or Master Clear.

## Status Register



Temporary Register - The Temporary register is used to hold data during memory-to-memory transfers. Following the completion of the transfers, the last byte moved can be read by the microprocessor. The Temporary register always contains the last byte transferred in the previous memory-tomemory operation, unless cleared by a Reset or Master Clear.

| OPERATION | A3 | A2 | A1 | AO | $\overline{\text { IOR }}$ | $\overline{\text { IOW }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Status Register | 1 | 0 | 0 | 0 | 0 | 1 |
| Write Command Register | 1 | 0 | 0 | 0 | 1 | 0 |
| Read Request Register | 1 | 0 | 0 | 1 | 0 | 1 |
| Write Request Regıster | 1 | 0 | 0 | 1 | 1 | 0 |
| Read Command Regıster | 1 | 0 | 1 | 0 | 0 | 1 |
| Write Single Mask Bit | 1 | 0 | 1 | 0 | 1 | 0 |
| Read Mode Regıster | 1 | 0 | 1 | 1 | 0 | 1 |
| Write Mode Register | 1 | 0 | 1 | 1 | 1 | 0 |
| Set First/Last F/F | 1 | 1 | 0 | 0 | 0 | 1 |
| Clear First/Last F/F | 1 | 1 | 0 | 0 | 1 | 0 |
| Read Temporary Register | 1 | 1 | 0 | 1 | 0 | 1 |
| Master Clear | 1 | 1 | 0 | 1 | 1 | 0 |
| Clear Mode Reg. Counter | 1 | 1 | 1 | 0 | 0 | 1 |
| Clear Mask Register | 1 | 1 | 1 | 0 | 1 | 0 |
| Read All Mask Bits | 1 | 1 | 1 | 1 | 0 | 1 |
| Write All Mask Bits | 1 | 1 | 1 | 1 | 1 | 0 |

Figure 4. SOFTWARE COMMAND CODES AND REGISTER CODES

## Software Commands

There are special software commands which can be executed by reading or writing to the 82 C 237 . These commands do not depend on the specific data pattern on the data bus, but are activated by the I/O operation itself. On read type commands, the data value is not guaranteed. These commands are:

Clear First/Last Flip-Flop: This command is executed prior to writing or reading new address or word count information to the 82C237. This command initializes the flip-flop to a known state (low byte first) so that subsequent accesses to register contents by the microprocessor will address upper and lower bytes in the correct sequence.

Set First/Last Flip-Flop: This command will set the flipflop to select the high byte first on read and write operations to address and word count registers.

Master Clear: This software instruction has the same effect as the hardware Reset. The Command, Status, Request, and Temporary registers, and Internal First/Last Flip-Flop and mode register counter are cleared and the Mask register is set. The 82 C 237 will enter the Idle cycle.

Clear Mask Register: This command clears the mask bits of all four channels, enabling them to accept DMA requests.

Clear Mode Register Counter: Since only one address location is available for reading the Mode registers, an internal two-bit counter has been included to select Mode registers during read operations. To read the Mode registers, first execute the Clear Mode Register Counter command, then do consecutive reads until the desired channel is read. Read order is channel 0 first, channel 3 last. The lower two bits on all Mode registers will read as ones.

## External EOP Operation

The $\overline{E O P}$ pin is a bidirectional, open drain pin which may be driven by external signals to terminate DMA operation. Because $\overline{E O P}$ is an open drain pin an external pull-up resistor to VCC is required. The value of the external pull-up resistor used should guarantee a rise time of less than 125 ns . It is important to note that the 82 C 237 will not accept external EOP signals when it is in an SI (Idle) state. The controller must be active to latch EXT EOP. Once latched, the EXT $\overline{\mathrm{EOP}}$ will be acted upon during the next S 2 state, unless the 82C237 enters an idle state first. In the latter case, the latched $\overline{\mathrm{EOP}}$ is cleared. External EOP pulses occurring between active DMA transfers in demand mode will not be recognized, since the 82C237 is in an SI state.

## 16-Bit Transfer Mode

The 82C237 is fully software and pin for pin compatible with the 82C37A. Therefore, the 82 C 237 may be used as a faster 82C37A without modifications to software or hardware. The 82C237 may be used as an 82C37A, however, the 82 C 237 has an additional feature in that it may be programmed to perform 16-bit DMA transfers, thus doubling data transfer rate. In 16-bit transfer mode the device operates the same as in normal (8-bit) transfer mode with exceptions noted in this section.

16-Bit Transfer Mode Initialization - To initialize the 82C237 to 16-bit Transfer Mode, a specific sequence of software commands must be written to the device immediately after a hardware Reset or a Master Clear instruction. The sequence to initialize 16-bit Transfer Mode is as follows:

1) Hardware Reset or Master Clear
2) Set First/Last Flip-Flop
3) Clear First/Last Flip-Flop

These software commands must occur sequentially with no communication to or from the 82C237 between commands. Once in 16-bit mode, the device will remain in this mode until a hardware Reset or Master Clear sets it back to normal ( 8 -bit) transfer mode. If this initialization sequence is not followed exactly, the 82 C 237 will operate exactly like the 82C37A or the 82C237 in normal 8-bit mode.
16-Bit DMA Transfers - In 16-bit transfer mode, each DMA channel may be programmed to perform 8-bit or 16-bit transfers. Channels which are programmed to perform 8-bit transfers will operate like a normal 82C37A transfer. On channels programmed to perform 16-bit transfers, the Current Address register, which is normally incremented or decremented by one after each transfer, is incremented or decremented by two after each transfer. Also, the Current Word Count register, which is normally decremented by one after each transfer, is decremented by two after each transfer.

16-Bit Memory-to-Memory Transfers - 16-bit memory-to-memory transfers require an external latch to temporarily store the 8 most significant bits of data. When 16-bit transfer mode is enabled, Pin 5 (DWLE) becomes an active output which may be used to enable the external data latch during memory-to-memory operations. See Figure 9 for a 16-bit DMA application. Channels 0 and 1 operate as memory-to-memory transfer channels. If either channel 0 or channel 1 is programmed to perform 16-bit transfers when a memory-to-memory transfer is initiated, the transfer will be a 16 -bit transfer. If 8 -bit memory-to-memory transfers are desired while the 82C237 is in 16-bit transfer mode, channels 0 and 1 must both be programmed for 8 -bit transfers.
Pin 5 DWLE Output - When the 82C237 is not initialized to 16-bit transfer mode, pin 5 is always high impedance tri-stated. This insures compatibility with the 82C37A pin 5 description. In 16-bit transfer mode, this output becomes active and serves a dual purpose.
During the S1 cycle of a transfer, the DWLE output indicates the data width ( $0=16-\mathrm{bit}, 1=8$-bit) of the active channel. This signal may be used with the AO output to generate a High Byte Enable signal for use in chip select decode logic. Since DWLE is a multiplexed pin, Data Width information needs to be captured in an external latch on the falling edge of ADSTB. See Figure 9 for a 16-bit DMA application.
During memory-to-memory transfers, the DWLE output is used to enable an external latch which temporarily stores the 8 most significant bits of data during the read-frommemory half of the transfer. DWLE enables this byte of data onto the data bus during the write-to-memory half of the transfer. See Figure 9 for a 16-bit DMA application.

If an active channel is cascaded, as defined by its mode register, DWLE will be driven low at the start of the transfer, and will remain low for the entire transfer. This allows the DWLE signal from the slave 82C237 to control the system. To form the system DWLE signal for cascaded 82C237s, simply "OR" the individual DWLE outputs of the Master and Slaves.

## Registers Affected By 16-Bit Transfer Mode

Current Address Register - Each channel has a 16-bit Current Address register. This register holds the value of the address used during DMA transfers. On channels programmed to perform 8-bit DMA transfers, the address is automatically incremented or decremented by one after each transfer. On channels programmed for 16-bit DMA transfers, the address is automatically incremented or decremented by two after each transfer.

During all 16-bit transfers, the AO output will remain low for the entire transfer, even if an odd address is programmed into the channel's Current Address register (i.e. only even word addresses will be generated).
The Current Address register is written or read by the microprocessor in successive 8-bit bytes. See Figure 6 for programming information. It may also be reinitialized by an Autoinitialize back to its original value. Autoinitialize takes place only after an $\overline{\mathrm{EOP}}$. In memory-to-memory mode, the channel 0 Current Address register can be prevented from incrementing or decrementing by setting the address hold bit in the Command register.

Current Word Count Register - Each channel has a 16-bit Current Word Count register. This register determines the number of transfers to be performed. On channels programmed for 8-bit transfers, the actual number of transfers will be one more than the number programmed in the Current Word Count register (i.e. programming a count of 100 will result in 101 transfers). The word count is decremented by one after each transfer on 8-bit transfer channels.

On channels programmed for 16-bit transfers, the word count is decremented by two after each transfer. This means that for even values in the Current Word Count register, the actual number of transfers will be $n / 2+1$, where n is the value in the Current Word Count register. For odd values in this register, the actual number of transfers will be $(n+1) / 2$. When the value in the Current Word Count register decrements past zero (i.e. 0 to FFFEH or 1 to FFFFH), a TC will be generated.

This register is loaded or read in successive 8-bit bytes by the microprocessor in the Program Condition. See Figure 6 for programming information. Following the end of a DMA service it may also be reinitialized by an Autoinitialization back to its original value. Autoinitialization can occur only when an $\overline{E O P}$ occurs. If it is not Autoinitialized, this register will have a count of FFFFH after TC on 8-bit transfers, or FFFEH after TC on 16-bit transfers.
Data-Width Register - When 16-bit transfer mode is enabled, the Data-Width register becomes accessible and is used to program each DMA channel to perform either

8-bit transfers or 16-bit transfers. Data bits 4-7 represent DREQ channels $0-3$ respectively and determine the data width (8-bit or 16 -bit) of each channel during DMA transfers. When programming this register, bit 3 of the data must be set to " 0 ". Since the address of the Data-Width register is the same as the Mask register, bit 3 selects which register is actually written.
Data-Width Register - 16-bit transfer mode enabled

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |$\quad$| Bit Number |
| :--- |

Mask Register - In 16-bit transfer mode this register operates the same as the previous Mask register description with the exception of bit 3 when writing the instruction to separately set or clear a mask bit. Bit 3 of the data must be " 1 " when writing a single mask bit. Bits 4-7 are ignored when this instruction is written. Refer to the following diagram for writing single mask bits.

Mask Register - 16-bit transfer mode enabled


The software command to write all four bits of the Mask register has no affect on the state of the Data-Width bits.

When reading the Mask/Data-Width register (they share the same address), bits $0-3$ will always display the mask bits of channels $0-3$, respectively. With 16-bit transfer mode not enabled, bits 4-7 will always read as logical ones. With 16-bit transfer mode enabled, bits 4-7 will display the data-width bits for channels 0-3 respectively.

The Mask and Data-Width registers are set by Reset or Master Clear. This disables all hardware DMA requests until a clear mask bit instruction allows them to be recognized. Reset or Master Clear forces the Mask and Data-Width registers to operate as in normal mode (Data-Width register not accessible) until 16-bit transfer mode is again entered. The four mask bits may also be cleared simultaneously by using the Clear Mask Register command (see software commands section). This command has no effect on the data-width bits.

Temporary Register - The internal Temporary register is used to hold data during memory-to-memory transfers. Following the completion of the transfers, the last byte moved can be read by the microprocessor. In the case of 16-bit transfers, only the least significant 8 bits of the last word transferred are stored in this register. The Temporary register always contains the last byte transferred in the previous memory-to-memory operation, unless cleared by a Reset or Master Clear.

## Software Commands Affected by 16-Bit Mode

Master Clear: This software instruction has the same effect as the hardware Reset. The Command, Status, Request, and Temporary registers, and Internal First/Last Flip-Flop and mode register counter are cleared and the Mask register is set. When the Master Clear instruction occurs while in 16-bit transfer mode, the 82C237 enters normal (8-bit) transfer mode in the Idle cycle.
Clear Mask Register: This command clears the mask bits of all four channels, enabling them to accept DMA requests. This command has no effect on data-width bits in 16-bit transfer mode.

| OPERATION | A3 | A2 | A1 | AO | $\overline{\text { IOR }}$ | $\overline{10 W}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Status Register | 1 | 0 | 0 | 0 | 0 | 1 |
| Write Command Register | 1 | 0 | 0 | 0 | 1 | 0 |
| Read Request Register | 1 | 0 | 0 | 1 | 0 | 1 |
| Write Request Register | 1 | 0 | 0 | 1 | 1 | 0 |
| Read Command Register | 1 | 0 | 1 | 0 | 0 | 1 |
| Write Single Mask Bit (Note 1) | 1 | 0 | 1 | 0 | 1 | 0 |
| Write All Data-Width Bits (Notes 1, 2) | 1 | 0 | 1 | 0 | 1 | 0 |
| Read Mode Register | 1 | 0 | 1 | 1 | 0 | 1 |
| Write Mode Register | 1 | 0 | 1 | 1 | 1 | 0 |
| Set First/Last F/F | 1 | 1 | 0 | 0 | 0 | 1 |
| Clear First/Last F/F | 1 | 1 | 0 | 0 | 1 | 0 |
| Read Temporary Register | 1 | 1 | 0 | 1 | 0 | 1 |
| Master Clear | 1 | 1 | 0 | 1 | 1 | 0 |
| Clear Mode Reg. Counter | 1 | 1 | 1 | 0 | 0 | 1 |
| Clear Mask Register | 1 | 1 | 1 | 0 | 1 | 0 |
| Read All Mask/Data-Width Bits (Note 2) | 1 | 1 | 1 | 1 | 0 | 1 |
| Write All Mask Bits | 1 | 1 | 1 | 1 | 1 | 0 |

NOTES 1 The register to be written is determined by data bit 3
2 Data-Width bits exist in 82C237, 16-bit mode only.
FIGURE 5. 16-BIT MODE SOFTWARE COMMAND CODES AND REGISTER CODES

| CHANNEL | REGISTER | OPERATION | SIGNALS |  |  |  |  |  |  | FIRST/LAST FLIP-FLOP STATE | $\begin{aligned} & \text { DATA BUS } \\ & \text { DB0-DB7 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\overline{\mathrm{CS}}$ | $\overline{\text { IOR }}$ | $\overline{10 W}$ | A3 | A2 | A1 | AO |  |  |
| 0 | Base and Current | Write | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | AO-A7 |
|  | Address |  | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | AO-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | A8-A15 |
|  | Base and Current | Write | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | W0-W7 |
|  | Word Count |  | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | W8-W15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | Wo-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | W8-W15 |
| 1 | Base and Current | Write | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | AO-A7 |
|  | Address |  | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | AO-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | A8-A15 |
|  | Base and Current | Write | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | Wo-W7 |
|  | Word Count |  | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | W8-W15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | W8-W15 |
| 2 | Base and Current | Write |  |  | $0$ | $0$ |  | 0 | $0$ | $0$ |  |
|  | Address |  | $0$ | $1$ | $0$ | 0 | $1$ | 0 | 0 | $1$ | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | AO-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | A8-A15 |
|  | Base and Current | Write | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | W0-W7 |
|  | Word Count |  | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | W8-W15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | Wo-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | W8-W15 |
| 3 | Base and Current | Write | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | AO-A7 |
|  | Address |  | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | AO-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | A8-A15 |
|  | Base and Current | Write | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | W0-W7 |
|  | Word Count |  | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | W8-W15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | W8-W15 |

FIGURE 6. WORD COUNT AND ADDRESS REGISTER COMMAND CODES

## Application Information

Figure 7 shows an application for a DMA system utilizing the 82 C 237 DMA controller and the 80 C 88 Microprocessor. In this application, the 82C237 DMA controller is used to improve system performance by allowing an I/O device to transfer data directly to or from system memory.

## Components

The system clock is generated by the 82C84A clock driver and is inverted to meet the clock high and low times required by the 82C237 DMA controller. The four OR gates are used to support the 80C88 Microprocessor in minimum mode by producing the control signals used by the processor to access memory or I/O. A decoder is used to generate chip select for the DMA controller and memory. The most significant bits of the address are output on the address/ data bus. Therefore, the 82C82 octal latch is used to demultiplex the address. Hold Acknowledge (HLDA) and

Address Enable (AEN) are "ORed" together to insure that the DMA controller does not have bus contention with the microprocessor.

## Operation

A DMA request (DREQ) is generated by the I/O device. After receiving the DMA request, the DMA controller will issue a Hold request (HRQ) to the processor. The system busses are not released to the DMA controller until a Hold Acknowledge signal is returned to the DMA controller from the $80 C 88$ processor. After the Hold Acknowledge has been received, addresses and control signals are generated by the DMA controller to accomplish the DMA transfers. Data is transferred directly from the I/O device to memory (or vice versa) with $\overline{\mathrm{IOR}}$ and $\overline{\mathrm{MEMW}}$ (or $\overline{\mathrm{MEMR}}$ and $\overline{\mathrm{OWW}}$ ) being active. Note that data is not read into or driven out of the DMA controller in I/O-to-memory or memory-to-1/O data transfers.

NOTE The address lines need pull-up resistors.
FIGURE 7. APPLICATION FOR DMA SYSTEM

Figure 8 shows an application for a DMA system using the 82C37A or 82C237 DMA controller and the 80C286 Microprocessor.

In this application, the system clock comes from the 82 C 284 clock generator PCLK signal which is inverted to provide proper READY setup and hold times to the DMA controller in an 80C286 system. The Read and Write signals from the DMA controller may be wired directly to the Read/Write control signals from the 82C288 Bus

Controller. The octal latch for A8 - A15 from the DMA controller's data bus is on the local 80 C 286 address bus so that memory chip selects may still be generated during DMA transfers. The transceiver on AO - A7 is controlled by AEN and is not necessary, but may be used to drive a heavily loaded system address bus during transfers. The data bus transceivers simply isolate the DMA controller from the local microprocessor bus and allow programming on the upper or lower half of the data bus.


FIGURE 8. 80C286 DMA APPLICATION

Figure 9 shows the data bus for a 16-bit DMA application with the 82C237. High memory and low memory are selected accordingly with AO and the $8 / 16$ signal during DMA transfers. The $8 / 16$ signal is formed from DWLE with a D flip-flop and ADSTB. ADSTB must be inverted to the D flip-flop since DWLE is set up to the falling edge of ADSTB and the 74F74 latches data on the rising edge of CLK.

The ADSTB inverted could be eliminated by using a 74F75 falling edge D latch. The latch on D8 - D15 is needed for 16-bit memory-to-memory transfers. The upper eight bits of data are latched by $\overline{M E M R}$ during the read half of the transfer. The data is then enabled onto the data bus during the write half of the transfer.

*Only needed for memory-to-memory transfers
FIGURE 9. DATA BUS FOR 16 BIT DMA APPLICATION

Absolute Maximum Ratings


## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $28^{\circ} \mathrm{C} / \mathrm{W}$ | $6^{\circ} \mathrm{C} / \mathrm{W}$ |
| LCC Package | $66^{\circ} \mathrm{C} / \mathrm{W}$ | $12^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe |  | 1 Watt |
| Gate Count |  | 2325 Gates |

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.

## Operating Conditions


D.C. Electrical Specifications $\mathrm{VCC}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 237)$
$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 237 )
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C237)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| VIH | Logical One Input Voltage | $\begin{array}{c}2.0 \\ 2.2\end{array}$ | - | - | V |
| V |  |  |  |  |  |$]$| $\mathrm{C} 82 \mathrm{C} 237,182 \mathrm{C} 237$ |
| :--- |
| $\mathrm{M82C237}$ |,

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPE | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | 20 | pF |  |
| COUT | Output Capacitance | 20 | pF |  |
| CI/O | I/O Capacitance | 20 | pF |  |

## A.C. Electrical Specifications $\mathrm{VCC}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}$, <br> $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C237), <br> $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(182 \mathrm{C} 237)$, <br> $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C237)

| SYMBOL | PARAMETER | 82 C 237 |  | 82C237-12 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| DMA (MASTER) MODE |  |  |  |  |  |  |
| (1) TAEL | AEN HIGH from CLK LOW (S1) Delay Time | - | 105 | - | 50 | ns |
| (2)TAET | AEN LOW from CLK HIGH (SI) Delay Time | - | 80 | $\bullet$ | 50 | ns |
| (3) TAFAB | ADR Active to Float Delay from CLK HIGH | - | 55 | - | 55 | ns |
| (4)TAFC | $\overline{\text { READ }}$ or $\overline{\text { WRITE }}$ Float Delay from CLK HIGH | - | 75 | - | 50 | ns |
| (5)TAFDB | DB Active to Float Delay from CLK HIGH | - | 135 | - | 90 | ns |
| (6)TAHR | ADR from $\overline{\text { READ }}$ HIGH Hold Time | TCY-75 | - | TCY-65 | - | ns |
| (7)TAHS | DB from ADSTB LOW Hold Tıme | TCL-18 | - | TCL-18 | - | ns |
| (8)TAHW | ADR from WRITE HIGH Hold Time | TCY-65 | - | TCY-50 | - | ns |
| (9)TAK | DACK Valid from CLK LOW Delay Time | - | 105 | - | 69 | ns |
|  | $\overline{\mathrm{EOP}}$ HIGH from CLK HIGH Delay Time | - | 105 | - | 90 | ns |
|  | $\overline{\text { EOP }}$ LOW from CLK HIGH Delay Time | - | 60 | - | 35 | ns |
| (10)TASM | ADR Stable from CLK HIGH | - | 60 | - | 50 | ns |
| (11)TASS | DB to ADSTB LOW Setup Time | TCH-20 | - | TCH-20 | - | ns |
| (12) TCH | Clock HIGH Tıme (Transitions 10ns) | 55 | - | 30 | - | ns |
| (13) TCL | Clock LOW Time (Transitoons 10ns) | 43 | - | 30 | - | ns |
| (14)TCY | CLK Cycle Time | 125 | - | 80 | - | ns |
| (15)TDCL | CLK HIGH to $\overline{\text { READ }}$ or WRITE LOW Delay | - | 130 | - | 120 | ns |
| (16)TDCTR | $\begin{aligned} & \overline{\text { READ }} \text { HIGH from CLK HIGH (S4) Delay } \\ & \text { Time } \end{aligned}$ | - | 115 | - | 80 | ns |
| (17)TDCTW | $\overline{\text { WRITE }}$ HIGH from CLK HIGH (S4) Delay Time | - | 80 | - | 70 | ns |
| (18)TDQ | HRQ Valid from CLK HIGH Delay Time | 1 | 75 | - | 30 | ns |
| (19)TEPH | $\overline{\text { EOP }}$ Hold TIme from CLK LOW (S2) | 90 | - | 50 | - | ns |
| (20)TEPS | $\overline{\text { EOP }}$ LOW to CLK LOW Setup Time | 25 | - | 0 | - | ns |
| (21)TEPW | $\overline{\text { EOP }}$ Pulse Width | 135 | - | 50 | - | ns |
| (22)TFAAB | ADR Valid Delay from CLK HIGH | - | 60 | - | 50 | ns |
| (23)TFAC | $\overline{\text { READ }}$ or $\overline{\text { WRITE }}$ Active from CLK HIGH | - | 90 | - | 50 | ns |
| (24)TFADB | DB Valid Delay from CLK HIGH | - | 60 | - | 45 | ns |
| (25)THS | HLDA Valid to CLK HIGH Setup Time | 45 | - | 10 | - | ns |

A.C. Electrical Specifications $\mathrm{VCC}=+5.0 \mathrm{~V} \pm 10 \%$, GND $=0 \mathrm{~V}$, (Continued)
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C237),
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (182C237),
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C237)

| SYMBOL | PARAMETER | 82C237 |  | 82C237-12 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| DMA (MASTER) MODE (Continued) |  |  |  |  |  |  |
| (26)TIDH | Input Data from $\overline{\text { MEMR }}$ HIGH Hold Time | 0 | - | 0 | - | ns |
| (27)TIDS | Input Data to $\overline{\text { MEMR }}$ HIGH Setup Time | 90 | - | 45 | - | ns |
| (28)TODH | Output Data from MEMW HIGH Hold Time | 15 | - | TCY-50 | - | ns |
| (29)TODV | Output Data Valıd to $\overline{\text { MEMW }}$ HIGH | TCY-35 | - | TCY-10 | - | ns |
| (30)TQS | DREQ to CLK LOW (SI, S4) Setup Time | 0 | - | 0 | - | ns |
| (31)TRH | CLK to READY LOW Hold Time | 20 | - | 10 | - | ns |
| (32)TRS | READY to CLK LOW Setup Time | 35 | - | 15 | - | ns |
| (33)TCLSH | ADSTB HIGH from CLK LOW Delay Time | - | 70 | - | 70 | ns |
| (34)TCLSL | ADSTB LOW from CLK LOW Delay Time | - | 120 | - | 60 | ns |
| (35)TWRRD | $\overline{\text { READ }}$ HIGH Delay from $\overline{\text { WRITE }}$ HIGH | 0 | - | 5 | - | ns |
| (36)TRLRH | $\overline{\text { READ }}$ Pulse Width, Normal Timing | 2TCY-60 | - | 2TCY-55 | - | ns |
| (37)TSHSL | ADSTB Pulse Width | TCY-50 | - | TCY-35 | - | ns |
| (38)TWLWHA | Extended $\overline{\text { WRITE }}$ Pulse Width | 2TCY-85 | - | 2TCY-80 | - | ns |
| (39)TWLWH | WRITE Pulse Width | TCY-85 | - | TCY-80 | - | ns |
| (40)TRLRHC | $\overline{\text { READ }}$ Pulse Width, Compressed | TCY-60 | - | TCY-55 | - | ns |
| (56)TAVRL | ADR Valid to $\overline{\text { READ }}$ LOW | 17 | - | 17 | - | ns |
| (57)TAVWL | ADR Valid to $\overline{\text { WRITE }}$ LOW | 7 | - | 7 | - | ns |
| (58)TRHAL | $\overline{\text { READ }}$ HIGH to AEN LOW | 15 | - | 15 | - | ns |
| (59)TRHSH | $\overline{\text { READ }}$ HIGH to ADSTB HIGH | 13 | - | 13 | - | ns |
| (60)TWHSH | $\overline{\text { WRITE }} \mathrm{HIGH}$ to ADSTB HIGH | 15 | - | 15 | - | ns |
| (61)TDVRL | DACK Valid to $\overline{\text { READ }}$ LOW | 25 | - | 25 | - | ns |
| (62)TDVWL | DACK Valid to WRITE LOW | 25 | - | 25 | - | ns |
| (63)TRHDI | $\overline{\text { READ }}$ HIGH to DACK Inactive | 12 | - | 12 | - | ns |
| (64)TAZRL | ADR Float to $\overline{\text { READ }}$ LOW | -2.5 | - | -2.5 | - | ns |
| (65)TOEV | Output Enable Valid Before $\overline{\text { WRITE }}$ HIGH | TCY +20 | - | TCY +20 | - | ns |
| (66)TOEH | Output Enable Hold Time from WRITE HIGH | TCY-50 | - | TCY-50 | - | ns |


| A.C. Electrical Specifications$\begin{aligned} & \text { VCC }=+5.0 \mathrm{~V} \pm 10 \%, G N D=0 \mathrm{~V}, \quad \text { (Continued) } \\ & T_{A}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 237), \\ & T_{A}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(182 \mathrm{C} 237), \\ & T_{A}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\text { M } 82 \mathrm{C} 237) \end{aligned}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PARAMETER | 82C237 |  | 82C237-12 |  | UNITS |
| SYMBOL |  | MIN | MAX | MIN | MAX |  |
| PERIPHERAL (SLAVE) MODE |  |  |  |  |  |  |
| (41)TAR | ADA Valid or $\overline{\mathrm{CS}}$ LOW to $\overline{\text { READ }}$ LOW | 10 | - | 0 | - | ns |
| (42)TAWL | ADR Valid to $\overline{\text { WRITE }}$ LOW Setup Time | 0 | - | 0 | - | ns |
| (43)TCWL | $\overline{\mathrm{CS}}$ LOW to $\overline{\text { WRITE }}$ LOW Setup Time | 0 | - | 0 | - | ns |
| (44)TDW | Data Valid to WRITE HIGH Setup Time | 100 | - | 60 | - | ns |
| (45)TRA | ADR or $\overline{\mathrm{CS}}$ Hold from $\overline{\text { READ }}$ HIGH | 0 | - | 0 | - | ns |
| (46)TRDE | Data Access from $\overline{\mathrm{READ}}$ | - | 120 | - | 80 | ns |
| (47)TRDF | DB Float Delay from $\overline{\text { READ }}$ HIGH | 5 | 85 | 5 | 55 | ns |
| (48)TRSTD | Power Supply HIGH to RESET LOW Setup Time | 500 | - | 500 | - | ns |
| (49)TRSTS | RESET to First $\overline{\mathrm{IOR}}$ or $\overline{\mathrm{IOW}}$ | 2TCY | - | 2TCY | - | ns |
| (50)TRSTW | RESET Pulse Width | 300 | - | 300 | - | ns |
| (51)TRW | $\overline{\text { READ Pulse Width }}$ | 155 | - | 85 | - | ns |
| (52)TWA | ADR from $\overline{\text { WRITE }}$ HIGH Hold Time | 0 | - | 0 | - | ns |
| (53)TWC | $\overline{\overline{C S}}$ HIGH from $\overline{\text { WRITE }}$ HIGH Hold Time | 0 | $\bullet$ | 0 | - | ns |
| (54)TWD | Data from $\overline{\text { WRITE }}$ HIGH Hold Time | 10 | - | 10 | - | ns |
| (55)TWWS | $\overline{\text { WRITE Pulse Width }}$ | 100 | - | 45 | - | ns |

## Waveforms

SLAVE MODE WRITE TIMING


FIGURE 10. SLAVE MODE TIMING

NOTE: Successive WRITE accesses to the 82C237 must allow at least TCY as recovery time between accesses. A TCY recovery time must be allowed before executing a WRITE access after a READ access.

SLAVE MODE READ TIMING


FIGURE 11. SLAVE MODE READ

NOTE: Successive READ accesses to the $82 C 237$ must allow at least TCY as recovery tıme between accesses A TCY recovery time must be allowed before executing a WRITE access after a READ access.

## Waveforms

DMA TRANSFER TIMING


FIGURE 12. DMA TRANSFER

[^11]
## Waveforms

MEMORY-TO-MEMORY TRANSFER TIMING


FIGURE 13. MEMORY-TO-MEMORY TRANSFER
*For 16 -bit mode, 82 C 237 only. In 8-bit mode this signal is always high impedance tri-stated. Waveform shown is for a 16 -bit memory-to-memory transfer. For an 8-bit transfer in 16-bit mode, DWLE will go high at least TASS before the falling edge of ADSTB in S2, then low TAHS after the falling edge of ADSTB, and will remain low until the next ADSTB where the cycle is repeated.

## Waveforms

READY TIMING


FIGURE 14. READY

NOTE: READY must not transition during the specified setup and hold times.

## COMPRESSED TRANSFER TIMING



FIGURE 15. COMPRESSED TRANSFER


FIGURE 16. RESET
A.C. Test Circuits

*Includes STRAY and FIXTURE Capacitance

TEST CONDITION DEFINITION TABLE

| PINS | V1 | R1 | $\mathbf{C 1}$ |
| :--- | :---: | :---: | :---: |
| All Outputs Except EOP | 1.7 V | $520 \Omega$ | 100 pF |
| EOP | VCC | $1.6 \mathrm{~K} \Omega$ | 50 pF |

A.C. Testing Input, Output Waveforms

| $\frac{\text { INPUT }}{}$ | OUTPUT |
| :---: | :---: |
| $\mathrm{VIH}+0.4 \mathrm{VOH}$ |  |
| 1.5 V | 1.5 V |



OUTPUT
L OR H $\rightarrow$ Z

A.C. Testing: All A.C. Parameters tested as per test circuits. Input RISE and FALL times are driven at InsN.

82C284

## Clock Generator and Ready Interface for 80C286 Processors

## Features

- Generates System Clock for 80C286 Processors
- Generates System Reset Output from Schmitt Trigger Input
- Improved Hysteresis
- Uses Crystal or External Signal for Frequency Source
- Dynamically Switchable between Two Input Frequencies
- Provides Local $\overline{\text { READY }}$ and MULTIBUS ${ }^{\circledR}$ ( $\overline{\text { READY }}$ Synchronization
- Static CMOS Technology
- Single +5V Power Supply
- Available in 18 Lead Cerdip Package


## Description

The Harris 82C284 is a clock generator/driver which provides clock signals for 80 C 286 processors and support components. It also contains logic to supply READY to the CPU from either asynchronous or synchronous sources and synchronous RESET from an asynchronous input with hysteresis.

Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | $\mathbf{1 0 M H z}$ | $\mathbf{1 2 . 5 M H z}$ |
| :---: | :---: | :--- | :--- |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | - | CD82C284-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C284-10 | ID82C284-12 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C284- <br> $10 / 883$ | MD82C284- <br> $12 / 883$ |

* Respective /883 specifications are included at the end of this data sheet.


## Pinout



TOP VIEW


Functional Diagram


Pin Description The following pin function descriptions are for the 82C284 clock generator.
TABLE 1. PIN DESCRIPTION

| PIN SYMBOL | NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| CLK | 10 | 0 | SYSTEM CLOCK: the signal used by the processor and support devices which must be synchronous with the processor. The frequency of the CLK output has twice the desired internal processor clock frequency. CLK can drive both TTL and CMOS CMOS level inputs. |
| F/ $\bar{C}$ | 6 | I | FREQUENCY/CRYSTAL SELECT: this pin selects the source for the CLK output. When there is a LOW level on this input, the internal crystal oscillator drives CLK. When there is a HIGH level on F/ $\bar{C}$, the EFI input drives the CLK input. This pin can be dynamically switched, which allows changing the processor CLK frequency while running for low-power operation, etc. |
| $\mathrm{x} 1, \mathrm{X} 2$ | 7, 8 | 1 | CRYSTAL IN: the pins to which a parallel resonant, fundamental mode crystal is attached for the internal oscilator. When F/C is LOW, the internal oscillator will drive the CLK output at the crystal frequency. The crystal frequency must be twice the desired internal processor clock frequency. |
| EFI | 5 | I | EXTERNAL FREQUENCY IN: drives CLK when the F/C input frequency must be twice the desired internal processor clock frequency. |
| PCLK | 13 | 0 | PERIPHERAL CLOCK: the output which provides a $50 \%$ duty cycle clock with one-half the frequency of CLK. PCLK will be in phase with the internal processor clock following the first bus cycle after the processor has been reset. |
| $\overline{\text { ARDYEN }}$ | 17 | 1 | ASYNCHRONOUS READY ENABLE: an active LOW input which qualifies the $\overline{\mathrm{ARDY}}$ input. $\overline{\text { ARDYEN }}$ selects $\overline{\text { ARDY }}$ as the source of $\overline{\text { READY }}$ for the current bus cycle. Inputs to ARDYEN may be applied asynchronously to CLK. Setup and hold times are given to assure a guaranteed response to synchronous outputs. |
| $\overline{\text { ARDY }}$ | 1 | 1 | ASYNCHRONOUS READY: an active LOW input used to terminate the current bus cycle. The $\overline{\text { ARDY }}$ input is qualified by $\overline{\text { ARDYEN. Inputs to } \overline{\text { ARDY }} \text { may be applied }}$ asynchronously to CLK. Setup and hold times are given to assure a guaranteed response to synchronous outputs. |
| $\overline{\text { SRDYEN }}$ | 3 | 1 | SYNCHRONOUS READY ENABLE: an active LOW input which qualifies $\overline{\text { SRDY }}$. $\overline{\text { SRDYEN selects } \overline{\text { SRDY }} \text { as the source for } \overline{\text { READY }} \text { to the CPU for the }}$ current bus cycle. Setup and hold time must be satisfied for proper operation. |
| $\overline{\text { SRDY }}$ | 2 | 1 | SYNCHRONOUS READY: an active LOW input used to terminate the current bus cycle. The SRDY input is qualified by the SRDYEN input. Setup and hold time must be satisfied for proper operation. |
| $\overline{\text { READY }}$ | 4 | 0 | READY: an active LOW output which signals to the processor that the current bus cycle is to be completed. The $\overline{\text { SRDY }} \overline{\text { SRDYEN }}, \overline{\mathrm{ARDY}}, \overline{\mathrm{ARDYEN}}, \overline{\mathrm{S} 1}$, $\overline{S O}$, and $\overline{\operatorname{RES}}$ inputs control $\overline{\operatorname{READY}}$ as explained later in the $\overline{\operatorname{READY}}$ generator section. READY is an open drain output requiring an external pull-up resistor. |
| $\overline{\mathrm{So}}, \overline{\mathrm{S} 1}$ | 15,16 | I | STATUS: these inputs prepare the 82C284 for a subsequant bus cycle. $\overline{\mathrm{SO}}$ and $\overline{\mathrm{S} 1}$ synchronize PCLK to the internal processor clock and control READY. Setup and hold times must be satisfied for proper operation. |
| RESET | 12 | 0 | RESET: an active HIGH output which is derived from the $\overline{\text { RES }}$ input. RESET is used to force the system into an initial state. When RESET is active, $\overline{\text { READY }}$ will be active (LOW). |
| $\overline{\mathrm{RES}}$ | 11 | 1 | RESET IN: an active LOW input which generates the system reset signal (RESET). Signals to RES may be applied asynchronously to CLK. A Schmitt trigger input is provided on RES, so that an RC circuit can be used to provide a time delay. Setup and hold times are given to assure a guaranteed response to synchronous inputs. |
| $\mathrm{V}_{\mathrm{CC}}$ | 18 |  | SYSTEM POWER: The +5 V Power Supply Pin. A $0.1 \mu$ F capacitor between $V_{C C}$ and GND is recommended for decoupling. |
| GND | 9 |  | SYSTEM GROUND: OV |

## Functional Description

## INTRODUCTION

The 82C284 generates the clock, ready, and reset signals required for 80 C 286 processors and support components. The 82C284 is packaged in an 18-pin DIP and contains a crystal controlled oscillator, clock generator, peripheral clock generator, MULTIBUS ${ }^{\oplus}$ ready synchronization logic, and system reset generation logic.

## CLOCK GENERATOR

The CLK output provides the basic timing control for an 80C286 system. CLK has output characteristics sufficient to drive CMOS devices. CLK is generated by either an internal crystal oscillator, or an external source as selected by the $F / \bar{C}$ input pin. When $F / \bar{C}$ is LOW, the crystal oscillator drives the CLK output. When F/ $\overline{\mathrm{C}}$ is HIGH, the EFI input drives the CLK output.

The $F / \bar{C}$ pin on the Harris 82C284 is dynamically switchable. This allows the CLK frequency to the processor to be changed from one frequency to another in a running system. With this feature, a system can be designed which operates at maximum speed when needed, and then dynamically switched to a lower frequency to implement a low-power mode. The lower frequency can be anything down to, but excluding, D.C. The following 3 conditions apply when dynamically switching the $F / \overline{\mathrm{C}}$ pin (see Figure 1):

1) The CLK is stretched in the low portion of the $\phi 2$ phase of it's cycle during transition from one CLK frequency to the other (see Waveforms).
2) When switching CLK frequency sources, there is a maximum transition latency of 2.5 clock cycles of the frequency being switched to, from the time CLK freezes low, until CLK restarts at the new frequency (see Waveforms).
3) The maximum latency from the time $F / \bar{C}$ is dynamically switched, to the time CLK freezes low, is 4 CLK cycles (see Waveforms).

The following steps describe the sequence of events that transpire when $F / \bar{C}$ is dynamically switched:
(A) $F / \bar{C}$ switched from high (using EFI input) to low (using the crystal input X1 - see Figure 1A).

1) The state of $F / \bar{C}$ is sampled when both CLK and PCLK are high until a change is detected.
2) On the second following falling edge of PCLK, CLK is frozen low.
3) CLK restarts at the crystal frequency on the rising edge of X 1 , after the second falling edge of X1.
(B) $F / \bar{C}$ switched from low (using the crystal input $X 1$ ) to high (using the EFI input - see Figure 1B).
4) The state of $F / \bar{C}$ is sampled when both CLK and PCLK are high until a change is detected.
5) On the second following falling edge of PCLK, CLK is frozen low.
6) CLK restarts at the EFI input frequency on the falling edge of EFI after the second rising edge of EFI.

(A) $F / \bar{C}$ SWITCHED FROM HIGH (USING EFI INPUT) TO LOW (USING THE CRYSTAL INPUT X1)

(B) F/C̄ SWITCHED FROM LOW (USING THE CRYSTAL INPUT X1) TO HIGH (USING THE EFI INPUT)

FIGURE 1. DYNAMICALLY SWITCHING THE F/C̄ PIN

The 82C284 provides a second clock output, PCLK, for peripheral devices. PCLK is CLK divided by two. PCLK has a duty cycle of $50 \%$ and CMOS output drive characteristics. PCLK is normally synchronized to the internal processor clock.

After reset, the PCLK signal may be out of phase with the internal processor clock. The $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 0}$ signals of the first bus cycle are used to synchronize PCLK to the internal processor clock. The phase of the PCLK output changes by extending its HIGH time beyond one system clock (see Waveforms). PCLK is forced HIGH whenever either $\overline{\mathrm{SO}}$ or $\overline{\mathrm{S} 1}$ were active (LOW) for the two previous CLK cycles. PCLK continues to oscillate when both $\overline{\mathrm{SO}}$ and $\overline{\mathrm{S} 1}$ are HIGH.

Since the phase of the internal processor clock will not change except during reset, the phase of PCLK will not change except during the first bus cycle after reset.

## OSCILLATOR

The oscillator circuit of the 82C284 is a linear Pierce oscillator which requires an external parallel resonant, fundamental mode, crystal. The output of the oscillator is internally buffered. The crystal frequency chosen should be twice the required internal processor clock frequency. The crystal should have a typical load capacitance of 32 pF .

X1 and X2 are the oscillator crystal connections. For stable operation of the oscillator, two loading capacitors are recommended, as shown in Table 2. The sum of the board capacitance and loading capacitance should equal the values shown. It is advisable to limit stray board capacitances (not including the effect of the loading capacitors or crystal capacitance) to less than 10 pF between the X1 and X2 pins. Decouple VCC and GND as close to the 82 C 284 as possible with a $0.1 \mu \mathrm{~F}$ polycarbonate capacitor.

TABLE 2. 82C284 CRYSTAL LOADING CAPACITANCE VALUES

| CRYSTAL <br> FREQUENCY | C1 <br> CAPACITANCE <br> (PIN 7) | C2 <br> CAPACITANCE <br> (PIN 8) |
| :--- | :---: | :---: |
| 1 to 8 MHz | 60 pF | 40 pF |
| 8 to 20 MHz | 25 pF | 15 pF |
| 20 to 25 MHz | 15 pF | 15 pF |

## CLK TERMINATION

Due to the CLK output having a very fast rise and fall time, it is recommended to properly terminate the CLK line at frequencies above 10 MHz to avoid signal reflections and ringing. Termination is accomplished by inserting a small resistor (typically $10-74 \Omega$ ) in series with the output, as shown in Figure 2. This is known as series termination. The resistor value plus the circuit output impedance (approximately $25 \Omega$ ) should be made equal to the impedance of the transmission line.


FIGURE 2. SERIES TERMINATION

## RESET OPERATION

The reset logic provides the RESET output to force the system into a known, initial state. When the RES input is active (LOW), the RESET output becomes active (HIGH), $\overline{\text { RES }}$ is synchronized internally at the falling edge of CLK before generating the RESET output (see Waveforms). Synchronization of the $\overline{\operatorname{RES}}$ input introduces a one or two CLK delay before affecting the RESET Output.

At power up, a system does not have a stable $\mathrm{V}_{\mathrm{CC}}$ and CLK. To prevent spurious activity, $\overline{\operatorname{RES}}$ should be asserted until $\mathrm{V}_{\mathrm{CC}}$ and CLK stabilize at their operating values. 80C286 processors and support components also require their RESET inputs be HIGH a minimum of 16 CLK cycles. An RC network, as shown in Figure 3, will keep $\overline{\text { RES }}$ LOW long enough to satisfy both needs.
A Schmitt trigger input with hysteresis on $\overline{\operatorname{RES}}$ assures a single transition of RESET with an RC circuit on $\overline{\text { RESS }}$. The hysteresis separates the input voltage level at which the circuit output switches from HIGH to LOW from the input voltage level at which the circuit output switches from LOW to HIGH. The $\overline{\text { RES }}$ HIGH to LOW input transition voltage is lower than the $\overline{\text { RES }}$ LOW to HIGH input transition voltage. As long as the slope of the $\overline{\mathrm{RES}}$ input voltage remains in the same direction (increasing or decreasing) around the $\overline{\operatorname{RES}}$ input transition voltage, the RESET output will make a single transition.


FIGURE 3. TYPICAL RC $\overline{\text { RES }}$ timing CIRCUIT

## READY OPERATION

The 82C284 accepts two ready sources for the system ready signal which terminates the current bus cycle. Either a synchronous ( $\overline{\mathrm{SRDY}}$ ) or asynchronous ready ( $\overline{\mathrm{ARDY}}$ ) source may be used. Each ready input has an enable (SRDYEN and $\overline{\text { ARDYEN }}$ ) for selecting the type of ready source required to terminate the current bus cycle. An address decoder would normally select one of the enable inputs.
$\overline{\text { READY }}$ is enabled (LOW), if either $\overline{\text { SRDY }}+\overline{\text { SRDYEN }}=0$ or $\overline{\text { ARDY }}+\overline{\text { ARDYEN }}=0$ when sampled by the 82C284 $\overline{\text { READY }}$ generation logic. $\overline{\text { READY }}$ will remain active for at least two CLK cycles.

The $\overline{\text { READY }}$ output has an open-drain driver allowing other ready circuits to be wire or'ed with it, as shown in Figure 4. The $\overline{\operatorname{READY}}$ signal of an 80 C 286 system requires an external pull-up resistor. To force the $\overline{\text { READY }}$ signal inactive (HIGH) at the start of a bus cycle, the


FIGURE 4. RECOMMENDED CRYSTAL AND READY CONDITIONS
$\overline{\text { READY }}$ output floats when either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{SO}}$ are sampled LOW at the faliing edge of CLK. Two system clock periods are allowed for the pull-up resistor to pull the
 forced active one CLK later (see Waveforms).

Figure 5 illustrates the operation of $\overline{\text { SRDY }}$ and $\overline{\text { SRDYEN }}$. These inputs are sampled on the falling edge of CLK when $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{SO}}$ are inactive and PCLK is HIGH. $\overline{\text { READY }}$ is forced active when both $\overline{\text { SRDY }}$ and SRDYEN are sampled as LOW.

Figure 6 shows the operation of $\overline{\text { ARDY }}$ and $\overline{\text { ARDYEN }}$. These inputs are sampled by an internal synchronizer at each falling edge of CLK. The output of the synchronizer is then sampled when PCLK is HIGH. If the synchronizer resolved both the ARDY and $\overline{\text { ARDYEN }}$ as active, the $\overline{\text { SRDY }}$ and SRDYEN inputs are ignored. Either $\overline{\text { ARDY }}$ or $\overline{\text { ARDYEN }}$ must be HIGH at the end of $T_{S}$, therefore at least one wait state is required when using the $\overline{\operatorname{ARDY}}$ and $\overline{\text { ARDYEN }}$ inputs as a basis for generating READY.
$\overline{\text { READY }}$ remains active until either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{SO}}$ are sampled LOW, or the ready inputs are sampled as inactive.


FIGURE 5. SYNCHRONOUS READY OPERATION


FIGURE 6. ASYNCHRONOUS READY OPERATION

```
Absolute Maximum Ratings
Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0V
Input, Output, or I/O Voltage Applied . . . GND - 0.5V to VCC + 0.5V
Storage Temperature Range . . . . . . . . . . . . . . . . -65'
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +1750
Lead Temperature (Soldering, 10 Sec) . . . . . . . . . . . . . . . . . +3000
ESD Classification ..................................... . Class 2
```


## Reliability Information

| Thermal Resistance Ceramic DIP Package | $\begin{gathered} \theta_{\mathrm{ja}} \\ 88.0^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ | $\begin{gathered} \theta_{\mathrm{jc}} \\ 27.0^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ |
| :---: | :---: | :---: |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 570mW |
| Gate Count |  | 200 Gates |

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 operations sections of this specification is not implied.

## Operating Conditions


D.C. Electrical Specifications $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}\left(\mathrm{CD82C284)}\right.$; $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (ID82C284)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.2 | - | v | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | EFI, F/C Input HIGH Voltage | 3.2 | - | v | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IHR }}$ | $\overline{\mathrm{RES}}$ HIGH Voltage | $\mathrm{v}_{\mathrm{CC}}-0.8$ | - | v | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {HYS }}$ | $\overline{\mathrm{RES}}$ Input Hysteresis | 0.5 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | RESET, PCLK Output LOW Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Note 2 |
| $\mathrm{V}_{\mathrm{OH}}$ | RESET, PCLK Output HIGH Voltage | $\mathrm{V}_{\mathrm{CC}}-0.4$ | - | V | $\mathrm{I}^{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Note 2 |
| $\mathrm{V}_{\text {OLR }}$ | $\overline{\text { READY }}$ Output LOW Voltage | - | 0.4 | V | $\mathrm{IOL}=10 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Note 2 |
| $\mathrm{V}_{\text {OLC }}$ | CLK Output LOW Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Note 2 |
| VOHC | CLK Output HIGH Voltage | $\mathrm{v}_{\mathrm{cc}}-0.4$ | - | v | $\mathrm{IOH}=-5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Note 2 |
| ILL | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| ICCOP | Active Power Supply Current | - | 60 | mA | 82C284-12 (Note 1) |
|  |  | - | 48 | mA | 82C284-10 (Note 1) |

NOTES: 1. ICCOP measured at 10 MHz for the $82 \mathrm{C} 284-10$ and at 12.5 MHz for the 82C284-12. VIN = GND or VCC, VCC $=5.5 \mathrm{~V}$, outputs unloaded.
A.C. Electrical Specifications $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{CD82C284}) ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (ID82C284)
A.C. Timings are Referenced to 0.8 V and 2.0 V Points of the Signals as Illustrated in Waveforms, Unless Otherwise Noted.

| SYMBOL | PARAMETER | 10 MHz |  | 12.5MHz |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| 11 | EFI LOW Time | 20 | - | 16 | - | ns | At $\mathrm{V}_{\mathrm{CC}} / 2$ (Note 8) |
| t2 | EFI HIGH Time | 20 | - | 20 | - | ns | At $\mathrm{V}_{\mathrm{CC}} / 2$ ( Note 8) |
| 5A | Status Setup Time for Status Going Active | 20 | - | 18 | - | ns |  |
| 5B | Status Setup Time for Status Going Inactive | 20 | - | 16 | - | ns |  |
| t6 | Status Hold Time | 1 | - | 1 | - | ns |  |
| t7 | F/C Setup Time | 15 | - | 15 | - |  |  |
| t8 | F/C Hold Time | 15 | - | 15 | - |  |  |
| t9 | $\overline{\text { SRDY }}$ or $\overline{\text { SRDYEN }}$ Setup Time | 15 | - | 15 | - | ns |  |
| t10 | $\overline{\text { SRDY }}$ or $\overline{\text { SRDYEN }}$ Hold Time | 2 | - | 2 | - | ns |  |
| t11 | $\overline{\text { ARDY }}$ or $\overline{\text { ARDYEN }}$ Setup Time | 5 | - | 5 | - | ns | (Note 3) |
| t12 | $\overline{\text { ARDY }}$ or $\overline{\text { ARDYEN }}$ Hold Time | 30 | - | 25 | - | ns | (Note 3) |
| t13 | $\overline{\mathrm{RES}}$ Setup Time | 20 | - | 18 | - | ns | (Notes 3, 7) |
| t14 | RES Hold Time | 10 | - | 8 | - | ns | (Notes 3, 7) |
| t16 | CLK Period | 50 | - | 40 | - | ns |  |
| t17 | CLK LOW Time | 12 | - | 11 | - | ns | (Notes 2, 6) |
| 118 | CLK HIGH Time | 16 | - | 13 | - | ns | Notes 2, 6) |
| t21 | $\overline{\text { READY }}$ Inactive Delay | 5 | - | 5 | - | ns | At 0.8 V (Note 4), Test Condition 2 |
| t22 | $\overline{\text { READY }}$ Active Delay | - | 24 | - | 18 | ns | At 0.8V (Note 4) |
| t23 | PCLK Delay | - | 20 | - | 16 | ns | $\mathrm{C}_{L}=75 \mathrm{pF}$, Test Condition 1 |
| t24 | RESET Delay | - | 27 | - | 26 | ns | $C_{L}=75 \mathrm{pF}$, Test Condition 3 |
| t25 | PCLK LOW Time | $\begin{array}{r} \hline 16 \\ -10 \end{array}$ | - | $\begin{gathered} \hline t 16 \\ -10 \end{gathered}$ | - | ns | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}($ Note 5 ) |
| t26 | PCLK HIGH Time | $\begin{array}{r} 116 \\ -10 \\ \hline \end{array}$ | - | $\begin{gathered} \mathrm{t} 16 \\ -10 \end{gathered}$ | - | ns | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}$ (Note 5) |

NOTES:

1. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V unless otherwise specified CLK loading: $C_{L}=100 \mathrm{pF}$
2 With the internal crystal oscillator using recommended crystal and capacitive loading, or with the EFI input meeting specifications $t_{1}$ and $t_{2}$. The recommended crystal loading for CLK frequencies of 8 MHz to 20 MHz are 25 pF from pin X 1 to ground, and 15 pF from pin X 2 to ground; for CLK frequencies from 20 MHz to 25 MHz the recommended loading is 15 pF from pin X1 to GND, and 15 pF from pin X2 to GND. These recommended values are $+5 p F$ and include all stray capacitance. Decouple $V_{C C}$ and GND as close to the 82C284 as possible.
2. This is an asynchronous input. This specification is given for testing purposes only, to assure recognition at a specific CLK edge.

4 The pull-up resistor value for the READY pin is $620 \Omega$ with the rated 150 pF load.
5. $t_{16}$ refers to any allowable CLK period.
6. When using a crystal with the recommended capacitive loading, CLK output HIGH and LOW times are guaranteed to meet 80 C 286 requirements
7. Measured from 1.0 V on the CLK to 0.8 V on the $\overline{\mathrm{RES}}$ waveform for $\overline{\mathrm{RES}}$ active, and to 4.2 V on the $\overline{\mathrm{RES}}$ waveform for $\overline{\mathrm{RES}}$ inactive.
8. Input test waveform characteristics: $\mathrm{V}_{\mathrm{IL}}=\mathrm{OV}, \mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V}$.

UNTESTED SPECIFICATIONS

| SYMBOL | PARAMETER | 10 MHz |  | 12.5 MHz |  | UNITS | CONDITIONS (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| CIN | Input Capacitance | - | 10 | - | 10 | pF | FREQ $=1 \mathrm{MHz}$, All measurements are referenced to device GND, $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |
| t15A | EFI HIGH to CLK LOW Delay | - | 30 | - | 25 | ns | (Note 2) |
| t15B | EFI LOW to CLK HIGH Delay | - | 35 | - | 30 | ns | (Note 3) |
| $t 19$ | CLK Rise Time | - | 8 | - | 8 | ns | 1.0 V to $3.6 \mathrm{~V}, \mathrm{CL}=100 \mathrm{pF}$ |
| t20 | CLK Fall Time | - | 8 | - | 8 | ns | 3.6 V to 1.0V, CL $=100 \mathrm{pF}$ |
| t27 | X1 HIGH to CLK | - | 35 | - | 30 | ns | (Note 4) |

NOTES: 1. The parameters listed in this table are controlled via design or process parameters and are not directly tested. These parameters are characterızed upon initial design and after major process and/or design changes.
2. Measured from 3.2 V on the EFI waveform to 1.0 V on the CLK
3. Measured from 0.8 V on the EFI waveform to 3.6 V on the CLK.
4. Measured from 3.6 V on the X 1 input to 3.6 V on the CLK.

## A.C. Specifications

A.C. DRIVE, SETUP, HOLD AND DELAY TIME MEASUREMENT POINTS


## A.C. Test Condition



| TEST CONDITION | RL | CL |
| :---: | :---: | :---: |
| 1 | $750 \Omega$ | 75 pF |
| 2 | $620 \Omega$ | 150 pF |
| 3 | $\infty$ | 75 pF |

Waveforms
CLK AS A FUNCTION OF EFI


NOTE: The EFI input LOW and HIGH times as shown are required to guarantee the CLK LOW and HIGH times shown.

RESET AND READY TIMING AS A FUNCTION OF RES WITH $\overline{S 1}, \overline{S O}, \overline{A R D Y}+\overline{\text { ARDYEN }}$, AND $\overline{\text { SRDY }}+\overline{\text { SRDYEN }}$ HIGH


NOTE: This is an asynchronous input. The setup and hold times shown are required to guarantee the response shown.
$\overline{R E A D Y}$ AND PCLK TIMING WITH $\overline{R E S}$ HIGH


NOTES. 1. This is an asynchronous input. The setup and hold times shown are required to guarantee the response shown.
2. If $\overline{\text { SRDY }}+\overline{\text { SRDYEN }}$ or $\overline{\text { ARDY }}+\overline{\text { ARDYEN }}$ are active before and/ or during the first bus cycle after RESET,


Waveforms (Continued) CLK AS A FUNCTION OF F/ $\bar{C}$, PCLK, X1, AND EFI during dynamic frequency switching


NOTE: This is an asynchronous input. The setup and hold times are required to guarantee the response shown.

## Clock Generator and Ready Interface

## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Generates System Clock for 80C286 Processors
- Generates System Reset Output from Schmitt Trigger Input - Improved Hysteresis
- Uses Crystal or External Signal for Frequency Source
- Dynamically Switchable Between Two Input Frequencies
- Provides Local $\overline{\text { READY }}$ and MULTIBUS ${ }^{\circledR} \overline{\text { READY Synchroniza- }}$ tion
- Static CMOS Technology
- Single +5V Power Supply
- Available in 18 Lead Cerdip Package


## Pinout

82C284/883 (CERAMIC DIP)
TOP VIEW


## Description

The Harris 82C284/883 is a clock generator/driver which provides clock signals for 80 C 286 processors and support components. It also contains logic to supply READY to the CPU from either asynchronous or synchronous sources and synchronous RESET from an asynchronous input with hysteresis.

Absolute Maximum Ratings


Reliability Information


CAUTION. Stresses above those listed in "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

## Operating Conditions

Operating Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
EFI Rise Time (From 0.8V to 3.2 V )
8ns (Max)
Operating Supply Voltage
+4.5 V to +5.5 V
EFI Fall Time (From 3.2 V to 0.8 V ).
. 8ns (Max)

TABLE 1. 82C284/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input LOW Voltage | VIL | $\mathrm{VCC}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Input HIGH Voltage | VIH | $\mathrm{VCC}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| EFI, F/C Input High Volt. | VIHC | $\mathrm{VCC}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 3.2 | - | V |
| $\overline{\text { RES }}$ HIGH Voltage | VIHR | $\mathrm{VCC}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \hline \text { VCC } \\ & -0.8 \end{aligned}$ | - | V |
| $\overline{\mathrm{RES}}$ Input Hysteresis | VHYS | $\mathrm{VCC}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 0.5 | - | V |
| RESET, PCLK Output LOW Voltage | VOL | $\begin{aligned} & \mathrm{IOL}=5 \mathrm{~mA}, \\ & \mathrm{VCC}=4.5 \mathrm{~V}, \text { Note } 2 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| RESET, PCLK Output Voltage | VOH | $\begin{aligned} & \mathrm{IOH}=-1 \mathrm{~mA}, \\ & \mathrm{VCC}=4.5 \mathrm{~V}, \text { Note } 2 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \hline \text { VCC } \\ & -0.4 \end{aligned}$ | - | V |
| READY Output LOW Voltage | VOLR | $\begin{aligned} & \mathrm{IOH}=10 \mathrm{~mA}, \\ & \mathrm{VCC}=4.5 \mathrm{~V}, \text { Note } 2 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| CLK Output LOW Voltage | VOLC | $\begin{aligned} & \text { IOL }=5 \mathrm{~mA}, \\ & \mathrm{VCC}=4.5 \mathrm{~V}, \text { Note } 2 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| CLK Output HIGH Voltage | VOHC | $\begin{aligned} & 1 O H=-5 \mathrm{~mA}, \\ & \mathrm{VCC}=4.5 \mathrm{~V}, \text { Note } 2 \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \hline \mathrm{VCC} \\ & -0.4 \end{aligned}$ | - | V |
| Input Leakage Current | 11 | $\begin{aligned} & \text { VIN }=\text { GND or VCC, } \\ & \text { VCC }=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | 10 | $\mu \mathrm{A}$ |
| Active Power Supply Current | ICCOP | $\begin{aligned} & 82 \mathrm{C} 284-10 / 883, \\ & \text { Note } 1 \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\mathrm{T}} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 48 | mA |
|  |  | 82C284-12/883, Note 1 | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 60 | mA |

NOTES 1. ICCOP measured at 10 MHz for the $82 \mathrm{C} 284-10 / 883$ and at 12.5 MHz for the $82 \mathrm{C} 284-12 / 883$. VIN $=\mathrm{GND}$ or VCC, VCC $=5.5 \mathrm{~V}$, outputs unloaded.
2. Interchanging of force and sense conditions is permitted.

TABLE 2. 82C284/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested. A.C. timings are referenced to 0.8 V and 2.0 V points of the signals as illustrated in datasheet waveforms, unless otherwise specified.

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | 82C284/883 |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 10 MHz |  | 12 MHz |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| EFI LOW Time | 11 | At VCC/2, Note 8 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| EFI HIGH Time | 12 | At VCC/2, Note 8 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 20 | - | ns |
| Status Setup Time for Status Going Active | 15A |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 18 | - | ns |
| Status Setup Time for Status Going Inactive | t5B |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Status Hold Time | t6 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| F/ट्ट Setup Time | t7 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 15 | - | ns |
| F/C C Hold Time | 18 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 15 | - | ns |
| $\overline{\text { SRDY }}$ or SRDYEN Setup Time | t9 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 15 | - | ns |
| $\overline{\text { SRDY or }} \overline{\text { SRDYEN }}$ Hold Time | t10 |  | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2 | - | 2 | - | ns |
| $\overline{\text { ARDY }}$ or $\overline{\text { ARDYEN }}$ Setup Time | t11 | Note 3 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | ns |
| $\overline{\text { ARDY or }} \overline{\text { ARDYEN }}$ Hold Time | t12 | Note 3 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 25 | - | ns |
| $\overline{\text { RES S Stup Time }}$ | t13 | Notes 3, 7 | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 18 | - | ns |
| $\overline{\text { RES }}$ Hold Time | t14 | Notes 3, 7 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | 8 | - | ns |
| CLK Period | t16 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | - | 40 | - | ns |
| CLK LOW Period | t17 | Notes 2, 6 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 11 | - | ns |
| CLK HIGH Time | t18 | Notes 2, 6 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 16 | - | 13 | - | ns |
| $\overline{\text { READY }}$ Inactive Delay | t21 | At 0.8V. Note 4, Test Condition 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | ns |
| $\overline{\text { READY Active }}$ Delay | t22 | At 0.8V. Note 4, | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 24 | - | 18 | ns |
| PCLK Delay | t23 | $\begin{aligned} & \mathrm{CL}=75 \mathrm{pF} \\ & \text { Test Condition } 1 \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 16 | ns |
| RESET Delay | t24 | $\begin{aligned} & \mathrm{CL}=75 \mathrm{pF}, \\ & \text { Test Condition } 3 \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 27 | - | 26 | ns |
| PCLK LOW Time | t25 | $\mathrm{CL}=75 \mathrm{pF},$ <br> Note 5 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\begin{gathered} \text { t16- } \\ 10 \end{gathered}$ | - | $\begin{gathered} \mathrm{t} 16- \\ 10 \end{gathered}$ | - | ns |
| PCLK HIGH Time | t26 | $C L=75 p F$ <br> Note 5 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\begin{gathered} \mathbf{t} 16- \\ 10 \end{gathered}$ | - | $\begin{gathered} \mathrm{t} 16- \\ 10 \end{gathered}$ | - | ns |

NOTES $1 \mathrm{VCC}=45 \mathrm{~V}$ and 55 V unless otherwise specified CLK loading. $\mathrm{CL}=100 \mathrm{pF}$
2 With the internal crystal oscillator using recommended crystal and capacitive loading, or with the EFI input meeting specifications $t 1$ and $t 2$ The recommended crystal loading for CLK frequencies of 8 MHz to 20 MHz are 25 pF from pin X 1 to GND, and 15 pF from pin X2 to GND, for CLK frequencies from 20 MHz to 25 MHz the recommended loading is 15 pF from pin X 1 to GND, and 15 pF from pin X2 to GND These recommended values are $\pm 5 \mathrm{pF}$ and include all stray capacitance Decouple VCC and GND as close to the $82 \mathrm{C} 284 / 883$ as possible
3 This is an asynchronous input This specification is given for testing purposes only, to assure recognition at a specific CLK edge
4 The pull-up resistor value for the $\overline{\operatorname{READY}}$ pin is $620 \Omega$ with the rated 150 pF load
5 t16 refers to any allowable CLK period
6 When using a crystal with the recommended capacitive loading, CLK output HIGH and LOW times are guaranteed to meet 80 C 286 requirements
7 Measured from 10 V on the CLK to 08 V on the $\overline{\mathrm{RES}}$ waveform for $\overline{\mathrm{RES}}$ active, and to 42 V on the $\overline{\mathrm{RES}}$ waveform for $\overline{\mathrm{RES}}$ inactive
8 Input test waveform characteristics VIL $=00 \mathrm{~V}, \mathrm{VIH}=45 \mathrm{~V}$.

TABLE 3. 82C284/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | 82C284/883 |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 10 MHz |  | 12.5 MHz |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | CIN | FREQ $=1 \mathrm{MHz}$, All measurements are referenced to device GND | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| EFI HIGH to CLK LOW Delay | t15A |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 25 | ns |
| EFI LOW to CLK HIGH Delay | t15B |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 35 | - | 30 | ns |
| CLK Rise Time | t19 | 1.0 V to 3.6 V , $C L=100 \mathrm{pF}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| CLK Fall Time | t20 | 3.6 V to 1.0 V , $C L=100 \mathrm{pF}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| X1 HIGH to CLK | t27 |  | 1,4 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 35 | - | 30 | ns |

NOTES: 1. The parameters listed in Table 3 are controlled via design or process parameters and are not direcily tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Measured from 3.2 V on the EFI waveform to 1.0 V on the CLK.
3. Measured from 0.8 V on the EFI waveform to 3.6 V on the CLK.
4. Measured from 3.6 V on the X 1 input to 3.6 V on the CL.K.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

A.C. Specifications (Continued)
A.C. DRIVE, SETUP, HOLD AND DELAY TIME MEASUREMENT POINTS

A.C. Test Condition


| TEST CONDITION | RL | CL |
| :---: | :---: | :---: |
| 1 | $750 \Omega$ | 75 pF |
| 2 | $620 \Omega$ | 150 pF |
| 3 | $\infty$ | 75 pF |

## Waveforms

## CLK AS A FUNCTION OF EFI



NOTE The EFI input LOW and HIGH times as shown are required to guarantee the CLK LOW and HIGH times shown

RESET AND READY TIMING AS A FUNCTION OF $\overline{\text { RES }}$ WITH $\overline{\text { S1 }}, \overline{\text { SO }}, \overline{\text { ARDY }}+\overline{\text { ARDYEN }}$, AND $\overline{\text { SRDY }}+\overline{\text { SRDYEN }}$ HIGH


NOTE: This is an asynchronous input. The setup and hold times shown are required to guarantee the response shown.

READY AND PCLK TIMING WITH RES HIGH


NOTES: 1. This is an asynchronous input. The setup and hold times shown are required to guarantee the response shown.
2. If $\overline{\text { SRDY }}+\overline{\text { SRDYEN }}$ or $\overline{\text { ARDY }}+\overline{\text { ARDYEN }}$ are active before and/ or during the first bus cycle after RESET, $\overline{\text { READY }}$ may not be deasserted until the falling edge of $\phi 2$ of $\mathrm{T}_{\mathrm{S}}$.

Waveforms (Continued) CLK AS A FUNCTION OF F/ $\bar{C}$, PCLK, X1, AND EFI DURING DYNAMIC FREQUENCY SWITCHING


NOTE: This is an asynchronous input. The setup and hold times are required to guarantee the response shown.

## Burn-In Circuit

18 PIN CERAMIC DIP


NOTES: 1. Supply Voltage: $\mathrm{VCC}=5.5 \mathrm{~V}, \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
Driver Voltage VIH $=4.5 \mathrm{~V} \pm 10 \%$, $\mathrm{VIL}=0 \mathrm{~V}$
2. Input Voltage Limits: VIL $(\operatorname{Max})=0.4 \mathrm{~V}$,
$\mathrm{VIH}(\mathrm{Min})=2.6 \mathrm{~V}$
3. Component Values: R1 $=47 \mathrm{k} \Omega$
$\mathrm{C} 1=0.1 \mu \mathrm{~F}$ (Min)
4. Oven type and frequency requirements microtest, FO through F12
5. Approximate current per unit. $I C C=03 \mathrm{~mA}$
6. Special requirements:
(a) Electrostatic Discharge Sensitive. Proper precautions must be used when handling units.
(b) All power supplies must be at zero volts when the boards are inserted into the ovens. After insertion, apply VCC first, then activate the driver power supplies.
7. Oscilloscope measurements: To be on loaded boards before insertion into the oven.

Packaging
18 PIN CERAMIC DIP


* INCREASE MAX LIMIT BY . 003 INCHES MEASURED AT CENTER OF FLAT FOR
- SOLDER FINISH

LEAD FINISH: Type A
COMPLIANT OUTLINE:
MATERIALS: Compliant to Mil-M-38510
Mil-Std-1835, GDIP1-T18

## Metallization Topology

DIE DIMENSIONS:
$63 \times 69 \times 19 \pm 1$ mils
METALLIZATION:
Type: Silicon - Aluminum
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: 10k $\AA$
DIE ATTACH:
Material: Gold - Silicon Eutectic Alloy
Temperature: Ceramic DIP - 460 ${ }^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
LEAD TEMPERATURE ( 10 Seconds Soldering): $\leq 300^{\circ} \mathrm{C}$

Metallization Mask Layout


# CMOS High Performance <br> Programmable DMA Controller 

## Features

- Compatible with the NMOS 8237A
- Four Independent Maskable Channels with AutoinitialIzation Capability
- Cascadable to any Number of Channels
- High Speed Data Transfers:
- Up to 4 MBytes/sec with 8MHz Clock
- Up to 6.25 MBytes/sec with 12.5MHz Clock
- Memory-to-Memory Transfers
- Static CMOS Design Permits Low Power Operation
- ICCSB = 10 $\mu$ A Maximum
- ICCOP = 2mAMHz Maximum
- Fully TTLCMOS Compatible
- Internal Registers may be Read from Software


## Description

The 82C37A is an enhanced version of the industry standard 8237A Direct Memory Access (DMA) controller, fabricated using Harris' advanced 2 micron CMOS process. Pin compatible with NMOS designs, the 82C37A offers increased functionality, improved performance, and dramatically reduced power consumption. The fully static design permits gated clock operation for even further reduction of power.
The 82C37A controller can improve system performance by allowing external devices to transier data directly to or from system memory. Memory-to-memory transfer capability is also provided, along with a memory block initialization feature. DMA requests may be generated by either hardware or software, and each channel is independently programmable with a variety of features for flexible operation.

The 82C37A is designed to be used with an external address latch, such as the 82 C 82 , to demultiplex the most significant 8 bits of address. The 82C37A can be used with industry standard microprocessors such as 80C286, 80286, 80C86, 80C88, 8086, 8088, 8085, Z80, NSC800, 80186 and others. Multimode programmability allows the user to select from three basic types of DMA services, and reconfiguration under program control is possible even with the clock to the controller stopped. Each channel has a full 64 K address and word count range, and may be programmed to autoinitialize these registers following DMA termination (end of process).

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 5 MHz | 8MHz | 12.5MHz |
| :---: | :---: | :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C37A-5 | CP82C37A | CP82C37A-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C37A-5 | IP82C37A | IP82C37A-12 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C37A-5 | CS82C37A | CS82C37A-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C37A-5 | IS82C37A | IS82C37A-12 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C37A-5 | CD82C37A | CD82C37A-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C37A-5 | ID82C37A | ID82C37A-12 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C37A-5/B | MD82C37AB | MD82C37A-12/B |
| SMD\# |  | Pending | Pending | Pending |
| LCC <br> SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C37-5AB | MR82C37AB | MR82C37A-12/B |
|  |  | Pending | Pending | Pending |

## Pinouts



Block Diagram


TABLE 1.

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| vcc | 31 |  | VCC: is the +5 V power supply pin. A 0.1 uF capacitor between pins 31 and 20 is recommended for decoupling. |
| GND | 20 |  | Ground |
| CLK | 12 | 1 | CLOCK INPUT: The Clock Input is used to generate the timing signals which control 82C37A operations. This input may be driven from DC to 12.5 MHz for the $82 \mathrm{C} 37 \mathrm{~A}-12$, from DC to 8 MHz for the 82C37A, or from DC to 5 MHz for the 82C37A-5. The Clock may be stopped in either state for standby operation. |
| $\overline{\mathrm{cs}}$ | 11 | 1 | CHIP SELECT: Chip Select is an active low input used to enable the controller onto the data bus for CPU communications. |
| RESET | 13 | 1 | RESET: This is an active high input which clears the Command, Status, Request, and Temporary registers, the First/Last Flip-Flop, and the mode register counter. The Mask register is set to ignore requests. Following a Reset, the controller is in an idle cycle. |
| READY | 6 | 1 | READY: This signal can be used to extend the memory read and write pulses from the 82C37A to accommodate slow memories or I/O devices. Ready must not make transitions during its specified set-up and hold times. See Figure 14 for timing. Ready is ignored in verify transfer mode. |
| HLDA | 7 | 1 | HOLD ACKNOWLEDGE: The active high Hold Acknowledge from the CPU indicates that it has relinquished control of the system busses. HLDA is a synchronous input and must not transition during its specified set-up time. There is an implied hold time (HLDA inactive) of TCH from the rising edge of clock, during which time HLDA must not transition. |
| $\begin{aligned} & \text { DREQO- } \\ & \text { DREQ3 } \end{aligned}$ | 16-19 | 1 | DMA REQUEST: The DMA Request (DREQ) lines are individual asynchronous channel request inputs used by peripheral circuits to obtain DMA service. In Fixed Priority, DREQO has the highest priority and DREQ3 has the lowest priority. A request is generated by activating the DREQ line of a channel. DACK will acknowledge the recognition of a DREQ signal. Polarity of DREQ is programmable. Reset initializes these lines to active high. DREQ must be maintained until the corresponding DACK goes active. DREQ will not be recognized while the clock is stopped. Unused DREQ inputs should be pulled High or Low (inactive) and the corresponding mask bit set. |
| $\begin{aligned} & \text { DBO- } \\ & \text { DB7 } \end{aligned}$ | $\begin{aligned} & 21-23 \\ & 26-30 \end{aligned}$ | 1/O | DATA BUS: The Data Bus lines are bidirectional three-state signals connected to the system data bus. The outputs are enabled in the Program condition during the I/O Read to output the contents of a register to the CPU. The outputs are disabled and the inputs are read during an I/O Write cycle when the CPU is programming the 82C37A control registers. During DMA cycles, the most significant 8 bits of the address are output onto the data bus to be strobed into an external latch by ADSTB. In memory-to-memory operations, data from the memory enters the 82C37A on the data bus during the read-from-memory transfer, then during the write-to-memory transfer, the data bus outputs write the data into the new memory location. |
| $\overline{\overline{O R}}$ | 1 | 1/0 | I/O READ: I/O Read is a bidirectional active low three-state line. In the Idle cycle, it is an input control signal used by the CPU to read the control registers. In the Active cycle, it is an output control signal used by the 82C37A to access data from a peripheral during a DMA Write transfer. |
| İW | 2 | 1/0 | I/O WRITE: I/O Write is a bidirectional active low three-state line. In the Idie cycle, it is an input control signal used by the CPU to load information into the 82C37A. In the Active cycle, it is an output control signal used by the 82C37A to load data to the peripheral during a DMA Read transfer. |
| $\overline{\text { EOP }}$ | 36 | 1/0 | END OF PROCESS: End of Process ( $\overline{\mathrm{EOP}}$ ) is an active low bidirectional signal. Information concerning the completion of DMA services is available at the bidirectional EOP pin. <br> The 82C37A allows an external signal to terminate an active DMA service by pulling the $\overline{\mathrm{EOP}}$ pin low. A pulse is generated by the 82C37A when terminal count (TC) for any channel is reached, except for channel 0 in memory-to-memory mode. During memory-to-memory transfers, $\overline{E O P}$ will be output when the TC for channel 1 occurs. <br> The $\overline{\mathrm{EOP}}$ pin is driven by an open drain transistor on-chip, and requires an external pull-up resistor to VCC. <br> When an $\overline{E O P}$ pulse occurs, whether internally or externally generated, the 82C37A will terminate the service, and if autoinitialize is enabled, the base registers will be written to the current registers of that channel. The mask bit and TC bit in the status word will be set for the currently active channel by $\overline{E O P}$ unless the channel is programmed for autoinitialize. In that case, the mask bit remains clear. |

## Pin Description

TABLE 1.

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| AO-A3 | 32-35 | 1/0 | ADDRESS: The four least significant address lines are bidirectional three-state signals. In the ldie cycle, they are inputs and are used by the 82C37A to address the control register to be loaded or read. In the Active cycle, they are outputs and provide the lower 4 bits of the output address. |
| A4-A7 | 37-40 | 0 | ADDRESS: The four most significant address lines are three-state outputs and provide 4 bits of address. These lines are enabled only during the DMA service. |
| HRQ | 10 | 0 | HOLD REQUEST: The Hold Request (HRQ) output is used to request control of the system bus. When a DREQ occurs and the corresponding mask bit is clear, or a software DMA request is made, the 82C37A issues HRQ. The HLDA signal then informs the controller when access to the system busses is permitted. For stand-alone operation where the 82C37A always controls the busses, HRQ may be tied to HLDA. This will result in one SO state before the transfer. |
| DACKODACK 3 | $\begin{aligned} & 14,15 \\ & 24,25 \end{aligned}$ | 0 | DMA ACKNOWLEDGE: DMA acknowledge is used to notify the individual peripherals when one has been granted a DMA cycle. The sense of these lines is programmable. Reset initializes them to active low. |
| AEN | 9 | 0 | ADDRESS ENABLE: Address Enable enables the 8-bit latch containing the upper 8 address bits onto the system address bus. AEN can also be used to disable other system bus drivers during DMA transfers. AEN is active HIGH. |
| ADSTB | 8 | 0 | ADDRESS STROBE: This is an active high signal used to control latching of the upper address byte. It will drive directly the strobe input of external transparent octal latches, such as the 82C82. During block operations, ADSTB will only be issued when the upper address byte must be updated, thus speeding operation through elimination of S1 states. ADSTB timing is referenced to the falling edge of the 82C37A clock. |
| MEMR | 3 | 0 | MEMORY READ: The memory Read signal is an active low three-state output used to access data from the selected memory location during a DMA Read or a memory-to-memory transfer. |
| MEMW | 4 | O | MEMORY WRITE: The Memory Write is an active low three-state output used to write data to the selected memory location during a DMA Write or a memory-to-memory transfer. |
| NC | 5 |  | NO CONNECT: Pin 5 is open and should not be tested for continuity. |

## Functional Description

The 82C37A direct memory access controller is designed to improve the data transfer rate in systems which must transfer data from an I/O device to memory, or move a block of memory to an I/O device. It will also perform memory-tomemory block moves, or fill a block of memory with data from a single location. Operating modes are provided to handle single byte transfers as well as discontinuous data streams, which allows the 82C37A to control data movement with software transparency.

The DMA controller is a state-driven address and control signal generator, which permits data to be transferred directly from an I/O device to memory or vice versa without ever being stored in a temporary register. This can greatly increase the data transfer rate for sequential operations, compared with processor move or repeated string instructions. Memory-to-memory operations require temporary internal storage of the data byte between generation of the source and destination addresses, so memory-to-memory transfers take place at less than half the rate of I/O operations, but still much faster than with central processor techniques. The maximum data transfer rates obtainable with the 82C37A are shown in Figure 1.

The block diagram of the 82C37A is shown on page 2. The timing and control block, priority block, and internal registers are the main components. Figure 2 lists the name and size of the internal registers. The timing and control block derives internal timing from the clock input, and generates external control signals. The Priority Encoder block resolves priority contention between DMA channels requesting service simultaneously.

| 82C37A <br> TRANSFER TYPE | 5 MHz | 8 MHz | 12.5 MHz | UNIT |
| :--- | :---: | :---: | :---: | :---: |
| Compressed | 2.50 | 4.00 | 6.25 | MByte/sec |
| Normal I/O | 1.67 | 2.67 | 4.17 | MByte/sec |
| Memory-to- | 0.63 | 1.00 | 1.56 | MByte/sec |
| Memory |  |  |  |  |

FIGURE 1. DMA TRANSFER RATES

## DMA Operation

In a system, the 82C37A address and control outputs and data bus pins are basically connected in parallel with the system busses. An external latch is required for the upper address byte. While inactive, the controller's outputs are in a high impedance state. When activated by a DMA request and bus control is relinquished by the host, the 82C37A drives the busses and generates the control signals to perform the data transfer. The operation performed by activating one of the four DMA request inputs has previously been programmed into the controller via the Command, Mode, Address, and Word Count registers.

For example, if a block of data is to be transferred from RAM to an I/O device, the starting address of the data is loaded into the 82C37A Current and Base Address registers for a particular channel, and the length of the block is loaded into that channel's Word Count register. The corresponding Mode register is programmed for a memory-to-I/O operation (read transfer), and various options are selected by the Command register and other Mode register bits. The channel's mask bit is cleared to enable recognition of a DMA request (DREQ). The DREQ can either be a hardware signal or a software command.

Once initiated, the block DMA transfer will proceed as the controller outputs the data address, simultaneous MEMR and $\overline{\mathrm{IOW}}$ pulses, and selects an I/O device via the DMA acknowledge (DACK) outputs. The data byte flows directly from the RAM to the I/O device. After each byte is transferred, the address is automatically incremented (or decremented) and the word count is decremented. The operation is then repeated for the next byte. The controller stops transferring data when the Word Count register underflows, or an external $\overline{\mathrm{EOP}}$ is applied.

| NAME | SIZE | NUMBER |
| :--- | :---: | :---: |
| Base Address Registers | 16 Bits | 4 |
| Base Word Count Registers | 16 Bits | 4 |
| Current Address Registers | 16 Bits | 4 |
| Current Word Count Registers | 16 Bits | 4 |
| Temporary Address Register | 16 Bits | 1 |
| Temporary Word Count Register | 16 Bits | 1 |
| Status Register | 8 Bits | 1 |
| Command Register | 8 Bits | 1 |
| Temporary Register | 8 Bits | 1 |
| Mode Registers | 6 Bits | 4 |
| Mask Register | 4 Bits | 1 |
| Request Register | 4 Bits | 1 |

FIGURE 2. 82C37A INTERNAL REGISTERS

To further understand 82C37A operation, the states generated by each clock cycle must be considered. The DMA controller operates in two major cycles, active and idle. After being programmed, the controller is normally idle until a DMA request occurs on an unmasked channel, or a software request is given. The 82C37A will then request control of the system busses and enter the active cycle. The active cycle is composed of several internal states, depending on what options have been selected and what type of operation has been requested.

The 82C37A can assume seven separate states, each composed of one full clock period. State I (SI) is the idle state. It is entered when the 82C37A has no valid DMA requests pending, at the end of a transfer sequence, or when a Reset or Master Clear has occurred. While in SI , the DMA controller is inactive but may be in the Program Condition (being programmed by the processor).

State $0(S 0)$ is the first state of a DMA service. The 82C37A has requested a hold but the processor has not yet returned an acknowledge. The 82C37A may still be programmed until it has received HLDA from the CPU. An acknowledge from the CPU will signal that DMA transfers may begin. S1, S2, S3 and S4 are the working states of the DMA service. If more time is needed to complete a transfer than is available with normal timing, wait states (SW) can be inserted between S3 and S4 in normal transfers by the use of the Ready line on the 82C37A. For compressed transfers, wait states can be inserted between S2 and S4. See timing Figures 14 and 15.

Note that the data is transferred directly from the I/O device to memory (or vice versa) with $\overline{\mathrm{IOR}}$ and $\overline{\mathrm{MEMW}}$ (or MEMR and $\overline{\mathrm{OOW}}$ ) being active at the same time. The data is not read into or driven out of the 82C37A in I/O-to-memory or memory-to-I/O DMA transfers.

Memory-to-memory transfers require a read-from and a write-to memory to complete each transfer. The states, which resemble the normal working states, use two-digit numbers for identification. Eight states are required for a single transfer. The first four states (S11, S12, S13, S14 are used for the read-from-memory half and the last four states (S21, S22, S23, S24) for the write-to-memory half of the transfer.

## Idle Cycle

When no channel is requesting service, the 82C37A will enter the Idle cycle and perform "Sl" states. In this cycle, the 82C37A will sample the DREQ lines on the falling edge of every clock cycle to determine if any channel is requesting a DMA service.

Note that for standby operation where the clock has been stopped, DMA requests will be ignored. The device will respond to $\overline{C S}$ (chip select), in case of an attempt by the microprocessor to write or read the internal registers of the 82C37A. When $\overline{C S}$ is low and HLDA is low, the 82C37A enters the Program Condition. The CPU can now establish, change or inspect the internal definition of the part by reading from or writing to the internal registers.
The 82C37A may be programmed with the clock stopped, provided that HLDA is low and at least one rising clock edge has occurred after HLDA was driven low, so the controller is in an SI state. Address lines AO-A3 are inputs to the device and select which registers will be read or written. The $\overline{\mathrm{OR}}$ and $\overline{\mathrm{OOW}}$ lines are used to select and time the read or write operations. Due to the number and size of the internal registers, an internal flip-flop called the First/Last Flip-Flop is used to generate an additional bit of address. The bit is used to determine the upper or lower byte of the 16 -bit Address and Word Count registers. The flip-flop is reset by Master Clear or Reset. Separate software commands can also set or reset this flip-flop.

Special software commands can be executed by the 82C37A in the Program Condition. These commands are decoded as sets of addresses with $\overline{\mathrm{CS}}, \overline{\mathrm{IOR}}$, and $\overline{\mathrm{IOW}}$. The commands do not make use of the data bus. Instructions include Set and Clear First/Last Flip-Flop, Master Clear, Clear Mode Register Counter, and Clear Mask Register.

## Active Cycle

When the 82C37A is in the Idle cycle, and a software request or an unmasked channel requests a DMA service, the device will issue HRQ to the microprocessor and enter the Active cycle. It is in this cycle that the DMA service will take place, in one of four modes:

Single Transfer Mode - In single transfer mode, the device is programmed to make one transfer only. The word count will be decremented and the address decremented or incremented following each transfer. When the word count "rolls over" from zero to FFFFH, a terminal count bit in the status register is set, an $\overline{E O P}$ pulse is generated, and the channel will autoinitialize if this option has been selected. If not programmed to autoinitialize, the mask bit will be set, along with the TC bit and EOP pulse.

DREQ must be held active until DACK becomes active. If DREQ is held active throughout the single transfer, HRQ will go inactive and release the bus to the system. It will again go active and, upon receipt of a new HLDA, another single transfer will be performed, unless a higher priority channel takes over. In 8080A, 8085A, 80C88, or 80C86 systems, this will ensure one full machine cycle execution between DMA transfers. Details of timing between the 82C37A and other bus control protocols will depend upon the characteristics of the microprocessor involved.

Block Transfer Mode - In Block Transfer mode, the device is activated by DREQ or software request and continues making transfers during the service until a TC, caused by word count going to FFFFH, or an external End of Process ( $\overline{\mathrm{EOP}}$ ) is encountered. DREQ need only be held active until DACK becomes active. Again, an Autoinitialization will occur at the end of the service if the channel has been programmed for that option.
Demand Transfer Mode - In Demand Transfer mode the device continues making transfers until a TC or external $\overline{E O P}$ is encountered, or until DREQ goes inactive. Thus, transfers may continue until the I/O device has exhausted its data capacity. After the I/O device has had a chance to catch up, the DMA service is reestablished by means of a DREQ. During the time between services when the microprocessor is allowed to operate, the intermediate values of address and word count are stored in the 82C37A Current Address and Current Word Count registers. Higher priority channels may intervene in the demand process, once DREQ has gone inactive. Only an EOP can cause an Autoinitialization at the end of the service. $\overline{\mathrm{EOP}}$ is generated either by TC or by an external signal.

Cascade Mode - This mode is used to cascade more than one 82C37A for simple system expansion. The HRQ and HLDA signals from the additional 82C37A are connected to the DREQ and DACK signals respectively of a channel for the initial 82C37A. This allows the DMA requests of the additional device to propagate through the priority network
circuitiry of the preceding device. The priority chain is preserved and the new device must wait for its turn to acknowledge requests. Since the cascade channel of the initial 82C37A is used only for prioritizing the additional device, it does not output an address or control signals of its own. These could conflict with the outputs of the active channel in the added device. The initial 82C37A will respond to DREQ and generate DACK but all other outputs except HRQ will be disabled. An external EOP will be ignored by the initial device, but will have the usual effect on the added device.

Figure 3 shows two additional devices cascaded with an initial device using two of the initial device's channels. This forms a two-level DMA system. More 82C37As could be added at the second level by using the remaining channels of the first level. Additional devices can also be added by cascading into the channels of the second level devices, forming a third level.


## FIGURE 3. CASCADED 82C37As

When programming cascaded controllers, start with the first level device (closest to the microprocessor). After RESET, the DACK outputs are programmed to be active low and are held in the high state. If they are used to drive HLDA directly, the second level device(s) cannot be programmed until DACK polarity is selected as active high on the initial device. Also, the initial device's mask bits function normally on cascaded channels, so they may be used to inhibit second-level services.

## Transfer Types

Each of the three active transfer modes can perform three different types of transfers. These are Read, Write and Verify. Write transfers move data from an I/O device to the memory by activating $\overline{M E M W}$ and $\overline{\mathrm{IOR}}$. Read transfers move data from memory to an I/O device by activating $\overline{M E M R}$ and $\overline{\mathrm{OWW}}$.

Verify transfers are pseudo-transfers. The 82C37A operates as in Read or Write transfers generating
adaresses and responding to $\overline{\mathrm{EOP}}$, etc., however the memory and I/O control lines all remain inactive. Verify mode is not permitted for memory-to-memory operation. Ready is ignored during verify transfers.

Autoinitialize - By setting bit 4 in the Mode register, a channel may be set up as an Autoinitialize channel. During Autoinitialization, the original values of the Current Address and Current Word Count registers are automatically restored from the Base Address and Base Word Count registers of that channel following EOP. The base registers are loaded simultaneously with the current registers by the microprocessor and remain unchanged throughout the DMA service. The mask bit is not set when the channel is in Autoinitialize mode. Following Autoinitialization, the channel is ready to perform another DMA service, without CPU intervention, as soon as a valid DREQ is detected, or software request made.

Memory-to-Memory - To perform block moves of data from one memory address space to another with minimum of program effort and time, the 82C37A includes a memory-to-memory transfer feature. Setting bit 0 in the Command register selects channels 0 and 1 to operate as memory-tomemory transfer channels.

The transfer is initiated by setting the software or hardware DREQ for channel 0. The 82C37A requests a DMA service in the normal manner. After HLDA is true, the device, using four-state transfers in Block Transfer mode, reads data from the memory. The channel 0 Current Address register is the source for the address used and is decremented or incremented in the normal manner. The data byte read from the memory is stored in the 82C37A internal Temporary register. Another four-state transfer moves the data to memory using the address in channel one's Current Address register and incrementing or decrementing it in the normal manner. The channel 1 Current Word Count is decremented.

When the word count of channel 1 decrements to FFFFH, a TC is generated causing an $\overline{\mathrm{EOP}}$ output, terminating the service, and setting the channel 1 TC bit in the Status register. The channel 1 mask bit will also be set, unless the channel 1 mode register is programmed for autoinitialization. Channel 0 word count decrementing to FFFFH will not set the channel 0 TC bit in the status register or generate an $\overline{E O P}$, or set the channel 0 mask bit in this mode. It will cause an autoinitialization of channel 0 , if that option has been selected.

If full Autoinitialization for a memory-to-memory operation is desired, the channel 0 and channel 1 word counts must be set to equal values before the transfer begins. Otherwise, if channel 0 underflows before channel 1 , it will autoinitialize and set the data source address back to the beginning of the block. If the channel 1 word count underflows before channel 0 , the memory-to- memory DMA service will terminate, and channel 1 will autoinitialize but channel 0 will not.

In memory-to-memory mode, Channel 0 may be programmed to retain the same address for all transfers. This allows a single byte to be written to a block of memory. This channel 0 address hold feature is selected by setting bit 1 in the Command register.

The 82C37A will respond to external $\overline{E O P}$ signals during memory-to-memory transfers, but will only relinquish the system busses after the transfer is complete (i.e., after an S24 state). It should be noted that an external EOP cannot cause the channel 0 Address and Word Count registers to autoinitialize, even if the Mode register is programmed for autoinitialization. An external EOP will autoinitialize the channel 1 registers, if so programmed. Data comparators in block search schemes may use the $\overline{\mathrm{EOP}}$ input to terminate the service when a match is found. The timing of memory-to-memory transfers is found in Figure 13. Memory-tomemory operations can be detected as an active AEN with no DACK outputs.
Priority - The 82C37A has two types of priority encoding available as software selectable options. The first is Fixed Priority which fixes the channels in priority order based upon the descending value of their numbers. The channel with the lowest priority is 3 followed by 2,1 and the highest priority channel, 0 . After the recognition of any one channel for service, the other channels are prevented from interfering with the service until it is completed.
The second scheme is Rotating Priority. The last channel to get service becomes the lowest priority channel with the others rotating accordingly. The next lower channel from the channel serviced has highest priority on the following request. Priority rotates every time control of the system busses is returned to the processor.

## Rotating Priority



With Rotating Priority in a single chip DMA system, any device requesting service is guaranteed to be recognized after no more than three higher priority services have occurred. This prevents any one channel from monopolizing the system.

Regardless of which priority scheme is chosen, priority is evaluated every time a HLDA is returned to the 82C37A.
Compressed Timing - In order to achieve even greater throughput where system characteristics permit, the 82C37A can compress the transfer time to two clock cycles. From Figure 12 it can be seen that state S3 is used to extend the access time of the read pulse. By removing state S3, the read pulse width is made equal to the write pulse width and a transfer consists only of state S2 to change the address and state S 4 to perform the read/write. S1 states will still occur when A8-A15 need updating (see Address Generation). Timing for compressed transfers is found in Figure 15. $\overline{E O P}$ will be output in S2 if compressed timing is selected. Compressed timing is not allowed for memory-to-memory transfers.
Address Generation - In order to reduce pin count, the 82C37A multiplexes the eight higher order address bits on
the data lines. State S1 is used to output the higher order address bits to an external latch from which they may be placed on the address bus. The falling edge of Address Strobe (ADSTB) is used to load these bits from the data lines to the latch. Address Enable (AEN) is used to enable the bits onto the address bus through a three-state enable. The lower order address bits are output by the 82C37A directly. Lines AO-A7 should be connected to the address bus. Figure 12 shows the time relationships between CLK, AEN, ADSTB, DB0-DB7 and AO-A7.

During Block and Demand Transfer mode service, which include multiple transfers, the addresses generated will be sequential. For many transfers the data held in the external address latch will remain the same. This data need only change when a carry or borrow from A7 to A8 takes place in the normal sequence of addresses. To save time and speed transfers, the 82C37A executes S1 states only when updating of A8-A15 in the latch is necessary. This means for long services, S1 states and Address Strobes may occur only once every 256 transfers, a savings of 255 clock cycles for each 256 transfers.

## Programming

The 82C37A will accept programming from the host processor anytime that HLDA is inactive, and at least one rising clock edge has occurred after HLDA went low. It is the responsibility of the host to assure that programming and HLDA are mutually exclusive.

Note that a problem can occur if a DMA request occurs on an unmasked channel while the 82C37A is being programmed. For instance, the CPU may be starting to reprogram the two byte Address register of channel 1 when channel 1 receives a DMA request. If the $82 C 37 A$ is enabled (bit 2 in the Command register is 0 ), and channel 1 is unmasked, a DMA service will occur after only one byte of the Address register has been reprogrammed. This condition can be avoided by disabling the controller (setting bit 2 in the Command register) or masking the channel before programming any of its registers. Once the programming is complete, the controller can be enabled/unmasked.

After power-up it is suggested that all internal locations be loaded with some known value, even if some channels are unused. This will aid in debugging.

## Register Description

Current Address Register - Each channel has a 16-bit Current Address register. This register holds the value of the address used during DMA transfers. The address is automatically incremented or decremented by one after each transfer and the values of the address are stored in the Current Address register during the transfer. This register is written or read by the microprocessor in successive 8-bit bytes. See Figure 6 for programming information. It may also be reinitialized by an Autoinitialize back to its original value. Autoinitialize takes place only after an EOP. In memory-to-memory mode, the channel 0 Current Address register can be prevented from incrementing or decrementing by setting the address hold bit in the Command register.

Current Word Count Register - Each channel has a 16-Bit Current Word Count register. This register determines the number of transfers to be performed. The actual number of transfers will be one more than the number programmed in the Current Word Count register (i.e., programming a count of 100 will result in 101 transfers). The word count is decremented after each transfer. When the value in the register goes from zero to FFFFH, a TC will be generated. This register is loaded or read in successive 8-bit bytes by the microprocessor in the Program Condition. See Figure 6 for programming information. Following the end of a DMA service it may also be reinitialized by an Autoinitialization back to its original value. Autoinitialization can occur only when an EOP occurs. If it is not Autoinitialized, this register will have a count of FFFFH after TC.

Base Address and Base Word Count Registers - Each channel has a pair of Base Address and Base Word Count registers. These 16-bit registers store the original value of their associated current registers. During Autoinitialize these values are used to restore the current registers to their original values. The base registers are written simultaneously with their corresponding current register in 8-bit bytes in the Program Condition by the microprocessor. See Figure 6 for programming information. These registers cannot be read by the microprocessor.
Command Register - This 8-bit register controls the operation of the 82C37A. It is programmed by the microprocessor and is cleared by Reset or a Master Clear instruction. The following diagram lists the function of the Command register bits. See Figure 4 for Read and Write addresses.

## Command Register



Mode Register - Each channel has a 6-bit Mode register associated with it. When the register is being written to by the microprocessor in the Program Condition, bits 0 and 1 determine which channel Mode register is to be written. When the processor reads a Mode register, bits 0 and 1 will both be ones. See the following diagram and Figure 4 for Mode register functions and addresses.

## Mode Register



Request Register - The 82C37A can respond to requests for DMA service which are initiated by software as well as by a DREQ. Each channel has a request bit associated with it in the 4-bit Request register. These are non-maskable and subject to prioritization by the Priority Encoder network. Each register bit is set or reset separately under software control. The entire register is cleared by a Reset or Master Clear instruction. To set or reset a bit, the software loads the proper form of the data word. See Figure 4 for register address coding, and the following diagram for Request register format. A software request for DMA operation can be made in block or single modes. For memory-to-memory transfers, the software request for channel 0 should be set. When reading the Request register, bits 4-7 will always read as ones, and bits $0-3$ will display the request bits of channels 0-3 respectively.

## Request Register



Mask Register - Each channel has associated with it a mask bit which can be set to disable an incoming DREQ. Each mask bit is set when its associated channel produces an $\overline{E O P}$ if the channel is not programmed to Autoinitialize. Each bit of the 4-bit Mask register may also be set or cleared separately or simultaneously under software control. The entire register is also set by a Reset or Master Clear. This disables all hardware DMA requests until a Clear Mask Register instruction allows them to occur. The instruction to separately set or clear the mask bits is similar in form to that used with the Request register. Refer to the following diagram and Figure 4 for details. When reading the Mask register, bits 4-7 will always read as logical ones, and bits 0-3 will display the mask bits of channels $0-3$, respectively. The 4 bits of the mask register may be cleared simultaneously by using the Clear Mask Register command (see software commands section).
Mask Register


All four bits of the Mask register may also be written with a single command.


Status Register - The Status register is available to be read out of the 82C37A by the microprocessor. It contains information about the status of the devices at this point. This information includes which channels have reached a terminal count and which channels have pending DMA requests. Bits 0-3 are set every time a TC is reached by that channel or an external EOP is applied. These bits are cleared upon Reset, Master Clear, and on each Status Read. Bits 4-7 are set whenever their corresponding channel is requesting service, regardless of the mask bit state. If the mask bits are set, software can poll the Status register to determine which channels have DREQs, and selectively clear a mask bit, thus allowing user defined service priority. Status bits 4-7 are updated while the clock is high, and latched on the falling edge. Status Bits 4-7 are cleared upon Reset or Master Clear.
Status Register


Temporary Register - The Temporary register is used to hold data during memory-to-memory transfers. Following the completion of the transfers, the last byte moved can be read by the microprocessor. The Temporary register always contains the last byte transferred in the previous memory-tomemory operation, unless cleared by a Reset or Master Clear.

| OPERATION | A3 | A2 | A1 | AO | $\overline{\text { IOR }}$ | $\overline{\text { IOW }}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Status Register | 1 | 0 | 0 | 0 | 0 | 1 |
| Write Command Register | 1 | 0 | 0 | 0 | 1 | 0 |
| Read Request Register | 1 | 0 | 0 | 1 | 0 | 1 |
| Write Request Register | 1 | 0 | 0 | 1 | 1 | 0 |
| Read Command Register | 1 | 0 | 1 | 0 | 0 | 1 |
| Write Single Mask Bit | 1 | 0 | 1 | 0 | 1 | 0 |
| Read Mode Register | 1 | 0 | 1 | 1 | 0 | 1 |
| Write Mode Register | 1 | 0 | 1 | 1 | 1 | 0 |
| Set First/Last F/F | 1 | 1 | 0 | 0 | 0 | 1 |
| Clear First/Last F/F | 1 | 1 | 0 | 0 | 1 | 0 |
| Read Temporary Register | 1 | 1 | 0 | 1 | 0 | 1 |
| Master Clear | 1 | 1 | 0 | 1 | 1 | 0 |
| Clear Mode Reg. Counter | 1 | 1 | 1 | 0 | 0 | 1 |
| Clear Mask Register | 1 | 1 | 1 | 0 | 1 | 0 |
| Read All Mask Bits | 1 | 1 | 1 | 1 | 0 | 1 |
| Write All Mask Bits | 1 | 1 | 1 | 1 | 1 | 0 |

FIGURE 4. SOFTWARE COMMAND CODES AND REGISTER CODES

## Software Commands

There are special software commands which can be executed by reading or writing to the 82C37A. These commands do not depend on the specific data pattern on the data bus, but are activated by the I/O operation itself. On read type commands, the data value is not guaranteed. These commands are:
Clear First/Last Flip-Flop: This command is executed prior to writing or reading new address or word count information to the 82C37A. This command initializes the flip-flop to a known state (low byte first) so that subsequent accesses to register contents by the microprocessor will address upper and lower bytes in the correct sequence.
Set First/Last Flip-Flop: This command will set the flipflop to select the high byte first on read and write operations to address and word count registers.
Master Clear: This software instruction has the same effect as the hardware Reset. The Command, Status, Request, and Temporary registers, and Internal First/Last Flip-Flop and mode register counter are cleared and the Mask register is set. The 82C37A will enter the Idle cycle.

Clear Mask Register: This command clears the mask bits of all four channels, enabling them to accept DMA requests.

Clear Mode Register Counter: Since only one address location is available for reading the Mode registers, an internal two-bit counter has been included to select Mode registers during read operations. To read the Mode registers, first execute the Clear Mode Register Counter command, then do consecutive reads until the desired channel is read. Read order is channel 0 first, channel 3 last. The lower two bits on all Mode registers will read as ones.

## External EOP Operation

The $\overline{E O P}$ pin is a bidirectional, open drain pin which may be driven by external signals to terminate DMA operation. Because $\overline{\mathrm{EOP}}$ is an open drain pin an external pull-up resistor to VCC is required. The value of the external pull-up resistor used should guarantee a rise time of less than 125 ns. It is important to note that the 82C37A will not accept external $\overline{\mathrm{EOP}}$ signals when it is in an SI (Idle) state. The controller must be active to latch EXT EOP. Once latched, the EXT EOP will be acted upon during the next S2 state, unless the 82C37A enters an idle state first. In the latter case, the latched EOP is cleared. External EOP pulses occurring between active DMA transfers in demand mode will not be recognized, since the 82C37A is in an SI state.

| CHANNEL | REGISTER | OPERATION | $\overline{\text { CS }}$ | IOR | IOW | A3 | A2 | A1 | A0 | $\begin{array}{\|l} \text { FIRST/LAST } \\ \text { FLIP-FLOP } \\ \text { STATE } \end{array}$ | DATA BUS DB0-DB7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | Base and Current Address | Write | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 1 |  | 0 | 0 | 0 | 0 | 0 1 | $\left\lvert\, \begin{aligned} & \text { A0-A7 } \\ & \text { A8-A15 } \end{aligned}\right.$ |
|  | Current Address | Read | 0 | 0 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | 0 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { AO-A7 } \\ & \text { A8-A15 } \end{aligned}$ |
|  | Base and Current Word Count | Write | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { wo-W7 } \\ & \text { W8-W15 } \end{aligned}$ |
|  | Current Word Count | Read | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Wo-W7 } \\ & \text { W8-W15 } \end{aligned}$ |
| 1 | Base and Current Address | Write | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 1 1 | 0 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { AO-A7 } \\ \text { A8-A15 } \end{array}$ |
|  | Current Address | Read | 0 | 0 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 0 | 0 | 1 | 0 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{array}{\|l\|} \text { AO-A7 } \\ \text { A8-A15 } \end{array}$ |
|  | Base and Current Word Count | Write | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 1 | 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { W0-W7 } \\ & \text { W8-W15 } \end{aligned}$ |
|  | Current Word Count | Read | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 1 | 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { W0-W7 } \\ & \text { W8-W15 } \end{aligned}$ |
| 2 | Base and Current Address <br> Current Address <br> Base and Current <br> Word Count <br> Current Word Count | Write |  | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | 0 | 1 | 0 | 1 0 | $0$ | $\begin{aligned} & \text { A0-A7 } \\ & \text { A8-A15 } \end{aligned}$ |
|  |  | Read | 0 | 0 | 1 | 0 | 1 | 0 | 0 0 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { AO-A7 } \\ & \text { A8-A15 } \end{aligned}$ |
|  |  | Write | 0 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | 1 | 0 | 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Wo-w7 } \\ & \text { W8-W15 } \end{aligned}$ |
|  |  | Read | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 0 | 1 | 0 | 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Wo-w7 } \\ & \text { W8-W15 } \end{aligned}$ |
| 3 | Base and Current Address | Write | 0 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | 1 | 1 | 0 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { AO-A7 } \\ & \text { A8-A15 } \end{aligned}$ |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 1 | 1 | 0 0 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { AO-A7 } \\ & \text { A8-A15 } \end{aligned}$ |
|  | Base and Current Word Count Current Word Count | Write | 0 | 1 | 0 | 0 | 1 | 1 | 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Wo-w7 } \\ & \text { W8-W15 } \end{aligned}$ |
|  |  | Read | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 0 | 1 | 0 | 1 | 1 | 1 | $0$ | $\begin{aligned} & \text { W0-W7 } \\ & \text { W8-W15 } \end{aligned}$ |

FIGURE 5. WORD COUNT AND ADDRESS REGISTER COMMAND CODES

## Application Information

Figure 6 shows an application for a DMA system utilizing the 82C37A DMA controller and the 80C88 Microprocessor. In this application, the 82C37A DMA controller is used to improve system performance by allowing an I/O device to transfer data directly to or from system memory.

## Components

The system clock is generated by the 82C84A clock driver and is inverted to meet the clock high and low times required by the 82C37A DMA controller. The four OR gates are used to support the 80C88 Microprocessor in minimum mode by producing the control signals used by the processor to access memory or I/O. A decoder is used to generate chip select for the DMA controller and memory. The most significant bits of the address are output on the address/ data bus. Therefore, the 82C82 octal latch is used to demultiplex the address. Hold Acknowledge (HLDA) and

Address Enable (AEN) are "ORed" together to insure that the DMA controller does not have bus contention with the microprocessor.

## Operation

A DMA request (DREQ) is generated by the I/O device. After receiving the DMA request, the DMA controller will issue a Hold request (HRQ) to the processor. The system busses are not released to the DMA controller until a Hold Acknowledge signal is returned to the DMA controller from the $80 C 88$ processor. After the Hold Acknowledge has been received, addresses and control signals are generated by the DMA controller to accomplish the DMA transfers. Data is transferred directly from the I/O device to memory (or vice versa) with $\overline{\mathrm{IOR}}$ and $\overline{\mathrm{MEMW}}$ (or $\overline{\mathrm{MEMR}}$ and $\overline{\mathrm{OWW}}$ ) being active. Note that data is not read into or driven out of the DMA controller in I/O-to-memory or memory-to-I/O data transfers.


NOTE The address lines need pull-up resistors
FIGURE 6. APPLICATION FOR DMA SYSTEM

Figure 7 shows an application for a DMA system using the 82C37A DMA controller and the 80C286 Microprocessor.

In this application, the system clock comes from the 82C284 clock generator PCLK signal which is inverted to provide proper READY setup and hold times to the DMA controller in an 80C286 system. The Read and Write signals from the DMA controller may be wired directly to the Read/Write control signals from the 82 C 288 Bus

Controller. The octal latch for A8 - A15 from the DMA controller's data bus is on the local 80C286 address bus so that memory chip selects may still be generated during DMA transfers. The transceiver on AO - A7 is controlled by AEN and is not necessary, but may be used to drive a heavily loaded system address bus during transfers. The data bus transceivers simply isolate the DMA controller from the local microprocessor bus and allow programming on the upper or lower half of the data bus.


FIGURE 7. 80C286 DMA APPLICATION

## Absolute Maximum Ratings

Supply Voltage . . . . . ................................... +8.0 Volts Input, Output or I/O Voltage Applied .....GND -0.5 V to VCC +0.5 V Storage Temperature Range . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Junction Temperature $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . . .+175^{\circ} \mathrm{C}$ Lead Temperature (Soldering, Ten Seconds) .............. $+300^{\circ} \mathrm{C}$

Reliability Information
 tion of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range
+4.5 V to $+5.5 \mathrm{~V} \quad$ Operating Temperature Ranges
C82C37A
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
I82C37A . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
M82C37A $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
D.C. Electrical Specifications $\mathrm{VCC}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 37 \mathrm{~A})$
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 37 A$)$
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C37A)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & \text { C82C37A, I82C37A } \\ & \text { M82C37A } \end{aligned}$ |
| VIL | Logical Zero Input Voltage | - | 0.8 | V |  |
| VOH | Output HIGH Voltage | $\begin{gathered} 3.0 \\ \text { vCC }-0.4 \end{gathered}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{aligned} & \mathbf{V} \\ & \mathbf{v} \end{aligned}$ | $\begin{aligned} & 1 \mathrm{OH}=-2.5 \mathrm{~mA} \\ & 1 \mathrm{OH}=-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | Output LOW Voltage | - | 0.4 | V | $I O L=+2.5 \mathrm{~mA}$ all output except $\overline{\mathrm{EOP}}$, $1 O L=+3.2$ for $\overline{E O P}$ pin 36 only. |
| II | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIN}=$ GND or VCC, Pins 6, 7, 11, 12, 13, 16-19 |
| 10 | Output Leakage Current | -10.0 | +10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VOUT = GND or VCC, Pins 1-4, 21-23, } \\ & 26-30,32-40 . \end{aligned}$ |
| 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 | - | 2 | $\mathrm{mA} / \mathrm{MHz}$ | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{CLK}$ FREQ $=$ Maximum, VIN = VCC or GND, Outputs Open |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPE | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | 20 | pF | FREQ $=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| COUT | Output Capacitance | 20 | pF | pF |
| CI/O | I/O Capacitance | 20 |  |  |


| À.C. Electrical Specifications |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PARAMETER | 82C37A-5 |  | 82C237A |  | 82C37A-12 |  | UNITS |
| SYMBOL |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| DMA (Master) Mode |  |  |  |  |  |  |  |  |
| (1)TAEL | AEN HIGH from CLK LOW (S1) Delay Time | - | 175 | - | 105 | - | 50 | ns |
| (2)TAET | AEN LOW from CLK HIGH (SI) Delay Time | - | 130 | - | 80 | - | 50 | ns |
| (3)TAFAB | ADR Active to Float Delay from CLK HIGH | - | 90 | - | 55 | - | 55 | ns |
| (4)TAFC | $\overline{R E A D}$ or WRITE Float Delay from CLK HIGH | - | 120 | - | 75 | - | 50 | ns |
| (5)TAFDB | DB Active to Float Delay from CLK HIGH | - | 170 | - | 135 | - | 90 | ns |
| (6)TAHR | ADR from READ HIGH Hold Time | TCY-100 | - | TCY-75 | - | TCY-65 | - | ns |
| (7)TAHS | DB from ADSTB LOW Hold Time | TCL-18 | - | TCL-18 | - | TCL-18 | - | ns |
| (8)TAHW | ADR from WRITE HIGH Hold Time | TCY-65 | - | TCY-65 | - | TCY-50 | - | ns |
| (9)TAK | DACK Valid from CLK LOW Delay Time | - | 170 | - | 105 | - | 69 | ns |
|  | EOP HIGH from CLK HIGH Delay Time | - | 170 | - | 105 | - | 90 | ns |
|  | EOP LOW from CLK HIGH Delay Time | - | 100 | - | 60 | - | 35 | ns |
| (10)TASM | ADR Stable from CLK HIGH | - | 110 | - | 60 | - | 50 | ns |
| (11)TASS | DB to ADSTB LOW Setup Time | TCH-20 | - | TCH-20 | - | TCH-20 | - | ns |
| (12)TCH | Clock HIGH Time (Transitions 10ns) | 70 | - | 55 | - | 30 | - | ns |
| (13)TCL | Clock LOW Time (Transitions 10ns) | 50 | - | 43 | - | 30 | - | ns |
| (14)TCY | CLK Cycle Time | 200 | - | 125 | - | 80 | - | ns |
| (15)TDCL | CLK HIGH to READ or WRITE LOW Delay | - | 190 | - | 130 | - | 120 | ns |
| (16)TDCTR | READ HIGH from CLK HIGH (S4) Delay Time | - | 190 | - | 115 | - | 80 | ns |
| (17)TDCTW | WRITE HIGH from CLK HIGH (S4) Delay Time | - | 130 | - | 80 | - | 70 | ns |
| (18)TDQ | HRQ Valid from CLK HIGH Delay Time | - | 120 | - | 75 | - | 30 | ns |
| (19)TEPH | EOP Hold Time from CLK LOW (S2) | 90 | - | 90 | - | 50 | - | ns |
| (20)TEPS | EOP LOW to CLK LOW Setup Time | 40 | - | 25 | - | 0 | - | ns |
| (21)TEPW | EOP Pulse Width | 220 | - | 135 | - | 50 | - | ns |
| (22)TFAAB | ADR Valid Delay from CLK HIGH | - | 110 | - | 60 | - | 50 | ns |
| (23)TFAC | READ or WRITE Active from CLK HIGH | - | 150 | - | 90 | - | 50 | ns |
| (24)TFADB | DB Valid Delay from CLK HIGH | - | 110 | - | 60 | - | 45 | ns |

## A.C. Electrical Specifications $\mathrm{VCC}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}$, (Continued) $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 37 \mathrm{~A})$, <br> $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(182 \mathrm{C} 37 \mathrm{~A})$, <br> $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 37 \mathrm{~A})$

| SYMBOL | PARAMETER | 82C37A-5 |  | 82C237A |  | 82C37A-12 |  | UNTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |

DMA (Master) Mode (Continued)

| (25)THS | HLDA Valid to CLK HIGH Setup Time | 75 | - | 45 | - | 10 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (26)TIDH | Input Data from MEMR HIGH Hold Time | 0 | - | 0 | - | 0 | - | ns |
| (27)TIDS | Input Data to MEMR HIGH Setup Time | 155 | - | 90 | - | 45 | - | ns |
| (28)TODH | Output Data from MEMW HIGH Hold Time | 15 | - | 15 | - | TCY-50 | - | ns |
| (29)TODV | Output Data Valid to MEMW HIGH | TCY-35 | - | TCY-35 | - | TCY-10 | - | ns |
| (30)TQS | DREQ to CLK LOW (SI, S4) Setup Time | 0 | - | 0 | - | 0 | - | ns |
| (31)TRH | CLK to READY LOW Hold Time | 20 | - | 20 | - | 10 | - | ns |
| (32)TRS | READY to CLK LOW Setup Time | 60 | - | 35 | - | 15 | - | ns |
| (33)TCLSH | ADSTB HIGH from CLK LOW Delay Time | - | 80 | - | 70 | - | 70 | ns |
| (34)TCLSL | ADSTB LOW from CLK LOW Delay Time | - | 120 | - | 120 | - | 60 | ns |
| (35)TWRRD | READ HIGH Delay from WRITE HIGH | 0 | - | 0 | - | 5 | - | ns |
| (36)TRLRH | READ Pulse Width, Normal Timing | 2TCY-60 | - | 2TCY-60 | - | 2TCY-55 | - | ns |
| (37)TSHSL | ADSTB Pulse Width | TCY-80 | - | TCY-50 | - | TCY-35 | - | ns |
| (38)TWLWHA | Extended WRITE Pulse Width | 2TCY-100 | - | 2TCY-85 | - | 2TCY-80 | - | ns |
| (39)TWLWH | WRITE Pulse Width | TCY-100 | - | TCY-85 | - | TCY-80 | - | ns |
| (40)TRLRHC | READ Pulse Width, Compressed | TCY-60 | - | TCY-60 | - | TCY-55 | - | ns |
| (56)TAVRL | ADR Valid to READ LOW | 17 | - | 17 | - | 17 | - | ns |
| (57)TAVWL | ADR Valid to WRITE LOW | 7 | - | 7 | - | 7 | - | ns |
| (58)TRHAL | READ HIGH to AEN LOW | 15 | - | 15 | - | 15 | - | ns |
| (59)TRHSH | READ HIGH to ADSTB HIGH | 13 | - | 13 | - | 13 | - | ns |
| (60) TWHSH | WRITE HIGH to ADSTB HIGH | 15 | - | 15 | - | 15 | - | ns |
| (61)TDVRL | DACK Valid to READ LOW | 25 | - | 25 | - | 25 | - | ns |
| (62)TDVWL | DACK Valid to WRITE LOW | 25 | - | 25 | $\bullet$ | 25 | - | ns |
| (63)TRHDI | READ HIGH to DACK Inactive | 12 | - | 12 | - | 12 | - | ns |
| (64)TAZRL | ADR Float to READ LOW | -2.5 | - | -2.5 | - | -2.5 | - | ns |

Peripheral (Slave) Mode

| (41)TAR | ADR Valid or CS LOW to READ LOW | 10 | - | 10 | - | 0 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (42)TAWL | ADR Valid to WRITE LOW Setup Time | 0 | - | 0 | - | 0 | - | ns |
| (43)TCWL | CS LOW to WRITE LOW Setup Time | 0 | - | 0 | - | 0 | - | ns |
| (44)TDW | Data Valid to WRITE HIGH Setup Time | 150 | - | 100 | - | 60 | - | ns |

A.C. Electrical Specifications $\mathrm{VCC}=+5.0 \mathrm{~V} \pm 10 \%$, GND $=0 \mathrm{~V}$, (Continued) $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C37A),
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (182C37A),
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C37A)

| SYMBOL | PARAMETER | 82C37A-5 |  | 82C237A |  | 82C37A-12 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |

Peripheral (Slave) Mode (Continued)

| (45)TRA | ADR or $\overline{C S}$ Hold from $\overline{\text { READ }}$ HIGH | 0 | - | 0 | - | 0 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (46)TRDE | Data Access from $\overline{\text { READ }}$ | - | 140 | - | 120 | - | 80 | ns |
| (47)TRDF | DB Float Delay from $\overline{\text { READ }}$ HIGH | 5 | 85 | 5 | 85 | 5 | 55 | ns |
| (48)TRSTD | Power Supply HIGH to RESET LOW Setup Time | 500 | - | 500 | - | 500 | - | ns |
| (49)TRSTS | RESET to First $\overline{\text { IOR }}$ or $\overline{\text { IOW }}$ | 2TCY | - | 2TCY | - | 2TCY | - | ns |
| (50)TRSTW | RESET Pulse Width | 300 | - | 300 | - | 300 | - | ns |
| (51)TRW | $\overline{\text { READ Pulse Width }}$ | 200 | - | 155 | - | 85 | - | ns |
| (52)TWA | ADR from WRITE HIGH Hold Time | 0 | - | 0 | - | 0 | - | ns |
| (53)TWC | $\overline{\text { CS }}$ HIGH from $\overline{\text { WRITE }}$ HIGH Hold Time | 0 | - | 0 | - | 0 | - | ns |
| (54)TWD | Data from WRITE HIGH Hold Time | 10 | - | 10 | - | 10 | - | ns |
| (55)TWWS | WRITE Pulse Width | 150 | - | 100 | - | 45 | - | ns |

## Waveforms

SLAVE MODE WRITE TIMING


FIGURE 8. SLAVE MODE TIMING
NOTE Successive WRITE accesses to the 82C37A must allow at least TCY as recovery time between accesses. A TCY recovery time must be allowed before executing a WRITE access after a READ access

SLAVE MODE READ TIMING


FIGURE 9. SLAVE MODE READ

NOTE Successive READ accesses to the 82C37A must allow at least TCY as recovery time between accesses A TCY recovery time must be allowed before executing a WRITE access after a READ access.

## iVaveforms

DMA TRANSFER TIMING


FIGURE 10. DMA TRANSFER

## Waveforms

MEMORY-TO-MEMORY TRANSFER TIMING


FIGURE 11. MEMORY-TO-MEMORY TRANSFER

## Waveforms

## READY TIMING



FIGURE 12. READY
NOTE: READY must not transition during the specified setup and hold tımes

COMPRESSED TRANSFER TIMING


FIGURE 13. COMPRESSED TRANSFER

| Waveforms \| A.C. Test Circuits | A.C. Test Circuits |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| RESET TIMING |  |  |  |  |
|  |  |  |  |  |
| FIGURE 14. RESET | *Includes STR <br> TEST COND | and FIXT | Capacitan |  |
|  | PINS | v1 | R1 | C1 |
|  | All Outputs Except EOP | 1.7 V | $520 \Omega$ | 100pF |
|  | EOP | vcc | $1.6 \mathrm{~K} \Omega$ | 50pF |

A.C. Testing Input, Output Waveforms

A.C. Testing: All A C. Parameters tested as per test circuits. Input RISE and FALL times are driven at InsN.

## Features

- 10 MHz or 8 MHz Clock Input Frequency
- Compatible with NMOS 8254
- Enhanced Version of NMOS 8253
- Three Independent 16 Bit Counters
- Six Programmable Counter Modes
- Status Read Back Command
- Binary or BCD Counting
- Fully TTL Compatible
- Single 5V Power Supply
- Low Power
- ICCSB $\qquad$
- ICCOP $\qquad$ 10 mA at 8 MHz
- Operating Temperature Ranges
- C82C54 . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I82C54 . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C54 . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 82 C 54 is a high performance CMO $\subseteq$ Programmable Interval Timer manufactured using an advar, :ed 2 micron CMOS process.

The 82C54 has three independently programmable and functional 16-bit counters, each capable of handling clock input frequencies of up to 8 MHz (82C54) or 10 MHz (82C54-10).

The high speed and industry standard configuration of the 82 C 54 make it compatible with the Harris 80C86, 80C88, and 80C286 CMOS microprocessors along with many other industry standard processors. Six programmable timer modes allow the 82C54 to be used as an event counter, elapsed time indicator, programmable one-shot, and many other applications. Static CMOS circuit design insures low power operation.

The Harris advanced CMOS process results in a significant reduction in power with performance equal to or greater than existing equivalent products.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 8MHz | 10MHz |
| :---: | :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C54 | CP82C54-10 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C54 | IP82C54-10 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C54 | CS82C54-10 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C54 | IS82C54-10 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C54 | CD82C54-10 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C54 | ID82C54-10 |
| SMD \# 8406501JA | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C54/B | MD82C54-10/B |
| LCC, SMD\# 84065013A | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C54/B | MR82C54-10/B |

## Pinouts



## Functional Diagram



COUNTER INTERNAL BLOCK DIAGRAM

## Pin Description

| SYMBOL | DIP PIN NUMBER | TYPE | DEFINITION |
| :---: | :---: | :---: | :---: |
| D7-D0 | 1-8 | 1/0 | DATA: Bi -directional three state data bus lines, connected to system data bus. |
| CLK 0 | 9 | 1 | CLOCK 0: Clock input of Counter 0. |
| OUT O | 10 | 0 | OUT 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 | OUT2: Output of Counter 2. |
| CLK 2 | 18 | I | CLOCK 2: Clock input of Counter 2. |
| AO, A1 | 19-20 | I | 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{R D}$ and $\overline{\mathrm{WR}}$ signals. $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are ignored otherwise. |
| $\overline{\mathrm{RD}}$ | 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 |  | VCC: The +5 V power supply Pin. A $0.1 \mu \mathrm{~F}$ capacitor between pins VCC and GND is recommended for decoupling. |

## 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 three-state, bi-directional, 8-bit buffer is used to interface the 82C54 to the system bus (see Figure 1).


FIGURE 1. DATA BUS BUFFER AND READ/WRITE LOGIC FUNCTIONS

## 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 WR 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 WR are ignored unless the 82C54 has been selected by holding CS low.

## Control Word Register

The Control Word Register (Figure 2) is selected by the Read/Write Logic when $\mathrm{A} 1, \mathrm{AO}=11$. If the CPU then does a write operation to the 82C54, 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. The counters are fully independent. Each Counter may operate in a different Mode.


FIGURE 2. CONTROL WORD REGISTER AND COUNTER FUNCTIONS

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.

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 communicates 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 CRM and CRL (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. CRM and CRL are 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.


FIGURE 3. COUNTER INTERNAL BLOCK DIAGRAM

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 AO, A1 connect to the AO, A1 address bus signals of the CPU. The $\overline{\mathrm{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.

## Operational Description

## 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 $A 1, A O=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, AO inputs are used to select the Counter to be written into. The format of the initial count is determined by the Control Word used.


FIGURE 4. 82C54 SYSTEM INTERFACE

## 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.

## Control Word Format

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

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC1 | SC0 | RW1 | RW0 | M2 | M1 | M0 | BCD |

SC - Select Counter:

| SC1 | SCO |  |
| :---: | :---: | :--- |
| 0 | 0 | Select Counter 0 |
| 0 | 1 | Select Counter 1 |
| 1 | 0 | Select Counter 2 |
| 1 | 1 | Read-Back Command (See Read Operations) |

RW - Read/Write:

| RW1 | RW0 |  |
| :---: | :---: | :--- |
| 0 | 0 | Counter Latch Command (See Read 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. |

M-Mode:

| M2 | M1 | M0 |  |
| :---: | :---: | :---: | :--- |
| 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 |

BCD - Binary Coded Decimal:

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

NOTE: Don't Care bits $(X)$ should be 0 to insure compatibility with future products.

FIGURE 5. CONTROL WORD FORMAT

|  | A1 | A0 |
| :--- | :---: | :---: |
| Control Word - Counter 0 | 1 | 1 |
| LSB of Count - Counter 0 | 0 | 0 |
| MSB of Count - Counter 0 | 0 | 0 |
| Control Word - Counter 1 | 1 | 1 |
| LSB of Count - Counter 1 | 0 | 1 |
| MSB of Count - Counter 1 | 0 | 1 |
| Control Word - Counter 2 | 1 | 1 |
| LSB of Count - Counter 2 | 1 | 0 |
| MSB of Count - Counter 2 | 1 | 0 |


|  | A1 | AO |
| :--- | :---: | :---: |
| Control Word - Counter 0 | 1 | 1 |
| Control Word - Counter 1 | 1 | 1 |
| Control Word - Counter 2 | 1 | 1 |
| LSB of Count - Counter 2 | 1 | 0 |
| LSB of Count - Counter 1 | 0 | 1 |
| LSB of Count - Counter 0 | 0 | 0 |
| MSB of Count - Counter 0 | 0 | 0 |
| MSB of Count - Counter 1 | 0 | 1 |
| MSB of Count - Counter 2 | 1 | 0 |


|  | A1 | A0 |
| :--- | :---: | :---: |
| Control Word - Counter 2 | 1 | 1 |
| Control Word - Counter 1 | 1 | 1 |
| Control Word - Counter 0 | 1 | 1 |
| LSB of Count - Counter 2 | 1 | 0 |
| MSB of Count - Counter 2 | 1 | 0 |
| LSB of Count - Counter 1 | 0 | 1 |
| MSB of Count - Counter 1 | 0 | 1 |
| LSB of Count - Counter 0 | 0 | 0 |
| MSB of Count - Counter 0 | 0 | 0 |


|  | A1 | A0 |
| :--- | :---: | :---: |
| Control Word - Counter 1 | 1 | 1 |
| Control Word - Counter 0 | 1 | 1 |
| LSB of Count - Counter 1 | 0 | 1 |
| Control Word - Counter 2 | 1 | 1 |
| LSB of Count - Counter 0 | 0 | 0 |
| MSB of Count - Counter 1 | 0 | 1 |
| LSB of Count - Counter 2 | 1 | 0 |
| MSB of Count - Counter 0 | 0 | 0 |
| MSB of Count - Counter 2 | 1 | 0 |

NOTE: In all four examples, all counters are programmed to Read/Write two-byte counts. These are only four of many programming sequences.
FIGURE 6. A FEW POSSIBLE PROGRAMMING SEQUENCES

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.

## Counter Latch Command

The other method for reading the Counters 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 A1, AO = 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 O=11 ; \overline{C S}=0 ; \overline{R D}=1 ; \overline{W R}=0$

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC1 | SC0 | 0 | 0 | X | X | X | X |

SC1, SCO - specify counter to be latched

| SC1 | SC0 | COUNTER |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | Read-Back Command |

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.

## 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" the counting element (CE). This allows 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$.
$A O, A 1=11 ; \overline{C S}=0 ; \overline{R D}=1 ; \overline{W R}=0$

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | $\overline{\text { COUNT }}$ | $\overline{\text { STATUS }}$ | CNT 2 | CNT 1 | CNT 0 | 0 |

D5: $0=$ Latch count of selected Counter(s)
D4: $0=$ Latch status of selected Counter(s)
D3: $\quad 1=$ Select Counter 2
D2: 1 = Select Counter 1
D1: 1 = Select Counter 0
DO: Reserved for future expansion; Must be 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 latched. 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 D4 $=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.

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OUTPUT | NULL <br> COUNT | RW1 | RW0 | M2 | M1 | M0 | BCD |

D7 $1=$ Out pin is 1
$0=$ Out pin is 0
D61 $=$ Null count
$0=$ Count available for reading
D5-DO $=$ Counter programmed mode (See Figure 5)
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 counter 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:
CAUSES:
A. Write to the control word register: (1) . . . . . . . . . Null Count $=1$
B. Write to the count register (CR): (2) . . . . . . . . . . . Null Count $=1$
C. New count is loaded into CE (CR - CE) ....... 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 significant 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 D5, D4 $=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.

| COMMAND |  |  |  |  |  |  |  | DESCRIPTION | RESULT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  | Count and Status Latched for <br> Counter 0 |
| 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | Read Back Count and Status <br> of Counter 0 | Status Latched for Counter 1 |
| 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | Read-Back Status of Counter 1 | Stus Latched for Counter 2, |
| But Not Counter 1 |  |  |  |  |  |  |  |  |  |

FIGURE 11. READ-BACK COMMAND EXAMPLE

| $\overline{\mathbf{C S}}$ | $\overline{\mathbf{R D}}$ | $\overline{\text { WR }}$ | A1 | AO |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 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 (Three-State) |
| 1 | X | X | X | X | No-Operation (Three-State) |
| 0 | 1 | 1 | X | X | No-Operation (Three-State) |

FIGURE 12. READ/WRITE OPERATIONS SUMMARY

## Mode Definitions

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

## 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 initial count of $N$, OUT does not go high until $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 one-shot 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.
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 from the new count. Otherwise, the new count will be loaded at the end of the current counting cycle.


NOTE: The following conventions apply to all mode timing diagrams.

1. Counters are programmed for binary (not BCD) counting and for reading/writing least significant byte (LSB) only.
2. The counter is always selected (CS always low).
3. CW stands for "Control Word"; CW = 10 means a control word of 10, Hex is written to the counter.
4. LSB stands for Least significant "byte" of count.
5. Numbers below diagrams are count values. The lower number is the least significant byte The upper number is the most significant byte. Since the counter is programmed to read/write LSB only, the most significant byte cannot be read.
6. N stands for an undefined count.
7. Vertical lines show transitions between count values.


FIGURE 14. MODE 1

FIGURE 13. MODE 0

## 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 of 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. This allows the Counter to be synchronized by software also.


FIGURE 15. MODE 2

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 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 is loaded on one CLK pulse, decremented by one on the next CLK pulse, and then decremented by two on succeeding CLK pulses. When the count expires, OUT goes low and the Counter is reloaded with the initial count. The count is decremented by three on the next CLK pulse, and then by two on succeeding CLK pulses. When the count expires, OUT goes high again and the Counter is reloaded with the initial count. 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 then go high again. The counting sequence is "Triggered" by writing the initial count.

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


FIGURE 17. MODE 4

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 $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.

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.


FIGURE 18. MODE 5

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 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 logic level is sampled on the rising edge of CLK. In modes $1,2,3$ and 5 the GATE input is rising-edge sensitive. In these Modes, a rising edge of Gate (trigger) sets an edge-sensitive flip-flop in the Counter. This flip-flop is then sampled on the next rising edge of CLK. The flip-flop is reset immediately 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 $2^{16}$ for binary counting and $10^{4}$ 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 | $\begin{aligned} & \text { LOW } \\ & \text { OR GOING } \\ & \text { LOW } \end{aligned}$ | RISING | 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 | 1) Disables counting | - | Enables counting |
| 5 | - | Initiates counting | - |

FIGURE 19. GATE PIN OPERATIONS SUMMARY

| MODE | MIN <br> COUNT | MAX <br> COUNT |
| :---: | :---: | :---: |
| 0 | 1 | 0 |
| 1 | 1 | 0 |
| 2 | 2 | 0 |
| 3 | 2 | 0 |
| 4 | 1 | 0 |
| 5 | 1 | 0 |

NOTE: $O$ is equivalent to $2^{16}$ for binary counting and $10^{4}$ for $B C D$ counting.
FIGURE 20. MINIMUM AND MAXIMUM INITIAL COUNTS

## Absolute Maximum Ratings



## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {c }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $47^{\circ} \mathrm{C} / \mathrm{N}$ | $8^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $49^{\circ} \mathrm{C} / \mathrm{N}$ | $5^{\circ} \mathrm{C} / \mathrm{N}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | .1.07W |
| Ceramic LCC Package |  | .1.03W |
| Gate Count |  | 50 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range. +4.5 V to +5.5 V

Operating Temperature Range
C82C54, C82C54-10.
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
182C54, I82C54-10
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ M82C54, M82C54-10
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
DC Electrical Specifications $\quad 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} 54, \mathrm{C} 82 \mathrm{C} 54-10)$
$T A=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (182C54, 182C54-10)
$\mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C54, M82C54-10)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | 2.0 | - | V | C82C54, 182C54 |
|  |  | 2.2 | - | V | M82C54 |
| VIL | Logical Zero Input Voltage | - | 0.8 | V |  |
| VOH | Output HIGH Voltage | 3.0 | - | V | $1 \mathrm{OH}=-2.5 \mathrm{~mA}$ |
|  |  | VCC-0.4 | - | V | $1 \mathrm{OH}=-100 \mu \mathrm{~A}$ |
| VOL | Output LOW Voltage | - | 0.8 | V | $1 \mathrm{OL}=+2.5 \mathrm{~mA}$ |
| II | Input Leakage Current | -1 | +1 | $\mu \mathrm{A}$ | VIN = GND or VCC <br> DIP Pins 9,11,14-16,18-23 |
| 10 | Output Leakage Current | -10 | +10 | $\mu \mathrm{A}$ | VOUT $=$ GND or VCC DIP Pins 1-8 |
| ICCSB | Standby Power Supply Current | $\bullet$ | 10 | $\mu \mathrm{A}$ | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{GND}$ or VCC, Outputs Open, Counters Programmed |
| ICCOP | Operating Power Supply Current | - | 10 | mA | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V}, \mathrm{CLKO}= \\ & \text { CLK1 }=\text { CLK } 2=8 \mathrm{MHz}, \\ & \text { VIN }=\text { GND or VCC, } \\ & \text { Outputs Open } \end{aligned}$ |

Capacitance $\mathrm{TA}=+25^{\circ} \mathrm{C}$; All Measurements Referenced to Device GND, Note 1

| SYMBOL | PARAMETER | TYP | UNTTS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :--- |
| CIN | Input Capacitance | 15 | pF | FREQ $=1 \mathrm{MHz}$ |
| COUT | Output Capacitance | 15 | pF | FREQ $=1 \mathrm{MHz}$ |
| CI/O | I/O Capacitance | 15 | pF | FREQ $=1 \mathrm{MHz}$ |

NOTE:

1. Not tested, but characterized at initial design and at major process/design changes.

AC Electrical Specifications $\quad V C C=+5.0 \mathrm{~V} \pm 10 \%, T A=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C82C54}, \mathrm{C} 82 \mathrm{C} 54-10)$ $T A=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(182 \mathrm{C} 54,182 \mathrm{C} 54-10)$
TA $=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C54, M82C54-10)

| SYMBOL | PARAMETER |  |  | PRELIMINARY |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 82 C 54 |  | 82C54-10 |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |

READ CYCLE

| $(1)$ | TAR | Address Stable Before $\overline{\mathrm{RD}}$ | 30 | - | 10 | - | ns | 1 |
| :---: | :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $(2)$ | TSR | $\overline{\mathrm{CS}}$ Stable Before $\overline{\mathrm{RD}}$ | 0 | - | 0 | - | ns | 1 |
| $(3)$ | TRA | Address Hold Time After $\overline{\mathrm{RD}}$ | 0 | - | 0 | - | ns | 1 |
| $(4)$ | TRR | $\overline{\mathrm{RD}}$ Pulse Width | 150 | - | 95 | - | ns | 1 |
| $(5)$ | TRD | Data Delay from $\overline{\mathrm{RD}}$ | - | 120 | - | 85 | ns | 1 |
| $(6)$ | TAD | Data Delay from Address | - | 210 | - | 185 | ns | 1 |
| $(7)$ | TDF | $\overline{\mathrm{RD}}$ to Data Floating | 5 | 85 | 5 | 65 | ns | 2, Note 1 |
| $(8)$ | TRV | Command Recovery Time | 200 | - | 165 | - | ns |  |

WRITE CYCLE

| $(9)$ | TAW | Address Stable Before $\overline{\mathrm{WR}}$ | 0 | - | 0 | - | ns |  |
| :---: | :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $(10)$ | TSW | $\overline{\mathrm{CS}}$ Stable Before $\overline{\mathrm{WR}}$ | 0 | - | 0 | - | ns |  |
| $(11)$ | TWA | Address Hold Time After $\overline{\mathrm{WR}}$ | 0 | - | 0 | - | ns |  |
| $(12)$ | TWW | $\overline{\mathrm{WR}}$ Pulse Width | 95 | - | 95 | - | ns |  |
| $(13)$ | TDW | Data Setup Time Before $\overline{\mathrm{WR}}$ | 140 | - | 95 | - | ns |  |
| $(14)$ | TWD | Data Hold Time After $\overline{\mathrm{WR}}$ | 25 | - | 0 | - | ns |  |
| $(15)$ | TRV | Command Recovery Time | 200 | - | 165 | - | ns |  |

## CLOCK AND GATE

| $(16)$ | TCLK | Clock Period | 125 | DC | 100 | DC | ns | 1 |
| :---: | :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $(17)$ | TPWH | High Pulse Width | 60 | - | 30 | - | $n s$ | 1 |
| $(18)$ | TPWL | Low Pulse Width | 60 | - | 40 | - | $n s$ | 1 |
| $(19)$ | TR | Clock Rise Time | - | 25 | - | 25 | ns |  |
| $(20)$ | TF | Clock Fall Time | - | 25 | - | 25 | ns |  |
| $(21)$ | TGW | Gate Width High | 50 | - | 50 | - | ns | 1 |
| $(22)$ | TGL | Gate Width Low | 50 | - | 50 | - | ns | 1 |
| $(23)$ | TGS | Gate Setup Tıme to CLK | 50 | - | 40 | - | ns | 1 |
| $(24)$ | TGH | Gate Hold Time After CLK | 50 | - | 50 | - | ns | 1 |
| $(25)$ | TOD | Output Delay from CLK | - | 150 | - | 100 | ns | 1 |
| $(26)$ | TODG | Output Delay from Gate | - | 120 | - | 100 | ns | 1 |
| $(27)$ | TWO | OUT Delay from Mode Write | - | 260 | - | 240 | ns | 1 |
| $(28)$ | TWC | CLK Delay for Loading | 0 | 55 | 0 | 55 | ns | 1 |
| $(29)$ | TWG | Gate Delay for Sampling | -5 | 40 | -5 | 40 | ns | 1 |
| $(30)$ | TCL | CLK Setup for Count Latch | -40 | 40 | -40 | 40 | ns | 1 |

NOTE:

1. Not tested, but characterized at inital design and at major process/design changes.

Timing Waveforms
wRite


READ

recovery


CLOCK AND GATE


## Burn-In Circuits

MD 82 C54 CERAMIC DIP


MR 82C54 CERAMIC LCC
$V C C=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$,
GND $=0 \mathrm{~V}$
$\mathrm{VIN}=45 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to 0.4 V
$R 1=47 \mathrm{k} \Omega \pm 5 \%$
$R 2=1.0 \mathrm{k} \Omega \pm 5 \%$
$R 3=2.7 \mathrm{k} \Omega \pm 5 \%$
$R 4=1.8 \mathrm{k} \Omega \pm 5 \%$
$R 5=1.2 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{C} 1=001 \mu \mathrm{~F}$ Minimum
$\mathrm{fO}=100 \mathrm{kHz} \pm 10 \%$
$\mathrm{f} 1=\mathrm{f0} / 2, \mathrm{f} 2=\mathrm{f} 1 / 2, \ldots \mathrm{f} 12=\mathrm{f} 11 / 2$


## CMOS Programmable <br> Peripheral Interface

## 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 the 80C86, 80C88 and other microprocessors.

Static CMOS circuit design insures low operating power. TTL compatibility over the full military temperature range and bus hold circuitry eliminate the need for pull-up resistors. The Harris advanced SAJI process results in performance equal to or greater than existing functionally equivalent products at a fraction of the power.

## Pin Description

| SYMBOL | DIP PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| vcc | 26 |  | VCC: the +5 V power supply pin. $\mathrm{A} 0.1 \mu \mathrm{~F}$ capacitor between pins 26 and 7 is recommended for decoupling. |
| GND | 7 |  | GROUND |
| D0-D7 | 27-34 | I/O | DATA BUS: The Data Bus lines are bidirectional three-state pins connected to the system data bus. |
| RESET | 35 | 1 | RESET: A high on this input clears the control register and all ports (A, B, C) are set to the input mode with the "Bus Hold" circuitry turned on. |
| $\overline{\text { cs }}$ | 6 | 1 | CHIP SELECT: Chip select is an active low input used to enable the 82C55A onto the Data Bus for CPU communications. |
| $\overline{\mathrm{RD}}$ | 5 | 1 | READ: Read is an active low input control signal used by the CPU to read status information or data via the data bus. |
| $\overline{W R}$ | 36 | 1 | WRITE: Write is an active low input control signal used by the CPU to load control words and data into the 82C55A. |
| A0-A1 | 8,9 | 1 | ADDRESS: These input signals, in conjunction with the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs, control the selection of one of the three ports or the control word register. AO and A1 are normally connected to the least significant bits of the Address Bus AO, A1). |
| PAO-PA7 | 1-4, 37-40 | 1/0 | PORT A: 8 Bit input and output port. Both bus hold high and bus hold low circuitry are present on this port. |
| PB0-PB7 | 18-25 | 1/0 | PORT B: 8 Bit input and output port. Bus hold high circuitry is present on this port. |
| PCO-PC7 | 10-17 | 1/O | PORT C: 8 Bit input and output port. Bus hold high circuitry is present on this port. |

## Functional Description



## Functional Description

## Data Bus Buffer

This three-state bi-directional 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.
(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 A1) Port Select 0 and Port Select 1. These input signals, in conjunction with the RD and WR inputs, control the selection of one of the three ports or the control word register. They are normally connected to the least significant bits of the address bus (AO and A1).

| 82C55A BASIC OPERATION |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A1 | AO | RD | WR | CS | INPUT OPERATION (READ) |
| 0 | 0 | 0 | 1 | 0 | Port A $\Rightarrow$ Data Bus |
| 0 | 1 | 0 | 1 | 0 | Port B $\Rightarrow$ Data Bus |
| 1 | 0 | 0 | 1 | 0 | Port $\mathrm{C} \Rightarrow$ Data Bus |
| 1 | 1 | 0 | 1 | 0 | Control Word $\Rightarrow$ Data Bus |
| OUTPUT OPERATION (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$ Three-State |
| X | X | 1 | 1 | 0 | Data Bus $\Rightarrow$ Three-State |



FIGURE 1. 82C55A BLOCK DIAGRAM. DATA BUS BUFFER, READ/WRITE, GROUP A \& B CONTROL LOGIC FUNCTIONS
(RESET) Reset. A "high" on this input initializes the control register to $9 B h$ 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 $400 \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-C0)
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, D 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. See Figure 2a.
Port B One 8 bit data input/output latch/buffer and one 8 bit data input buffer. See Figure 2b.
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$. See Figure 2 b .


FIGURE 2. PORT A, PORT C BUS-HOLD CONFIGURATION

## Operational Description

## Mode Selection

There are three basic modes of operation than 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 to pullup or pulldown resistors in all-CMOS designs. The control word register will contain 9Bh. 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. Any port programmed as an output port is initialized to all zeros when the control word is written.


FIGURE 3. BASIC MODE DEFINITIONS AND BUS INTERFACE


FIGURE 4. MODE DEFINITION FORMAT

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 inter-rupt-driven basis.

The mode definitions and possible mode conbinations 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 support almost any peripheral device with no external logic. Such design represents the maximum use of the available pins.

Single Bit Set/Reset Feature (Figure 5)
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.

CONTROL WORD


FIGURE 5. BIT SET/RESET FORMAT

## 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 associated 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 Flip-Flop Definition:

(BIT-SET)-INTE is SET - Interrupt Enable
(BIT-RESET)-INTE is RESET - Interrupt Disable
NOTE: All Mask flip-flops are automatıcally reset during mode selection and device Reset.

## Operating Modes

Mode 0 (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 0 Basic Functional Definitions:

- Two 8 bit ports and two 4 bit ports
- Any Port can be input or output
- Outputs are latched
- Input are not latched
- 16 different Input/Output configurations possible

MODE O PORT DEFINITION

| A |  | B |  | GROUP A |  |  | GROUP B |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D4 | D3 | D1 | D0 | PORT A | PORT C (Upper) | \# | PORT B | PORT C (Lower) |
| 0 | 0 | 0 | 0 | Output | Output | 0 | Output | Outp |
| 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 | Inpu | 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 (Basic Input)


MODE 0 (Basic Output)


MODE 0 CONFIGURATIONS

CONTROL WORD \#0


CONTROL WORD \#2

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |



CONTROL WORD \#1

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |



CONTROL WORD \#3

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |





## 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 "hand shaking" signals. In mode 1, port A and port B use the lines on port $C$ to generate or accept these "hand shaking" signals.

CONTROL WORD \#14

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{7}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 |



CONTROL WORD \#15

| $\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 | 1 | 1 | 0 | 1 | 1 |



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.


## Input Control Signal Definition

(Figures 6 and 7)

## 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 and input device is requesting service. INTR is set by the condition: $\overline{\text { 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 PC4.

## INTE B

Controlled by bit set/reset of PC2.


FIGURE 6. MODE 1 INPUT


FIGURE 7. MODE 1 (STROBED INPUT)

## Output Control Signal Definition

## (Figures 8 and 9)

$\overline{\text { OBF }}$ (Output Buffer Full F/F). The $\overline{\mathrm{OBF}}$ output will go "low" to indicate that the CPU has written data out to the specified port. This does not mean valid data is sent out of the part at this time since $\overline{O B F}$ can go true before data is available. Data is guaranteed valid at the rising edge of $\overline{O B F}$. See Note 1. The OBF F/F will be set by the rising edge of the WR input and reset by $\overline{A C K}$ input being low.

ACK (Acknowledge Input). A "low" on this input informs the 82C55A that the data from Port A or Port B is ready to be accepted. In essence, a response from the peripheral device indicating that is is rady to accept data. See Note 1.

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 ACK is a "one", OBF 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 PC6.

## INTE B

Controlled by Bit Set/Reset of PC2.
NOTE: 1. To strobe data into the peripheral device, the user must operate the strobe line in a hand shaking mode. The user needs to send $\overline{O B F}$ to the peripheral device, generates an $\overline{A C K}$ from the peripheral device and then latch data into the peripheral device on the rising edge of $\overline{\mathrm{OBF}}$.


FIGURE 8. MODE 1 OUTPUT


FIGURE 9. MODE 1 (STROBED OUTPUT)


PORT A - (STROBED INPUT) PORT B - (STROBED OUTPUT)


PORT A - (STROBED OUTPUT) PORT B - (STROBED INPUT)

FIGURE 10. COMBINATIONS OF MODE 1

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.

## Operating Modes

## Mode 2 (Strobed Bi-directional 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 (bi-directional bus I/O). "Hand shaking" 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)


## Bi-directional Bus I/O Control Signal Definition

(Figures 11, 12, 13, 14)
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.

ACK (Acknowledge). A "low" on this input enables the three-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 PC4.

## 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 PC4.

CONTROL WORD

$\mathrm{C}_{20}$
1 = INPUT
$0=$ OUTPUT

PORT B
1 = INPUT $0=$ OUTPUT

GROUP B MODE $0=$ MODE 0

FIGURE 11. MODE CONTROL WORD


FIGURE 12. MODE 2


FIGURE 13. MODE 2 (BI-DIRECTIONAL)
NOTE: Any sequence where $\overline{W R}$ occurs before $\overline{A C K}$ and $\overline{\text { STB }}$ occurs before RD is permissible.
(INTR = IBF • MASK • STB • RD + OBF • MASK • ACK • WR)


FIGURE 14. MODE 2 COMBINATIONS

|  | MODE 0 |  | MODE 1 |  | MODE 2 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | IN | OUT | IN | OUT | GROUP A ONLY |
| PAO | In | Out | In | Out | $\rightarrow$ |
| PA1 | In | Out | In | Out | $\longrightarrow$ |
| PA2 | In | Out | In | Out | $\longrightarrow$ |
| PA3 | In | Out | In | Out | $\longrightarrow$ |
| PA4 | In | Out | In | Out | $\longrightarrow$ |
| PA5 | In | Out | In | Out |  |
| PA6 | In | Out | In | Out |  |
| PA7 | In | Out | In | Out |  |
| PBO | In | Out | In | Out |  |
| PB1 | In | Out | In | Out |  |
| PB2 | In | Out | In | Out |  |
| PB3 | In | Out | In | Out |  |
| PB4 | In | Out | In | Out |  |
| PB5 | In | Out | In | Out |  |
| PB6 | In | Out | In | Out |  |
| PB7 | In | Out | In | Out |  |
| PCO | In | Out | INTR $_{\text {B }}$ | INTR $_{\text {B }}$ | 1/0 |
| PC1 | In | Out | $\mathrm{IBF}_{B}$ | $\overline{\text { OBF }}^{\text {B }}$ | 1/O |
| PC2 | In | Out | $\overline{S T B}_{B}$ | $\overline{A C K}_{B}$ | 1/0 |
| PC3 | In | Out | ${ }^{\text {INTR }}$ A | INTR $_{\text {A }}$ | INTRA $^{\text {STB }}$ |
| PC4 | In | Out | $\overline{\text { STB }}_{\text {A }}$ | 1/O | $\overline{S T B}_{A}$ |
| PC5 | In | Out | $\mathrm{IBF}_{\text {A }}$ | 1/O | $\mathrm{IBF}_{\text {A }}$ |
| PC6 | In | Out | I/O | $\overline{\text { ACK }}_{\text {A }}$ | $\overline{\text { ACK }}_{\text {A }}$ |
| PC7 | In | Out | 1/0 | $\overline{O B F}_{A}$ | $\overline{\mathrm{OBF}}_{\mathrm{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 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{\text { STB }}$ lines, will be placed on the data bus. In place of the $\overline{A C K}$ and $\overline{\text { 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 IBF and $\overline{\mathrm{OBF}}$ ) can be written, or an interrupt enable flag can be either set or reset. Port C lines programmed as inputs, including $\overline{A C K}$ and $\overline{S T B}$ lines, associated with Port C fare not affectged by a "Set/ Reset Port C Bit" command. Writing to the corresponding Port C bit positions of the $\overline{A C K}$ and $\overline{S T B}$ 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.
input configuration


OUTPUT CONFIGURATION


FIGURE 15. MODE 1 STATUS WORD FORMAT

(DEFINED BY MODE O OR MODE 1 SELECTION)
FIGURE 16. MODE 2 STATUS WORD FORMAT

## Current Drive Capability:

Any output on Port A, B or C can sink or source 2.5 mA . 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 (Figures 15 and 16)

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 executed to perform this function.

| INTERRUPT <br> ENABLE FLAG* | POSITION | ALTERNATE PORT C <br> PIN SIGNAL (MODE) |
| :---: | :---: | :--- |
| INTE B | PC2 | $\overline{A C K}_{B}$ (Output Mode 1) <br> or STB <br> (Input Mode 1) |
| INTE A2 | PC4 | $\overline{S T B}_{\mathrm{A}}$ (Input Mode 1 <br> or Mode 2) |
| INTE A1 | PC6 | $\overline{\text { ACK }}_{\mathrm{A}}$ (Output Mode 1 <br> or Mode 2) |

FIGURE 17. INTERRUPT ENABLE FLAGS IN MODES 1 AND 2

## 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 18 through 24 present a few examples of typical applications of the 82C55A.


FIGURE 18. PRINTER INTERFACE


FIGURE 19. KEYBOARD AND DISPLAY INTERFACE
interaupt


FIGURE 22. BASIC CRT CONTROLLER INTERFACE


FIGURE 20. KEYBOARD AND TERMINAL ADDRESS INTERFACE


FIGURE 21. DIGITAL TO ANALOG, ANALOG TO DIGITAL

FIGURE 23. BASIC FLOPPY DISC INTERFACE



FIGURE 24. MACHINE TOOL CONTROLLER INTERFACE

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | . +8.0 V |
| Input, Output or I/O Voltage | GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

CAUTION: Stresses above those listed in "Absolute Maxımum 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.

## Operating Conditions

| Operating Voltage Range . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5V |  | Operating Temperature Range |
| :---: | :---: | :---: |
|  |  | C82C55A. |
|  |  | 182C55A. |
|  |  | M82C55A. |

DC Electrical Specifications $\quad 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} 55 \mathrm{~A})$; $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (182C55A);
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C55A)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ | - | V | 182C55A, C82C55A, M82C55A |
| $\mathrm{V}_{\text {IL }}$ | Logical Zero Input Voltage | $\bullet$ | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One Output Voltage | $\begin{gathered} 3.0 \\ v_{c c}-0.4 \end{gathered}$ | $\bullet$ | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-2.5 \mathrm{~mA}, \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $1 \mathrm{loL}+2.5 \mathrm{~mA}$ |
| 1 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & \text { DIP Pins: } 5,6,8,9,35,36 \end{aligned}$ |
| 10 | I/O Pin Leakage Current | -10 | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {CC }}$ or GND DIP Pins: 27-34 |
| IBHH | Bus Hold High Current | -50 | -400 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=3.0 \mathrm{~V}$. Ports A, B, C |
| IBHL | Bus Hold Low Current | 50 | 400 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=1.0 \mathrm{~V}$. Port A ONLY |
| IDAR | Darlington Drive Current | -2.0 | Note 1 | mA | Ports A, B, C. Test Condition 3 |
| ICCSB | Standby Power Supply Current | $\bullet$ | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or GND. Output Open |
| ICCOP | Operating Power Supply Current | - | 1 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{MHz} \end{aligned}$ | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, Typical (See Note2) |

## NOTES:

1. No internal current limiting exists on Port Outputs. A resistor must be added externally to limit the current.
2. $I C C O P=1 \mathrm{~mA} / \mathrm{MHz}$ of Peripheral Read/Write cycle time. (Example: $1.0 \mu \mathrm{~s}$ I/O Read/Write cycle time $=1 \mathrm{~mA}$ )

Capacitance $T_{A}=25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{1 \mathrm{~N}}$ | Input Capacitance | 10 | pF | FREQ $=1 \mathrm{MHz}$, All Measurements are <br> referenced to device GND |
| $\mathrm{C}_{10}$ | I/O Capacitance | 20 | pF |  |

Specifications 82C55A
AC Electrical Specifications $V_{C C}=+5 \mathrm{~V}_{\mathrm{I}} 10 \%, \mathrm{GND}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C55A) (M82C55A-5);
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (182C55A) (182C55A-5);
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C55A) (C82C55A-5)

| SYMBOL | PARAMETER | 82C55A-5 |  | 82C55A |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| READ TIMING |  |  |  |  |  |  |  |
| (1) tAR | Address Stable Before $\overline{\mathrm{RD}}$ | 0 | - | 0 | - | ns |  |
| (2) tRA | Address Stable After $\overline{\mathrm{RD}}$ | 0 | - | 0 | - | ns |  |
| (3) tRR | $\overline{\mathrm{RD}}$ Pulse Width | 250 | $\bullet$ | 150 | - | ns |  |
| (4) tRD | Data Valid From $\overline{\mathrm{RD}}$ | - | 200 | $\bullet$ | 120 | ns | 1 |
| (5) tDF | Data Float After $\overline{\mathrm{RD}}$ | 10 | 75 | 10 | 75 | ns | 2 |
| (6) tRV | Time Between $\overline{\mathrm{RD}} \mathrm{s}$ and/or $\overline{\mathrm{WR}}$ s | 300 | - | 300 | - | ns |  |

## WRITE TIMING

| (7) tAW | Address Stable Before $\overline{\mathrm{WR}}$ | 0 | - | 0 | - | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| (8) tWA | Address Stable After $\overline{\mathrm{WR}}$ | 20 | - | 20 | - | ns |  |
| (9) tWW | $\overline{\text { WR }}$ Pulse Width | 100 | - | 100 | - | ns |  |
| (10) tDW | Data Valid to $\overline{\mathrm{WR}}$ High | 100 | - | 100 | - | ns |  |
| (11) tWD | Data Valid After $\overline{\mathrm{WR}}$ High | 30 | - | 30 | - | ns |  |

OTHER TIMING

| (12) tWB | $\overline{W R}=1$ to Output | - | 350 | - | 350 | ns | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (13) tIR | Peripheral Data Before $\overline{\mathrm{RD}}$ | 0 | - | 0 | - | ns |  |
| (14) tHR | Peripheral Data After $\overline{\mathrm{RD}}$ | 0 | - | 0 | - | ns |  |
| (15) tAK | ACK Pulse Width | 200 | - | 200 | - | ns |  |
| (16) tST | STB Puise Width | 100 | - | 100 | - | ns |  |
| (17) tPS | Peripheral Data Before STB High | 20 | - | 20 | - | ns |  |
| (18) tPH | Peripheral Data After STB High | 50 | - | 50 | - | ns |  |
| (19) tAD | ACK $=0$ to Output | - | 175 | - | 175 | ns | 1 |
| (20) tKD | ACK $=1$ to Output Float | 20 | 250 | 20 | 250 | ns | 2 |
| (21) tWOB | $\overline{\mathrm{WR}}=1$ to $\mathrm{OBF}=0$ | - | 150 | - | 150 | ns | 1 |
| (22) tAOB | $A C K=0$ to $O B F=1$ | - | 150 | - | 150 | ns | 1 |
| (23) tSIB | $\mathrm{STB}=0$ to $\mathrm{IBF}=1$ | - | 150 | - | 150 | ns | 1 |
| (24) tRIB | $\overline{\mathrm{RD}}=1$ to $\mathrm{IBF}=0$ | - | 150 | - | 150 | ns | 1 |
| (25) tRIT | $\overline{\mathrm{RD}}=0$ to $\mathrm{INTR}=0$ | - | 200 | - | 200 | ns | 1 |
| (26) tSIT | STB = 1 to $\mathrm{INTR}=1$ | - | 150 | - | 150 | ns | 1 |
| (27) tAIT | ACK = 1 to INTR = 1 | - | 150 | - | 150 | ns | 1 |
| (28) tWIT | $\overline{\mathrm{WR}}=0$ to INTR $=0$ | - | 200 | - | 200 | ns | 1 |
| (29) tRES | Reset Pulse Width | 500 | - | 500 | - | ns | 1, (Note 1) |

NOTE:

1. Period of initial Reset pulse after power-on must be at least $50 \mu \mathrm{sec}$. Subsequent Reset pulses may be 500 ns minimum.

Timing Waveforms
MODE 0 (BASIC INPUT)


MODE $O$ (BASIC OUTPUT)


MODE 1 (STROBED INPUT)


Timing Waveforms (Continued)


MODE 2 (BI-DIRECTIONAL)
 (INTR $=\mathrm{IBF} \bullet \overline{\mathrm{MASK}} \bullet \overline{\mathrm{STB}} \cdot \overline{\mathrm{RD}} \cdot \overline{\mathrm{OBF}} \cdot \overline{\text { MASK }} \bullet \overline{\mathrm{ACK}} \bullet \overline{\mathrm{WR}})$

## WRITE TIMING



READ TIMING


*Includes Stray and Jig Capacitance

AC Testing Input, Output Waveforms


AC Testing All parameters tested as per test circuits. Input rise and fall tumes are driven at $1 \mathrm{~ns} / \mathrm{N}$
TEST CONDITION DEFINITION TABLE

| TEST CONDITION | V1 | R1 | R2 | C1 |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1.7 V | $523 \Omega$ | Open | 150 pF |
| 2 | VCC | $2 \mathrm{k} \Omega$ | $1.7 \mathrm{k} \Omega$ | 50 pF |
| 3 | 1.5 V | $750 \Omega$ | Open | 50 pF |

Burn-In Circuits

$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ minımum
$V C C=55 \mathrm{~V} \pm 05 \mathrm{~V}$
All resistors are $47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{fO}=100 \mathrm{kHz} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to 04 V
$\mathrm{f} 1=\mathrm{f} 0 \div 2 ; \mathrm{f} 2=\mathrm{f} 1 \div 2 ; \ldots ; \mathrm{f} 15=\mathrm{f} 14 \div 2$

## Metallization Topology

DIE DIMENSIONS:
$131.4 \times 167.7 \times 19 \pm 1$ mils
METALLIZATION:
Type: Silicon - Aluminum
Thickness: $11 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy (LCC has Gold Preform)
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$0.78 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout
82C55A


## REFERENCE APP NOTE 109

February 1992

## CMOS Priority Interrupt Controller

## Features

- $12.5 \mathrm{MHz}, 8 \mathrm{MHz}$ and 5 MHz Versions Available
- 12.5MHz Operation. . . . . . . . . . . . . . . . . . . 82C59A-12
- 8MHz Operation . . . . . . . . . . . . . . . . . . . . . . . 82C59A
- 5MHz Operation . . . . . . . . . . . . . . . . . . . . . . 82C59A-5
- High Speed, "No Wait-State" Operation with 12.5MHz 80C286 and 8MHz 80C86/88
- Pin Compatible with NMOS 8259A
- 80C86/88/286 and 8080/85/86/88/286 Compatible
- Eight-Level Priority Controller, Expandable to 64 Levels
- Programmable Interrupt Modes
- Individual Request Mask Capability
- Fully Static Design
- Fully TTL Compatible
- Low Power Operation
- ICCSB
. . $20 \mu \mathrm{~A}$ Maximum
- ICCOP . . . . . . . . . . . . . . . . . . . . . . 1mAMMHz Maximum
- Single 5V Power Supply
- Operating Temperature Ranges
- C82C59A
$.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I82C59A $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C59A $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 82C59A is a high performance CMOS Priority Interrupt Controller manufactured using an advanced 2 micron CMOS process. The 82C59A is designed to relieve the system CPU from the task of polling in a multi-level priority system. The high speed and industry standard configuration of the 82C59A make it compatible with microprocessors such as $80 \mathrm{C} 286,80286,80 \mathrm{C} 86 / 88,8086 / 88$, 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/88/286 formats.

Static CMOS circuit design insures low operating power. The Harris advanced CMOS process results in performance equal to or greater than existing equivalent products at a fraction of the power.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 5 MHz | 8MHz | 12.5MHz |
| :---: | :---: | :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C59A-5 | CP82C59A | CP82C59A-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C59A-5 | IP82C59A | IP82C59A-12 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C59A-5 | CS82C59A | CS82C59A-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C59A-5 | IS82C59A | IS82C59A-12 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C59A-5 | CD82C59A | CD82C59A-12 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C59A-5 | ID82C59A | ID82C59A-12 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C59A-5/B | MD82C59A/B | - |
| SMD\# |  | 5962-8501601YA | 5962-8501602YA | $\bullet$ |
| LCC <br> SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C59A-5/B | MR82C59A/B | - |
|  |  | 5962-85016013A | 5962-85016023A | - |

Pinouts


| PIN | DESCRIPTION |
| :--- | :--- |
| $\overline{D 7}-$ D0 | Data Bus (Bi-Directional) |
| $\overline{\text { RD }}$ | Read Input |
| $\overline{\text { WR }}$ | Write Input |
| A0 | Command Select Address |
| $\overline{C S}$ | Chip Select |
| CAS 2-CAS 0 | Cascade Lines |
| $\overline{\text { SP/EN }}$ | Slave Program Input Enable |
| INT | Interrupt Output |
| $\overline{\text { INTA }}$ | Interrupt Acknowledge Input |
| IRO - IR7 | Interrupt Request Inputs |

## Functional Diagram



Pin Description

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| VCC | 28 | 1 | VCC: The +5 V power supply pin. A $0.1 \mu \mathrm{~F}$ capacitor between pins 28 and 14 is recommended for decoupling. |
| GND | 14 | 1 | GROUND |
| $\overline{\mathrm{CS}}$ | 1 | 1 | CHIP SELECT: A low on this pin enables $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ communications between the CPU and the 82C59A. $\overline{\text { NTA }}$ functions are independent of $\overline{\text { CS. }}$ |
| $\overline{\mathrm{WR}}$ | 2 | 1 | WRITE: A low on this pin when $\overline{\mathrm{CS}}$ is low enables the 82C59A to accept command words from the CPU. |
| $\overline{\mathrm{RD}}$ | 3 | 1 | READ: A low on this pin when $\overline{\mathrm{CS}}$ is low enables the 82C59A to release status onto the data bus for the CPU. |
| D7-D0 | 4-11 | 1/0 | BI-DIRECTIONAL DATA BUS: Control, status, and interrupt-vector information is transferred via this bus. |
| CASO- $\text { CAS } 2$ | 12, 13, 15 | 1/0 | CASCADE LINES: The CAS lines form a private 82C59A bus to control a multiple 82C59A structure. These pins are outputs for a master 82C59A and inputs for a slave 82C59A. |
| $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ | 16 | 1/0 | SLAVE PROGRAM/ENABLE BUFFER: This is a dual function pin. When in the Buffered Mode it can be used as an output to control buffer transceivers ( $\overline{\mathrm{EN}}$ ). When not in the buffered mode it is used as an input to designate a master ( $\overline{\mathrm{SP}}=1$ ) or slave ( $\overline{\mathrm{SP}}=0$ ). |
| INT | 17 | 0 | INTERRUPT: This pin goes high whenever a valid interrupt request is asserted. It is used to interrupt the CPU, thus it is connected to the CPU's interrupt pin. |
| IRO-IR7 | 18-25 | 1 | INTERRUPT REQUESTS: Asynchronous inputs. An interrupt request is executed by rassing an IR input (low to high), and holding it high until it is acknowledged (Edge Triggered Mode), or just by a high level on an IR input (Level Triggered Mode). Internal pull-up resistors are implemented on IRO-7. |
| $\overline{\text { INTA }}$ | 26 | 1 | INTERRUPT ACKNOWLEDGE: This pin is used to enable 82C59A interrupt-vector data onto the data bus by a sequence of interrupt acknowledge pulses issued by the CPU. |
| AO | 27 | 1 | ADDRESS LINE: This pin acts in conjunction with the $\overline{\mathrm{CS}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{RD}}$ pins. It is used by the 82C59A to decipher various Command Words the CPU writes and status the CPU wishes to read. It is typically connected to the CPU AO address line (A1 for 80C86/88/286). |

## 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 throughput, 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.


POLLED METHOD

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.


## INTERRUPT METHOD

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.

## 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/O 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 indicate 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 8080, 8085, 8086/88, 80C86/88, 80286, and 80C286 input levels.

## Interrupt Acknowledge (INTA)

$\overline{\mathbb{I N T A}}$ 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, bi-directional 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{\mathbf{C S}}$ )

A LOW on this input enables the 82C59A. No reading or writing of the device will occur unless the device is selected.

## Write ( $\overline{W R}$ )

A LOW on this input enables the CPU to write control words (ICWs and OCWs) to the 82C59A.

## 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.

## AO

This input signal is used in conjunction with $\overline{W R}$ and $\overline{\mathrm{RD}}$ signals to write commands into the various command registers, as well as to read the various status registers of the chip. This line can be tied directly to one of the system address lines.

## The Cascade Buffer/Comparator

This function block stores and compares the IDs of all 82C59As 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 8080/8085 system:

1. One or more of the INTERRUPT REQUEST lines (IRO IR7) 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 $\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 will also release a CALL instruction code (11001101) onto the 8-bit data bus through D0 - D7.
5. This CALL instruction will initiate two additional INTA pulses to be sent to 82C59A from the CPU group.
6. These two $\overline{\text { NTA }}$ 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 $\overline{\mathrm{NTTA}}$ 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 $\overline{\operatorname{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 80C86/88/286 system are the same until step 4.
8. The 82C59A does not drive the data bus during the first $\overline{\text { INTA }}$ pulse.
9. The $80 C 86 / 88 / 286$ CPU will initiate a second INTA pulse. During this INTA pulse, the appropriate ISR bit is set and the corresponding bit in the IRR is reset. The 82C59A outputs the 8-bit pointer onto the data bus to be 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 Interrupt Response Mode

This sequence is timed by three INTA pulses. During the first INTA pulse, the CALL opcode is enabled onto the data bus.

First Interrupt Vector Byte Data: Hex CD

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Call Code | 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, A5-A7 are programmed, while AO-A4 are automatically inserted by the 82C59A. When interval $=8$, only A6 and A7 are programmed, while AO-A5 are automatically inserted.

CONTENT OF SECOND INTERRUPT VECTOR BYTE

| IR | Interval $=4$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | Do |
| 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 | Do |
| 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 $\overline{\text { INTA }}$ pulse, the higher address of the appropriate service routine, which was programmed as byte 2 of the initialization sequence (A8-A15), 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, 80C88, 80C286 Interrupt Response Mode
80C86/88/286 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 the $86 / 88 / 286$ 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 A5 - A11 are unused in the 86/88/286 mode).

CONTENT OF INTERRUPT VECTOR BYTE FOR 80C86/88/286 SYSTEM MODE

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 |
| IR0 | T7 | T6 | T5 | T4 | T3 | 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 $\overline{W R}$ 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
b. Rotating priority mode
c. Special mask 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{AO}=0$ and D4 $=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)
A5 - A15: 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 (AO - A15). When the routine interval is $4, A 0-A 4$ are automatically inserted by the 82C59A, while A5 - A15 are programmed externally. When the routine interval is $8, A O$ - A5 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 80C86/88/286 system, A15-A11 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. A10 - A5 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: ALL address interval. $\mathrm{ADI}=1$ then interval $=4$; $A D I=0$ then interval $=8$.

SNGL: Single. Means that this is the only 82C59A in the system. If 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 $\overline{\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 release bytes 2 and 3 (for 80C86/88/ 286, only byte 2) through the cascade lines.
b. In the slave mode (either when $\overline{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 \mathrm{C} 86 / 88 / 286$ ) 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).

ICW1

| $A_{0}$ | $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $A_{7}$ | $A_{6}$ | $A_{5}$ | 1 | LTIM | ADI | SNGL | IC4 |


$\mathrm{A}_{7}-\mathrm{A}_{5}$ of Interrupt vector address (MCS-80/85 mode only)

ICW2

$\mathrm{A}_{15}-\mathrm{A}_{8}$ of interrupt vector address (MCS80/85 mode)
$\mathrm{T}_{7}-\mathrm{T}_{3}$ of interrupt vector address (8086/8088 mode)
ICW3 (MASTER DEVICE)

| $A_{0}$ | $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $S_{7}$ | $S_{6}$ | $S_{5}$ | $S_{4}$ | $S_{3}$ | $S_{2}$ | $S_{1}$ | $S_{0}$ |

$1=\mathbb{R}$ input has a slave
$0=I R$ input does not have a slave
ICW3 (SLAVE DEVICE)

| $A_{0}$ | $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | 0 | 0 | $I D_{2}$ | $I D_{1}$ | $I D_{0}$ |

> SLAVE ID(1) $\rightarrow$| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |

ICW4

| $A_{0}$ | $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | SFNM | BUF | M/S | AEOI | $\mu$ PM |

(1) Slave ID is equal to the corresponding master IR input.
$-1=8086 / 8088$ mode
$0=$ MCS $-80 / 85$ mode
$-1=$ Auto EOI
$0=$ Normal EOI

- Non buffered mode
- Buffered mode slave
- Buffered mode master
$1=$ Special fully nested moded
$0=$ Not special fully nested mode


## Initialization Command Word 4 (ICW4)

SFNM: If $S F N M=1$, the special fully nested mode is programmed.

BUF: If BUF $=1$, the buffered mode is programmed. In buffered mode, $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ becomes an enable output and the master/slave determination is by M/S.
$\mathrm{M} / \mathrm{S}$ : If buffered mode is selected: $\mathrm{M} / \mathrm{S}=1$ means the 82 C 59 A is programmed to be a master, $M / 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}$ : Microprocessor mode: $\mu \mathrm{PM}=0$ sets the 82C59A for 8080/85 system operation, $\mu \mathrm{PM}=1$ sets the 82C59A for 80C86/88/286 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)


OCW1

| $A_{0}$ | $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $M_{7}$ | $M_{6}$ | $M_{5}$ | $M_{4}$ | $M_{3}$ | $M_{2}$ | $M_{1}$ | $M_{0}$ |


| $\mathrm{A}_{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}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | R | SL | EOI | 0 | 0 | $\mathrm{~L}_{2}$ | $\mathrm{~L}_{1}$ | $\mathrm{~L}_{0}$ |

RLEVEL TO BE ACTED UPON


| $\mathrm{A}_{0}$ | $\mathrm{D}_{\mathbf{7}}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{\mathbf{4}}$ | $\mathrm{D}_{\mathbf{3}}$ | $\mathrm{D}_{\mathbf{2}}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | ESMM | SMM | 0 | 1 | P | RR | R 1 S |

READ REGISTER COMMAND


82C59A OPERATION COMMAND WORD FORMAT

## Operation Control Word 1 (OCW1)

OCW1 sets and clears the mask bits in the Interrupt Mask Register (IMR). M7-M0 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.

L2, L1, LO - 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 $S M M=0$, the 82C59A will revert to normal mask mode. When $E S M M=0, S M M$ 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 (ISO-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 the AEOI (Automatic End of Interrupt) bit is set, until the trailing edge of the last $\overline{\mathbb{N T A}}$. 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 the 82C59A before returning from a service routine (EOI Command). An EOI command must be issued twice if servicing a slave in the Cascade mode, once for the master and once for the corresponding slave.

There are two forms of EOI command: Specific and NonSpecific. 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 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 ( $\mathrm{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 EOI can be issued with OCW2 $(E O I=1, S L=1, R=0$, and $L O-L 2$ 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/88/ 286). 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 | IS0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "IS" Status | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 |
| Priority <br> STATUS | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  | Iowest | 亿 highest |  |  |  |  |  |  |

After Rotate (IR4 was serviced, all other priorities rotated correspondingly)

|  | IS7 | IS6 | IS5 | IS4 | IS3 | IS2 | IS1 | IS0 |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "IS" Status | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |
|  | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 |  |  |  |
|  | highest |  |  |  |  |  |  |  |  |  | lowest |

There are two ways to accomplish Automatic Rotation using OCW2, the Rotation on Non-Specific EOI Command ( $R=1$, $\mathrm{SL}=0, \mathrm{EOI}=1$ ) and the Rotate in Automatic EOI Mode which is set by $(R=1, S L=0, E O I=0)$ and cleared by $(R=0, S L=0, E O I=0)$.

## Specific Rotation (Specific Priority)

The programmer can change priorities by programming the lowest priority and thus fixing all other priorities; i.e., if IR5 is programmed as the lowest priority device, then IR6 will have the highest one.

The Set Priority command is issued in OCW2 where: $R=1$, $\mathrm{SL}=1, \mathrm{LO}-\mathrm{L} 2$ is the binary priority level code of the lowest 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 $(R=1, S L=1, E O I=1$, and $L O-L 2=I R$ level to receive lowest 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 operation of other channels.

## 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 OCW3 where: $E S S M=1$, $S M M=1$, and cleared where $E S S M=1, S M M=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 OCW3. The 82C59A treats the next $\overline{\mathrm{RD}}$ pulse to the 82C59A (i.e., $\overline{R D}=0, \overline{C S}=0$ ) as an interrupt acknowledge, sets the appropriate IS bit if there is a request, and reads the priority level. Interrupt is frozen from $\overline{W R}$ to $\overline{R D}$.

The word enabled onto the data bus during RD is:

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| I | - | - | - | - | W2 | W1 | W0 |

WO-W2: Binary code of the highest priority level requesting service.
$\mathrm{I}: \quad$ 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.

## 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).

Interrupt Request Register (IRR): 8-bit register which contains the levels requesting an interrupt to be acknowledged. The highest request level is reset from the IRR when an interrupt is acknowledged. IRR is not affected by 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 ( $R$ R $=1$, RIS $=0$ ).

The ISR can be read when, prior to the $\overline{\mathrm{RD}}$ pulse, a Read Register Command is issued with OCW3 (RR = 1, 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 $\overline{N T A}$. 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{\mathrm{RD}}$ is active and $A O=1$ (OCW1). Polling overrides status read when $P=1, R R=1$ in OCW3.

## 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 an 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 with the IR lines normally high. This will minimize the current through the internal pull-up resistors on the IR pins.


IR TRIGGERING TIMING REQUIREMENTS

## The Special Fully Nested Mode

This mode will 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 special 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 nonspecific 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 on $\overline{S P} / E N$ to enable the buffers. In this mode, whenever the 82C59A's data bus outputs are enabled, the $\overline{\mathrm{SP}} / \overline{\mathrm{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 (CAS2-0). The cascade bus acts like chip selects to the slaves during the INTA sequence.

In a cascade configuration, the slave interrupt outputs (INT) 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 $80 C 86 / 88 / 286$ ).
The cascade bus lines are normally low and will contain the slave address code from the leading edge of the first INTA pulse to the trailing edge of the last INTA 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. Note: Auto EOI is supported in the slave mode for the 82C59A.

The cascade lines of the Master 82C59A are activated only for slave inputs, non-slave inputs leave the cascade line inactive (low). Therefore, it is necessary to use a slave address of 0 (zero) only after all other addresses are used.


| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output or I/O Voltage | .GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

## Reliability Information

| Thermal Resistance | $\theta^{\text {ja }}$ | $\theta^{\mathrm{c}}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $47^{\circ} \mathrm{C} / \mathrm{W}$ | $10^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $53^{\circ} \mathrm{C} / \mathrm{W}$ | $6^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | .1.08W |
| Ceramic LCC Package |  | 932mW |
| Gate Count |  | 50 G |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range C82C59A 182C59A. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ M82C59A $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $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} 59 \mathrm{~A}), \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(182 \mathrm{C} 59 \mathrm{~A}), T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C59A)

| 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 { C82C59A, I82C59A } \\ & \text { M82C59A } \end{aligned}$ |
| VIL | Logical Zero Input Voitage | - | 0.8 | V |  |
| VOH | Output HIGH Voltage | $\begin{gathered} 3.0 \\ \text { vCC }-0.4 \end{gathered}$ | -- | V V | $\begin{aligned} & 1 \mathrm{IOH}=-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}$ |
| 11 | input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | VIN $=$ GND or VCC, Pins 1-3, 26-27 |
| 10 | Output Leakage Current | -10.0 | +10.0 | $\mu \mathrm{A}$ | VOUT $=$ GND or VCC, Pins 4-13, 15-16 |
| ILIR | IR Input Load Current | - | $\begin{gathered} -200 \\ 10 \end{gathered}$ | $\begin{aligned} & \mu A \\ & \mu A \end{aligned}$ | $\mathrm{VIN}=\mathrm{OV}, \mathrm{VIN}=\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, (Note 1) |
| ICCOP | Operating Power Supply Current | - | 1 | mAMHz | $\mathrm{VCC}=5.0 \mathrm{~V}, \mathrm{CLK}$ FREQ $=5 \mathrm{MHz}, \mathrm{VIN}=\mathrm{VCC}$ or GND, Outputs Open, $\mathrm{T}_{\mathrm{A}}=+250 \mathrm{C}$, (Note 2) |

NOTES:

1. Except for IRO - IR7 where VIN = VCC or open.
2. $I C C O P=1 \mathrm{~mA} / \mathrm{MHz}$ of peripheral read/write cycle time, (ex: $1.0 \mu \mathrm{~s} \mathrm{I} / \mathrm{O}$ read $/ \mathrm{write}$ cycle time $=1 \mathrm{~mA}$ ).

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYP | UNTS | TEST CONDITIONS |  |
| :---: | :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | 15 | pF | FREQ $=1 \mathrm{MHz}$, all measurements reference to <br> device GND. |  |
| COUT | Output Capacitance | 15 | pF |  |  |
| CI/O | I/O Capacitance | 15 | pF |  |  |

Specifications 82C59A
AC Electrical Specifications $\mathrm{VCC}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C59A), $\mathrm{T}_{\mathrm{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}$ (M82C59A)

|  | PARAMETER | 82C59A -5 |  | 82C59A |  | 82C59A -12 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |

TIMING REQUIREMENTS

| (1)TAHRL | AO//CS Setup to $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}}$ | 10 | - | 10 | - | 5 | - | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (2)TRHAX | A0/ $/ \overline{C S}$ Hold after $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}}$ | 5 | - | 5 | - | 0 | - | ns |  |
| (3)TRLRH | $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}}$ Pulse Width | 235 | - | 160 | - | 60 | - | ns |  |
| (4)TAHWL | A0/ $\overline{C S}$ Setup to $\overline{W R}$ | 0 | - | 0 | 0 | 0 | - | ns |  |
| (5)TWHAX | A0/ $\overline{C S}$ Hold after $\overline{W R}$ | 5 | - | 5 | - | 0 | - | ns |  |
| (6)TWLWH | $\overline{\text { WR Pulse Width }}$ | 165 | - | 95 | - | 60 | - | ns |  |
| (7)TDVWH | Data Setup to WR | 240 | - | 160 | - | 70 | - | ns |  |
| (8)TWHDX | Data Hold after $\overline{W R}$ | 5 | - | 5 | - | 0 | - | ns |  |
| (9)TJLJH | Interrupt Request Width Low) | 100 | - | 100 | - | 40 | - | ns |  |
| (10)TCVIAL | Cascade Setup to Second or Third INTA Slave Only) | 55 | - | 40 | - | 30 | - | ns |  |
| (11)TRHRL | End of $\overline{R D}$ to next $\overline{R D}$, End of $\overline{\mathrm{INTA}}$ within an $\overline{\operatorname{NTTA}}$ sequence only | 160 | - | 160 | - | 90 | - | ns |  |
| (12)TWHWL | End of $\overline{\mathrm{WR}}$ to next $\overline{\mathrm{WR}}$ | 190 | - | 190 | - | 60 | - | ns |  |
| (13)TCHCL* | End of Command to next command not same command type), End of INTA sequence to next INTA sequence | 500 | - | 400 | - | 90 | - | ns |  |


| (14)TRLDV | Data Valid from $\overline{\mathrm{RD}} / \overline{\mathrm{NTTA}}$ | - | 160 | - | 120 | - | 40 | ns | 1 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (15)TRHDZ | Data Float after $\overline{\mathrm{RD} / \overline{\mathrm{NTA}}}$ | 5 | 100 | 5 | 85 | 5 | 22 | ns | 2 |
| (16)TJHIH | Interrupt Output Delay | - | 350 | - | 300 | - | 90 | ns | 1 |
| (17)TIALCV | Cascade Valid from First $\overline{\mathrm{INTA}}$ <br> (Master Only) | - | 565 | - | 360 | - | 50 | ns | 1 |
| (18)TRLEL | Enable Active from $\overline{\mathrm{RD}}$ or $\overline{\mathrm{NTA}}$ | - | 125 | - | 100 | - | 40 | ns | 1 |
| (19)TRHEH | Enable Inactive from $\overline{\mathrm{RD}}$ or $\overline{\mathrm{INTA}}$ | - | 60 | - | 50 | - | 22 | ns | 1 |
| (20)TAHDV | Data Valid from Stable Address | - | 210 | - | 200 | - | 60 | ns | 1 |
| (21)TCVDC | Cascade Valid to Valid Data | - | 300 | - | 200 | - | 70 | ns | 1 |

* Worst case timing for TCHCL in an actual microprocessor system is typically greater than the values specified for the 82C59A. (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}, 80 \mathrm{C} 286-10=131 \mathrm{~ns}, 80 \mathrm{C} 286-12=98 \mathrm{~ns}$ )


## A.C. Test Circuit



* Includes Stray and Jig Capacitance

TEST CONDITION DEFINITION TABLE

| TEST <br> CONDITION | V1 | R1 | R2 | C1 |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1.7 V | $523 \Omega$ | Open | 100 pF |
| 2 | VCC | $1.8 \mathrm{k} \Omega$ | $1.8 \mathrm{k} \Omega$ | 50 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}$. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{V}$.

Timing Waveforms WRITE

$\overline{\text { READ } / \overline{N T A}}$


INTA SEQUENCE


NOTES:

1. Interrupt Request (IR) must remain HIGH until leading edge of first INTA.
2. $80 \mathrm{C} 86 / 88 / 286$ mode.
3. During first INTA the Data Bus is not active in $80 C 86 / 88 / 286$ mode
4. $8080 / 8085$ mode

## Burn-In Circuits

MD82C59A CERAMIC DIP


MR82C59A CERAMIC LCC


NOTES:
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to 0.4 V
GND $=0 \mathrm{~V}$
$\mathrm{R} 1=47 \mathrm{k} \Omega \pm 5 \%$
$R 2=510 \Omega \pm 5 \%$
$R 3=10 k \Omega \pm 5 \%$
$R 4=1.2 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{C} 1=0.01 \mu \mathrm{~F} \mathrm{~min}$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0 / 2, F 2=F 1 / 2, \ldots F 8=F 7 / 2$

## Metallization Topology

DIE DIMENSIONS:
$154.3 \times 173.2 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - AL
Thickness: $11 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy (LCC has Gold Preform)
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)

$$
\text { Ceramic LCC }-420^{\circ} \mathrm{C} \text { (Max) }
$$

WORST CASE CURRENT DENSITY:
$1.64 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

## Metallization Mask Layout

82C59A


## Features

- Full Eight-Bit Parallel Latching Buffer
- Bipolar 8282 Compatible
- Three-State Noninverting Outputs
- Propagation Delay 35ns Max.
- Gated Inputs:
- Reduce Operating Power
- Ellminate the Need for Pull-Up Resistors
- Single 5V Power Supply
- Low Power Operation
$I C C S B=10 \mu A$
- Operating Temperature Ranges
- C82C82 . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I82C82 . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C82
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 82C82 is a high performance CMOS Octal Latching Buffer manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV). The 82C82 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.

## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | ORDER CODE |
| :--- | :---: | :--- |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C82 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C82 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C82 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C82 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C82 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C82 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C82/B |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C82/B |
|  |  | 84067012 A |

## Pinouts

## 20 LEAD DIP TOP VIEW

20 LEAD PLCC AND LCC TOP VIEW


TRUTH TABLE

| STB | $\overline{O E}$ | $\mathbf{D I}$ | DO |
| :---: | :---: | :---: | :---: |
| $X$ | $H$ | $X$ | $H i-Z$ |
| $H$ | $L$ | $L$ | $L$ |
| $H$ | $L$ | $H$ | $H$ |
| $\downarrow$ | $L$ | $X$ | $*$ |

H = Logic One
L = Logic Zero
= Don't Care
$=$ Latched to Value of Last Data
Hi-Z $=$ High Impedance
$\downarrow=$ Neg. Transition

PIN NAMES

| PIN | DESCRIPTION |
| :--- | :--- |
| DIO-DI7 | Data Input Pins |
| DO0-DO7 | Data Output Pins |
| STB | Active High Strobe |
| $\overline{\text { OE }}$ | Active Low Output <br> Enable |

## Functional Diagram



## Gated Inputs

During normal system operation of a latch, signals on the bus at the device inputs will become high impedance or make transitions unrelated to the operation of the latch. These unrelated input transitions switch the input circuitry and typically cause an increase in power dissipation in CMOS devices by creating a low resistance path between VCC and GND when the signal is at or near the input switching threshold. Additionally, if the driving signal becomes high impedance ("float" condition), it could create an indeterminate logic state at the input and cause a disruption in device operation.

The Harris 82C8X series of bus drivers eliminates these conditions by turning off data inputs when data is latched (STB = logic zero for the $82 \mathrm{C} 82 / 83 \mathrm{H}$ ) and when the device is disabled $(\overline{\mathrm{OE}}=$ logic one for $82 \mathrm{C} 86 \mathrm{H} / 87 \mathrm{H})$. These gated inputs disconnect the input circuitry from the VCC and ground power supply pins by turning off the upper P-channel and lower N-channel (see Figures 1, 2). No new current flow from VCC to GND occurs during input transitions and invalid logic states from floating inputs are not transmitted. The next stage is held to a valid logic level internal to the device.


FIGURE 1. 82C82/83H
D.C. input voltage levels can also cause an increase in ICC if these input levels approach the minimum VIH or maximum VIL conditions. This is due to the operation of the input circuitry in its linear operating region (partially conducting state). The 82C8X series gated inputs mean that this condition will occur only during the time the device is in the transparent mode ( $\mathrm{STB}=$ logic one). ICC remains below the maximum ICC standby specification of 10 mA during the time inputs are disabled, thereby greatly reducing the average power dissipation of the 82C8X series devices.

## Typical 82C82 System Example

In a typical 80C86/88 system, the 82C82 is used to latch multiplexed addresses and the STB input is driven by ALE (Address Latch Enable) (see Figure 3). The high pulse width of ALE is approximately 100 ns with a bus cycle time of $800 \mathrm{~ns}(80 \mathrm{C} 86 / 88$ @ 5 MHz ). The 82 C 82 inputs are active only $12.5 \%$ of the bus cycle time. Average power dissipation related to input transitioning is reduced by this factor also.


FIGURE 2. $82 \mathrm{C} 86 \mathrm{H} / 87 \mathrm{H}$ GATED INPUTS

## Application Information

## Decoupling Capacitors

The transient current required to charge and discharge the 300 pF load capacitance specified in the 82C82 data sheet is determined by
$\mathrm{I}=\mathrm{CL}(\mathrm{dv} / \mathrm{dt})$
Assuming that all outputs change state at the same time and that dv/dt is constant;
$\mathrm{I}=\mathrm{CL}$

$$
\frac{(\mathrm{VCC} \times 80 \%)}{\mathrm{tR} / \mathrm{tF}}
$$

where $\mathrm{tR}=20 \mathrm{~ns}, \mathrm{VCC}=5.0 \mathrm{~V}, \mathrm{CL}=300 \mathrm{pF}$ on each of eight outputs.
$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}$

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 disc decoupling capacitor be placed between VCC and GND at each device, with placement being as near to the device as possible.


FIGURE 3. SYSTEM EFFECTS OF GATED INPUTS

| Absolute Maximum Ratings |  | Reliability Information |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | +8.0V | Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {¢ }}$ |
| Input, Output or I/O Voltage | GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ | Ceramic DIP Package | $79^{\circ} \mathrm{C} / \mathrm{N}$ | $20^{\circ} \mathrm{C} / \mathrm{W}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Ceramic LCC Package | $76^{\circ} \mathrm{C} / \mathrm{N}$ | $19^{\circ} \mathrm{C} / \mathrm{W}$ |
| Junction Temperature | $+175^{\circ} \mathrm{C}$ | Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ | Ceramic DIP Package . |  |  |
| ESD Classification | Class 1 | Ceramic LCC Package . . . . . . . . . . . . . . . . . . . . . . . . . . 664 |  |  |
| Gate Count . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 Gates |  |  |  |  |
| CAUTION Stresses above those listed in "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. |  |  |  |  |

## Operating Conditions

| Operating Voltage Range $\ldots \ldots \ldots \ldots \ldots \ldots \ldots+4.5 \mathrm{~V}$ to |
| :--- |
| DC Electrical Specifications $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%$; |

Operatng Temperature Range
$\mathrm{C} 82 \mathrm{C} 82 \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$182 \mathrm{C} 82 \ldots \ldots$
 M82C82 $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \omega^{5} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $V C C=5.0 \mathrm{~V} \pm 10 \% ; \quad T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C82); $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 82 );
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C82)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | 2.0 | - | V | C82C82, 182C82 (Note 1) |
|  |  | 2.2 | - | V | M82C82 (Note 1) |
| VIL | Logical Zero Input Voltage | - | 0.8 | V |  |
| VOH | Logical One Output Voltage | 2.9 | - | V | $1 \mathrm{OH}=-8 \mathrm{~mA}, \overline{\mathrm{OE}}=\mathrm{GND}$ |
|  |  | VCC -0.4V | - | V | $1 \mathrm{OH}=-100 \mu \mathrm{~A}, \overline{\mathrm{OE}}=\mathrm{GND}$ |
| VOL | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{IOL}=8 \mathrm{~mA}, \overline{\mathrm{OE}}=\mathrm{GND}$ |
| 11 | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | VIN = GND or VCC, DIP Pins 1-9, 11 |
| 10 | Output Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{GND}$ or $\mathrm{VCC}, \overline{\mathrm{OE}} \geq \mathrm{VCC}-0.5 \mathrm{~V}$ DIP Pins 12-19 |
| ICCSB | Standby Power Supply Current | - | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$, Outputs Open |
| ICCOP | Operatıng Power Supply Current | - | 1 | $\mathrm{mA} / \mathrm{MHz}$ | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{VCC}=5 \mathrm{~V}$, Typical (See Note 2) |

NOTES:

1. VIH is measured by applying a pulse of magnitude $=$ VIHmin to one data input at a time and checking the corresponding device output for a valıd logical "1" during valid input high time. Control pins (STB, $\overline{O E}$ ) are tested separately with all device data input pins at VCC -0.4
2. Typical ICCOP $=1 \mathrm{~mA} / \mathrm{MHz}$ of STB cycle time. (Example: 5 MHz $\mu \mathrm{P}, \mathrm{ALE}=1.25 \mathrm{MHz}, \mathrm{ICCOP}=1.25 \mathrm{~mA})$.

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | 13 | pF | Freq $=1 \mathrm{MHz}$, all measurements are <br> referenced to device GND |
| COUT | Output Capacitance | 20 | pF |  |

Specifications $82 C 82$
AC Electrical Specifications $V C C=5.0 \mathrm{~V} \pm 10 \% ; \quad T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C82);
$C_{L}=300 \mathrm{pF} *$, Freq $=1 \mathrm{MHz} \quad T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(182 \mathrm{C} 82) ;$
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C82)

|  | SYMBOL | PARAMETER | MIN | MAX | UNTTS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (1) | TIVOV | Propagation Delay Input to Output | - | 35 | ns | Notes 1, 2 |
| (2) | TSHOV | Propagation Delay STB to Output | - | 55 | ns | Notes 1, 2 |
| (3) | TEHOZ | Output Disable Time | - | 35 | ns | Notes 1, 2 |
| (4) | TELOV | Output Enable Time | - | 50 | ns | Notes 1, 2 |
| (5) | TIVSL | Input to STB Setup Time | 0 | - | ns | Notes 1, 2 |
| (6) | TSLIX | Input to STB Hold Time | 25 | - | ns | Notes 1, 2 |
| (7) | TSHSL | STB High Time | 25 | - | ns | Notes 1, 2 |
| (8) | TR, TF | Input Rise/Fall Times | - | 20 | ns | Notes 1, 2 |

*Output load capacitance is rated at 300pF for ceramic and plastic packages.
NOTES:

1. All AC parameters tested as per test circuits and definitions 2. Input test signals must switch between VIL -0.4 V and $\mathrm{VIH}+0.4 \mathrm{~V}$. below. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{V}$.

Timing Waveforms


Test Load Circuits


TIVOV, TSHOV, TELOV


TEHOZ OUTPUT HIGH DISABLE

* Includes stray and jig capacitance


TEHOZ OUTPUT LOW DISABLE

## Burn-In Circuits



MR 82C82 CERAMIC LCC


NOTES:
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to 0.4 V
$\mathrm{R}_{1}=47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{R}_{2}=2.0 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{R}_{3}=4.2 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{R}_{4}=470 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ minimum
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0 / 2, F 2=F 1 / 2$

## Metallization Topology

## DIE DIMENSIONS:

$118.1 \times 92.1 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - AI
Thickness: $11 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 k \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy (LCC has Gold Preform)
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$2.00 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout

$\square \Delta \Delta \longrightarrow$
SEMICONDUCTOR

## Features

- Full Eight-Bit Parallel Latching Buffer
- Bipolar 8283 Compatible
- Three State Inverting Outputs
- Propagation Delay

25ns Max

- Gated Inputs:
- Reduce Operating Power
- Eliminate the Need for Pull-up Resistors
- Single 5V Power Supply
- Low Power Operation
- ICCSB

10 mA

- Operating Temperature Ranges
- C82C83H . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I82C83H . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C83H . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 82 C 83 H is a high performance CMOS Octal Latching Buffer manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV). The 82C83H 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 (OE) permits simple interface to microprocessor systems. The 82 C 83 H provides inverted data at the outputs.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | ORDER CODE |
| :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C83H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C83H |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C83H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C83H |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C83H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C83H |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C83H/B |
| SMD\# |  | 8406702RA |
| LCC SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C83H/B |
|  |  | 84067022A |

## Pinouts

## 20 LEAD DIP <br> TOP VIEW



TRUTH TABLE

| STB | $\overline{\mathrm{OE}}$ | DI | $\overline{\mathbf{D O}}$ |
| :---: | :---: | :---: | :---: |
| $\mathbf{X}$ | H | X | $\mathrm{Hi}-\mathrm{Z}$ |
| H | L | L | H |
| H | L | H | L |
| $\downarrow$ | L | X | $*$ |

H = Logic One
$\mathrm{Hi}-\mathrm{Z}=$ High Impedance
L = Logic Zero
X = Don't Care

* $=$ Latched to Value of Last Data

PIN NAMES

| PIN | DESCRIPTION |
| :--- | :--- |
| $\mathrm{DI}_{0}-\mathrm{DI}_{7}$ | Data Input Pins |
| $\overline{\mathrm{DO}}_{0}-\overline{\mathrm{DO}}_{7}$ | Data Output Pins |
| $\overline{\mathrm{STB}}$ | Active High Strobe |
| $\overline{\mathrm{OE}}$ | Active Low Output Enable |

## Functional Diagram



## Gated Inputs

During normal system operation of a latch, signals on the bus at the device inputs will become high impedance or make transitions unrelated to the operation of the latch. These unrelated input transitions switch the input circuitry and typically cause an increase in power dissipation in CMOS devices by creating a low resistance path between $V_{C C}$ and GND when the signal is at or near the input switching threshold. Additionally, if the driving signal becomes high impedance ("float"' condition), it could create an indeterminate logic state at the inputs and cause a disruption in device operation.
The Harris 82C8X series of bus drivers eliminates these conditions by turning off data inputs when data is latched (STB = logic zero for the $82 \mathrm{C} 82 / 83 \mathrm{H}$ ) and when the device is disabled $(\overline{O E}=$ logic one for the $82 \mathrm{C} 86 \mathrm{H} / 87 \mathrm{H})$. These gated inputs disconnect the input circuitry from the VCC and ground power supply pins by turning off the upper P-channel and lower N-channel (See Figures 1 and 2). No current flow from VCC to GND occurs during input transitions and invalid logic states from floating inputs are not transmitted. The next stage is held to a valid logic level internal to the device.


FIGURE 1. $82 \mathrm{C} 82 / 83 \mathrm{H}$
D.C. input voltage levels can also cause an increase in ICC if these input levels approach the minimum $\mathrm{V}_{\mathrm{IH}}$ or maximum $\mathrm{V}_{\mathrm{IL}}$ conditions. This is due to the operation of the input circuitry in its linear operating region (partially conducting
state). The 82 C 8 X series gated inputs mean that this condition will occur only during the time the device is in the transparent mode (STB = logic one). ICC remains below the maximum ICC standby specification of $10 \mu \mathrm{~A}$ during the time inputs are disabled, thereby greatly reducing the average power dissipation of the 82 C 8 X series devices.


FIGURE 2. 82C86H/87H GATED INPUTS

## Decoupling Capacitors

The transient current required to charge and discharge the 300 pF load capacitance specified in the 82 C 83 H data sheet is determined by

$$
I=C_{L}(d v / d t)
$$

Assuming that all outputs change state at the same time and that dv/dt is constant;
$I=C_{L} \quad \frac{\left(V_{C C} \times 80 \%\right)}{t R / t F}$
where $\mathrm{tR}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$ on each eight outputs.
$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}$
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 disc capacitor be placed between $\mathrm{V}_{\mathrm{CC}}$ and GND at each device, with placement being as near to the device as possible.


FIGURE 3. SYSTEM EFFECTS OF GATED INPUTS

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | 8.0 V |
| Input, Output or I/O Voltage | .GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {gc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $70^{\circ} \mathrm{CW}$ | $15^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $76^{\circ} \mathrm{CN}$ | $19^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | . 720 mW |
| Ceramic LCC Package |  | . 664 mW |
| Gate Count |  | . 265 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . +4.5 V to +5.5 V

Operating Temperature Range

| C82C83H. | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| 182 C 83 H | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| M82C83H | $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

DC Electrical Specifications $\quad 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} 83 \mathrm{H})$; $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(182 \mathrm{C} 83 \mathrm{H})$; $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C83H)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ | - | V | C82C83H, I82C83H <br> M82C83H, (Note 1) |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical Zero Input Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One Output Voltage | $\begin{gathered} 3.0 \\ v_{c c}-0.4 \mathrm{~V} \end{gathered}$ | - | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}, \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mathrm{~mA}, \overline{\mathrm{OE}}=\mathrm{GND} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}, \overline{\mathrm{OE}}=\mathrm{GND}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=$ GND or $\mathrm{V}_{\mathrm{CC}}$, DIP Pins 1-9, 11 |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{O}=G N D \text { or } \overline{O E} \geq V_{C C}-0.5 \mathrm{~V} \\ & \text { DIP Pins } 12-19 \end{aligned}$ |
| ICCSB | Standby Power Supply Current | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \text { Outputs Open } \end{aligned}$ |
| ICCOP | Operating Power Supply Current | - | 1 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{MHz} \end{aligned}$ | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$, Typical (See Note 2) |

## NOTES:

1. $\mathrm{V}_{\mathrm{IH}}$ is measured by applying a pulse of magnitude $=\mathrm{V}_{\mathrm{IH} \text { min }}$ to one data input at a time and checking the corresponding device output for a valid logical "1" during valid input high time. Control pins (STB, $\overline{\mathrm{OE}}$ ) are tested separately with all device data input pins at $\mathrm{V}_{\mathrm{CC}}-0.4 \mathrm{~V}$.
2. Typical ICCOP $=1 \mathrm{mAMMz}$ of STB cycle time. (Example: 5 MHz $\mu \mathrm{P}, \mathrm{ALE}=1.25 \mathrm{MHz}, \mathrm{ICCOP}=1.25 \mathrm{~mA}$ ).

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 13 | pF | FREQ $=1 \mathrm{MHz}$, all measurements are <br> referenced to device GND |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 20 | pF |  |

```
AC Electrical Specifications \(\quad V_{C C}=5.0 \mathrm{~V} \pm 10 \% ; C_{L}=300 \mathrm{pF} *\), \(F R E Q=1 \mathrm{MHz}\)
\(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 83 \mathrm{H})\);
\(\mathrm{T}_{\mathrm{A}}-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) ( 182 C 83 H );
\(\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\) to \(+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 83 \mathrm{H})\)
```

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| (1) TIVOV | Propagation Delay Input to Output | 5 | 25 | ns | See Notes 1, 2 |
| (2) TSHOV | Propagation Delay STB to Output | 10 | 50 | ns | See Notes 1, 2 |
| (3) TEHOZ | Output Disable Time | 5 | 22 | ns | See Notes 1, 2 |
| (4) TELOV | Output Enable Time | 10 | 45 | ns | See Notes 1, 2 |
| (5) TIVSL | Input to STB Set Up Time | 0 | - | ns | See Notes 1, 2 |
| (6) TSLIX | Input to STB Hold Time | 30 | - | ns | See Notes 1, 2 |
| (7) TSHSL | STB High Time | 15 | - | ns | See Notes 1, 2 |
| (8) TR, TF | Input Rise/Fall Times | - | 20 | ns | See Notes 1, 2 |

* Output load capacitance is rated 300 pF for both ceramic and plastic packages

NOTES:

1. All A.C. Parameters tested as per test load circuits. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{N}$.
2. Input test signals must switch between $\mathrm{V}_{\mathrm{IL}}-0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}+0.4 \mathrm{~V}$.

## Timing Waveform



All timing measurements are made at 1.5 V unless otherwise noted.

## Test Load Circuits



TIVOV, TSHOV


TELOV OUTPUT LOW ENABLE


TELOV OUTPUT HIGH ENABLE

MD82C83H CERAMIC DIP


MR82C83H CERAMIC LCC

NOTES:
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$ GND $=0 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2$ to 0.4 V
$R 1=47 \mathrm{k} \Omega \pm 5 \%$
$R 2=2.0 \mathrm{k} \Omega \pm 5 \%$
$R 3=1.0 \mathrm{k} \Omega \pm 5 \%$
$R 4=5.0 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ Minimum
$F O=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0 / 2, F 2=F 1 / 2, F 3=F 2 / 2$


## Metallization Topology

DIE DIMENSIONS:
$138.6 \times 155.5 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Silicon - Aluminum
Thickness: $11 \mathrm{k} \AA \pm 2 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$

## DIE ATTACH:

Material: Gold - Silicon Eutectic Alloy (LCC has Gold
Preform)
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC - 4200ㅇ (Max)
WORST CASE CURRENT DENSITY:
$2.0 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout


## 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
- TTL Compatible Inputs/Outputs
- Very Low Power Consumption
- Single 5V Power Supply
- Operating Temperature Ranges
- C82C84A . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I82C84A . . . . . . . . . . . . . . . . . . . . . . . . -40 ${ }^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C84A. . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## 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 X1 and RES) are TTL compatible over 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.

| PACKAGE | TEMPERATURE RANGE | ORDER CODE |
| :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C84A |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C84A |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C84A |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C84A |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C84A |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C84A |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C84A/B |
| SMD\# |  | 8406801V'A |
| LCCSMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C84A/B |
|  |  | 84068012A |

## Pinouts




## Functional Diagram



| CONTROL PIN | LOGICAL 1 | LOGICAL 0 |
| :--- | :--- | :--- |
| F/त्ट | External Clock | Crystal Drive |
| $\overline{\text { RES }}$ | Normal | Reset |
| RDY1, RDY2 | Bus Ready | Bus Not Ready |
| $\overline{\text { AEN1 }}, \overline{\text { AEN2 }}$ | Address Disabled | Address Enable |
| $\overline{\text { ASYNC }}$ | 1 Stage Ready <br> Synchronization | 2 Stage Ready <br> Synchronization |

## Pin Description

| SYMBOL | NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\overline{\overline{\operatorname{AEN1}}} \overline{\mathrm{AEN2}}$ | 3, 7 | 1 | ADDRESS ENABLE: $\overline{\text { AEN }}$ is an active LOW signal. $\overline{\operatorname{AEN}}$ serves to qualify its respective Bus Ready Signal (RDY1 or RDY2). $\overline{\text { AEN } 1 ~ v a l i d a t e s ~ R D Y 1 ~ w h i l e ~} \overline{\operatorname{AEN2}}$ validates RDY2 Two $\overline{\text { AEN }}$ signal inputs are useful in system configurations which permit the processor to access two MultiMaster System Busses. In non-Multi-Master configurations, the $\overline{\operatorname{AEN}}$ signal inputs are tied true (LOW). |
| RDY1, RDY2 | 4,6 | 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 $\overline{A E N 1}$ while RDY2 is qualified by $\overline{\text { AEN2 }}$. |
| $\overline{\text { ASYNC }}$ | 151 |  | 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 ASYNC is left open or HIGH a single stage of READY synchronization is provided. |
| READY | 5 | 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, $\mathrm{X}_{2}$ | 17,16 | 10 | CRYSTAL $\mathbb{N}$ : X1 and X2 are the pins to which a crystal is attached. The crystal frequency is 3 times the desired processor clock frequency.* |
| F/E | 13 | 1 | FREQUENCY/CRYSTAL SELECT: F/Z is a strapping option. When strapped LOW. F/C permits the processor's clock to be generated by the crystal. When F/C is strapped HIGH, CLK is generated for the EFI input.* |
| EFI | 14 | 1 | EXTERNAL FREQUENCY $\mathbb{I N}$ : When F/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. |
| CLK | 8 | 0 | PROCESSOR CLOCK: CLK is the clock output used by the processor and all devices which directly connect to the processor's local bus. CLK has an output frequency which is $1 / 3$ of the crystal or EFI input frequency and a $1 / 3$ duty cycle. |
| PCLK | 2 | 0 | PERIPHERAL CLOCK: PCLK is a peripheral clock signal whose output frequency is $1 / 2$ that of CLK and has a $50 \%$ duty cycle. |
| OSC | 12 | 0 | OSCILLATOR OUTPUT: OSC is the output of the internal oscillator circuitry. Its frequency is equal to that of the crystal. |
| $\overline{\text { RES }}$ | 11 | 1 | RESET IN: $\overline{\operatorname{RES}}$ is an active LOW signal which is used to generate RESET. The 82C84A provides a Schmitt trigger input so that an RC connection can be used to establish the power-up reset of proper duration. |
| RESET | 10 | 0 | RESET: RESET is an active HIGH signal which is used to reset the 80 C86 family processors. Its timing characteristics are determined by $\overline{\operatorname{RES}}$. |
| CSYNC | 1 | 1 | CLOCK SYNCHRONIZATION: CSYNC is an active HIGH signal which allows multiple 82C84As to be synchronized to provide clocks that are in phase. When CSYNC is HIGH the internal counters are reset. When CSYNC goes LOW the internal counters are allowed to resume counting. CSYNC needs to be externally synchronized to EFI. When using the internal oscillator CSYNC should be hardwired to ground. |
| GND | 9 |  | Ground |
| vcc | 18 |  | VCC: the +5 V power supply pIn. A $0.1 \mu \mathrm{~F}$ capacitor between VCC and GND is recommended for decoupling. |

* If the crystal inputs are not used X1 must be tied to VCC or GND and X2 should be left open.


## 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 (C1 = C2) 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.

TABLE 1. CRYSTAL SPECIFICATIONS

| PARAMETER | TYPICAL CRYSTAL SPEC |
| :--- | :--- |
| Frequency | $2.4-25 \mathrm{MHz}$, Fundamental, "AT" cut |
| Type of Operation | Parallel |
| Unwanted Modes | 6 dB (Minimum) |
| Load Capacitance | $18-32 \mathrm{pF}$ |

Capacitors C1, C2 are chosen such that their combined capacitance

$$
\mathrm{CT}=\frac{\mathrm{C} 1 \times \mathrm{C} 2}{\mathrm{C} 1+\mathrm{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 1). The counter output is a $33 \%$ duty cycle clock at one-third the input frequency.

* The $F / \bar{C}$ input is a strapping pin that selects either the crystal oscillator or the EFI input as the clock for the +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.

The CLK output is a $33 \%$ duty cycle clock driver designed to drive the $80 \mathrm{C} 86,80 \mathrm{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 power-on reset by utilizing this function of the 82C84A.

## READY Synchronization

Two READY input (RDY1, RDY2) are provided to accommodate two system busses. Each input has a qualifier ( $\overline{\text { AEN1 }}$ and AEN2, respectively). The AEN signals validate their respective RDY signals. If a Multi-Master system is not being used the $\overline{\text { AEN }}$ pin should be tied LOW.
Synchronization is required for all asynchronous active-going 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{A S Y N C}$ 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 a the rising edge of CLK (requiring a setup time tR1VCH) and the synchronized to flip-flop two at the next falling edge of CLK, after which time the READY output will go active (HIGH). Neg-ative-going asynchronous READY inputs will be synchronized directly to flip-flop two at the falling edge of CLK, after which 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.
When $\overline{\text { ASYNC }}$ is high or left open, the first READY flip-flop 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.
$\overline{A S Y N C}$ can be changed on every bus cycle to select the appropriate mode of synchronization for each device in the system.

## Clock Outputs



FIGURE 1. CSYNC SYNCHRONIZATION
NOTE: If EF1 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 V |
| Input, Output or I/O Voltage | .GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta^{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $86^{\circ} \mathrm{C} / \mathrm{W}$ | $24^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $73^{\circ} \mathrm{C} / \mathrm{W}$ | $20^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | 580mW |
| Ceramic LCC Package |  | 532 mW |
| Gate Count |  | 50 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . +4.5 V to $+5.5 \mathrm{~V} \quad$ Operating Temperature Range
$\qquad$
$\qquad$
M82C84A. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $\quad \mathrm{VCC}=+5.0 \mathrm{~V} \pm 10 \%$
$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 84 \mathrm{~A})$
$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (182C84A)
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 84 \mathrm{~A})$

| 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}$ | C82C84A, I82C84 M82C84A, Notes 1, 2 |
| VIL | Logical Zero Input Voltage |  | 0.8 | V | Notes 1, 2, 3 |
| VIHR | Reset Input High Voltage | VCC -0.8 |  | V |  |
| VILR | Reset Input Low Voltage |  | 0.5 | V |  |
| VT+-VT- | Reset Input Hysteresis | 0.2 VCC |  |  |  |
| VOH | Logical One Output Current | VCC -0.4 |  | V | $1 \mathrm{OH}=-4.0 \mathrm{~mA}$ for CLK Output $10 \mathrm{H}=-2.5 \mathrm{~mA}$ for All Others |
| VOL | Logical Zero Output Voltage |  | 0.4 | V | $10 L=+4.0 \mathrm{~mA}$ for CLK Output <br> $10 \mathrm{~L}=+2.5 \mathrm{~mA}$ for All Others |
| 11 | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | ```VIN = VCC or GND except \overline{ASYNC,} X1: (Note 4)``` |
| ICCOP | Operating Power Supply Current |  | 40 | mA | Crystal Frequency $=25 \mathrm{MHz}$ Outputs Open, Note 5 |

NOTES:

1. $F / \overline{\mathrm{C}}$ is a strap option and should be held either $\leq 0.8 \mathrm{~V}$ or $\geq 2.2 \mathrm{~V}$. Does not apply to $\mathrm{X1}$ or X 2 pins.
2. Due to test equipment limitations related to noise, the actual tested value may differ from that specified, but the specified limit is guaranteed.
3. $\overline{\mathrm{CSYNC}}$ pin is tested with VIL $\leq 0.8 \mathrm{~V}$.
4. ASYNC pin includes an internal $17.5 \mathrm{k} \Omega$ nominal pull-up resistor. For $\overline{\text { ASYNC }}$ input at GND, $\overline{\text { ASYNC }}$ input leakage current $=300 \mu \mathrm{~A}$ nominal, X1 - crystal feedback input.
5. $f=25 \mathrm{MHz}$ may be tested using the extrapolated value based on measurements taken at $f=2 \mathrm{MHz}$ and $\mathrm{f}=10 \mathrm{MHz}$.

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | 10 | pF | FREQ $=1 \mathrm{MHz}$, all measurements are <br> referenced to device GND |
| COUT | Output Capacitance | 15 | pF |  |

AC Electrical Specifications $\quad V_{C C}=+5 \mathrm{~V} \pm 10 \%$

$$
\begin{aligned}
& T_{A}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 84 \mathrm{~A}) \\
& T_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(182 \mathrm{CB4A}) \\
& T_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\text { M } 82 \mathrm{C} 84 \mathrm{~A})
\end{aligned}
$$

| SYMBOL |  | PARAMETER | LIMITS |  | UNITS | (NOTE 1) TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| TIMING REQUIREMENTS |  |  |  |  |  |  |
| (1) | TEHEL |  | External Frequency HIGH Time | 13 | - | ns | 90\%-90\% VIN |
| (2) | TELEH | External Frequency LOW Time | 13 | - | ns | 10\%-10\% VIN |
| (3) | TELEL | EFI Period | 36 | - | ns |  |
|  |  | XTAL Frequency | 2.4 | 25 | MHz | Note 2 |
| (4) | TR2VCL | RDY1, RDY2 Active Setup to CLK | 35 | - | ns | ASYNC $=$ HIGH |
| (5) | TR1VCH | RDY1, RDY2 Active Setup to CLK | 35 | - | ns | ASYNC = LOW |
| (6) | TR1VCL | RDY1, RDY2 Inactive Setup to CLK | 35 | - | ns |  |
| (7) | TCLR1X | RDY1, RDY2 Hold to CLK | 0 | - | ns |  |
| (8) | TAYVCL | $\overline{\text { ASYNC }}$ Setup to CLK | 50 | - | ns |  |
| (9) | TCLAYX | $\overline{\text { ASYNC }}$ Hold to CLK | 0 | - | ns |  |
| (10) | TA1VR1V | $\overline{\mathrm{AEN1}}, \overline{\mathrm{AEN2}}$ Setup to RDY1, RDY2 | 15 | - | ns |  |
| (11) | TCLA1X | $\overline{\text { AEN1 }}$, $\overline{\text { AEN2 }}$ Hold to CLK | 0 | - | ns |  |
| (12) | TYHEH | CSYNC Setup to EFI | 20 | - | ns |  |
| (13) | TEHYL | CSYNC Hold to EFI | 20 | - | ns |  |
| (14) | TYHYL | CSYNC Width | 2 TELEL | - | ns |  |
| (15) | TI1HCL | $\overline{\text { RES }}$ Setup to CLK | 65 | - | ns | Note 3 |
| (16) | TCLITH | $\overline{\text { RES }}$ Hold to CLK | 20 | - | ns | Note 3 |
| TIMING RESPONSES |  |  |  |  |  |  |
| (17) | TCLCL | CLK Cycle Period | 125 | - | ns | Note 6 |
| (18) | TCHCL | CLK HIGH Time | $(1 / 3$ TCLCL) +2.0 | - | ns | Note 6 |
| (19) | TCLCH | CLK LOW Time | ( $2 / 3$ TCLCL) -15.0 | - | ns | Note 6 |
| $\begin{aligned} & \text { (20) } \\ & \text { (21) } \end{aligned}$ | $\begin{aligned} & \text { TCH1CH2 } \\ & \text { TCL2CL1 } \end{aligned}$ | CLK Rise or Fall Time | - | 10 | ns | 1.0 V to 3.0V |
| (22) | TPHPL | PCLK HIGH Time | TCLCL-20 | - | ns | Note 6 |
| (23) | TPLPH | PCLK LOW Time | TCLCL-20 | - | ns | Note 6 |
| (24) | TRYLCL | Ready Inactive to CLK (See Note 4) | -8 | - | ns | Note 4 |
| (25) | TRYHCH | Ready Active to CLK (See Note 3) | $(2 / 3$ TCLCL) -15.0 | - | ns | Note 5 |
| (26) | TCLIL | CLK to Reset Delay | - | 40 | ns |  |
| (27) | TCLPH | CLK to PCLK HIGH Delay | - | 22 | ns |  |
| (28) | TCLPL | CLK to PCLK LOW Delay | - | 22 | ns |  |
| (29) | TOLCH | OSC to CLK HIGH Delay | -5 | 22 | ns |  |
| (30) | TOLCL | OSC to CLK LOW Delay | 2 | 35 | ns |  |

## NOTES:

1. Tested as follows: $\mathrm{f}=2.4 \mathrm{MHz}, \mathrm{VIH}=2.6 \mathrm{~V}, \mathrm{VIL}=0.4 \mathrm{~V}, \mathrm{CL}=50 \mathrm{pF}$, $\mathrm{VOH} \geq 1.5 \mathrm{~V}, \mathrm{VOL} \leq 1.5 \mathrm{~V}$, unless otherwise specified. $\overline{\mathrm{RES}}$ and $\mathrm{F} / \overline{\mathrm{C}}$ must switch between 0.4 V and VCC -0.4 V . Input rise and fall times driven at $1 \mathrm{~ns} / \mathrm{V}$. VIL $\leq \mathrm{VIL}(\max )-0.4 \mathrm{~V}$ for CSYNC pin. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .
2. Tested using EFI or X1 input pin.
3. Setup and hold necessary only to guarantee recognition at next clock.
4. Applies only to T 2 states.
5. Applies only to T3 TW states.
6. Tested with EFI input frequency $=4.2 \mathrm{MHz}$.

Timing Waveforms

## WAVEFORMS FOR CLOCKS AND RESET SIGNALS



NOTE: All timing measurements are made at 1.5 Volts, unless otherwise noted.
WAVEFORMS FOR READY SIGNALS (FOR ASYNCHRONOUS DEVICES)


WAVEFORMS FOR READY SIGNALS (FOR SYNCHRONOUS DEVICES)


## Test Load Circuits

TEST LOAD MEASUREMENT CONDITIONS


NOTES:

1. $C L=100 \mathrm{pF}$ for CLK output
2. $C L=50 p F$ for all outputs except CLK
3. $C L=$ Includes probe and jig capacitance

TCHCL, TCLCH LOAD CIRCUIT


TRYLCL, TRYHCH LOAD CIRCUIT


## A.C. Testing Input, Output Waveform



NOTE: Input test signals must switch between VIL (maximum) -0.4 V and VIH (minimum) +0.4 V . $\overline{\mathrm{RES}}$ and $\mathrm{F} / \overline{\mathrm{C}}$ must switch between 0.4 V and VCC -0.4 V . Input rise and fall times driven at $1 \mathrm{~ns} / \mathrm{V}$. VIL $\leq \mathrm{VIL}(\max )-0.4 \mathrm{~V}$ for CSYNC pin. VCC -4.5 V and 5.5 V .

## Burn-In Circuits

MD82C84A CERAMIC DIP


MR82C84A CERAMIC LCC


NOTES:
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
VIL $=-0.2$ to 0.4 V
$\mathrm{R} 1=47 \mathrm{k} \Omega, \pm 5 \%$,
$R 2=10 \mathrm{k} \Omega, \pm 5 \%$,
$\mathrm{R} 3=2.2 \mathrm{k} \Omega \pm 5 \%$,
$\mathrm{R} 4=1.2 \mathrm{k} \Omega, \pm 5 \%$,
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ (minimum)
$\mathrm{F} 0=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0 / 2, F 2=F 1 / 2, \ldots F 12=F 11 / 2$

## Metallization Topology

DIE DIMENSIONS:
$66.1 \times 70.5 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si-AI
Thickness: $11 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy (LCC has Gold Preform)
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC $-420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.42 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

## Metallization Mask Layout



SEMICONDUCTOR

## CMOS Static Clock Controller/Generator

## Features

- Generates the System Clock For CMOS or NMOS Microprocessors and Peripherals
- Complete Control Over System Operation for Very Low System Power
- Stop-Oscillator
- Low Frequency
- Stop-Clock
- Full Speed Operation
- DC to $\mathbf{2 5 M H z}$ Operation (DC to $\mathbf{8 M H z}$ System Clock)
- Generates 50\% and 33\% Duty Cycle Clocks (Synchronized)
- Uses a Parallel Mode Crystal Circuit or External Frequency Source
- TTL Compatible Inputs/Outputs
- 24 Pin Slimline Dual-In-Line or 28 Pad Square LCC Package Options
- Single 5V Power Supply
- Operating Temperature Range
- C82C85 $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I82C85 $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C85 . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 82C85 Static CMOS Clock Controller/Generator provides complete control of static CMOS system operating modes and supports full speed, slow, stop-clock and stoposcillator operation. While directly compatible with the Harris 80C86 and 80C88 16-bit Static CMOS Microprocessor Family, the 82C85 can also be used for general system clock control.

For static system designs, separate signals are provided on the 82C85 for stop (S0, S1, $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}$ ) and start (START) control of the crystal oscillator and system clocks. A single control line (SLO/FST) determines 82C85 fast (crystal/EFI frequency divided by 3) or slow (crystal/EFI frequency divided by 768) mode operation. Automatic maximum mode 80C86 and 80C88 software HALT instruction decode logic in the 82C85 enables software-based clock control. Restart logic insures valid clock start-up and complete synchronization of system clocks.
The 82C85 is manufactured using the Harris advanced Scaled SAJI IV CMOS process. In addition to clock control circuitry, the 82 C 85 also contains a crystal controlled oscillator (up to 25 MHz ), clock generation logic, complete "Ready" synchronization and reset logic. This permits the designer to tailor the system power-performance product to provide optimum performance at low power levels.

## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | ORDER <br> CODE |
| :--- | :---: | :--- |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C85 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C85 |
|  | $0^{\circ} \mathrm{Cto}+70^{\circ} \mathrm{C}$ | CD 82 C 85 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C85 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C85/B |
| LCC | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C85/B |

## Pinouts



Pin Descriptions

| SYMBOL | DIP PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \hline \mathrm{X} 1 \\ & \mathrm{X} 2 \end{aligned}$ | $\begin{aligned} & 23 \\ & 22 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | CRYSTAL CONNECTIONS: X1 and X2 are the crystal oscillator connections. The crystal frequency must be 3 times the maximum desired processor clock frequency. X 1 is the oscillator circuit input and X 2 is the output of the oscillator circuit. If the crystal inputs are not used, X1 must be tied to $\mathrm{V}_{\mathrm{CC}}$ or GND, and X 2 should be left open. |
| EFI | 20 | 1 | EXTERNAL FREQUENCY IN: When F/ $\overline{\mathrm{C}}$ is HIGH, CLK is generated from the EFI input signal. This input signal should be a square wave with a frequency of three times the maximum desired CLK output frequency. If the crystal inputs are not used. XI must be tied to $\mathrm{V}_{\mathrm{CC}}$ or GND, and X2 should be left open. |
| F/ $\bar{C}$ | 19 | 1 | FREQUENCY/CRYSTAL SELECT: F/C selects either the crystal oscillator or the EFI input as the main frequency source. When F/C is LOW, the 82C85 clocks are derived from the crystal oscillator circuit. When F/ $\bar{C}$ is HIGH, CLK is generated from the EFI input. F/ $\bar{C}$ cannot be dynamically switched during normal operation. |
| START | 11 | 1 | A low-to-high transition on START will restart the CLK, CLK50 and PCLK outputs after the appropriate restart sequence is completed. <br> When in the crystal mode ( $F / \overline{\mathrm{C}}$ LOW) with the oscillator stopped. The oscillator will be restarted when a Start command is received. The CLK, CLK50 and PCLK outputs will start after the oscillator input signal (X1) reaches the Schmitt trigger input threshold and 8 K internal counter reaches terminal count. If F/C̄ is HIGH (EFI mode), CLK, CLK50 and PCLK will restart within 3 EFI cycles after START is recognized. <br> The 82C85 will restart in the same mode ( $\overline{\mathrm{SLO} / \mathrm{FST}}$ ) in which it stopped. A high level on START disables the STOP mode. |
| $\begin{gathered} \text { SO } \\ \bar{S} 1 \\ \hline \text { STOP } \end{gathered}$ | $\begin{aligned} & 13 \\ & 14 \\ & 15 \end{aligned}$ | $\begin{aligned} & \text { I } \\ & \text { i } \\ & \text { in } \end{aligned}$ | $\overline{\text { S2 }} / \overline{\mathrm{STOP}}, \mathrm{S} 1, \mathrm{SO}$ are used to stop the 82 C 85 clock outputs (CLK, CLK50, PCLK) and are sampled by the rising edge of CLK, CLK50 and PCLK are stopped by $\overline{\text { S2 }} / \mathrm{STOP}, \mathrm{S} 1, \mathrm{SO}$ being in the LHH state on the low-to-high transition of CLK. This LHH state must follow a passive HHH state occurring on the previous low-to-high CLK transition. CLK and CLK50 stop in the high state when F/ $\overline{\mathrm{C}}$ is low and may stop in either the high or low state when F/C्C is high. PCLK stops in its current state (high or low). <br> When in the crystal mode (F/C̄) low and a STOP command is issued, the 82 C 85 oscillator will stop along with the CLK, CLK50 and PCLK outputs. When in the EFI mode, only the CLK, CLK50 and PCLK outputs will be halted. The oscillator circuit if operational, will continue to run. The oscillator and/or clock is restarted by the START input signal going true (HIGH) or the reset input ( $\overline{\mathrm{RES}}$ ) going low. |
| SLO/FST | 12 | I | $\overline{\text { SLO} / F S T ~ i s ~ a ~ l e v e l-t r i g g e r e d ~ i n p u t . ~ W h e n ~ H I G H, ~ t h e ~ C L K ~ a n d ~ C L K 50 ~ o u t p u t s ~ r u n ~ a t ~ t h e ~ m a x i m u m ~}$ frequency (crystal or EFI frequency divided by 3). When LOW, CLK and CLK50 frequencies are equal to the crystal or EFI frequency divided by 768 . SLO/FST changes are internally synchronized so proper CLK and CLK50 phase relationships are maintained and minimum pulse width specifications are met. START and STOP control of the oscillator or EFI is available in either the SLOW or FAST frequency modes. The SLO/FST input must be held LOW for at least 195 OSC/ EFI clock cycles before it will be recognized. This eliminates unwanted frequency changes which could be caused by glitches or noise transients. The $\overline{\text { SLO} / F S T ~ i n p u t ~ m u s t ~ b e ~ h e l d ~ H I G H ~ f o r ~ a t ~ l e a s t ~}$ 6 OSC/EFI clock pulses to guarantee a transition to FAST mode operation. |
| CLK | 8 | 0 | PROCESSOR CLOCK: CLK is the clock output used by the 80 C 86 or 80 C 88 processor and other peripheral devices. When SLO/FST is high, CLK has an output frequency which is equal to the crystal or EFI input frequency divided by three. When SLO/FST is low, CLK has an output frequency which is equal to the crystal or EFI input frequency divided by 768. CLK has a $33 \%$ duty cycle. |
| CLK50 | 10 | 0 | $50 \%$ DUTY CYCLE CLOCK: CLK50 is an auxiliary clock with a $50 \%$ duty cycle and is synchronized to the falling edge of CLK. When SLO/FST is high, CLK50 has an output frequency which is equal to the crystal or EFI input frequency divided by 3. When SLO/FST is low, CLK50 has an output frequency equal to the crystal or EFI input frequency divided by 768. |
| PCLK | 2 | 0 | PERIPHERAL CLOCK: PCLK is a peripheral clock signal whose output frequency is equal to the crystal or EFI input frequency divided by 6 and has a $50 \%$ duty cycle. PCLK frequency is unaffected by the state of the SLO/FST input. |
| OSC | 18 | 0 | OSCILLATOR OUTPUT: OSC is the output of the internal oscillator circuitry. Its frequency is equal to that of the crystal oscillator circuit. OSC is unaffected by the state of the SLO/FST input. When the 82C85 is in the crystal mode (F/C/ low) and a STOP command is issued, the OSC output will stop in the HIGH state. When the 82C85 is in the EFI mode (F// HIGH, the oscillator (if operational) will continue to run when a STOP command is issued and OSC remains active. |

## Pin Descriptions (Continued)

| SYMBOL | DIP PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\overline{\text { RES }}$ | 17 | 1 | RESET IN: $\overline{\operatorname{RES}}$ is an active LOW signal which is used to generate RESET. The 82C85 provides a Schmitt trigger input so that an RC connection can be used to establish the power-up reset of proper duration. $\overline{\mathrm{RES}}$ starts crystal oscillator operation. |
| RESET | 16 | 0 | RESET: RESET is an active HIGH signal which is used to reset the 80 C 86 family processors. Its timing characteristics are determined by $\overline{\text { RES}}$. RESET is guaranteed to be HIGH for a minimum of 16 CLK pulses after the rising edge of $\overline{\text { RES }}$. |
| CSYNC | 1 | 1 | CLOCK SYNCHRONIZATION: CSYNC is an active HIGH signal which allows multiple 82C85 and 82C84A to be synchronized to provide multiple in-phase clock signals When CSYNC is HIGH, the internal counters are reset and force CLK, CLK50 and PCLK into a HIGH state. When CSYNC is LOW, the internal counters are allowed to count and the CLK, CLK50 and PCLK outputs are active. CSYNC must be externally synchronized to EFI. |
| $\overline{\overline{\overline{A E N 1}} \overline{\text { AEN2 }}}$ | $\begin{aligned} & 3 \\ & 7 \end{aligned}$ | 11 | ADDRESS ENABLE: $\overline{A E N}$ is an active LOW signal. $\overline{\text { AEN }}$ serves to qualify its respective Bus Ready Signal (RDY1 or RDY2). $\overline{\text { AEN1 }}$ validates RDY1 while $\overline{\text { AEN2 }}$ validates RDY2. Two $\overline{\text { AEN }}$ signal inputs are useful in system configurations which permit the processor to access two MultiMaster System Buses. |
| RDY1 RDY2 | $\begin{aligned} & 4 \\ & 6 \end{aligned}$ | 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 $\overline{A E N 1}$ while RDY2 is qualified by $\overline{A E N 2}$. |
| $\overline{\text { ASYNC }}$ | 21 | 1 | READY SYNCHRONIZATION SELECT: $\overline{\text { ASYNC }}$ 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{A S Y N C}$ is left open or HIGH a single stage of READY synchronization is provided. |
| READY | 5 | 0 | READY: READY is an active HIGH signal which is the synchronized RDY signal input. |
| GND | 9 | 1 | Ground |
| $\mathrm{V}_{\mathrm{CC}}$ | 24 | 1 | $\mathrm{V}_{\mathrm{Cc}}$ : is the +5 V power supply pin. A 0.1 mF capacitor between $\mathrm{V}_{\mathrm{Cc}}$ and GND is recommended. |

Functional Block Diagram


## Functional Description

The 82C85 Static Clock Controller/Generator provides simple and complete control static CMOS system operating modes. The 82C85 supports full speed, slow, stop-clock and stop-oscillator operation. While it is directly compatible with the Harris $80 C 86$ and 80 C 88 CMOS 16-bit static microprocessors, the 82C85 can also be used for general purpose system clock control.
The 82C85 pinout is a superset of the 82C84A Clock Generator/Driver. 82C85 pins 1-9, 16-24 are compatible with 82C84A pins 1-9, 10-18 respectively. An 82C84A can be placed in the upper 18 pins of an 82C85 socket and it will operate correctly (without the ability to control the clock and oscillator operation.) This allows dual design for simple system upgrades. The 82C85 will also emulate an 82C84A when pins $11-15$ on the 82 C 85 are tied to $\mathrm{V}_{\mathrm{CC}}$.
For static systems designs, separate signals are provided on the 82C85 for stop and start control of the crystal oscillator and clock outputs. A single control line determines 82C85 fast (crystal/EFI frequency divided by 3 ) or slow (crystal/EFI frequency divided by 768) mode operation. The 82C85 also contains a crystal controlled oscillator, clock generation logic, complete "Ready" synchronization and reset logic.
Automatic 80C86/88 software HALT instruction decode logic is present to ease the design of software-based clock control systems and provide complete software control of STOP mode operation. Restart logic insures valid clock start-up and complete synchronization of CLK, CLK50 and PCLK.

## Static Operating Modes

In static CMOS system design, there are four basic operating modes. The 82C85 Static Clock Controller supports each of them. These modes are: FAST, SLOW, STOP-CLOCK and STOP-OSCILLATOR. Each has distinct power and performance characteristics which can be matched to the needs of a particular system at a specific time (See Table 1).
Keep in mind that a single system may require all of these operating modes at one time or another during normal operation. A design need not be limited to a single operating mode or a specific combination of modes. The appropriate operating mode can be matched to the power-performance level needed at a specific time or in a particular circumstance.

## Reset Logic

The 82C85 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 power-on reset by utilizing this function of the 82C85.
When in the crystal oscillator ( $F / \overline{\mathrm{C}}=$ LOW ) or the EFI (F/C $=$ HIGH) mode, a LOW state on the RES input will set the RESET output to the HIGH state. It will also restart the oscillator circuit if it is in the idle state. The RESET output is guaranteed to stay in the HIGH state for a minimum of 16 CLK cycles after a low-to-high transition of the $\overline{\mathrm{RES}}$ input.

An oscillator restart count sequence will not be disturbed by RESET if this count is already in progress. After the restart counter expires, the RESET output will stay HIGH at least for 16 periods of CLK before going LOW. RESET can be kept high beyond this time by a continuing low input on the RES input.
If F/ $\bar{C}$ is low (crystal oscillator mode), a low state on $\overline{\text { RES }}$ starts the crystal oscillator circuit. The stopped outputs remain inactive, until the oscillator signal amplitude reaches the X1 Schmitt trigger input threshold voltage and 8192 cycles of the crystal oscillator output are counted by an internal counter. After this count is complete, the stopped outputs (CLK, CLK50, PCLK, and OSC) start cleanly with the proper phase relationships.

This 8192 count requirement insures that the CLK, CLK50 and PCLK outputs will meet minimum clock requirements and will not be affected by unstable oscillator characteristics which may exist during the oscillator start-up sequence. This sequence is also followed when a START command is issued while the 82C85 oscillator is stopped.

## Oscillator/Clock Start Control

Once the oscillator is stopped (or committed to stop) or at power-on, the restart sequence is initiated by a HIGH state on START or LOW state on $\overline{\text { RES. If F/C }}$ is HIGH, then restart occurs immediately after the START or $\overline{\mathrm{RES}}$ input is synchronized internally. This insures that stopped outputs (CLK, PCLK, OSC and CLK50) start cleanly with the proper phase relationship.
If $F / \bar{C}$ is low (crystal oscillator mode), a HIGH state on the START input or a low state on $\overline{R E S}$ causes the crystal oscillator to be restarted. The stopped outputs remain

TABLE 1. STATIC SYSTEM OPERATING MODE CHARACTERISTICS

| OPERATING MODE | DESCRIPTION | POWER LEVEL | PERFORMANCE |
| :---: | :---: | :---: | :---: |
| Stop-Oscillator | All system clocks and main clock oscillator are stopped | Maximum savings | Slowest response due to oscillator restart time |
| Stop-Clock | System CPU and peripherals clocks stop but main clock oscillator continues to run at rated frequency | Reduced system power | Fast restart-no oscillator restart time |
| Slow | System CPU clocks are slowed while peripheral clock and main clock oscillator run at rated frequency | Power dissipation slightly higher than Stop-Clock | Continuous operation at low frequency |
| Fast | All clocks and oscillators run at rated frequency | Highest power | Fastest response |

stopped, until the oscillator signal amplitude reaches the X1 Schmitt trigger input threshold voltage and 8192 cycles of the crystal oscillator output are counted by an internal counter. After this count is complete, the stopped outputs (CLK, CLK50, PCLK, and OSC) start cleanly with the proper phase relationships.

Typically, any input signal which meets the START input timing requirements can be used to start the 82C85. In many cases, this would be the INT output from an 82C59A CMOS Priority Interrupt Controller (See Figure 1). This output, which is active high, can be connected to both the 82C85 START pin and to the appropriate interrupt request input on the microprocessor.


FIGURE 1. CMOS PERIPHERAL CONTROL OF 82 C 85 STOP, START AND SLOW/FAST OPERATIONS

When the INT output becomes active, the oscillator/clock circuit on the 82C85 will restart. Upon completion of the appropriate restart sequence, the CLK signal to the CPU will become active. The CPU can then respond to the still pending interrupt request.
If the 82C59A882C85 restart combination is used in conjunction with an 82C55A $\overline{\text { STOP }}$ control, the 82C55A must be initialized prior to the 82C59A after reset. The 82C59A interrupt output is driven high at reset, causing the 82C85 to remain in the START mode regardless of the state of the $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}$ input. This will avoid stopping the 82C85 due to negative transitions on the S2/STOP input which may occur during a mode change on the 82C55A or during the operation of any peripheral I/O device prior to initialization.
Another method of insuring proper operation of the START function upon reset or system initialization is to bias the $\overline{S_{2} /}$ $\overline{\text { STOP }}$ input low with an external pull-down resistor. The $\overline{\mathrm{S} 2 /}$ $\overline{\text { STOP }}$ input will remain low until driven high by the 82C55A port pin or by external logic. This insures that the 82C85 STOP command (HHH prior to LHH requirement on the status inputs) will not be satisfied. To minimize power dissipation in this case (using a pulldown resistor), the S2/ STOP input should be normally LOW and pulsed HIGH to develop the necessary HHH-to-LHH STOP sequence. In this manner, the output driving the $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}$ input will be normally LOW and will not be driving to the opposite state of the pull-down resistor.

## Fast Mode

The most common operating mode for a system is the FAST mode. In this mode, the 82C85 operates at the maximum frequency determined by the main oscillator or EFI frequency.

TABLE 2. TYPICAL SYSTEM POWER SUPPLY CURRENT FOR STATIC CMOS OPERATING MODES

|  | FAST |  | SLOW | STOP-CLOCK |
| :--- | :---: | :---: | :---: | :---: | STOP-OSC

All measurements taken at room temperature, $\mathrm{V}_{\mathrm{CC}}=+5.0$ Volts. Power supply current levels will be dependent upon system configuration and frequency of operation.

FAST mode operation is enabled by each of two conditions:

- The SLO/FST input is HIGH and a START or reset command is issued
- The $\overline{\text { SLO/FST input is held HIGH for at least } 6}$ oscillator or EFI cycles.


## Alternate Operating Modes

Using alternate modes of operation (slow, stop-clock, stoposcillator) will reduce the average system operating power dissipation in a static CMOS system (See Table 2). This does not mean that system speed or throughput must be reduced. When used appropriately, the slow, stopclock, stoposcillator modes can make your design more power efficient while maintaining maximum system performance.

## Stop-Oscillator Mode

When the 82C85 is stopped while in the crystal mode (F/C LOW), the oscillator, in addition to all system clock signals (CLK, CLK50 and PCLK), are stopped. CLK and CLK50 stop in the high state. PCLK stops in it's current state (high or low).
With the oscillator stopped, 82C85 power drops to it's lowest level. All clocks and oscillators are stopped. All devices in the system which are driven by the 82 C 85 go into the lowest power standby mode. The 82C85 also goes into standby and requires a power supply current of less than 100 microamps.

## Stop-Clock Mode

When the 82C85 is in the EFI mode (F/ $\overline{\mathrm{C}}$ HIGH) and a $\overline{\text { STOP }}$ command is issued, all system clock signals (CLK, CLK50, and PCLK) are stopped. CLK and CLK50 stop in the high state when $F / \overline{\bar{C}}$ is low and may stop in either the high or low state when F/ $\overline{\mathrm{C}}$ is high. PCLK stops in its current state (high or low).

The 82C85 can also provide it's own EFI source simply by connecting the OSC output to the EFI input and pulling the F/C input HIGH. This puts the 82C85 into the External Frequency Mode using it's own oscillator as an external source signal (See Figure 2). In this configuration, when the 82C85 is stopped in the EFI mode, the oscillator continues to run. Only the clocks to the CPU and peripherals (CLK, CLK50 and PCLK) are stopped.


FIGURE 2. STOP-CLOCK MODE USING $82 C 85$ IN EFI MODE WITH OSCILLATOR AS FREQUENCY SOURCE

## Oscillator/Clock Stop Operation

Three control lines determine when the 82C85 clock outputs or oscillator will stop. These are S0, S1 and $\overline{\mathrm{S}} / \overline{\mathrm{STOP}}$. These three lines are designed to connect directly to the MAXimum mode 80 C 86 and 80 C 88 status lines or to be driven by external I/O signals (such as an 82C55A output port).
In the MAXimum mode configuration, the 82C85 will automatically recognize a software HALT command from the 80C86 or 80C88 and stop the system clocks or oscillator. This allows complete software control of the $\overline{\text { STOP }}$ function.

If the 80C86 or 80C88 is used in the MINimum mode, the 82 C 85 can be controlled using the $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}$ input (with S0 and S1 held high). This can be done using an external I/O control line, such as from an 82C55A or by decoding the state of the 80C86 MINimum mode status signals.
82 C 85 status inputs $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}, \mathrm{S} 1, \mathrm{SO}$ are sampled on the rising edge of CLK. The oscillator (F/C LOW only) and clock outputs are stopped by $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}, \mathrm{S} 1$, S0 being in the LHH state on a low-to-high transition of CLK. This LHH state must follow a passive HHH state ocurring on the previous low-tohigh CLK transition. CLK and CLK50 will stop in the logic HIGH state after two additional complete cycles of CLK. PCLK stops in it's current state (HIGH or LOW). This is true for both SLOW and FAST mode operation.

## 80C86/88 Maximum Mode Clock Control

The 82C85 STOP function has been optimized for 80C86/ 88 MAXimum mode operation. In this mode, the three 82C85 status inputs (S2/STOP, S1, S0) are connected directly to the MAXimum mode status lines ( $\mathrm{S} 2, \mathrm{~S} 1, \mathrm{~S} 0$ ) of the Harris 80C86 or 80C88 static CMOS microprocessors (See Figure 3).

When in the MAXimum mode, the 80C86/88 status lines identify which type of bus cycle the CPU is starting to execute. 82C85 S2/STOP, S1 and S0 control input logic will recognize a valid MAXimum mode software HALT executed by the 80 C 86 or 80 C 88 . Once this state has been recognized, the 82 C 85 stops the clock (F/E HIGH) and oscillator (F/C LOW) operation.


FIGURE 3. 82C85STOP CONTROLUSING 80C86/88 MAXIMUM MODE STATUS LINES

The 82C85 $\overline{\text { S2 }} / \overline{\mathrm{STOP}}, \mathrm{S} 1$ and S0 control lines were designed to detect a passive 111 state followed by a HALT 011 logic state before recognizing the HALT instruction and stopping the system clocks. In the MAXimum mode, the 80C86/88 status lines go into a passive (no bus cycle) logic 111 state prior to executing a HALT instruction. The qualification of a passive no bus cycle logic 111 state insures that random transitions of the status lines into a logic 011 state will not stop the system clock. This is necessary since the status lines of the 80C86/88 transition through an unknown state during T3 of the bus cycle.

Once the HALT instruction is decoded by the 82C85, either the oscillator is stopped (STOP-OSCILLATOR mode F/C̄ tied low ) or the external frequency source is gated off internally (STOP-CLOCK mode F/ $\overline{\mathrm{C}}$ HIGH). When the HALT instruction is decoded with F/C low, the CLK and CLK50 will be stopped in a logic high state after 2 additional cycles of the clock. PCLK stops in it's current state (high or low). This is true for both SLOW and FAST mode operation. The HALT instruction is detected in the same manner whether the 82C85 is in the SLOW or FAST mode.

## Independent Stop Control for Minimum Mode Operation

When the 80 C 86 and 80 C 88 microprocessors are configured in MINimum Mode (MN/ $\overline{M X}$ pin tied high), their status lines S0, S1, and S2 assume alternate functions. The logic states and sequences (passive before a HALT) necessary for automatic HALT detect in the 82C85 do not occur as in the MAXimum mode. The 82C85 controller cannot use the microprocessor status lines to detect a software Halt instruction when operating in MINimum mode.
However, the negative edge-activated $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}$ pin provides a simple means for clock control in MINimum mode 80C86 and 80 C 88 systems. $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}$ can be used as an independent $\overline{S T O P}$ control when S1 and S0 are held in the logical HIGH state. Keeping the S0 and S1 inputs at a logic 1 level and transitioning S2/STOP from high to low will meet the passive 111 state prior to a 011 state requirement of the 82 C 85 . This feature allows 82 C 85 operation with the 80 C 86 and 80 C 88 in the MINimum mode, provides compatibility with other static CMOS microprocessors and allows maximum flexibility in a system.
With $\mathrm{S} 2 / \overline{\mathrm{STOP}}$ being used as a stand-alone STOP command line, system clocks can be controlled via an 82C55A programmable peripheral interface or other similar interface circuits. This is accomplished by driving the $\overline{\mathrm{S} 2 /}$ $\overline{\text { STOP }}$ input with a PORT pin on the 82C55A (See Figure 1). The 82C55A port pin should be configured as an output and must present a logic HIGH to the $\overline{\mathrm{S} 2} / \mathrm{STOP}$ input for at least one CLK cycle, followed by a LOW state. This will meet the 82 C 85 status input requirement of 111 followed by a 011.
When a logic 0 is written to a 82C55A port pin, the $\overline{\mathrm{S} 2} / \overline{\text { STOP }}$ pin is pulled low, stopping the system clocks (CLK, CLK50, PCLK). In essence, the 82C85 is software controlled via the 82C55A. As with the $\overline{\text { SLO} / F S T ~ i n t e r f a c e, ~ P O R T ~} C$ is a logical choice for this job since the individual bit set and reset commands available for this port make control of the $\overline{\mathrm{S} 2 /}$ $\overline{\text { STOP }}$ input simple.

A START command issued to the 82C85 will override a $\overline{\text { STOP }}$ command and the 82 C 85 will begin normal operation. The low state of the negative-edge triggered $\overline{\mathrm{S} 2} / \overline{\mathrm{STOP}}$ input will not prohibit the clocks from restarting. After a START or $\overline{\text { RES }}$ command, the 82 C 85 must see a passive (111) state followed by a HALT (011) state to stop the system clocks. To accomplish this, the 82C55A port output must be brought high and then returned low again for the 82C85 to recognize the next $\overline{\text { STOP }}$ command.

## External Decode Adds Halt Control

SSO, $10 / \bar{M}$ and $D T / \bar{R}$ can identify a MINimum mode $80 C 88$ HALT execution. During T2 of the system timing (while ALE is high), SSO, $10 / \bar{M}$, and $D T / \bar{R}$ go into a 111 state when the 80 C 88 is executing a software HALT. These signals cannot be tied directly to the S2/STOP, S1 and S0 inputs since they are not guaranteed to go into a passive state prior to their 111 state. These signals can be decoded during the time ALE is high to indicate a software HALT execution.

## Slow Mode

When continuous operation is critical but power consumption remains a concern, the 82C85 SLOW mode operation provides a lower frequency at the CLK and CLK50 outputs (crystal/EFI frequency divided by 768). The frequency of PCLK is unaffected. The SLOW mode allows the CPU and the system to operate at a reduced rate which, in turn, reduces system power.
For example, the operating power for the 80C86 or 80C88 CPU is $10 \mathrm{~mA} / \mathrm{MHz}$ of clock frequency. When the SLOW mode is used in a typical 5 MHz system, CLK and CLK50 run at approximately 20 kHz . At this reduced frequency, the average operating current of the CPU drops to 200 microamps. Adding the 80C86/88 500 microamps standby current brings the total current to 700 microamps.
While the CPU and peripherals run slower and the 82C85 CLK and CLK50 outputs switch at a reduced frequency, the main 82C85 oscillator is still running at the maximum frequency (determined by the crystal or EFI input frequency.) Since CMOS power is directly related to operating frequency, 82C85 power supply current will typically be reduced by 15-20\%.

## Clock Slow/Fast Operation

The $\overline{\text { SLO} / F S T ~ i n p u t ~ d e t e r m i n e s ~ w h e t h e r ~ t h e ~ C L K ~ a n d ~ C L K 50 ~}$ outputs run at full speed (crystal or EFI frequency divided by 3) or at slow speed (crystal or EFI frequency divided by 768) (See Figure 4). When in the SLOW mode, 82C85 stop-clock and stop-oscillator functions operate in the same manner as in the FAST mode.

Internal logic requires that the $\overline{\text { SLO} / F S T ~ p i n ~ b e ~ h e l d ~ l o w ~ f o r ~}$ at least 195 oscillator or EFI clock pulses before the SLOW mode command is recognized. This requirement eliminates unwanted FAST-to-SLOW mode frequency changes which could be caused by glitches or noise spikes.
To guarantee FAST mode recognition, the SLO/FST pin must be held high for at least 6 OSC or EFI pulses. The 82 C 85 will begin FAST mode operation on the next PCLK edge after FAST command recognition. Proper CLK and

CLK 50 phase relationships are maintained and minimum pulse width specifications are met.
FAST-to-SLOW or SLOW-to-FAST mode changes will occur on the next rising or falling edge of PCLK. It is important to remember that the transition time for operating freqeuncy changes, which are dependent upon PCLK, will vary with the 82C85 oscillator or EFI frequency.

## Slow Mode Control

The 82C55A programmable peripheral interface can be used to provide control of the $\overline{\text { SLO} / F S T ~ p i n ~ b y ~ c o n n e c t i n g ~ a ~ p o r t ~}$ pin of the 82C55A directly to the $\overline{\text { SLO} / F S T ~ p i n ~(S e e ~ F i g u r e ~}$ 1). With the port pin configured as an output, software control of the SLO/FST pin is provided by simply writing a logical one (FAST mode) or logical zero (SLOW Mode) to the corresponding port. PORT C is well-suited for this function due to it's bit set and reset capabilities. Since PCLK continues to run at a frequency equal to the oscillator or EFI frequency divided by 6, it can be used by other devices in the system which need a fixed high frequency clock. For example, PCLK could be used to clock an 82C54 programmable interval timer to produce a real-time clock for the system or as a baud rate generator to maintain serial data communications during SLOW mode operation.

## Oscillator

The oscillator circuit of the 82C85 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 connections. The output of the oscillator is buffered and available at the OSC output (pin 18) for generation of other system timing signals.

For the most stable operation of the oscillator (OSC) output circuit, two capacitors ( $\mathrm{C} 1=\mathrm{C} 2$ ) are recommended. Capacitors C1 and C2 are chosen such that their combined capacitance matches the load capacitance as specified by the crystal manufacturer. This insures operation within the frequency tolerance specified by the crystal manufacturer.

The crystal/capacitor configuration and the formula used to determine the capacitor values are shown in Figure 5. Crystal Specifications are shown in Table 3.

$$
\mathrm{CT}=\frac{\mathrm{C} 1 \cdot \mathrm{C} 2}{\mathrm{C} 1+\mathrm{C} 2} \quad \text { (Including stray capacitance) }
$$



FIGURE 5. 82C85 CRYSTAL CONNECTION
TABLE 3. CRYSTAL SPECIFICATIONS

| PARAMETER | TYPICAL CRYSTAL <br> SPECIFICATION |
| :--- | :--- |
| Frequency | 2.4 to 25 MHz |
| Type of Operation | Parallel Resonent, Fund. Mode |
| Load Capacitance | 20 or 32 pF |
| RSERIES (Max) | $35 X\left(f=25 \mathrm{MHz}, \mathrm{C}_{\mathrm{L}}=32 \mathrm{pF}\right)$ <br> $66 \mathrm{X}\left(\mathrm{f}=25 \mathrm{MHz}, \mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}\right)$ |

## Frequency Source Selection

The F/ $\overline{\mathrm{C}}$ input is a strapping pin that selects either the crystal oscillator or the EFI input as the source frequency for clock generation. If the EFI input is selected as the source, the oscillator section (OSC output) can be used independently for another clock source. If a crystal is not used, then crystal input X1 (pin 23) must be tied to $\mathrm{V}_{\mathrm{CC}}$ or GND and X2 (pin 22) should be left open. If the EFI mode is not used, then EFI (pin 20) should be tied to $\mathrm{V}_{\mathrm{CC}}$ or GND.


FIGURE 4. $\overline{\text { LLO} / F S T ~ T I M I N G ~ O V E R V I E W ~}$

## Clock Generator

The clock generator consists of two synchronous divide-bythree counters with special clear inputs that inhibit the counting. One counter generates a $33 \%$ duty cycle waveform (CLK) and the other generates a $50 \%$ duty cycle waveform (CLK50). These two counters are negative-edge synchronized, with the low-going transitions of both waveforms occurring on the same oscillator transition. The CLK and CLK50 output frequencies are one-third of the base input frequency when SLO/FST is high and are equal to the base input frequency divided by 768 when SLO/FST is low.

The CLK output is a $33 \%$ duty cycle clock signal designed to drive the 80C86 and 80C88 microprocessors directly. CLK50 has a $50 \%$ duty cycle output synchronous with CLK, designed to drive coprocessors and peripherals requiring a $50 \%$ duty cycle clock. When $\overline{\text { SLO}} / \mathrm{FST}$ is high, CLK and CLK50 have output frequencies which are $1 / 3$ that of EFI/ OSC. When SLO/FST is low, CLK and CLK50 have output frequencies which are OSC (EFI) divided by 768.

PCLK is a peripheral clock signal with an output frequency equal to the oscillator or EFI frequency divided by 6. PCLK has a $50 \%$ duty cycle. PCLK is unaffected by SLO/FST. When the 82C85 is placed in the $\overline{\text { STOP }}$ mode, PCLK will remain in it's current state (logic high or logic low) until a RESET or START command restarts the 82C85 clock circuitry. PCLK is negative-edge synchronized with CLK and CLK50.

## Clock Synchronization

The clock synchronization (CSYNC) input allows the output clocks to be synchronized with an external event (such as another 82C85 or 82C84A clock signal). CSYNC going active causes all clocks (CLK, CLK50 and PCLK) to stop in the HIGH state.

It is necessary to synchronize the CSYNC input to the EFI clock external to the 82C85. This is accomplished with two flip-flops when synchronizing two 82C85s and with three flip-flops when synchronizing an 82C85 to an 82C84A (See Figure 6). Multiple external flip-flops are necessary to minimize the occurence of metastable (or indeterminate) states.

## Ready Synchronization

Two READY inputs (RDY1, RDY2) are provided to accommodate two system busses. Each READY input is qualified by ( $\overline{\mathrm{AEN} 1}$ and $\overline{\mathrm{AEN2} 2}$, respectively). The $\overline{\mathrm{AEN}}$ signals validate their respective RDY signals.

Synchronization is required for all asynchronous activegoing edges of either RDY input to guarantee that the RDY set up 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{A S Y N C}$ 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 TR1VCH) and then synchronized to flip-flop two at the next falling edge of CLK, after which time the READY output will go 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.
When $\overline{A S Y N C}$ is high or left open, the first READY flip-flop 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. $\overline{A S Y N C}$ can be changed on every bus cycle to select the appropriate mode of synchronization for each device in the system.


FIGURE 6. 82C85 AND 82C84A CSYNC SYNCHRONIZATION METHODS

## Specifications 82C85

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output or I/O Voitage | .GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. . . . . | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {c }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $53^{\circ} \mathrm{C} / \mathrm{N}$ | $18^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $61^{\circ} \mathrm{CN}$ | $11^{\circ} \mathrm{CN}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | 1.07W |
| Ceramic LCC Package |  | 1.03W |
| Gate Count |  | 500 Gates |

CAUTION Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range .
+4.5 V to +5.5 V Operating Temperature Range
C82C85
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
I82C85. $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
M82C85 . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} 10 \% ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C85);
$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 85 );
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C85)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ | - | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & \text { C82C85, 182C85 } \\ & \text { M82C85 } \end{aligned}$ |
| $\mathrm{V}_{\text {IHR }}$ | Reset Input High Voltage | 2.8 | - | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical Zero Input Voltage | - | 0.8 | V | Note 1 |
| $\mathrm{V}_{\mathrm{T}^{+}} \mathrm{V}_{\mathrm{T}}$ | Reset Input Hysteresis | 0.25 | - | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One Output Voltage | $\mathrm{V}_{\mathrm{CC}}-0.4$ | - | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-5.0 \mathrm{~mA}(\text { (CLK, CLK50) } \\ & \mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}(\mathrm{X} 2) \\ & \mathrm{I}_{\mathrm{OH}}=-2.5 \mathrm{~mA} \text { (all other outputs) } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.5 \mathrm{~mA}(\mathrm{X} 2) \\ & \mathrm{I}_{\mathrm{OL}}=+5.0 \mathrm{~mA} \text { (all other outputs) } \end{aligned}$ |
| 11 | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | $V_{I N}=V_{C C} \text { or GND, except DIP }$ $\text { Pins } 11-15,21,23$ |
| IBHH | Bus-hold High Leakage Current | -10 | -200 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=3.0 \mathrm{~V}$; Pins 11-15, 21 |
| ICCSB | Standby Power Supply Current | - | 100 | $\mu \mathrm{A}$ | 82C85 in HALT state with oscillator stopped |
| ICCOP | Operating Power Supply Current | - | 50 | mA | Crystal Frequency $=15 \mathrm{MHz}$, outputs open, inputs = GND or $V_{C C}$ |
|  |  | - | 70 | mA | Crystal Frequency $=25 \mathrm{MHz}$, outputs open, inputs $=$ GND or $V_{C C}$ |
| ICCSLOW | Slow Mode Operating Current | - | 40 | mA Crystal Freq $=15 \mathrm{MHz}$ | Outputs Open; $\overline{\text { SLO }} / \mathrm{FST}=\mathrm{GND}$, START $=\mathrm{V}_{\mathrm{CC}}$, Other inputs $-\mathrm{V}_{\mathrm{IN}}=$ $V_{C C}$ or GND |
|  |  | - | 60 | $\begin{gathered} \text { mA Crystal } \\ \text { Freq }=25 \mathrm{MHz} \end{gathered}$ |  |

NOTE: 1. For CSYNC, $\mathrm{V}_{\mathrm{LL}}=\mathrm{GND}$

Capacitance $T_{A}=25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS |  |
| :--- | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 15 | pF | FREQ $=1 \mathrm{MHz}$, all measurements are referenced to device |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 20 | pF | GND |

## $82 C 85$

AC Electrical Specifications $V_{C C}=5 \mathrm{~V} \pm 10 \% ; T_{A}=0^{\circ} \mathrm{C}$ t0 $+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 85) ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( $182 \mathrm{C85}$ );
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C85)

| SYMBOL |  | PARAMETER | LIMITS |  | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| TIMING REQUIREMENTS |  |  |  |  |  |  |
| (1) | TEHEL |  | External Frequency HIGH Time | 15 | - | ns | $\begin{aligned} & 90 \%-90 \% V_{\text {IN }}, \text { Note } 1, \\ & f=25 \mathrm{MHz} \end{aligned}$ |
|  | TELEH | External Frequency LOW Time | 15 | - | ns | $\begin{aligned} & 10 \%-10 \% V_{\text {IN }} \text {, Note } 1, \\ & f=25 \mathrm{MHz} \end{aligned}$ |
| (3) | TELEL | EFI or Crystal Period | 40 | - | ns | Note 1 |
| (4) | TEFIDC | External Frequency Input Duty Cycle | 45 | 55 | \% | $\mathrm{f}=25 \mathrm{MHz}$, Note 1 |
| (5) | FX | Crystal Frequency | 2.4 | 25 | MHz | Note 1 |
| (6) | TR1VCL | RDY1, RDY2 Active Setup to CLK | 35 | - | ns | $\overline{\text { ASYNC }}=\mathrm{HIGH}$ |
| (7) | TR1VCH | RDY1, RDY2 Active Setup to CLK | 35 | - | ns | $\overline{\overline{A S Y N C}}=$ LOW |
| (8) | TR1VCL | RDY1, RDY2 Inactive Setup to CLK | 35 | - | ns |  |
| (9) | TCLR1X | RDY1, RDY2 Hold to CLK | 0 | - | ns |  |
| (10) | TAYVCL | $\overline{\text { ASYNC }}$ Setup to CLK | 50 | - | ns |  |
| (11) | TCLAYX | $\overline{\text { ASYNC }}$ Hold to CLK | 0 | - | ns |  |
| (12) | TA1VR1V | $\overline{\text { AEN1 }}$, $\overline{\text { AEN2 }}$ Setup to RDY1, RDY2 | 15 | - | ns |  |
| (13) | TCLA1X | $\overline{\text { AEN1 }}, \overline{\text { AEN2 }}$ Hold to CLK | 0 | - | ns |  |
| (14) | TYHEH | CSYNC Setup to EFI | 10 | - | ns |  |
| (15) | TEHYL | CSYNC Hold to EFI | 10 | - | ns |  |
| (16) | TYHYL | CSYNC Pulse Width | 2TELEL | - | ns |  |
| (17) | T11HCL | $\overline{\text { RES }}$ Setup to CLK | 65 | - | ns | Note 2 |
| (18) | TSVCH | S0, S1, $\overline{\text { S2 }} / \overline{\text { STOP }}$ Setup to CLK | 35 | - | ns |  |
| (19) | TCHSV | S0, S1, $\overline{\text { S2 }} / \overline{\text { STOP }}$ Hold to CLK | 35 | - | ns |  |
| (20) | TRSVCH | $\overline{\text { RES }}$, START Setup to CLK | 65 | - | ns | Note 2 |
| (21) | TSHSL | $\overline{\mathrm{RES}}$ (Low) or START (High) Pulse Width | TCLCLs3 | - | ns |  |
| (22) | TSFPC | $\overline{\text { SLO/FST Setup to PCLK }}$ | TEHEL + 100 | - | ns | Note 2 |
| (23) | TSTART | $\overline{\mathrm{RES}}$ or START Valid to CLK Low | 2 TELEL + 2 | $\cdot$ | ns |  |
| (24) | TSTOP | STOP Command Valid to CLK High | $\begin{aligned} & \text { 2TCHCH + } \\ & \text { TRSVCH } \end{aligned}$ | $\begin{gathered} \text { 3TCHCH } \\ +34 \end{gathered}$ | ns | TCHCH $=$ TCLCL |

TIMING RESPONSES

| (25) | TCLCL | CLKJCLK50 Cycle Period | 125 | - | ns | Note 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (26) | TCHCL | CLK HIGH Time | (1/3 TCLCL)+2 | - | ns |  |
| (27) | TCLCH | CLK LOW Time | (2/3 TCLCL)-15 | - | ns |  |
| (28) | T5CHCL | CLK50 HIGH Time | (1/2 TCLCL)-7.5 | - | ns |  |
| (29) | T5CLCH | CLK50 LOW Time | (1/2 TCLCL)-7.5 | - | ns |  |
| (30) | TCH1CH2 | CLKJCLK50 Rise Time | - | 8 | ns | 1.0 V to 3.5 V |
| (31) | TCL2CL1 | CLK/CLK50 Fall Time | - | 8 | ns | 1.0 V to 3.5 V |
| (32) | TPHPL | PCLK HIGH Time | TCLCL-20 | - | ns |  |
| (33) | TPLPH | PCLK LOW Time | TCLCL-20 | - | ns |  |
| (34) | TRYLCL | Ready Inactive to CLK | -8 | - | ns | Note 4 |

AC Electrical Specifications $\quad V_{C C}=5 \mathrm{~V} \pm 10 \% ; T_{A}=0^{\circ} \mathrm{C} 10+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 85) ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(182 \mathrm{C} 85)$; $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C85) (Continued)

| SYMBOL |  | PARAMETER | LIMITS |  | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| (35) | TRYHCH |  | Ready Active to CLK | 2/3(TCLCL)-15 | - | ns | Note 3 |
| (36) | TCLIL | CLK to Reset Delay | - | 40 | ns |  |
| (37) | TCLPH | CLK to PCLK HIGH Delay | $\bullet$ | 22 | ns |  |
| (38) | TCLPL | CLK to PCLK LOW Delay | $\cdot$ | 22 | ns |  |
| (39) | TOST | Start/Reset Valid to Clock LOW | - | 2 | ms | Typ. - Note 8 |
| (40) | TOLOH | Output Rise Time (except CLK) | - | 15 | ns | From 0.8 V to 2.0 V |
| (41) | TOHOL | Output Fall Time (except CLK) | $\bullet$ | 12 | ns | From 2.0 V to 0.8 V |
| (42) | TRST | RESET output HIGH Time | $16 \times$ TCLCL | - | ns |  |
| (43) | TCLC50L | CLK LOW to CLK50 LOW Skew | - | 5 | ns |  |

NOTES:

1. Slow and Fast Modes.
2. Setup and hold necessary only to guarantee recognition at next clock.
3. Applies only to T3, TW states.
4. Applies only to T 2 states.
5. All timing delays are measured at 1.5 volts unless otherwise noted.
6. Input signals must switch between $\mathrm{V}_{\mathrm{IL}} \max -0.4$ and $\mathrm{V}_{\mathrm{IH}} \min +$ 0.4 volts
7. Timing measurements made with EFI duty cycle $=50 \%$.
8. Oscillator start up time depends on several factors including crystal frequency, crystal manufacturer, capacitive load, temperature, power supply voltage, etc. This parameter is given for information only.
9. Output signals switch between $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ unless otherwise specified.

## Timing Waveforms

WAVEFORMS FOR CLOCKS


NOTE: All Timing Mesurements are made at 1.5 Volts Unless Otherwise Noted.

WAVEFORMS FOR READY SIGNALS (FOR ASYNCHRONOUS DEVICES)


## Timing Waveforms (Continued)

WAVEFORMS FOR READY SIGNALS (FOR SYNCHRONOUS DEVICES)


CLOCK STOP (F/C HIGH OR F/C LOW)


$\overline{\text { RES }}$ START $\rightarrow$ TRSVCH (20)
NOTE: 1. When F/C is low, CLK and CLK50 stop high. When F/C is high, CLK and CLK50 may stop either high or low. CLOCKS START (F/C HIGH)


Timing Waveforms (Continued)


NOTE: Start up count begins when the crystal oscillator reaches a suitable threshold level.
RESET TIMING (CLK RUNNING WITH F//्̄ट् LOW-OSC MODE)
(CLK RUNNING-OR STOPPED WITH F/C HIGH EFI MODE)


RESET TIMING (OSCILLATOR STOPPED, F/C̄ LOW)


NOTE: 1. CLK, CLK50, PCLK Remain in the High State until $\overline{\text { RES }}$ goes high and 8192 valid oscillator cycles have been registered by the 82C85 internal counter (TOST time period). After RES goes high and CLK, CLK50, PCLK become active, the RESET output will remain high for minimum of 16 CLK cycles (TRST)

Timing Waveforms (Continuod)

## SLO/FST TIMING OVERVIEW



NOTE: See Fast to Slow Clock Mode Transition for Detailed Timing See Slow to Fast Clock Mode Transition for Detailed Timing

FAST TO SLOW CLOCK MODE TRANSITION


SLOW TO FAST CLOCK MODE TRANSITION E\&I
ORC
OSC 保


[^12]
## Test Load Circuits

PASSIVE LOAD

$\mathrm{R}=360$ © $\mathrm{V}=2.25$ for CLK and CLK50 outputs $R=470$ © $\mathrm{V}=2.87$ for all other outputs (Except X2)

DYNAMIC LOAD

$I_{\text {OL }}=5 \mathrm{~mA}, 1 O H=-5 \mathrm{~mA}$ for CLK and CLK50 outputs
$\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}, 1 \mathrm{OH}=-2.5 \mathrm{~mA}$ for all other outputs (Except X2)
$\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}, \mathrm{IOH}=-1.0 \mathrm{~mA}$ for X 2 output
(DC Performance characteristic only)
$\mathrm{V}_{\mathrm{TRIP}}=1.4 \mathrm{~V}$

NOTES: 1. $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ for CLK and CLK50 output
2. $C_{L}=50 \mathrm{pF}$ minimum for all other outputs
3. $\mathrm{C}_{\mathrm{L}}=$ Includes probe and jig capacitance

TCHCL, TCLCH LOAD CIRCUIT (USING X1, X2)
TCHCL, TCLCH LOAD CIRCUIT (USING EFI)


TRYLCL, TRYHCH LOAD CIRCUIT (USING X1, X2)
TRYLCL, TRYHCH LOAD CIRCUIT (USING EFI)

A.C. Testing Input, Output Waveform


## Burn-In Circuits



MR82C85 CERAMIC LCC
BOTTOM VIEW


NOTES:
$\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
$\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{V}_{\mathrm{IL}}=-0.2$ to 0.4 V
$R_{1}=100 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{R}_{2}=10 \mathrm{k} \Omega, \pm 5 \%$
$\mathrm{R}_{3}=47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{R}_{4}=470 \mathrm{k} \Omega, \pm 5 \%$
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ (minimum)
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$

## Metallization Topology

## DIE DIMENSIONS:

$107.9 \times 122.0 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - AL
Thickness: $11 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy (LCC has Gold Preform)
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC $-420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$2.26 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
This device meets glassivation integrity test requirements per MIL-STD-883 Method 2021 and MIL-M-38510, Paragraph 3.5.5.4.

## Metallization Mask Layout



## Features

- Full Eight Bit Bi-directional Bus Interface
- Industry Standard 8286 Compatible Pinout
- High Drive Capability
- B Side IOL

20 mA

- A Side IOL

12 mA

- Three-State Outputs
- Propagation Delay 35ns Max.
- Gated Inputs
- Reduce Operating Power
- Eliminate the Need for Pull-Up Resistors
- Single 5V Power Supply
- Low Power Operation $I C C S B=10 \mu A$
- Operating Temperature Range
- C82C86H $\qquad$ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- 182 C 86 H . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C86H $\qquad$


## Description

The Harris 82 C 86 H is a high performance CMOS Octal Transceiver manufactured using a self-aligned silicon gate CMOS process (Scaled SAJI IV). The 82C86H 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}}$ ) permits simple interface to the $80 \mathrm{C} 86,80 \mathrm{C} 88$ and other microprocessors. The 82 C 86 H has gated inputs, eliminating the need for pull-up/pull-down resistors and reducing overall system operating power dissipation.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 5 MHz | 8MHz |
| :---: | :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C86H-5 | CP82C86H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C86H-5 | IP82C86H |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C86H-5 | CS82C86H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C86H-5 | IS82C86H |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C86H-5 | CD82C86H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C86H-5 | ID82C86H |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C86H-5/B | - |
| SMD \# |  | 5962-8757701RA | - |
| LCCSMD \# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C86H-5/B | - |
|  |  | 5962-87577012A | - |

## Pinouts

## 20 LEAD DIP TOP VIEW



20 LEAD PLCC AND LCC
TOP VIEW


TRUTH TABLE

| $\mathbf{T}$ | $\overline{O E}$ | $\mathbf{A}$ | $\mathbf{B}$ |
| :---: | :---: | :---: | :---: |
| $\mathbf{X}$ | $H$ | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ |
| $H$ | L | I | O |
| $\mathbf{L}$ | L | O | I |

$=$ Logic One
= Logic Zero
= Input Mode
= Output Mode
= Don't Care
Hi -Z $=$ High Impedance

PIN NAMES

| PIN | DESCRIPTION |
| :---: | :--- |
| $A_{0}-A_{7}$ | Local Bus Data I/O Pins |
| $B_{0}-B_{7}$ | System Bus Data I/O Pins |
| $T$ | Transmit Control Input |
| $\overline{O E}$ | Active Low Output Enable |

## Functional Diagram



## Gated Inputs

During normal system operation of a latch, signals on the bus at the device inputs will become high impedance or make transitions unrelated to the operation of the latch. These unrelated input transitions switch the input circuitry and typically cause an increase in power dissipation in CMOS devices by creating a low resistance path between VCC and GND when the signal is at or near the input switching threshold. Additionally, if the driving signal becomes high impedance ("float" condition), it could create an indeterminate logic state at the inputs and cause a disruption in device operation.

The Harris 82C8X series of bus drivers eliminates these conditions by turning off data inputs when data is latched (STB = logic zero for the $82 \mathrm{C} 82 / 83 \mathrm{H}$ ) and when the device is disabled ( $\overline{\mathrm{OE}}=$ logic one for the $82 \mathrm{C} 86 \mathrm{H} / 87 \mathrm{H}$ ). These gated inputs disconnect the input circuitry from the VCC and
ground power supply pins by turning off the upper P-channel and lower N-channel (See Figures 1 and 2). No current flow from VCC to GND occurs during input transitions and invalid logic states from floating inputs are not transmitted. The next stage is held to a valid logic level internal to the device.
D.C. input voltage levels can also cause an increase in ICC if these input levels approach the minimum VIH or maximum VIL conditions. This is due to the operation of the input circuitry in its linear operating region (partially conducting state). The 82C8X series gated inputs mean that this condition will occur only during the time the device is in the transparent mode (STB = logic one). ICC remains below the maximum ICC standby specification of $10 \mu \mathrm{~A}$ during the time inputs are disabled, thereby greatly reducing the average power dissipation of the 82C8X series devices.

## Decoupling Capacitors

The transient current required to charge and discharge the 300 pF load capacitance specified in the $82 \mathrm{C} 86 \mathrm{H} / 87 \mathrm{H}$ data sheet is determined by

$$
\mathrm{I}=\mathrm{CL}(\mathrm{dv} / \mathrm{dt})
$$

Assuming that all outputs change state at the same time and that $\mathrm{dv} / \mathrm{dt}$ is constant;

$$
\mathrm{I}=\mathrm{CL} \frac{(\mathrm{VCC} \times 80 \%)}{\mathrm{tR} / \mathrm{tF}}
$$

where $\mathrm{tR}=20 \mathrm{~ns}, \mathrm{VCC}=5.0 \mathrm{~V}, \mathrm{CL}=300 \mathrm{pF}$ on each 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 \mu \mathrm{~F}$ ceramic disc capacitor be placed between VCC and GND at each device, with placement being as near to the device as possible.


FIGURE 1. 82C82/83H


FIGURE 2. 82C86H/87H GATED INPUTS

## Absolute Maximum Ratings

| Input, Output or I/O Voltage | $\cdots \ldots \ldots \ldots . .+8.0 \mathrm{~V}$ |
| :---: | :---: |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Clas |

## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{10}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $70^{\circ} \mathrm{C} / \mathrm{N}$ | $15^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $76^{\circ} \mathrm{C} / \mathrm{N}$ | $19^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 720 m |
| Ceramic LCC Package |  |  |
| Gate Co |  |  |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

| Operating Voltage Range. | +4.5V to +5.5V | Operating Temperature Range |
| :---: | :---: | :---: |
|  |  | C82C86H. |
|  |  | 182 C 86 H |
|  |  | M82C86H |

$\begin{array}{ll}\text { DC Electrical Specifications } \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} 86 \mathrm{H}) ; \\ \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(182 \mathrm{C} 86 \mathrm{H}) ; \\ \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 86 \mathrm{H})\end{array}$

| 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}$ | C82C86H, 182C86H <br> M82C86H (Note 1) |
| VIL | Logical Zero Input Voltage | $\bullet$ | 0.8 | V |  |
| VOH | Logical One Output Voltage <br> B Outputs <br> A Outputs <br> A or B Outputs | $\begin{gathered} 3.0 \\ 3.0 \\ \text { vCC }-0.4 \end{gathered}$ |  | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ | $\begin{aligned} 10 \mathrm{OH} & =-8 \mathrm{~mA} \\ 1 \mathrm{OH} & =-4 \mathrm{~mA} \\ 10 \mathrm{H} & =-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | Logical Zero Output Voltage <br> B Outputs <br> A Outputs |  | $\begin{aligned} & 0.45 \\ & 0.45 \end{aligned}$ | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & 1 O L=20 \mathrm{~mA} \\ & 1 O L=12 \mathrm{~mA} \end{aligned}$ |
| 11 | Input Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | VIN = GND or VCC DIP Pins 9, 11 |
| 10 | Output Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VO}=\mathrm{GND} \text { or } \mathrm{VCC}, \overline{\mathrm{OE}} \geq \mathrm{VCC}-0.5 \mathrm{~V} \\ & \text { DIP Pins } 1-8,12-19 \end{aligned}$ |
| ICCSB | Standby Power Supply Current | - | 10 | $\mu \mathrm{A}$ | VIN $=$ VCC or GND, VCC $=5.5 \mathrm{~V}$, Outputs Open |
| ICCOP | Operating Power Supply Current | - | 1 | mA/MHz | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Typical (See Note 2) |

## NOTES:

1. VIH is measured by applying a pulse of magnitude $=$ VIHmin to one data input at a time and checking the corresponding device output for a valid logical " 1 " during valid input high time. Control pins ( $T, \overline{O E}$ ) are tested separately with all device data input pins at VCC -0.4
2. Typical ICCOP $=1 \mathrm{~mA} / \mathrm{MHz}$ of read/cycle time. (Example: $1.0 \mu \mathrm{~s}$ read $/$ write cycle time $=1 \mathrm{~mA}$ ).

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance |  |  |  |
|  | B Inputs | 18 | pF | Freq $=1 \mathrm{MHz}$, all measurements are <br> referenced to device GND |
|  | A Inputs | 14 | pF |  |

Specifications 82C86H

|  |  |  | $\begin{aligned} & T_{A}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 86 \mathrm{H}) ; \\ & T_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(182 \mathrm{C} 86 \mathrm{H}) ; \\ & T_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 8 \mathrm{H}) \end{aligned}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL |  | PARAMETER | MIN | NOTE 4 |  | UNITS | TEST CONDITIONS |
|  |  | $\begin{gathered} \text { 82C86H } \end{gathered}$ |  | ${\underset{\text { MAX }}{ }}_{82 \mathrm{C} 86 \mathrm{H}-5}$ |  |  |
|  | TIVOV |  | Input to Output Delay Inverting <br> Non-Inverting | 5 | $\begin{aligned} & 30 \\ & 32 \end{aligned}$ | 35 35 | ns <br> ns | Notes 1, 2 |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
| (2) | TEHTV | Transmit/Receive Hold Time | 5 | - | - | ns | Notes 1, 2 |  |
| (3) | TTVEL | Transmit/Receive Setup Time | 10 | - | - | ns | Notes 1, 2 |  |
| (4) | TEHOZ | Output Disable Time | 5 | 30 | 35 | ns | Notes 1, 2 |  |
| (5) | TELOV | Output Enable Time | 10 | 50 | 65 | ns | Notes 1, 2 |  |
| (6) | TR, TF | Input Rise/Fall Times | - | 20 | 20 | ns | Notes 1, 2 |  |
|  | TEHEL | Minimum Output Enable High Time |  |  |  |  | Note 3 |  |
|  |  | $82 \mathrm{C} 86 \mathrm{H}$ | 30 | - | - | ns |  |  |
|  |  | 82C86H-5 | 35 | - | - | ns |  |  |

## NOTES:

1. All AC parameters tested as per test circuits and definitions in timing waveforms and test load circuits. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{V}$.
2. Input test signals must switch between VIL -0.4 V and $\mathrm{VIH}+0.4 \mathrm{~V}$.
3. A system limitation only when changing direction. Not a measured parameter.
4. 82 C 86 H is available in commercial and industrial temperature ranges only. $82 \mathrm{C} 86 \mathrm{H}-5$ is available in commercial, industrial and military temperature ranges.

## Timing Waveform



All timing measurements are made at 1.5 V unless otherwise noted.

## Test Load Circuits

A SIDE OUTPUTS


TIVOV
LOAD CIRCUIT


TELOV OUTPUT HIGH ENABLE LOAD CIRCUIT


TELOV OUTPUT LOW ENABLE LOAD CIRCUIT


TEHOZ OUTPUT LOW/HIGH DISABLE LOAD CIRCUIT

B SIDE OUTPUTS


TIVOV
LOAD CIRCUIT


TELOV
OUTPUT HIGH ENABLE LOAD CIRCUIT


TELOV OUTPUT LOW ENABLE LOAD CIRCUIT


TEHOZ OUTPUT LOW/HIGH DISABLE LOAD CIRCUIT

## Burn-In Circuits



MR82C86H CERAMIC LCC


NOTES:
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to 0.4 V
$R 1=47 \mathrm{k} \Omega \pm 5 \%$
$R 2=2.4 \mathrm{k} \Omega \pm 5 \%$
$R 3=1.5 \mathrm{k} \Omega \pm 5 \%$
$R 4=1 \mathrm{k} \Omega \pm 5 \%$
$R 5=5 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ minimum
$F 0=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0 / 2, F 2=F 1 / 2, F 3=F 2 / 2$

## Metallization Topology

DIE DIMENSIONS:
$138.6 \times 155.5 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy (LCC has Gold Preform)
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC $-420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.47 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout


82C87H

## CMOS Octal Inverting Bus Transceiver

## Features

- Full Eight Bit Bi-directional Bus Interface
- Industry Standard 8287 Compatible Pinout
- High Drive Capability:
- B Side IOL

20 mA

- A Side IOL 12mA
- Three-State Inverting Outputs
- Propagation Delay .35ns Max
- Gated Inputs:
- Reduce Operating Power
- Eliminate the Need for Pull-Up Resistors
- Single 5V Power Supply
- Low Power Operation $I C C S B=10 \mu A$
- Operating Temperature Range
- C82C87H
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I82C87H .$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C87H $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 82C87H is a high performance CMOS Octal Transceiver manufactured using a self-aligned silicon gate CMOS process (Scaled SANI IV). The 82C87H provides a full eight-bit bi-directional bus interface in a 20 pin package. The Transmit ( T ) control determines the data direction. The active low output enable ( $\overline{\mathrm{OE}})$ permits simple interface to the $80 \mathrm{C} 86,80 \mathrm{C} 88$ and other microprocessors. The 82 C 87 H has gated inputs, eliminating the need for pull-up/pulldown resistors and reducing overall system operating power dissipation. The 82 C 87 H provides inverted data at the outputs.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 5 MHz | 8MHz |
| :---: | :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C87H-5 | CP82C87H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C87H-5 | IP82C87H |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C87H-5 | CS82C87H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C87H-5 | IS82C87H |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C87H-5 | CD82C87H |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C87H-5 | ID82C87H |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C87H-5/B | - |
| SMD \# |  | 5962-8757702RA | - |
| LCC SMD \# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C87H-5/B | - |
|  |  | 5962-87577022A | - |

## Pinouts

## 20 LEAD DIP TOP VIEW



20 LEAD PLCC AND LCC TOP VIEW


TRUTH TABLE

| $\mathbf{T}$ | $\overline{\mathrm{OE}}$ | $\mathbf{A}$ | $\mathbf{B}$ |
| :---: | :---: | :---: | :---: |
| $\mathbf{X}$ | H | $\mathrm{Hi}-\mathbf{Z}$ | $\mathrm{Hi}-\mathbf{Z}$ |
| $H$ | L | I | O |
| $\mathbf{L}$ | L | O | I |

$\mathrm{H}=$ Logic One
L = Logic Zero
$1=$ Input Mode
$\mathrm{O}=$ Output Mode
X $=$ Don't Care
Hi-Z = High Impedance

PIN NAMES

| PIN | DESCRIPTION |
| :---: | :--- |
| AO-A7 | Local Bus Data I/O Pins |
| $\overline{\mathrm{B0}}-\overline{\mathrm{B} 7}$ | System Bus Data I/O Pins |
| T | Transmit Control Input |
| $\overline{\mathrm{OE}}$ | Active Low Output Enable |

## Functional Diagram



## Gated Inputs

During normal system operation of a latch, signals on the bus at the device inputs will become high impedance or make transitions unrelated to the operation of the latch. These unrelated input transitions switch the input circuitry and typically cause an increase in power dissipation in CMOS devices by creating a low resistance path between VCC and GND when the signal is at or near the input switching threshold. Additionally, if the driving signal becomes high impedance ("float" condition), it could create an indeterminate logic state at the inputs and cause a disruption in device operation.

The Harris 82C8X series of bus drivers eliminates these conditions by turning off data inputs when data is latched (STB = logic zero for the $82 \mathrm{C} 82 / 83 \mathrm{H}$ ) and when the device is disabled ( $\overline{\mathrm{OE}}=$ logic one for the $82 \mathrm{C} 86 \mathrm{H} / 87 \mathrm{H}$ ). These gated inputs disconnect the input circuitry from the VCC and
ground power supply pins by turning off the upper P-channel and lower N -channel (See Figures 1 and 2). No current flow from VCC to GND occurs during input transitions and invalid logic states from floating inputs are not transmitted. The next stage is held to a valid logic level internal to the device.
D.C. input voltage levels can also cause an increase in ICC if these input levels approach the minimum VIH or maximum VIL conditions. This is due to the operation of the input circuitry in its linear operating region (partially conducting state). The 82C8X series gated inputs mean that this condition will occur only during the time the device is in the transparent mode (STB = logic one). ICC remains below the maximum ICC standby specification of $10 \mu \mathrm{~A}$ during the time inputs are disabled, thereby greatly reducing the average power dissipation of the 82C8X series devices.

## Decoupling Capacitors

The transient current required to charge and discharge the 300 pF load capacitance specified in the $82 \mathrm{C} 86 \mathrm{H} / 87 \mathrm{H}$ data sheet is determined by

$$
\mathrm{I}=\mathrm{CL}(\mathrm{dv} / \mathrm{dt})
$$

Assuming that all outputs change state at the same time and that $d v / d t$ is constant;

$$
I=C L \frac{(V C C \times 80 \%)}{t R / t F}
$$

where $\mathrm{tR}=20 \mathrm{~ns}, \mathrm{VCC}=5.0 \mathrm{~V}, \mathrm{CL}=300 \mathrm{pF}$ on each eight outputs.


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 disc capacitor be placed between VCC and GND at each device, with placement being as near to the device as possible.


FIGURE 2. 82C86H/87H GATED INPUTS



FIGURE 1. $82 \mathrm{C} 82 / 83 \mathrm{H}$

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output or I/O Voltage | .GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $70^{\circ} \mathrm{C}$ W | $15^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $76^{\circ} \mathrm{C} / \mathrm{N}$ | $19^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | 720mW |
| Ceramic LCC Package |  | 664mW |
| Gate Count |  | 65 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V Operating Temperature Range
C82C87H. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
182C87H . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
M82C87H . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
DC Electrical Specifications $V C C=5.0 \mathrm{~V} \pm 10 \%$;
$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ( C 82 C 87 H$)$;
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 87 H );
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 87 \mathrm{H})$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ | - | V | C82C87H, 182 C 87 H , M82C87H (Note 1) |
| VIL | Logical Zero Input Voltage | - | 0.8 | V |  |
| VOH | Logical One Output Voltage <br> B Outputs <br> A Outputs <br> A or B Outputs | $\begin{gathered} 3.0 \\ 3.0 \\ \text { vCC }-0.4 \end{gathered}$ |  | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ | $\begin{aligned} 1 O H & =-8 \mathrm{~mA} \\ 1 O H & =-4 \mathrm{~mA} \\ 1 O H & =-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | Logical Zero Output Voltage <br> B Outputs <br> A Outputs |  | $\begin{aligned} & 0.45 \\ & 0.45 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & 1 O L=20 \mathrm{~mA} \\ & 1 \mathrm{OL}=12 \mathrm{~mA} \end{aligned}$ |
| 11 | Input Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | VIN = GND or VCC, DIP Pins 9, 11 |
| 10 | Output Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VO }=\text { GND or VCC, } \overline{O E} \geq \text { VCC }-0.5 V \\ & \text { DIP Pins } 1-8,12-19 \end{aligned}$ |
| ICCSB | Standby Power Supply Current | - | 10.0 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$, Outputs Open |
| ICCOP | Operating Power Supply Current | - | 1 | mA/MHz | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{VCC}=5 \mathrm{~V}$, Typical (See Note 2) |

NOTES:

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 "1" during valid input high time. Control pins ( $T, \overline{\mathrm{OE}}$ ) are tested separately with all device data input pins at VCC -0.4 V .
2. Typical ICCOP $=1 \mathrm{~mA} / \mathrm{MHz}$ of read/write cycle time. (Example: $1.0 \mu \mathrm{~s}$, read/write cycle time $=1 \mathrm{~mA}$ ).

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance |  | Freq $=1 \mathrm{MHz}$, all measurements are <br> referenced to device GND |  |
|  | B Inputs | 18 | pF |  |


| AC Electrical |  | $\begin{aligned} \text { Pecifications } & \text { VCC } \end{aligned}=5.0 \mathrm{~V} \pm 10 \% ; ~ 子 \text { Freq }=1 \mathrm{MHz} \text {; }$ |  | $\begin{aligned} & T_{A}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 87 \mathrm{H}) ; \\ & T_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(182 \mathrm{C} 87 \mathrm{H}) ; \\ & T_{A}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 87 \mathrm{H}) \end{aligned}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | YMBOL | PARAMETER | MIN | NOTE 4 82C87H MAX | NOTE 4 82C87H-5 MAX | UNITS | TEST CONDITIONS |
| (1) | TIVOV | Input to Output Delay Inverting <br> Non-Inverting | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 30 \\ & 32 \end{aligned}$ | $\begin{aligned} & 35 \\ & 35 \end{aligned}$ | ns ns | Notes 1, 2 |
| (2) | TEHTV | Transmit/Receive Hold Time | 5 | - | $\bullet$ | ns | Notes 1, 2 |
| (3) | TTVEL | Transmit/Receive Setup Time | 10 | - | - | ns | Notes 1, 2 |
| (4) | TEHOZ | Output Disable Time | 5 | 30 | 35 | ns | Notes 1, 2 |
| (5) | TELOV | Output Enable Time | 10 | 50 | 65 | ns | Notes 1, 2 |
| (6) | TR, TF | Input Rise/Fall Times | - | 20 | 20 | ns | Notes 1, 2 |
| (7) | TEHEL | Minimum Output Enable High Time $82 \mathrm{C} 87 \mathrm{H}$ 82C87H-5 | $\begin{aligned} & 30 \\ & 35 \end{aligned}$ |  | - | ns ns | Note 3 |

## NOTES:

1. All AC parameters tested as per test circuits and definitions in timing waveforms and test load circuits. Input rise and fall times are driven at 1 ns N .
2. Input test signals must switch between VIL -0.4 V and $\mathrm{VIH}+0.4 \mathrm{~V}$.
3. A system limitation only when changing direction. Not a measured parameter.
4. 82 C 87 H is available in commercial and industrial temperature ranges only. $82 \mathrm{C} 87 \mathrm{H}-5$ is available in commercial, industrial and military temperature ranges.

Timing Waveform


## Test Load Circuits

A SIDE OUTPUTS


TIVOV
LOAD CIRCUIT


TELOV
OUTPUT HIGH ENABLE LOAD CIRCUIT


TELOV
OUTPUT LOW ENABLE LOAD CIRCUIT


TEHOZ OUTPUT LOW/HIGH DISABLE LOAD CIRCUIT

B SIDE OUTPUTS



TELOV
TIVOV LOAD CIRCUIT


TELOV
OUTPUT LOW ENABLE LOAD CIRCUIT


TEHOZ OUTPUT LOW/HIGH DISABLE LOAD CIRCUIT

* Includes jig and stray capacitance


## Burn-In Circuits

## MD82C87H CERAMIC DIP



MR82C87H CERAMIC LCC


NOTES:
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to 0.4 V
$R 1=47 \mathrm{k} \Omega \pm 5 \%$
$R 2=2.4 \mathrm{k} \Omega \pm 5 \%$
$R 3=1.5 \mathrm{k} \Omega \pm 5 \%$
$R 4=1 \mathrm{k} \Omega \pm 5 \%$
R5 $=5 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ minimum
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0 / 2, F 2=F 1 / 2, F 3=F 2 / 2$

## Metallization Topology

DIE DIMENSIONS:
$138.6 \times 155.5 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$

## GLASSIVATION:

Type: $\mathrm{SiO}_{2}$
Thickness: $8 k \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy (LCC has Gold Preform)
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.47 \times 10^{5} \mathrm{Acm}^{2}$

Metallization Mask Layout
82C87H


## Features

- Compatibie with Bipolar 8288
- Performance Compatible with:
- 80C86/80C88
.(5/8MHz)
- 80186/80188 ...................... . . . . . . . . . (6/8MHz)
- 8086/8088 . . . . . . . . . . . . . . . . . . . . . . . . . . . . (5/8MHz)
- 8089
- Provides Advanced Commands for Multi-Master Busses
- Three-State Command Outputs
- Bipolar Drive Capability
- Scaled SAJIIV CMOS Process
- Single 5V Power Supply
- Low Power Operation
- ICCSB $\qquad$
- ICCOP ....... 1 mA . . . . .
- Operating Temperature Ranges
- C82C88
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- 182C88 . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C88 . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 82 C88 is a high performance CMOS Bus Controller manufactured using a self-aligned silicon gate CMOS process (Scaled SAJIIV). The 82 C 88 provides the control and command timing signals for $80 \mathrm{C} 86,80 \mathrm{C} 88$, $8086,8088,8089,80186$, and 80188 based systems. The high output drive capability of the 82C88 eliminates the need for additional bus drivers.

Static CMOS circuit design insures low operating power. The Harris advanced SAJI process results in performance equal to or greater than existing equivalent products at a significant power savings.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | ORDER CODE |
| :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C88 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C88 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C88 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C88 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C88 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C88 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C88/B |
| SMD\# |  | 8406901RA |
| LCC SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C88/B |
|  |  | 84069012A |

Pinouts

|  |  |  |
| :---: | :---: | :---: |
| 1081 | 20 | vcc |
| CLK 2 | 19 | $\overline{\text { so }}$ |
| S1 3 | 18 | $\overline{\text { S2 }}$ |
| DT/ $/ \overline{\text { R }} 4$ | 17 | MCE/PDEN |
| ALE 5 | 16 | den |
| $\overline{\text { AEN }} 6$ | 15 | CEN |
| $\overline{\text { MRDC }} 7$ | 14 | INTA |
| $\overline{\text { AMWC }} 8$ | 13 | $\overline{O R C}$ |
| MWTC 9 | 12 | $\overline{\text { AIOWC }}$ |
| GND 10 | 11 | IowC |



## Functional Diagram



## Pin Description

| $\begin{gathered} \text { PIN } \\ \text { SYMBOL } \end{gathered}$ | NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| VCC | 20 |  | VCC: The +5 V power supply pin. A $0.1 \mu \mathrm{~F}$ capacitor between pins 10 and 20 is recommended for decoupling. |
| GND | 10 |  | GROUND. |
| $\overline{\mathrm{So}}, \overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2}$ | 19, 3, 18 | 1 | STATUS INPUT PINS: These pins are the input pins from the $80 C 86,80 C 88,8086 / 88,8089$ processors. The 82 C 88 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 Table1). |
| CLK | 2 | 1 | CLOCK: This is a CMOS compatible input which receives a clock signal from the 82C84A or 82C85 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 and 82 C 83 H . |
| 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. |
| DT/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 from VO or memory). |
| $\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 (250ns maximum) after it becomes active (LOW). $\overline{\text { AEN }}$ going inactive immediately three-states the command output drivers. $\overline{\text { AEN }}$ does not affect the VO command lines if the 82 C 88 is in the I/O Bus mode (IOB tied HIGH). |
| CEN | 15 | 1 | COMMAND ENABLE. When this signal is LOW all 82 C88 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. |
| 10B | 1 | 1 | INPUT/OUTPUT BUS MODE: When the IOB pin is strapped HIGH, the 82 C 88 functions in the I/O Bus mode. When it is strapped LOW, the $82 \mathrm{CB8}$ 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{\text { AIOWC }}$ issues an VO 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 { ORC }}$ | 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{\text { AMWC }}$ 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{\mathrm{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. |
| $\frac{\text { MCEI }}{\text { 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. PDEN (IOB IS TIED HIGH): Peripheral Data Enable enables the data bus transceiver for the VO bus that DEN performs for the system bus. PDEN is active LOW. |

## Functional Description

The command logic decodes the three 80C86, 8086, 80C88, $8088,80186,80188$ 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 2}}$ | $\overline{\mathbf{S 1}}$ | $\overline{\mathbf{S 0}}$ | PROCESSOR STATE | 82C88 <br> COMMAND |
| :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | 0 | Interrupt Acknowledge | $\overline{\mathrm{INTA}}$ |
| 0 | 0 | 1 | Read I/O Port | $\overline{\mathrm{IORC}}$ |
| 0 | 1 | 0 | Write I/O Port | $\overline{\overline{O W C}, \overline{A l O W C}}$ |
| 0 | 1 | 1 | Halt | None |
| 1 | 0 | 0 | Code Access | $\overline{\text { MRDC }}$ |
| 1 | 0 | 1 | Read Memory | $\overline{\text { MRDC }}$ |
| 1 | 1 | 0 | Write Memory | $\overline{\text { MWTC }}, \overline{\text { AMWC }}$ |
| 1 | 1 | 1 | Passive | None |

## VO 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{I O W C}, \overline{A I O W C}, \overline{I N T A}$ ) 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{\text { PDEN }}$ and DT/ $\overline{\mathrm{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 perpherals dedicated to one processor exist in a multiprocessor system.

## System Bus Mode

The 82 C 88 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{A E N}$ line is activated (LOW). This mode assumes bus arbitration logic will inform the bus controller (on the $\overline{\text { 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.
$\overline{\mathrm{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.

The command outputs are:
$\overline{\text { MRDC }}$ - Memory Read Command
MWTC - Memory Write Command
IORC - I/O Read Command
IOWC - I/O Write Command
$\overline{\text { AMWC - Advanced Memory Write Command }}$
AIOWC - Advanced I/O Write Command
$\overline{\mathbb{N T A}}$ - Interrupt Acknowledge

## Control Outputs

The control outputs of the 82C88 are Data Enable (DEN), Data Transmit/Receive (DT//Z) 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 DT/R determines the direction of data transfer. These two signals usually go to the chip select and direction pins of a transceiver.
The MCE/PDEN pin changes function with the two modes of the 82C88. When the 82C88 is in the IOB mode (IOB HIGH), the $\overline{\text { 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 $82 \mathrm{C} 82 / 82 \mathrm{C} 83 \mathrm{H}$ address latches. ALE also serves to strobe the status $(\overline{\mathrm{S} 0}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 2})$ into a latch for halt state decoding.

## Command Enable

The Command Enable (CEN) input acts as a command qualifier for the 82C88. 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.

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | . +8.0 V |
| Input, Output or I/O Voltage | GND-0.5V to VCC +0.5 V |
| Storage Temperature Range | . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |


| Reliability Information |  |  |
| :---: | :---: | :---: |
| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{1 c}$ |
| Ceramic DIP Package . | $77.8^{\circ} \mathrm{CN}$ | $18.9{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $76.0^{\circ} \mathrm{CN}$ | $19.0{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 646 mW |
| Ceramic LCC Package |  | 664mW |
| Gate Count |  | 100 Gate |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . +4.5 V to +5.5 V Operating Temperature Range

| C82C88 | to $+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| $182 \mathrm{C88}$. | -40 ${ }^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| M82C88 | - $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

DC Electrical Specifications $\quad \mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%$;
$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ( C 82 C 88 );
$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 88 );
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C88)

| 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 { C82C88, 182C88 } \\ & \text { M82C88 } \end{aligned}$ |
| VIL | Logical Zero Input Voltage | $\bullet$ | 0.8 | V |  |
| VIHC | CLK Logical One Input Voltage | VCC -0.8 | - | V |  |
| VILC | CLK Logical Zero Input Voltage | - | 0.8 | V |  |
| VOH | Output High Voltage Command Outputs | $\begin{gathered} 3.0 \\ \text { vCC }-0.4 \end{gathered}$ | $\bullet$ | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & 1 \mathrm{IOH}=-8.0 \mathrm{~mA} \\ & 10 \mathrm{H}=-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{IOH}=-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}=+12.0 \mathrm{~mA}$ |
|  | Output Low Voltage Control Outputs | - | 0.4 | V | $1 \mathrm{OL}=+8.0 \mathrm{~mA}$ |
| II | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{GND}$ or VCC, except $\overline{\mathrm{SO}}, \overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2}$, DIP Pins 1-2, 6, 15 |
| IBHH | Input Leakage Current-Status Bus | -50 | -300 | $\mu \mathrm{A}$ | $\mathrm{VIN}=2.0 \mathrm{~V}, \overline{\mathrm{~S} 0}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 2}$ (See Note 1) |
| 10 | Output Leakage Current | -10.0 | 10.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{GND}$ or VCC, $\mathrm{IOB}=\mathrm{GND}, \overline{\mathrm{AEN}}=\mathrm{VCC}$, DIP Pins 7-9, 11-14 |
| ICCSB | Standby Power Supply | - | 10 | $\mu \mathrm{A}$ | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{VCC}$ or GND, Outputs Open |
| ICCOP | Operating Power Supply Current | - | 1 | $\mathrm{mA} M \mathrm{Mz}$ | VCC $=5.5 \mathrm{~V}$, Outputs Open (See Note 2) |

## NOTES:

1. IBHH should be measured after raising the VIN on $\overline{\mathrm{SO}}, \overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2}$ to
2. $I C C O P=1 \mathrm{mAMMHz}$ of CLK cycle time (TCLCL)

VCC and then lowering to valid input high level of 2.0 V .

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :--- |
| CIN | Input Capacitance | 10 | pF | FREQ $=1 \mathrm{MHz}$, all measurements are <br> referenced to device GND |
| COUT | Output Capacitance | 17 | pF |  |

AC Electrical Specifications VCC $=5.0 \mathrm{~V} \pm 10 \%$;
$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C88);
$T_{A}=-40^{\circ} \mathrm{C} 10+85^{\circ} \mathrm{C}$ ( 182 C 88 );
$T_{A}=-55^{\circ} \mathrm{C} 10+125^{\circ} \mathrm{C}$ (M82C88)

| SYMBOL |  | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TIMING REQUIREMENTS |  |  |  |  |  |  |
| (1) | TCLCL | CLK Cycle Period | 125 | $\cdot$ | ns |  |
| (2) | TCLCH | CLK Low Time | 55 | - | ns |  |
| (3) | TCHCL | CLK High Time | 40 | $\cdot$ | ns |  |
| (4) | TSVCH | Status Active Setup Time | 35 | - | ns |  |
| (5) | TCHSV | Status Inactive Hold Time | 10 | - | ns |  |
| (6) | TSHCL | Status Inactive Setup Time | 35 | $\cdot$ | ns |  |
| (7) | TCLSH | Status Active Hold Time | 10 | - | ns |  |

TIMING RESPONSES

| (8) | TCVNV | Control Active Delay | 5 | 45 | ns | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (9) | TCVNX | Control Inactive Delay | 10 | 45 | ns | 1 |
| (10) | TCLLH. | ALE Active Delay (from CLK) | - | 20 | ns | 1 |
| (11) | TCLMCH | MCE Active Delay (from CLK) | $\cdot$ | 25 | ns | 1 |
| (12) | TSVLH | ALE Active Delay (from Status) | - | 20 | ns | 1 |
| (13) | TSVMCH | MCE Active Delay (from Status) | - | 30 | ns | 1 |
| (14) | TCHLL | ALE Inactive Delay | 4 | 18 | ns | 1 |
| (15) | TCLML | Command Active Delay | 5 | 35 | ns | 2 |
| (16) | TCLMH | Command Inactive Delay | 5 | 35 | ns | 2 |
| (17) | TCHDTL | Direction Control Active Delay | - | 50 | ns | 1 |
| (18) | TCHDTH | Direction Control Inactive Delay | - | 30 | ns | 1 |
| (19) | TAELCH | Command Enable Time (Note 1) | - | 40 | ns | 3 |
| (20) | TAEHCZ | Command Disnable Time (Note 2) | - | 40 | ns | 4 |
| (21) | TAELCV | Enable Delay Time | 110 | 250 | ns | 2 |
| (2) | TAEVNV | AEN to DEN | - | 25 | ns | 1 |
| (2) | TCEVNV | CEN to DEN, $\overline{\text { PDEN }}$ | - | 25 | ns | 1 |
| (24) | TCELRH | CEN to Command |  | TCLML +10 | ns | 2 |
| (25) | TLHLL | ALE High Time | TCLCH -10 | - | ns | 1 |

NOTES:

1. TAELCH measurement is between 1.5 V and 2.5 V .

## AC Testing Input, Output Waveform


A.C. Testing: . All input signals (other than CLK) must switch between VIL -0.4 V and VIH +0.4 . CLK must switch between 0.4 V and VCC -0.4 V . Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{N}$.
2. TAEHCZ measured at 0.5 V change in VOUT.

Timing Waveforms (Note 3)


## Timing Waveforms (Continued) (Note 3)

den, PDen qualification timing


ADDRESS ENABLE ( $\overline{\operatorname{AEN}})$ TIMING (THREE-STATE ENABLE/DISABLE)


NOTE: CEN must be low or invalid prior to T 2 to prevent the command from being generated.

NOTES:

1. Address/Data Bus is shown only for reference purposes.
2. Leading edge of ALE and MCE is determined by the falling edge of CLK or status going active. Whichever occurs last.
3. All tıming measurements are made at 1.5 V unless otherwise specified.

## Burn-In Circuit

MD82C88 CERAMIC DIP


MR82C88 CERAMIC LCC


NOTES:

1. $\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$ GND $=0 \mathrm{~V}$
2. $\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$ $\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
3. Component Values:
$R 1=47 \mathrm{k} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$R 2=1.5 \mathrm{k} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$R 3=10 \mathrm{k} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$R 4=1.2 \mathrm{k} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$\mathrm{C} 1=0.01 \mu \mathrm{~F}(\mathrm{Min})$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
F1 = F0/2
$F 2=F 1 / 2 \ldots F 7=F 6 / 2$

## Metallization Topology

DIE DIMENSIONS:
$103.5 \times 116.5 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 2 \mathrm{k} \AA$

## GLASSIVATION:

Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max) Ceramic LCC $-420^{\circ} \mathrm{C}$ (Max)

WORST CASE CURRENT DENSITY:
$1.9 \times 10^{5} \mathrm{~A} \mathrm{~cm}^{2}$

## Metallization Mask Layout



CMOS Bus Arbiter

## Features

- Pin Compatible with Bipolar 8289
- Performance Compatible with:
- 80C86/80C88
(5/8MHz)
- Provides Multi-Master System Bus Control and Arbitration
- Provides Simple Interface with 82C88/8288 Bus Controller
- Synchronizes 80C86/8086, 80C88/8088 Processors with Multi-Master Bus
- Bipolar Drive Capability
- Four Operating Modes for Flexible System Configuration
- Low Power Operation
- ICCSB $10 \mu A$ (Max)
- ICCOP 1mA/MHz (Max)
- Operating Temperature Ranges
- C82C89 . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- I82C89 . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- M82C89 . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 82 C 89 Bus Aribiter is manufactured using a selfaligned silicon gate CMOS process (Scaled SAJI IV). This circuit, along with the 82C88 bus controller, provides full bus arbitration and control for multi-processor systems. The 82 C 89 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.

Static CMOS circuit design insures low operating power. The advanced Harris SAJI CMOS process results in performance equal to or greater than existing equivalent products at a significant power savings.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | ORDER CODE |
| :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C89 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C89 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C89 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C89 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C89 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C89 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C89/B |
| SMD\# |  | 5962-8552801RA |
| LCC SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C89/B |
|  |  | 5962-85528012A |

## Pinouts




20 LEAD PLCC AND LCC
TOP VIEW


## Functional Diagram



## Pin Description

| PIN SYMBOL | NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| vcc | 20 |  | VCC: The +5 V Power supply pin. A $0.1 \mu \mathrm{~F}$ capacitor between pins 10 and 20 is recommened for decoupling. |
| GND | 10 |  | GROUND. |
| $\overline{\mathrm{S} 0}, \overline{\mathrm{~s} 1}, \overline{\mathrm{~S} 2}$ | 1, 18-19 | 1 | STATUS INPUT PINS: The status input pins from an $80 \mathrm{C} 86,80 \mathrm{C} 88$ or 8089 processor. The 82C89 decodes these pins to initiate bus request and surrender actions. (See Table 1). |
| CLK | 17 | 1 | CLOCK: From the 82C84A or 82C85 clock chip and serves to establish when bus arbiter actions are initiated. |
| $\overline{\text { LOCK }}$ | 16 | 1 | LOCK: A processor generated signal which when activated (low) prevents the arbiter from surrendering the multi-master system bus to any other bus arbiter, regardless of its priority. |
| $\overline{\text { CRQLCK }}$ | 15 | 1 | COMMON REQUEST LOCK: An active low signal which prevents the arbiter from surrendering the multi-master system bus to any other bus arbiter requesting the bus through the $\overline{C B R Q}$ input pin. |
| RESB | 4 | 1 | RESIDENT BUS: A strapping option to configure the arbiter to operate in systems having both a multi-master system bus and a Resident Bus. Strapped high, the multi-master system bus is requested or surrendered as a function of the SYSB/ $/ \overline{\operatorname{RESB}}$ input pin. Strapped low, the SYSB/ $\overline{\operatorname{RESB}}$ input is ignored. |
| ANYRQST | 14 | 1 | ANY REQUEST: A strapping option which permits the multi-master system bus to be surrendered to a lower priority arbiter as if it were an arbiter of higher priority (i.e., when a lower priority arbiter requests the use of the multi-master system bus, the bus is surrendered as soon as it is possible). When ANYRQST is strapped low, the bus is surrendered according to Table A in Design Information. If ANYRQST is strapped high and $\overline{C B R Q}$ is activated, the bus is surrendered at the end of the present bus cycle. Strapping CBRQ low and ANYRQST high forces the 82C89 arbiter to surrender the multi-master system bus after each transfer cycle. Note that when surrender occurs $\overline{B R E Q}$ is driven false (high). |

Pin Description (Continued)

| PIN SYMBOL | NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OB}}$ | 2 | 1 | 10 BUS: A strapping option which configures the 82C89 Arbiter to operate in systems having both an IO Bus (Peripheral Bus) and a multi-master system bus. The arbiter requests and surrenders the use of the multi-master system bus as a function of the status line, $\overline{\mathrm{S}}$. The multi-master system bus is permitted to be surrendered while the processor is performing IO commands and is requested whenever the processor performs a memory command.Interrupt cycles are assumed as coming from the peripheral bus and are treated as an 10 command. |
| $\overline{\text { AEN }}$ | 13 | 0 | ADDRESS ENABLE: The output of the 82C89 Arbiter to the processor's address latches, to the 82C88 Bus Controller and 82C84A or 82C85 Clock Generator. $\overline{\text { AEN }}$ serves to instruct the Bus Controller and address latches when to three-state their output drivers. |
| $\overline{\text { INIT }}$ | 6 | 1 | INITIALIZE: An active low multi-master system bus input signal used to reset all the bus arbiters on the multi-master system bus. After initialization, no arbiters have the use of the multi-master system bus. |
| $\frac{\text { SYSB/ }}{\text { RESB }}$ | 3 | 1 | SYSTEM BUS/RESIDENT BUS: An input signal when the arbiter is configured in the System/ Resident Mode ( $\overline{\operatorname{RESB}}$ is strapped high) which determines when the multi-master system bus is requested and multi-master system bus surrendering is permitted. The signal is intended to originate from a form of address-mapping circuitry, such as a decoder or PROM attached to the resident address bus. Signal transitions and glitches are permitted on this pin from $\theta 1$ of T4 to $\theta 1$ of T2 of the processor cycle. During the period from $\theta 1$ of T2 to $\theta 1$ of T4, only clean transitions are permitted on this pin (no glitches). If a glitch occurs, the arbiter may capture or miss it, and the multi-master system bus may be requested or surrendered, depending upon the state of the glitch. The arbiter requests the multi-master system bus in the System/Resident Mode when the state of the SYSB/RESB pin is high and permits the bus to be surrendered when this pin is low. |
| $\overline{\text { CBRQ }}$ | 12 | 1/0 | COMMON BUS REQUEST: An input signal which instructs the arbiter if there are any other arbiters of lower priority requesting the use of the multi-master system bus. <br> The $\overline{\text { CBRQ }}$ pins (open-drain output) of all the 82 C 89 Bus Arbiters which surrender to the multimaster system bus upon request are connected together. <br> The Bus Arbiter running the current transfer cycle will not itself pull the $\overline{\mathrm{CBRQ}}$ line low. Any other arbiter connected to the CDRQ line can request the milti-master system bus. The arbiter presently running the current transfer cycle drops its $\overline{B R E Q}$ signal and surrenders the bus whenever the proper surrender conditions exist. Strapping CBRQ low and ANYRQST high allows the multimaster system bus to be surrendered after each transfer cycle. See the pin definition of ANYRQST. |
| $\overline{\text { BCLK }}$ | 5 | 1 | BUS CLOCK: The multi-master system bus clock to which all multi-master system bus interface signals are synchronized. |
| $\overline{\text { BREQ }}$ | 7 | 0 | BUS REQUEST: An active low output signal in the Parallel Priority Resolving Scheme which the arbiter activates to request the use of the multi-master system bus. |
| $\overline{\text { BPRN }}$ | 9 | 1 | BUS PRIORITY $\mathbb{N}$ : The active low signal returned to the arbiter to instruct it that it may acquire the multi-master system bus on the next falling edge of $\overline{\mathrm{BCLK}}$. $\overline{\mathrm{BPRN}}$ active indicates to the arbiter that it is the highest priority requesting arbiter presently on the bus. The loss of BPRN instructs the arbiter that it has lost priority to a higher priority arbiter. |
| $\overline{\text { BPRO }}$ | 8 | 0 | BUS PRIORITY OUT: An active low output signal used in the serial priority resolving scheme where $\overline{\mathrm{BPRO}}$ is daisy-chained to $\overline{\mathrm{BPRN}}$ of the next lower priority arbiter. |
| $\overline{\text { BUSY }}$ | 11 | I/O | BUSY: An active low open-drain multi-master system bus interface signal used to instruct all the arbiters on the bus when the multi-master system bus is available. When the multi-master system bus is available the highest requesting arbiter (determined by $\overline{\mathrm{BPRN}}$ ) seizes the bus and pulls BUSY low to keep other arbiters off of the bus. When the arbiter is done with the bus, it releases the $\overline{B U S Y}$ signal, permitting it to go high and thereby allowing another arbiter to acquire the multimaster system bus. |

## Functional Description

The 82C89 Bus Arbiter operates in conjunction with the 82C88 Bus Controller to interface 80C86, 80C88 processors to a multi-master system bus (both the 80C86 and 80C88 are configured in their max mode). The processor is unaware of the arbiter's existence and issues commands as though it has exclusive use of the system bus. If the processor does not have the use of the multi-master system bus, the arbiter prevents the Bus Controller (82C88), the data transceivers and the address latches from accessing the system bus (e.g. all bus driver outputs are forced into the high impedance state). Since the command sequence was not issued by the 82C88, the system bus will appear as "Not Ready" and the processor will enter wait states. The processor will remain in Wait until the Bus Arbiter acquires the use of the multi-master system bus whereupon the arbiter will allow the bus controller, the data transceivers, and the address latches to access the system. Typically, once the command has been issued and a data transfer has taken place, a transfer acknowledge (XACK) is returned to the processor to indicate "READY" from the accessed slave device. The processor then completes its transfer cycle. Thus the arbiter serves to multiplex a processor (or bus master) onto a multi-master system bus and avoid contention problems between bus masters.

## Arbitration Between Bus Masters

In general, higher priority masters obtain the bus when a lower priority master completes its present transier cycle. Lower priority bus masters obtain the bus when a higher priority master is not accessing the system bus. A strapping option (ANYRQST) is provided to allow the arbiter to surrender the bus to a lower priority master as though it were a master of higher priority. If there are no other bus masters requesting the bus, the arbiter maintains the bus so long as its processor has not entered the HALT State. The arbiter will not voluntarily surrender the system bus and has to be forced off by another master's bus request, the HALT State being the only exception. Additional strapping options permit other modes of operation wherein the multi-master system bus is surrendered or requested under different sets of conditions.

## Priority Resolving Techniques

Since there can be many bus masters on a multi-master system bus, some means of resolving priority between bus masters simultaneously requesting the bus must be provided. The 82C89 Bus Arbiter provides several resolving techniques. All the techniques are based on a priority concept that at a given time one bus master will have priority above all the rest. There are provisions for using parallel priority resolving techniques, serial priority resolving techniques, and rotating priority techniques.

## Parallel Priority Resolving

The parallel priority resolving technique uses a separate bus request line BREQ for each arbiter on the multi-master system bus, see Figure 1. Each $\overline{B R E Q}$ line enters into a priority encoder which generates the binary address of the highest priority $\overline{\mathrm{BREQ}}$ line which is active. The binary address is decoded by a decoder to select the corresponding BPRN
(Bus Priority In) line to be returned to the highest priority requesting arbiter. The arbiter receiving priority ( $\overline{B P R N}$ true) then allows its associated bus master onto the multi-master system bus as soon as it becomes available (i.e., the bus is no longer busy). When one bus arbiter gains priority over another arbiter it cannot immediately seize the bus, it must wait until the present bus transaction is complete. Upon completing its transaction the present bus occupant recognizes that it no longer has priority and surrenders the bus by releasing $\overline{B U S Y}$. $\overline{\mathrm{BUSY}}$ is an active low "OR" tied signal line which goes to every bus arbiter on the system bus. When $\overline{B U S Y}$ goes inactive (high), the arbiter which presently has bus priority ( $\overline{\mathrm{BPRN}}$ true) then seizes the bus and pulls BUSY low to keep other arbiters off of the bus. See waveform timing diagram, Figure 2. Note that all multimaster system bus transactions are synchronized to the bus clock ( $\overline{\mathrm{BCLK}}$ ). This allows the parallel priority resolving circuitry or any other priority resolving scheme employed to settle.


FIGURE 1. PARALLEL PRIORITY RESOLVING TECHNIQUE


NOTES:

1. Higher priority bus arbiter requests the Multi-Master system bus.
2. Attains priority.
3. Lower priority bus arbiter releases BUSY.
4. Higher priority bus arbiter then acquires the bus and pulls $\overline{\mathrm{BUSY}}$ down.

## FIGURE 2. HIGHER PRIORITY ARBITER OBTAINING THE BUS FROM A LOWER PRIORITY ARBITER

## Serial Priority Resolving

The serial priority resolving technique eliminates the need for the priority encoder-decoder arrangement by daisychaining the bus arbiters together, connecting the higher priority bus arbiter's $\overline{\text { BPRO }}$ (Bus Priority Out) output to the $\overline{\text { BPRN }}$ of the next lower priority. See Figure 3.


NOTE: The number of arbiters that may be daisy-chained together in the serial priority resolving scheme is a function of $\overline{B C L K}$ and the propagation delay from arbiter to arbiter. Normally, at 10 MHz only 3 arbiters may be daisychained.

FIGURE 3. SERIAL PRIORITY RESOLVING

## Rotating Priority Resolving

The rotating priority resolving technique is similar to that of the parallel priority resolving technique except that priority is dynamically re-assigned. The priority encoder is replaced by a more complex circuit which rotates priority between requesting arbiters thus allowing each arbiter an equal chance to use the multi-master system bus, over time.

## Which Priority Resolving Technique To Use

There are advantages and disadvantages for each of the techniques described above. The rotating priority resolving
technique requires substantial external logic to implement while the serial technique uses no external logic but can accommodate only a limited number of bus arbiters before the daisy-chain propagation delay exceeds the multimaster's system bus clock (BCLK). The parallel priority resolving technique is in general a good compromise between the other two techniques. It allows for many arbiters to be present on the bus while not requiring too much logic to implement.

## 82C89 Modes Of Operation

There are two types of processors for which the 82C89 will provide support: An Input/Output processor (i.e. an NMOS 8089 IOP) and the 80C86, 80C88. Consequently, there are two basic operating modes in the 82C89 bus arbiter. One, the IOB (I/O Peripheral Bus) mode, permits the processor access to both an I/O Peripheral Bus and a multi-master system bus. The second, the RESB (Resident Bus mode), permits the processor to communicate over both a Resident Bus and a multi-master system bus. An I/O Peripheral Bus is a bus where all devices on that bus, including memory, are treated as I/O devices and are addressed by I/O commands. All memory commands are directed to another bus, the multi-master system bus. A Resident Bus can issue both memory and I/O commands, but it is a distinct and separate bus from the multi-master system bus. The distinction is that the Resident Bus has only one master, providing full availability and being dedicated to that one master.
The $\overline{\mathrm{IOB}}$ strapping option configures the 82C89 Bus Arbiter into the $\overline{\mathrm{IOB}}$ mode and the strapping option RESB configures it into the RESB mode. It might be noted at this point that if both strapping options are strapped false, the arbiter interfaces the processor to a multi-master system bus only (see Figure 4). With both options strapped true, the arbiter interfaces the processor to a multi-master system bus, a Resident Bus, and an I/O Bus.


FIGURE 4. TYPICAL MEDIUM COMPLEXITY CPU SYSTEM

In the $\overline{\mathrm{OB}}$ mode, the processor communicates and controls a host of peripherals over the Peripheral Bus. When the I/O Processor needs to communicate with system memory, it does so over the system memory bus. Figure 5 shows a possible I/O Processor system configuration.
The 80C86 and 80C88 processors can communicate with a Resident Bus and a multi-master system bus. Two bus controllers and only one Bus Arbiter would be needed in such a configuration as shown in Figure 6. In such a system config-
uration the processor would have access to memory and peripherals of both busses. Memory mapping techniques are applied to select which bus is to be accessed. The SYSB/ $\overline{\text { RESB }}$ input on the arbiter serves to instruct the arbiter as to whether or not the system bus is to be accessed. The signal connected to SYSB/RESB also enables or disables commands from one of the bus controllers. A summary of the modes that the 82 C 89 has, along with its response to its status lines inputs, is shown in Table 1.


FIGURE 5. TYPICAL MEDIUM COMPLEXITY IOB SYSTEM


FIGURE 6. 82C89 BUS ARBITER SHOWN IN SYSTEM - RESIDENT BUS CONFIGURATION
*By adding another 82 C 89 arbiter and connecting its $\overline{\mathrm{AEN}}$ to the 82 C 88 whose $\overline{\mathrm{AEN}}$ is presently grounded, the processor could have access to two multi-master buses.

TABLE 1. SUMMARY OF $82 C 89$ MODES, REQUESTING AND RELINQUISHING THE MULTH-MASTER SYSTEM BUS

| SINGLE LINES FROM 80C86 OR 80C88 OR 8088 |  |  |  | $\begin{gathered} \text { IOB MODE } \\ \text { ONLY } \\ 10 B=L O W \\ \text { RESB }=\text { LOW } \end{gathered}$ | RESB MODE ONLY <br> $\overline{\mathrm{O}} \mathrm{B}=\mathrm{HIGH}, \mathrm{RESB}=\mathrm{HIGH}$ |  | IOB MODE RESB MODE $\overline{\mathrm{OBB}}=\mathrm{LOW}$, RESB $=\mathrm{HIGH}$ |  | $\begin{gathered} \text { SINGLE BUS } \\ \text { MODE } \\ \text { IOB }=\text { HIGH } \\ \text { RESB }=\text { LOW } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { S2 }}$ | $\overline{51}$ | $\overline{\mathbf{S O}}$ |  | SYSB/RESB $=$ HIGH | $\begin{gathered} \text { SYSB/XESB }= \\ \text { LOW } \end{gathered}$ | $\text { SYSB/RESB }=$ HIGH | $\begin{gathered} \text { SYSB/ } / \overline{\text { RESB }}= \\ \text { LOW } \end{gathered}$ |  |
| I/O Commands | 0 0 0 | 0 0 1 | 0 1 0 | X X X | $\dagger$ $\dagger$ $\dagger$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X X X | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\dagger$ $\dagger$ $\dagger$ |
| Halt | 0 | 1 | 1 | X | X | X | X | X | X |
| Memory Commands | 1 1 1 | 0 0 1 | 0 1 $0+$ | t t t | $\dagger$ $\dagger$ $\dagger$ | X X X | $\dagger$ $\dagger$ $\dagger$ | X X X | $\dagger$ $\dagger$ $\dagger$ |
| Idle | 1 | 1 | 1 | X | X | X | X | X | X |

NOTES:

1. $X=$ Multi-Master System Bus is allowed to be Surrendered.
2. $\dagger=$ Multi-Master System Bus is Requested.

| MODE | PIN STRAPPING | MULTL-MASTER SYSTEM BUS |  |
| :---: | :---: | :---: | :---: |
|  |  | REQUESTED** | SURRENDERED* |
| Single Bus Multi-Master Mode | $\begin{aligned} & \overline{\mathrm{IOB}}=\text { High } \\ & \text { RESB }=\text { Low } \end{aligned}$ | Whenever the processor's status lines go active | $\mathrm{HLT}+\mathrm{TI} \cdot \overline{\mathrm{CBRQ}}+\mathrm{HPBRQ} \ddagger$ |
| RESB Mode Only | $\begin{aligned} & \overline{\mathrm{IOB}}=\text { High } \\ & \mathrm{RESB}=\mathrm{High} \end{aligned}$ | SYSB/ $\overline{\text { RESB }}+$ High $\cdot$ ACTIVE STATUS | $\begin{aligned} & (\mathrm{SYSB} / \overline{\text { RESB }}=\operatorname{Low}+\mathrm{TI}) \bullet \\ & \mathrm{CBRQ}+\mathrm{HLT}+\mathrm{HPBRQ} \end{aligned}$ |
| IOB Mode Only | $\begin{aligned} & \overline{\mathrm{IOB}}=\mathrm{LOW} \\ & \mathrm{RESB}=\mathrm{Low} \end{aligned}$ | Memory Commands | $\begin{aligned} & (I / O \text { Status + TI) } \cdot \overline{\mathrm{CBRQ}}+\mathrm{HLT}+ \\ & \text { HPBRQ } \end{aligned}$ |
| IOB Mode RESB Mode | $\begin{aligned} & \overline{\mathrm{IOB}}=\text { Low } \\ & \mathrm{RESB}=\mathrm{High} \end{aligned}$ | (Memory Command) • (SYSB/RESB $=$ High) | (I/O Status Commands) + SYSB $/ \overline{\operatorname{RESB}}=$ Low $) \cdot \overline{\mathrm{CBRQ}}+$ HPBRQ $\ddagger+$ HLT |

NOTES:

* $\overline{\text { LOCK }}$ prevents surrender of Bus to any other arbiter, $\overline{\text { CRQLCK }}$ prevents surrender of Bus to any lower priority arbiter.
** Except for HALT and Passive or IDLE Status.
$\ddagger$ HPBRQ, Higher priority Bus request or $\overline{B P R N}=1$.

1. $\bar{O} B$ Active Low.
2. RESB Active High.
3.     + is read as "OR" and • as "AND"
4. $\mathrm{TI}=$ Processor Idle Status $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}, \overline{\mathrm{S0}}=111$
5. $\mathrm{HLT}=$ Processor Halt Status $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}, \overline{\mathrm{SO}}=011$

## Absolute Maximum Ratings

| Supply Voltage | +8.0V |
| :---: | :---: |
| Input, Output or I/O Voltage | . GND-0.5V to VCC +0.5 V |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta^{\prime \prime}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $80^{\circ} \mathrm{C} / \mathrm{W}$ | $21^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $76^{\circ} \mathrm{C} / \mathrm{W}$ | $19^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | 620 mW |
| Ceramic LCC Package |  | 664mW |
| Gate Count |  | 200 Gates |

CAUTION: Stresses above those listed in "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

## Operating Conditions

Operating Voltage Range +4.5 V to +5.5 V

Operating Temperature Range
C82C89
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
182C89. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
M82C89
$55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $\quad \mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%$;
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (C82C89);
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( 182 C 89 );
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C89)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ | - | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \text { C82C89, I82C89 } \\ & \text { M82C89, Note } 1 \end{aligned}$ |
| VIL | Logical Zero Input Voltage | - | 0.8 | V | Note 1 |
| VIHC | CLK Logical One Input Voltage | 0.7 VCC | - | V |  |
| VILC | CLK Logical Zero Input Voltage | - | 0.2 VCC | V |  |
| VOL | $\frac{\text { Output }}{\text { Low Voltage }}$ $\frac{\overline{B U S Y}}{\overline{A E N}} \overline{\text { CBRQ }}$ $\overline{B P R O}, \overline{B R E Q}$ | - | $\begin{aligned} & 0.45 \\ & 0.45 \\ & 0.45 \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ | $\begin{aligned} & 1 \mathrm{OL}=20 \mathrm{~mA} \\ & 1 \mathrm{OL}=16 \mathrm{~mA} \\ & \mathrm{IOL}=8 \mathrm{~mA} \end{aligned}$ |
| VOH1 | $\frac{\text { Output }}{\text { BUSY }} \frac{\text { High Voltage }}{\text { CBRD }}$ $\overline{B U S Y}, \overline{C B R Q}$ | Open | Drain |  |  |
| VOH2 | Output High Voltage All Other Outputs | $\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 O H=-100 \mu \mathrm{~A} \end{aligned}$ |
| 11 | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | VIN = GND or VCC, DIP Pins 1-6, 9, 14-19 |
| 10 | I/O Leakage | -10.0 | 10.0 | $\mu \mathrm{A}$ | VO = GND or VCC, DIP Pins 11-12 |
| ICCSB | Standby Power Supply | - | 10 | $\mu \mathrm{A}$ | VCC $=5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{VCC}$ or GND, Outputs Open |
| ICCOP | Operating Power Supply Current | - | 1 | mAMHz | VCC $=5.5 \mathrm{~V}$, Outputs Open, Note 2 |

## NOTES:

1. Does not apply to $\overline{\mathrm{OB}}$, RESB, or ANYRQST. These are strap options and should be held to VCC or GND.
2. Maximum current defined by CLK or BCLK, whichever has the highest operating frequency

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | 10 | pF | FREQ $=1$ MHz, all measurements are <br> referenced to device GND |
| COUT | Output Capacitance | 10 | pF |  |
| CIO | I/O Capacitance | 15 | pF |  |

## Specifications $82 C 89$

AC Electrical Specifications $V C C=5.0 \mathrm{~V} \pm 10 \% ; G N D=0 \mathrm{~V}$ :

$$
\begin{aligned}
& T_{A}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 89) ; \\
& T_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \text { (I82C89); } \\
& \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{M} 82 \mathrm{C} 89)
\end{aligned}
$$

| SYMBOL |  | PARAMETER | MIN | MAX | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (1) | TCLCL | CLK Cycle Period | 125 | - | ns | Note 3 |
| (2) | TCLCH | CLK Low Time | 55 | - | ns | Note 3 |
| (3) | TCHCL | CLK High Time | 35 | $\bullet$ | ns | Note 3 |
| (4) | TSVCH | Status Active Setup | 65 | $\begin{gathered} \text { TCLCL- } \\ 10 \end{gathered}$ | ns | Note 3 |
| (5) | TSHCL | Status Inactive Setup | 50 | $\begin{gathered} \text { TCLCL- } \\ 10 \end{gathered}$ | ns | Note 3 |
| (6) | THVCH | Status Inactive Hold | 10 | - | ns | Note 3 |
| (7) | THVCL | Status Active Hold | 10 | - | ns | Note 3 |
| (8) | TBYSBL | $\overline{\text { BUSY }} \downarrow \uparrow$ Setup to $\overline{\text { BCLK }} \downarrow$ | 20 | - | ns | Note 3 |
| (9) | TCBSBL | $\overline{\text { CBRQ }} \downarrow \uparrow$ Setup to $\overline{\text { BCLK }} \downarrow$ | 20 | - | ns | Note 3 |
| (10) | TBLBL | $\overline{\text { BCLK }}$ Cycle Time | 100 | - | ns | Note 3 |
| (11) | TBHCL | $\overline{\text { BCLK }}$ High Time | 30 | $\begin{gathered} 0.65 \\ \text { (TBLBL) } \end{gathered}$ | ns | Note 3 |
| (12) | TCLLL1 | LOCK Inactive Hold | 10 | - | ns | Note 3 |
| (13) | TCLLL2 | $\overline{\text { LOCK Active Setup }}$ | 40 | - | ns | Note 3 |
| (14) | TPNBL | $\overline{\text { BPRN }} \downarrow \uparrow \uparrow$ to BCLK Setup Time | 20 | $\bullet$ | ns | Note 3 |
| (15) | TCLSR1 | SYSB/ $\overline{\text { RESB }}$ Setup | 0 | - | ns | Note 3 |
| (16) | TCLSR2 | SYSB/RESB Hold | 30 | $\bullet$ | ns | Note 3 |
| (17) | TIVIH | Initialization Pulse Width | 675 | - | ns | Note 3 |
| (18) | TBLBRL | $\overline{\text { BCLK }}$ to $\overline{\text { BREQ }}$ Delay $\downarrow \uparrow$ | - | 35 | ns | Note 3 |
| (19) | TBLPOH | $\overline{\text { BCLK }}$ to $\overline{B P R O} \downarrow \uparrow$ | - | 35 | ns | Note 1 and 3 |
| (20) | TPNPO | $\overline{\text { BPRN }} \downarrow \uparrow$ to $\overline{\text { BPROO}} \downarrow \uparrow$ Delay | $\bullet$ | 22 | ns | Note 1 and 3 |
| (21) | TBLBYL | $\overline{\text { BCLK }}$ to $\overline{\text { BUSY }}$ Low | - | 60 | ns | Note 3 |
| (22) | TBLBYH | $\overline{\text { BCLK }}$ to $\overline{B U S Y}$ Float | - | 35 | ns | Note 2 and 3 |
| (23) | TCLAEH | CLK to AEN High | $\bullet$ | 65 | ns | Note 3 |
| (24) | TBLAEL | $\overline{\text { BCLK }}$ to $\overline{A E N}$ Low | $\bullet$ | 40 | ns | Note 3 |
| (25) | TBLCBL | $\overline{\text { BCLK }}$ to $\overline{C B R Q}$ Low | $\bullet$ | 60 | ns | Note 3 |
| (26) | TBLCBH | $\overline{\text { BCLK }}$ to $\overline{C B R Q}$ Float | - | 40 | ns | Note 2 and 3 |
| (27) | TOLOH | Output Rise Time | - | 20 | ns | From 0.8 V to 2.0 V , Note 4 |
| (28) | TOHOL | Output Fall Time | - | 12 | ns | From 2.0 V to 0.8 V , Note 4 |
| (29) | TILIH | Input Rise Time | - | 20 | ns | From 0.8 V to 2.0 V |
| (30) | TIHIL | Input Fall Time | - | 20 | ns | From 2.0 V to 0.8 V |

NOTES:

1. $\overline{B C L K}$ generates the first $\overline{B P R O}$ wherein subsequent $\overline{B P R O}$ changes lower in the chain are generated through BPRON.
2. Measured at 0.5 V above GND.
3. All AC parameters tested as per AC test load circuits. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{V}$.
4. Except $\overline{B U S Y}$ and $\overline{C B R Q}$

## AC Test Load Circuits

$\overline{B U S Y}, \overline{C B R Q}$ LOAD CIRCUIT

$\overline{A E N}$ LOAD CIRCUIT

$\overline{B P R O}, \overline{B R E Q}$ LOAD CIRCUTT


* Includes Stray and Jig Capacitance


## AC Testing Input, Output Waveform

| INPUT | OUTPUT |  |
| :---: | :---: | :---: |
| $\mathrm{VIH}+\mathbf{0 . 4 V}$ | VOH | AC Testing: Inputs are driven at VIH +0.4 V for a logic "1" and VIL |
|  |  | -0.4 V for a logic " 0 ". The clock is driven at $\mathrm{VCC}-0.4 \mathrm{~V}$ and 0.4 V . Timing measurements are made at 1.5 V for both a logic " 1 " and " 0 ". |
| VIL -0.4V | vo |  |

## Timing Waveform



## NOTES:

1. $\overline{\text { LOCK }}$ active can occur during any state, as long as the relationships shown above with respect to the CLK are maintained. LOCK inactive has no critical time and can be asynchronous. $\overline{\text { CRQLCK }}$ has no critical timing and is considered an asynchronous input signal.
2. Glitching of SYSB/RESB is permitted during this time. After $\theta 2$ of T1, and before $\theta 1$ of $T 4, S Y S B / \overline{R E S B}$ should be stable to maintan system efficiency.
3. $\overline{A E N}$ leading edge is related to $\overline{B C L K}$, tralling edge to CLK. The trailing edge of AEN occurs after bus priority is lost.

## ADDITIONAL NOTES:

The signals related to CLK are typical processor signals, and do not relate to the depicted sequence of events of the signals referenced to $\overline{B C L K}$. The signals shown related to the $\overline{B C L K}$ represent a hypothetical sequence of events for illustration. Assume 3 bus arbiters of priorities 1,2 and 3 configured in serial priority resolving scheme (as shown in Figure 3). Assume arbiter 1 has the bus and is holding BUSY low. Arbiter \#2 detects its processor wants the bus and puils low $\overline{B R E Q} \# 2$. If $\overline{B P R N}$ \#2 is high (as shown), arbiter \#2 will pull low CBRQ line. $\overline{C B R Q}$ signals to the higher priority arbiter \#1 that a lower priority arbiter wants the bus. [A higher priority arbiter would be granted BPRN when it makes the bus request rather than having to wait for another arbiter to release the bus through $\overline{\mathrm{CBRO}}$ ]. *Arbiter \#1 will relinquish the multi-master system bus when it enters a state not requiring it (see Table 1), by lowering its $\overline{\text { BPRO } \# 1 \text { (tied to } \overline{B P R N} \# 2 \text { ) and releasing } \overline{B U S Y} \text {. }}$ Arbiter \#2 now sees that is has priority from BPRN \#2 being low and releases CBRQ. As soon as BUSY signifies the bus is avallable (high), arbiter \#2 pulls $\overline{B U S Y}$ low on next falling edge of $\overline{B C L K}$. Note that if arbiter \#2 didn't want the bus at the time it received priority, it would pass priority to the next lower priority arbiter by lowering its BPRO \#2 [TPNPO].
*Note that even a higher priority arbiter which is acquiring the bus through $\overline{B P R N}$ will momentarily drop $\overline{\mathrm{CBRQ}}$ until it has acquired the bus.

## Burn-In Circuits



MR82C89 CERAMIC LCC


NOTES:

1. $\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
2. $\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%, \mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
3. Components Values:
$R 1=1.2 \mathrm{k} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$R 2=47 \mathrm{k} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ minimum
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
F1 $=$ F0/2
$F 2=F 1 / 2 \ldots$
$F 14=F 13 / 2$

## Metallization Topology

DIE DIMENSIONS:
$92.9 \times 95.7 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \AA 2 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 k \AA \pm 2 k \AA$

## DIE ATTACH:

Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)

$$
\text { Ceramic LCC }-420^{\circ} \mathrm{C} \text { (Max) }
$$

WORST CASE CURRENT DENSITY:
$1.8 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout

## 82 C 89



## CMOS DATA COMMUNICATIONS

PAGE
CMOS DATA COMMUNICATIONS DATASHEETS
82C50A Asynchronous Communications Element ..... 5-3
82C52 Serial Controller Interface ..... 5-23
CDP1854A, AC Programmable UART ..... 5-41
CDP1854A/3, AC/3 High-Reliability Programmable UART ..... 5-58
CDP6402, C Universal Asynchronous Receiver Transmitter (UART) ..... 5-67
HD-4702 Programmable Bit Rate Generator ..... 5-76
HD-4702/883 Programmable Bit Rate Generator ..... 5-82
HD-6402 Universal Asynchronous Receiver Transmitter (UART) ..... 5-88
HD-6402/883 Universal Asynchronous Receiver Transmitter (UART) ..... 5-95
HD-6408 Asynchronous Serial Manchester Adaptor ..... 5-101
HD-6409 Manchester Encoder-Decoder (MED) ..... 5-108
HD-6409/883 Manchester Encoder-Decoder (MED) ..... 5-121
HD-15530 Manchester Encoder-Decoder (MED) ..... 5-127
HD-15531 Manchester Encoder-Decoder (MED) ..... 5-139
HD-15531/883 Manchester Encoder-Decoder (MED) ..... 5-151
HS-3182 ARINC 429 Bus Driver ..... 5-158
HS-3282 ARINC 429 Bus Interface Circuit ..... 5-163
ICL232 +5V Powered Dual RS-232 Transmitter/Receiver ..... 5-176

## RELATED APPLICATION NOTES

App Note $108 \quad 82 \mathrm{C} 52$ Programmable UART ..... 7-3
App Note 400 Using the HS-3282 Bus Interface Circuit ..... 7-61

# CMOS Asynchronous Communications Element 



## Description

The 82C50A Asynchronous Communication Element (ACE) is a high performance programmable Universal Asynchronous Receiver/Transmitter (UART) and Baud Rate Generator (BRG) on a sıngle chip Usıng Harrıs Semiconductor's advanced Scaled SAJI IV CMOS Process, the ACE will support data rates from DC to 625 K baud $(0-10 \mathrm{MHz}$ clock)
The ACE's receiver circuitry converts start, data, stop, and parity bits into a parallel data word The transmitter circuitry converts a parallel data word into serial form and appends the start, parity, and stop bits. The word length is programmable to $5,6,7$, or 8 data bits. Stop bit selection provides a choice of 1,15 , or 2 stop bits

The Baud Rate Generator divides the clock by a divisor programmable from 1 to $2^{16-1}$ to provide standard RS-232C 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 (BAUDOUT) provides elther a buffered oscillator or 16X (16 times the data rate) baud rate clock for general purpose system use

To meet the system requirements of a CPU interfacing to an asynchronous channel, the modem control signals $\overline{\mathrm{RTS}}, \overline{\mathrm{CTS}}$, $\overline{D S R}, \overline{D T R}, \overline{R I}, \overline{D C D}$ are provided. Inputs and outputs have been designed with full TTL/CMOS compatability in order to facilitate mixed TTL/NMOS/CMOS system design.

## Functional Diagram



Ordering Information

| PACK <br> -AGE | TEMP RANGE | 625K BAUD |
| :--- | :---: | :---: |
| Plastic <br> DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C50A-5 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C50A-5 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C50A-5 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C50A-5 |
|  | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C50A-5 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C50A-5 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C50A-5/B |

## Pin Description

| SYMBOL | PIN NUMBER | TYPE | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| $\frac{\text { DISTR, }}{\text { DISTR }}$ | $\begin{aligned} & 22 \\ & 21 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{gathered} H \\ L \end{gathered}$ | DATA IN STROBE, DATA IN STROBE: DISTR, $\overline{\text { DISTR }}$ are read inputs which cause the 82C50A to output data to the data bus (D0-D7). The data output depends upon the register selected by the address inputs A0, A1, A2. The chip select inputs CS0, CS1, CS2 enable the DISTR, $\overline{\text { DISTR inputs. }}$ <br> Only an active DISTR or $\overline{\text { DISTR, }}$, not both, is used to receive data from the 82C50A during a read operation. If DISTR is used as the read input, $\overline{\text { DISTR }}$ should be tied high. If DISTR is used as the active read input, DISTR should be tied low. |
| $\frac{\text { DOSTR }}{\text { DOSTR }}$ | $\begin{aligned} & 19 \\ & 18 \end{aligned}$ | $1$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | DATA OUT STROBE, DATA OUT STROBE: DOSTR, $\overline{\text { DOSTR }}$ are write inputs which cause data from the data bus (D0-D7) to be input to the 82C50A. The data input depends upon the register selected by the address inputs A0, A1, A2. The chip select inputs CSO, CS1, $\overline{\text { CS2 }}$ enable the DOSTR, $\overline{\text { DOSTR inputs. }}$ <br> Only an active DOSTR or $\overline{\text { DOSTR, not both, is used to transmit data to }}$ the 82C50A during a write operation. If DOSTR is used as the write input, $\overline{\text { DOSTR }}$ should be tied high. If $\overline{\text { DOSTR }}$ is used as the write input, DOSTR should be tied low. |
| D0-D7 | 1-8 | 1/O |  | DATA BITS 0-7: The Data Bus provides eight, 3-state input/output lines for the transfer of data, control and status information between the82C50A and the CPU. For character formats of less than 8 bits, D7, D6 and D5 are "don't cares" for data write operatıons and 0 for data read operations. These lines are normally in a high impedance state except during read operations. D0 is the Least Significant Bit (LSB) and is the first serial data bit to be received or transmitted. |
| $\mathrm{A} 0, \mathrm{~A} 1$ A2 | $\begin{gathered} 28,27 \\ 26 \end{gathered}$ | I | H | REGISTER SELECT: The address lines select the internal registers during CPU bus operations. See Table 1. |
| XTAL1, <br> XTAL2 | $\begin{aligned} & 16 \\ & 17 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ |  | CRYSTAL/CLOCK: Crystal connections for the internal Baud Rate Generator. XTAL1 can also be used as an external clock input, in which case XTAL2 should be left open. |
| SOUT | 11 | 0 |  | SERIAL DATA OUTPUT: Serial data output from the 82C50A transmitter circuitry. A Mark (1) is a logic one (high) and Space (0) is a logic zero (low). SOUT is held in the Mark condition when the transmitter is disabled, MR is true, the Transmitter Register is empty, or when in the Loop Mode. SOUT is not affected by the $\overline{\mathrm{CTS}}$ input. |
| GND | 20 |  | L | GROUND: Power supply ground connection (VSS). |
| $\overline{\mathrm{CTS}}$ | 36 | 1 | L | CLEAR TO SEND: The logical state of the $\overline{\mathrm{CTS}}$ pin is reflected in the CTS bit of the (MSR) Modem Status Register (CTS is bit 4 of the MSR, written MSR(4)). A change of state in the CTS pin since the previous reading of the MSR causes the setting of DCTS (MSR(0)) of the Modem Status Register. When $\overline{\text { CTS }}$ pin is ACTIVE (low), the modem is indicating that data on SOUT can be transmitted on the communications link. If $\overline{\mathrm{CTS}}$ pin goes INACTIVE (high), the 82C50A should not be allowed to transmit data out of SOUT. CTS pin does not affect Loop Mode operation. |
| $\overline{\text { DSR }}$ | 37 | 1 | L | DATA SET READY: The logical state of the $\overline{D S R}$ pin is reflected in MSR(5) of the Modem Status Register. DDSR (MSR(1)) indicates whether the $\overline{D S R}$ pin has changed state since the previous reading of the MSR. When the $\overline{D S R}$ pin is ACTIVE (low), the modem is indicating that it is ready to exchange data with the 82 C 50 A , while the $\overline{\mathrm{DSR}}$ Pin INACTIVE (high) indicates that the modem is not ready for data exchange. The ACTIVE condition indicates only the condition of the local Data Communicatıons Equipment (DCE), and does not imply that a data circuit as been established with remote equipment. |

## Pin Description

| SYMBOL | PIN NUMBER | TYPE | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { DTR }}$ | 33 | O | L | DATA TERMINAL READY: The $\overline{\text { DTR }}$ pin can be set (low) by writing a logic 1 to MCR(0), Modem Control Register bit 0. This signal is cleared (high) by writing a logic 0 to the DTR bit (MCR(0)) or whenever a MR ACTIVE (high) is applied to the 82C50A. When ACTIVE (low), DTR pin Indicates to the DCE that the 82C50A is ready to receive data In some instances, $\overline{D T R}$ pin is used as a power on indicator The INACTIVE (high) state causes the DCE to disconnect the modem from the telecommunications circuit. |
| $\overline{R T S}$ | 32 | 0 | L | REQUEST TO SEND. The $\overline{R T S}$ signal is an output used to enable the modem The $\overline{R T S}$ pin is set low by writıng a logic 1 to MCR(1) bit 1 of the Modem Control Register. The $\overline{\mathrm{RTS}}$ pin is reset high by Master Reset When ACTIVE, the $\overline{R T S}$ pin indicates to the DCE that the 82C50A has data ready to transmit. In half duplex operations, $\overline{\mathrm{RTS}}$ is used to control the direction of the line. |
| $\overline{\text { BAUDOUT }}$ | 15 | 0 |  | BAUDOUT. This output is a 16 X clock out used for the transmitter section ( $16 \mathrm{X}=16$ tımes the data rate) The $\overline{\mathrm{BAUDOUT}}$ clock rate is equal to the reference oscillator frequency divided by the specified divisor in the Baud Rate Generator Divisor Latches DLL and DLM. $\overline{\text { BAUDOUT }}$ may be used by the Receiver section by tying this output to RCLK. |
| $\overline{\text { OUT1 }}$ | 34 | 0 | L | OUTPUT 1 This is a general purpose output that can be programmed ACTIVE (low) by setting MCR(2) (OUT1) of the Modem Control Register to a high level. The OUT1 pin is set high by Master Reset. The OUT1 pin is INACTIVE (high) during loop mode operation. |
| $\overline{\text { OUT2 }}$ | 31 | 0 | L | OUTPUT 2. This is a general purpose output that can be programmed ACTIVE (low) by setting MCR(3) (OUT2) of the Modem Control Regıster to a high level The OUT2 pın is set high by Master Reset. The OUT2 signal is INACTIVE (high) during loop mode operation. |
| $\overline{\mathrm{RI}}$ | 39 | 1 | L | RING INDICATOR. When low, $\overline{\mathrm{RI}}$ indicates that a telephone ringing signal has been received by the modem or data set. The $\overline{\operatorname{RI}}$ signal is a modem control input whose condition is tested by reading MSR(6) (RI). The Modem Status Register output TERI (MSR(2)) indicates whether the $\overline{\mathrm{RI}}$ input has changed from a Low to High since the previous reading of the MSR. If the interrupt is enabled (IER $(3)=1)$ and $\overline{R I}$ changes from a Low to High, an interrupt is generated. The ACTIVE (low) state of $\overline{\mathrm{RI}}$ indicates that the DCE is receiving a ringing signal. $\overline{R I}$ will appear ACTIVE for approximately the same length of time as the ACTIVE segment of the ringing cycle The INACTIVE state of $\overline{\mathrm{RI}}$ will occur |


|  |  |  |  | during the INACTIVE segments of the ringing cycle, or when ringing is not detected by the DCE. This circuit is not disabled by the INACTIVE condition of DTR. |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{D C D}$ | 38 | 1 | L | DATA CARRIER DETECT. When ACTIVE (low), $\overline{D C D}$ indicates that the data carrier has been detected by the modem or data set. $\overline{\mathrm{DCD}}$ is a modem input whose condition can be tested by the CPU by reading MSR(7) (DCD) of the Modem Status Register. MSR(3) (DDCD) of the Modem Status Register indıcates whether the $\overline{\mathrm{DCD}}$ input has changed since the previous reading of the MSR. $\overline{D C D}$ has no effect on the receiver. If the $\overline{D C D}$ changes state with the modem status interrupt enabled, an interrupt is generated. <br> When $\overline{D C D}$ is ACTIVE (low), the received line signal from the remote terminal is within the limits specified by the DCE manufacturer. The INACTIVE (high) signal indicates that the signal is not within the specified limits, or is not present. |

## Pin Description

| SYMBOL | PIN NUMBER | TYPE | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| MR | 35 | 1 | H | MASTER RESET. The MR input forces the 82C50A 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 Line Status Register (LSR) is cleared except for the THRE and TEMT bits, which are set. The 82C50A remains in an idle state until programmed to resume serial data activities. The MR input is a Schmitt trigger input See the D. C. Electrical Characteristics for Schmitt trıgger logic input voltage levels. See Table 7 for a summary of Master Reset's effect on 82C50A operation. |
| INTRPT | 30 | 0 | H | INTERRUPT REQUEST. The INTRPT output goes ACTIVE (high) when one of the following interrupts has an ACTIVE (high) condition and is enabled by the Interrupt Enable Register• Receiver Error flag, Received Data Available, Transmitter Holding Register Empty, and Modem Status. The INTRPT is reset low upon appropriate service or a MR operation. See Figure 1. Interrupt Control Structure. |
| SIN | 10 | 1 | H | SERIAL DATA INPUT. The SIN input is the serial data input from the communication line or modem to the 82C50A receiver circuits. A mark $(1)$ is high, and a space (0) is low. Data inputs on SIN are disabled when operating in the loop mode. |
| VCC | 40 |  | H | VCC: +5 volt positive power supply pin. A $0.1 \mu \mathrm{~A}$ decoupling capacitor from VCC ( p in 40) to GND ( pin 20 ) is recommended. |
| $\mathrm{CSO}_{\frac{\mathrm{CS}}{\mathrm{CS}}}^{\mathrm{CS}}$ | $\begin{gathered} 12,13 \\ 14 \end{gathered}$ | $1$ | $\underset{L}{H}, H_{L}$ | CHIP SELECT: The Chip Select inputs act as enable signals for the write (DOSTR, $\overline{\text { DOSTR }}$ ) and read (DISTR, DISTR) input signals. The Chip Select inputs are latched by the $\overline{A D S}$ input |
| NC | 29 |  |  | Do Not Connect |
| CSOUT | 24 | 0 | H | CHIP SELECT OUT: When ACTIVE (high), this pin indicates that the chip has been selected by active CSO, CS1, and $\overline{\mathrm{CS} 2}$ inputs. No data transfer can be initiated until CSOUT is a logic 1, ACTIVE (high). |
| DDIS | 23 | 0 | H | DRIVER DISABLE: This output is INACTIVE (low) when the CPU is reading data from the 82C50A. An ACTIVE (high) DDIS output can be used to disable an external transceiver when the CPU is reading data. |
| $\overline{\text { ADS }}$ | 25 | 1 | L | ADDRESS STROBE: When ACTIVE (low), $\overline{A D S}$ latches the Register Select (A0,A1,A2) and Chip Select (CSO, CS1, CS2) inputs. An active $\overline{A D S}$ is required when the Register Select pins are not stable for the duration of the read or write operation, multiplexed mode. If not required, the $\overline{A D S}$ input should be tied low, non-multiplexed mode. |
| RCLK | 9 | 1 |  | This input is the 16X Baud Rate Clock for the receiver section of the 82C50A. This input may be provided from the BAUDOUT output or an external clock. |

## Block Diagram



## Accessible Registers

The three types of internal registers in the 82C50A used in the operation of the device are control, status, and data registers. The control registers are the Bit Rate Select Register DLL and DLM, Line Control Register, Interrupt Enable Register and the Modem Control registers, while the status registers are the Line Status Registers and the Modem Status Register. The data registers are the Receiver Buffer Register and Transmitter Holding Register. The Address, Read, and Write inputs are used in conjunction with the Divisor Latch Access BIt in the Line Control Register (LCR(7)) to select the register to be written or read (see Table 1.). Individual bits within these registers are referred to by the register mnemonic and the bit number in parenthesis. An example, LCR(7) refers to Line Control Register Bit 7.

TABLE 1. ACCESSING 82C50A INTERNAL REGISTERS

| DLAB | A2 | A1 | A0 | MNEMONIC | REGISTER |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | RBR | Receiver Buffer Register <br> (read only) |
| 0 | 0 | 0 | 0 | THR | Transmitter Holding <br> Register (write only) |
| 0 | 0 | 0 | 1 | IER | Interrupt Enable Register <br> X |
| 0 | 1 | 0 | IIR | Interrupt Identification <br> Register (read only) |  |
| X | 0 | 1 | 1 | LCR | Line Control Register |
| X | 1 | 0 | 0 | MCR | Modem Control Register |
| X | 1 | 0 | 1 | LSR | Line Status Register |
| X | 1 | 1 | 0 | MSR | Modem Status Register |
| X | 1 | 1 | 1 | SCR | Scratch Register |
| 1 | 0 | 0 | 0 | DLL | Divisor Latch (LSB) |
| 1 | 0 | 0 | 1 | DLM | Divisor Latch (MSB) |

The Transmitter Buffer Register and Receiver Buffer Register are data registers holding from 5-8 data bits. If less than eight data bits are transmitted, data is right justified to the LSB. Bit 0 of a data word is always the first serial data bit received and transmitted. The 82C50A data
registers are double buffered so that read and write operations can be performed at the same time the UART is performing the parallel to serial nd serial to parallel conversion. This provides : $\because$ nicroprocessor with increased flexibility in its read and write timing.


## Line Control Register (LCR)

The format of the data character is controlled by the Line Control Register. The contents of the LCR may be read, eliminating the need for separate storage of the line characteristics in system memory. The contents of the LCR are described below.

## LCR Bits 0 thru 7

LCR (0) Word Length Select Bit 0 (WLSO)
LCR (1) Word Length Select Bit 1 (WLS1)
LCR (2) Stop Bit Select (STB)
LCR (3) Parity Enable (PEN)
LCR (4) Even Parity Select (EPS)
LCR (5) Stick Parity
LCR (6) Set Break
LCR (7) Divisor Latch Access Bit (DLAB)
LCR(0) and LCR(1) word length select bit 0, word length select bit 1: The number of bits in each transmitted or received serial character is programmed as follows

| LCR(1) | LCR(0) | WORD LENGTH |
| :---: | :---: | :---: |
| 0 | 0 | 5 Bits |
| 0 | 1 | 6 Bits |
| 1 | 0 | 7 Bits |
| 1 | 1 | 8 Bits |

LCR(2) Stop Bit Select: LCR(2) specifies the number of stop bits in each transmitted character. If LCR(2) is a logic 0 , one stop bit is generated in the transmitted data. If $\operatorname{LCR}(2)$ is a logic 1 when a 5 bit word length is selected, 1.5 stop bits are generated. If LCR(2) is a logic 1 when either a 6 -, 7-, or 8 -bit word length is selected, two stop bits are generated. The receiver checks for two stop bits if programmed.

LCR(3): Parity Enable: When LCR(3) is high, a parity bit between the last data word bit and stop bit is generated and checked.

LCR(4) Even Parity Select: When parity is enabled $(\operatorname{LCR}(3)=1), \operatorname{LCR}(4)=0$ selects odd parity, and LCR(4)=1 selects even parity.

LCR(5) Stick Parity: When parity is enabled (LCR(3)=1), $\operatorname{LCR}(5)=1$ causes the transmission and reception of a parity bit to be in the opposite state from that indicated by LCR(4). This allows the user to force parity to a known state and for the receiver to check the parity bit in a known state.

LCR(6) Break Control: When LCR(6) is set to logic-1, the serial output (SOUT) is forced to the spacing (logic 0 ) state. The break is disabled by setting LCR(6) to a logic-0. The Break Control bit acts only on SOUT and has no effect on the transmitter logic. Break Control enables the

CPU to alert a terminal in a computer communications system. If the following sequence is used, no erroneous or extraneous characters will be transmitted because of the break.

1. Load an all Os pad character in response to THRE.
2. Set break in response to the next THRE.
3. Wait for the transmitter to be idle, (TEMT=1), and clear break when normal transmission has to be restored.

During the break, the transmitter can be used as a character timer to accurately establish the break duration.

LCR(7) Divisor Latch Access Bit (DLAB): LCR(7) must be set high (logic 1) to access the Divisor Latches DLL and DLM of the Baud Rate Generator during a read or write operation. LCR(7) must be input low to access the Receiver Buffer, the Transmitter Holding Register, or the Interrupt Enable Register.

## Line Status Register (LSR)

The LSR is a single register that provides status indications. The LSR is usually the first register read by the CPU to determine the cause of an interrupt or to poll the status of the 82C50A.

Three error flags OE, FE, and PE provide the status of any error conditions detected in the receiver circuitry. During reception of the stop bits, the error flags are set high by an error condition. The error flags are not reset by the absence of an error condition in the next received character. The flags reflect the last character only if no overrun occured. The Overrun Error (OE) indicates that a character in the Receiver Buffer Register has been overwritten by a character from the Receiver Shift Register before being read by the CPU. The character is lost. Framing Error (FE) indicates that the last character received contained incorrect (low) stop bits. This is caused by the absence of the required stop bit or by a stop bit too short to be detected. Parity Error (PE) indicates that the last character received contained a parity error based on the programmed and calculated parity of the received character.

The Break Interrupt (BI) status bit indicates that the last character received was a break character. A break character is an invalid data character, with the entire character, including parity and stop bits, logic zero.

The Transmitter Holding Register Empty (THRE) bit indicates that the THR register is empty and ready to receive another character. The Transmission Shift Register Empty (TEMT) bit indicates that the Transmitter Shift Register is empty, and the 82C50A has completed transmission of the last character. If the interrupt is enabled (IER(1)), an active THRE causes an interrupt (INTRPT).

The Data Ready (DR) bit indicates that the RBR has been loaded with a received character (including Break) and that the CPU may access this data.

Reading the LSR clears LSR(1)-LSR(4). (OE, PE, FE \& BI)

LSR Bits 0 Thru 7

|  | LOGIC 1 | LOGIC 0 |
| :--- | :---: | :---: |
| LSR (0) Data Ready (DR) | Ready | Not Ready |
| LSR (1) Overrun Error (OE) | Error | No Error |
| LSR (2) Parity Error (PE) | Error | No Error |
| LSR (3) Framing Error (FE) | Error | No Error |
| LSR (4) Break Interrupt (BI) | Break | No Break |
| LSR (5) Transmitter Holding | Empty | Not Empty |
| Register Empty (THRE) |  |  |
| LSR (6) Transmitter Empty (TEMT) | Empty | Not Empty |
| LSR (7) Not Used |  |  |

The contents of the Line Status Register are indicated in the above table and are described below.

LSR(0) Data Ready (DR): Data Ready is set high when an incoming character has been received and transferred into the Receiver Buffer Register. LSR(0) is reset low by a CPU read of the data in the Receiver Buffer Register.

LSR(1) Overrun Error (OE): Overrun Error indicates that data in the Receiver Buffer Register was not read by the CPU before the next character was transferred into the Receiver Buffer Register, overwriting the previous character. The OE indicator is reset whenever the CPU reads the contents of the Line Status Register.

LSR(2) Parity Error (PE): Parity Error indicates that the received data character does not have the correct even or odd parity, as selected by the Even Parity Select bit (LCR(4)). The PE bit is set high upon detection of a parity error, and is reset low when the CPU reads the contents of the LSR.

LSR(3) Framing Error (FE): Framing Error indicates that the received character did not have a valid stop bit. LSR(3) is set high when the stop bit following the last data bit or parity bit is detected as a zero bit (spacing level). The FE indicator is reset low when the CPU reads the contents of the LSR.

LSR(4) Break Interrupt ( BI ): Break Interrupt is set high when the received data input is held in the spacing (logic 0 ) state for longer than a full word transmission time (start bit + data bits + parity + stop bits). The Bl indicator is reset when the CPU reads the contents of the Line Status Register.

LSR(1) - LSR(4) are the error conditions that produce a Receiver Line Status interrupt (priority 1 interrupt in the Interrupt Identification Register (IIR)) when any of the conditions are detected. This interrupt is enabled by setting $\operatorname{IER}(2)=1$ in the Interrupt Enable Register.

LSR(5) Transmitter Holding Register Empty (THRE): THRE indicates that the 82C50A is ready to accept a new character for transmission. The THRE bit is set high when a character is transferred from the Transmitter Holding Register into the Transmitter Shift Register. LSR(5) is reset low by the loading of the Transmitter Holding Register by the CPU. LSR(5) is not reset by a CPU read of the LSR.

When the THRE interrupt is enabled (IER(1)=1), THRE causes a priority 3 interrupt in the IIR. If THRE is the interrupt source indicated in IIR, INTRPT is cleared by a read of the IIR.

LSR(6) Transmitter Empty (TEMT): TEMT is set high when the Transmitter Holding Register (THR) and the Transmitter Shift Register (TSR) are both empty. LSR(6) is reset low when a character is loaded into the THR and remains low until the character is transferred out of SOUT. TEMT is not reset low by a CPU read of the LSR.

LSR(7): This bit is permanently set to logic 0 .

## Modem Control Register (MCR)

The MCR controls the interface with the modem or data set as described below. The MCR can be written and read. The $\overline{R T S}, \overline{D T R}, \overline{O U T 1}$, and OUT2 outputs are directly controlled by their control bits in this register. A high input asserts a low (true) at the output pins.

MCR Bits 0 thru 7

|  |  | MCR BIT LOGIC 1 | MCR BIT LOGIC 0 |
| :---: | :---: | :---: | :---: |
| MCR (0) | Data Terminal Ready (DTR) | $\overline{D T R}$ <br> Output Low | $\overline{\text { DTR }}$ Output High |
| MCR (1) | Request to Send (RTS) | $\begin{gathered} \overline{\text { RTS }} \\ \text { Output Low } \end{gathered}$ | $\overline{\text { RTS }}$ Output High |
| MCR (2) | OUT1 | OUT1 Output Low | $\begin{gathered} \overline{\text { OUT1 }} \\ \text { Output High } \end{gathered}$ |
| MCR (3) | OUT2 | $\begin{gathered} \overline{\text { OUT2 }} \\ \text { Output Low } \end{gathered}$ | $\begin{gathered} \overline{\text { OUT2 } 2} \\ \text { Output High } \end{gathered}$ |
| MCR (4) | LOOP | LOOP Enabled | LOOP Disabled |
| MCR (5) | 0 |  |  |
| MCR (6) | 0 |  |  |
| MCR (7) | 0 |  |  |

$\operatorname{MCR}(0)$ : When $\operatorname{MCR}(0)$ is set high, the $\overline{D T R}$ output is forced low. When MCR $(0)$ is reset low, the $\overline{D T R}$ output is forced high. The $\overline{D T R}$ output of the 82C50A may be input into an EIA inverting line driver as the 1488 to obtain the proper polarity input at the modem or data set.
$\operatorname{MCR}(1)$ : When $\operatorname{MCR}(1)$ is set high, the $\overline{R T S}$ output is forced low. When MCR(1) is reset low, the RTS output is forced high. The $\overline{R T S}$ output of the 82C50A may be input into an EIA inverting line driver as the 1488 to obtain the proper polarity input at the modem or data set.

MCR(2): When MCR(2) is set high, the OUT1 output is forced low. When MCR(2) is reset low, the OUT1 output is forced high. OUT1 is an user designated output.

MCR(3): When MCR(3) is set high, the OUT2 output is forced low. When MCR(3) is reset low, the OUT2 output is forced high. OUT2 is an user designated output.

MCR(4): MCR(4) provides a local loopback feature for diagnostic testing of the 82C50A. When MCR(4) is set high, Serial Output (SOUT) is set to the marking (logic 1) state, and the receiver data input Serial Input (SIN) is disconnected. The output of the Transmitter Shift Register is looped back into the Receiver Shift Register input. The four modem control inputs ( $\overline{C T S}, \overline{D S R}, D C$, and $\overline{\mathrm{RI}}$ ) are disconnected. The four modem control outputs (DTR, $\overline{\text { RTS }}, \overline{\text { OUT1 }}$ and $\overline{O U T 2}$ ) are internally connected to the four modem control inputs. The modem control output pins are forced to their inactive state (high). In the diagnostic mode, data transmitted is immediately received. This allows the processor to verify the transmit and receive data paths of the 82C50A.

In the diagnostic mode, the receiver and transmitter interrupts are fully operational. The modem control interrupts are also operational, but the interrupt sources are now the lower four bits of the MCR instead of the four modem control inputs. The interrupts are still controlled by the Interrupt Enable Register.

MCR(5) - MCR(7): These bits are permanently set to logic 0.


## Modem Status Register (MSR)

The MSR provides the CPU with status of the modem input lines from the modem or peripheral device. The MSR allows the CPU to read the modem signal inputs by accessing the data bus interface of the 82C50A. In addition to
the current status information, four bits of the MSR indicate whether the modem inputs have changed since the last reading of the MSR. The delta status bits are set high when a control input from the modem changes state, and reset low when the CPU reads the MSR.

The modem input lines are CTS (pin 36), $\overline{\mathrm{DSR}}$ (pin 37), $\overline{\mathrm{RI}}$ (pin 39), and $\overline{\mathrm{DCD}}$ (pin 38). MSR(4) - MSR(7) are status indications of these lines. The status indications follow the status of the input lines. If the modem status interrupt in the Interrupt Enable Register is enabled (IER(3)), a change of state in a modem input signals will be reflected by the modem status bits in the IIR register, and an interrupt (INTRPT) is generated. The MSR is a priority 4 interrupt. The contents of the Modem Status Register are described below:

Note that the state (high or low) of the status bits are inverted versions of the actual input pins.

MSR Bits 0 thru 7

| MSR BIT | MNEMONIC | DESCRIPTION |
| :--- | :---: | :--- |
| MSR (1) | DDSR | Delta Data Set Ready |
| MSR (2) | TERI | Trailing Edge of Ring |
| MSR (0) | DCTS | Indicator |
| Delta Clear To Send |  |  |
| MSR (3) | DDCD | Delta Data Carrier Detect |
| MSR (4) | CTS | Clear To Send |
| MSR (5) | DSR | Data Set Ready |
| MSR (6) | RI | Ring Indicator |
| MSR (7) | DCD | Data Carrier Detect |

MSR(0) Delta Clear to Send (DCTS): DCTS indicates that the $\overline{\mathrm{CTS}}$ input (Pin-36) to the 82C50A has changed state since the last time it was read by the CPU.

MSR(1) Delta Data Set Ready (DDSR): DDSR indicates that the $\overline{\mathrm{DSR}}$ input (Pin-37) to the 82C50A has changed state since the last time it was read by the CPU.

MSR(2) Trailing Edge of Ring Indicator (TERI): TERI indicates that the $\overline{\mathrm{RI}}$ input ( $\mathrm{Pin}-39$ ) to the 82C50A has changed state from Low to High since the last time it was read by the CPU. High to Low transitions on $\overline{\mathrm{RI}}$ do not activate TERI.

MSR(3) Delta Data Carrier Detect (DDCD): DDCD indicates that the $\overline{D C D}$ input (Pin-38) to the 82C50A has changed state since the last time it was read by the CPU.

MSR(4) Clear to Send (CTS): Clear to Send (CTS) is the status of the CTS input (Pin-36) from the modem indicating to the 82C50A that the modem is ready to receive data from the 82C50A transmitter output (SOUT). If the 82C50A is in the loop mode (MCR(4)=1), MSR(4) is equivalent to RTS in the MCR.

MSR(5) Data Set Ready (DSR): Data Set Ready (DSR) is a status of the $\overline{D S R}$ input (Pin-37) from the modem to the 82C50A which indicates that the modem is ready to provide received data to the 82C50A receiver circuitry. If the $82 C 50 A$ is in the loop mode $(M C R(4)=1), \operatorname{MSR}(5)$ is equivalent to DTR in the MCR.

MSR(6) Ring Indicator MSR(6): Indicates the status of the $\overline{R 1}$ input (Pin-39). If the 82C50A is in the loop mode ( $\operatorname{MCR}(4)=1), \operatorname{MSR}(6)$ is equivalent to OUT1 in the MCR.

MSR(7) Data Carrier Detect (MSR(7)). Data Carrier Detect indicates the status of the Data Carrier Detect ( $\overline{D C D}$ ) input (Pin-38). If the 82C50A is in the loop mode ( $M C R(4)=1$ ), $\operatorname{MSR}(4)$ is equivalent to OUT2 of the MCR.

The modem status inputs (RI, DCD, DSR and CTS) reflect the modem input lines with any change of status. Reading the MSR register will clear the delta modem status indications but has no effect on the status bits. The status bits reflect the state of the input pins regardless of the mask control signals. If a DCTS, DDSR, TERI, or DDCD are true and a state change occurs during a read operation (DISTR, $\overline{D I S T R}$ ), the state change is not indicated in the MSR If DCTS, DDSR, TERI, or DDCD are false and a state change occurs during a read operation, the state change is indicated after the read operation.

For LSR and MSR, the setting of status bits is inhibited during status register read (DISTR DISTR) operations. If a status condition is generated during a read (DISTR, $\overline{\text { DISTR }}$ ) operation, the status bit is not set until the trailing edge of the read (DISTR, $\overline{\text { DISTR }}$ ).

If a status bit is set during a read (DISTR, $\overline{\text { DISTR }}$ ) operatıon, and the same status condition occurs, that status bit will be cleared at the trailing edge of the read (DISTR, $\overline{\text { DISTR }}$ ) instead of being set again.

## Baud Rate Select Register (BRSR)

The 82C50A contains a programmable Baud Rate Generator (BRG) that divides the clock (DC to 10 MHz ) by any divisor from 1 to $2^{16-1}$ (see also BRG description). The output frequency of the Baud Generator is 16 X the data rate [divisor $\#=$ frequency input $\div$ (baud rate $\times 16$ )]. Two 8 -bit divisor latch registers store the divisor in a 16 bit binary format. These Divisor Latch registers must be loaded during initialization. Upon loading either of the Divisor Latches, a 16 -bit Baud counter is immediately loaded. This prevents long counts on initial load.

Sample Divisor Number Calculation:
Given: Desired Baud Rate 1200 Baud
Frequency Input 1.8432 MHz
Formula: Divisor \# = Frequency Input $\div$ (Baud Rate $\times 16$ )

$$
\text { Divisor \# }=1843200 \div(1200 \times 16)
$$

Answer: Divisor \# = 96 = 60HEX $\rightarrow$ DLL $=01100000$

$$
\text { DLM }=00000000
$$

Check: The Divisor \# 96 will divide the input frequency 1.8432 MHz down to 19200 which is 16 times the desired baud rate.

Divisor Latch Least Significant BYTE

| DLL (0) | Bit 0 |
| :--- | :--- |
| DLL (1) | Bit 1 |
| DLL (2) | Bit 2 |
| DLL (3) | Bit 3 |
| DLL (4) | Bit 4 |
| DLL (5) | Bit 5 |
| DLL (6) | Bit 6 |
| DLL (7) | Bit 7 |

Divisor Latch Most Significant BYTE

| DLM (0) | Bit 8 |
| :--- | :--- |
| DLM (1) | Bit 9 |
| DLM (2) | Bit 10 |
| DLM (3) | Bit 11 |
| DLM (4) | Bit 12 |
| DLM (5) | Bit 13 |
| DLM (6) | Bit 14 |
| DLM (7) | Bit 15 |

## Receiver Buffer Register (RBR)

The receiver circuitry in the 82C50A 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 least significant bit (LSB = Data Bit 0 (RBR (0)). Data Bit 0 of a data word (RBR $(0)$ ) is the first data bit received. The unused bits in a character less than 8 bits are output low to the parallel output by the 82C50A.

Received data at the SIN input pin is shifted into the Receiver Shift Register by the 16X clock provided at the RCLK input. This clock is synchronized to the incoming data based on the position of the start bit. When a complete character is shifted into the Receiver Shift Register, the assembled data bits are parallel loaded into the Receiver Buffer Register. The DR flag in the LSR register is set.

Double buffering of the received data permits continuous reception of data without losing received data. While the Receiver Shift Register is shifting a new character into the 82C50A, the Receiver Buffer Register is holding a previously received character for the CPU to read. Failure to read the data in the RBR before complete reception of the next character result in the loss of the data in the Receiver Register. The OE flag in the LSR register indicates the overrun condition.

RBR Bits 0 thru 7

| RBR (0) | Data Bit 0 |
| :--- | :--- |
| RBR (1) | Data Bit 1 |
| RBR (2) | Data Bit 2 |
| RBR (3) | Data Bit 3 |
| RBR (4) | Data Bit 4 |
| RBR (5) | Data Bit 5 |
| RBR (6) | Data Bit 6 |
| RBR (7) | Data Bit 7 |

## Transmitter Holding Register (THR)

The Transmitter Holding Register (THR) holds parallel data from the data bus (D0-D7) until the Transmitter Shift Register is empty and ready to accept a new character for transmission. The transmitter and receiver word length and number of stop bits are the same. If the character is less than eight bits, unused bits at the microprocessor data bus are ignored by the transmitter.

Data Bit 0 (THR (0)) is the first serial data bit transmitted. The THRE flag (LSR (5)) reflect the status of the THR. The TEMT flag (LSR (6)) indicates if both the THR and TSR are empty.

THR Bits 0 thru 7

| THR (0) | Data Bit 0 |
| :--- | :--- |
| THR (1) | Data Bit 1 |
| THR (2) | Data Bit 2 |
| THR (3) | Data Bit 3 |
| THR (4) | Data Bit 4 |
| THR (5) | Data Bit 5 |
| THR (6) | Data Bit 6 |
| THR (7) | Data Bit 7 |

## Scratchpad Register (SCR)

This 8-bit Read/Write register has no effect on the 82C50A. It is intended as a scratchpad register to be used by the programmer to hold data temporarily.

SCR Bits 0 thru 7

| SCR (0) | Data Bit 0 |
| :--- | :--- |
| SCR (1) | Data Bit 1 |
| SCR (2) | Data Bit 2 |
| SCR (3) | Data Bit 3 |
| SCR (4) | Data Bit 4 |
| SCR (5) | Data Bit 5 |
| SCR (6) | Data Bit 6 |
| SCR (7) | Data Bit 7 |

## Interrupt Structure

## Interrupt Identification Register (IIR)

The 82C50A has interrupt capability for interfacing to current microprocessors. In order to mınimize software overhead during data character transfers, the 82C50A prioritizes interrupts into four levels. The four levels of interrupt conditions are as follows:

1. Receiver Line Status (priority 1)
2. Received Data Ready (priority 2)
3. Transmitter Holding Register Empty (priority 3)
4. Modem Status (priority 4).

Information indicating that a prioritized interrupt is pending and the type of interrupt is stored in the Interrupt Identification Register (IIR). When addressed during chip select time, the IIR indicates the highest priority interrupt pending. No other interrupts are acknowledged until the interrupt is serviced by the CPU. The contents of the IIR are indicated in Table 2 and are described below.

IIR(0): IIR(0) can be used in either a hardwired prioritized or polled environment to indicate whether an interrupt is pending. When $\operatorname{IIR}(0)$ is low, an interrupt is pending, and the IIR contents may be used as a pointer to the appropriate interrupt service routine. When IIR(0) is high, no interrupt is pending.
$\| \operatorname{li}(1)$ and $\operatorname{IIR(2):~} \operatorname{IIR(1)}$ and $\| R(2)$ are used to identify the highest priority interrupt pending as indicated in Table 2.

IIR(3) - IIR(7): These five bits of the IIR are logic 0 .

## Interrupt Enable Register (IER)

The Interrupt Enable Register (IER) is a Write register used to independently enable the four 82C50A interrupts which activate the interrupt (INTRPT) output. All interrupts are disabled by resetting $\operatorname{IER}(0)-\operatorname{IER}(3)$ of

TABLE 2. INTERRUPT IDENTIFICATION REGISTER

| INTERRUPT IDENTIFICATION |  |  |  | INTERRUPT SET AND RESET FUNCTIONS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| BIT 2 | BIT 1 | BIT 0 | PRIORITY <br> LEVEL | INTERRUPT <br> FLAG | INTERRUPT <br> SOURCE | INTERRUPT <br> RESET CONTROL |
| X | X | 1 |  | None | None |  |
| 1 | 1 | 0 | First | Receiver <br> Line Status | OE, PE, <br> FE, or BI | LSR Read |
| 1 | 0 | 0 | Second | Received <br> Data <br> Available | Receiver <br> Data <br> Available | RBR Read |
| 0 | 1 | 0 | Third | THRE | THRE | IIR Read if THRE is the <br> interrupt source or <br> THR Write |
| 0 | 0 | 0 | Fourth | Modem <br> Status | $\overline{\mathrm{CTS}, \overline{\mathrm{DSR}}}$ <br> $\mathrm{RI}, \overline{\mathrm{DCD}}$ | MSR Read |

[^13]the Interrupt Enable Register. Interrupts are enabled by setting the appropriate bits of the IER high. Disabling the interrupt system inhibits the Interrupt Identification Register and the active (high) INTRPT output. All other system functions operate in their normal manner, including the setting of the Line Status and Modem Status Registers. The contents of the Interrupt Enable Register are indicated in Table 3 and are described below.
$\operatorname{IER}(0)$ : When programmed high (IER(0)=Logic 1), IER(0) enables Received Data Available interrupt.
$\operatorname{IER}(1)$ : When programmed high (IER(1)=Logic 1), $\operatorname{IER}(1)$ enables the Transmitter Holding Register Empty interrupt.
$\operatorname{IER}(2)$ : When programmed high (IER(2)=Logic 1), IER(2) enables the Receiver Line Status interrupt.
IER(3): When programmed high (IER(3)=Logic 1), IER (3) enables the Modem Status interrupt.
$\operatorname{IER}(4)-\operatorname{IER}(7)$ : These four bits of the IER are logic 0.


FIGURE 1. 82C50A INTERRUPT CONTROL STRUCTURE

TABLE 3. 82C50A ACCESSIBLE REGISTER SUMMARY
(NOTE See Table 1 for how to access these registers)

| REGISTER MNEMONIC | REGISTER BIT NUMBER |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
| $\begin{gathered} \text { RBR } \\ \text { (Read Only) } \end{gathered}$ | $\begin{gathered} \text { Data } \\ \text { Bit } 7 \\ \text { (MSB) } \end{gathered}$ | Data <br> Bit 6 | Data <br> Bit 5 | Data <br> Bit 4 | Data Bit 3 | Data Bit 2 | Data Bit 1 | Data Bit 0 (LSB)* |
| $\begin{gathered} \text { THR } \\ \text { (Write Only) } \end{gathered}$ | Data Bit 7 | Data Bit 6 | Data <br> Bit 5 | Data <br> Bit 4 | Data <br> Bit 3 | Data <br> Bit 2 | Data <br> Bit 1 | Data Bit 0 |
| DLL | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| DLM | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 |
| IER | 0 | 0 | 0 | 0 | (EDSSI) <br> Enable Modem Status Interrupt | (ELSI) <br> Enable <br> Receiver Line Status Interrupt | (ETBEI) <br> Enable <br> Transmitter Holding Register Empty Interrupt | (ERBFI) <br> Enable Received Data Available Interrupt |
| $\begin{gathered} \text { IIR } \\ \text { (Read Only) } \end{gathered}$ | 0 | 0 | 0 | 0 | 0 | Interrupt ID Bit (1) | Interrupt ID Bit (0) | "0" 1 F <br> Interrupt Pending |
| LCR | (DLAB) <br> Divisor Latch Access Bit | Set Break | Stick Parity | (EPS) <br> Even Parity Select | (PEN) Parity Enable | (STB) <br> Number of Stop Bits | (WLSB1) <br> Word Length Select Bit 1 | (WLSB0) Word Length Select Bit 0 |
| MCR | 0 | 0 | 0 | Loop | Out 2 | Out 1 | (RTS) Request To Send | (DTR) <br> Data <br> Termınal Ready |
| LSR | 0 | (TEMT) Transmitter Empty | (THRE) <br> Transmitter Holding Register Empty | (BI) <br> Break Interrupt | (FE) <br> Framing Error | (PE) <br> Parity <br> Error | (OE) Overrun Error | (DR) <br> Data <br> Ready |
| MSR | (DCD) Data Carrier Detect | (RI) <br> Ring Indicator | (DSR) <br> Data Set <br> Ready | (CTS) <br> Clear to Send | (DDCD) Delta Data Carrier Detect | (TERI) <br> Trailing Edge Ring Indicator | (DDSR) <br> Delta <br> Data Set Ready | (DCTS) <br> Delta <br> Clear to Send |
| SCR | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |

[^14]
## Transmitter

The serial transmitter section consists of a Transmitter Holding Register (THR), Transmitter Shift Register (TSR), and associated control logic. The Transmitter Holding Register Empty (THRE) and Transmitter Shift Register Empty (TEMT) are two bits in the Line Status Register which indicate the status of THR and TSR. To transmit a 5-8 bit word, the word is written through D0-D7 to the THR. The microprocessor should perform a write operation only if THRE is high. The THRE is set high when the word is automatically transferred from the THR to the TSR during the transmission of the start bit.

When the transmitter is idle, both THRE and TEMT are high. The first word written causes THRE to be reset to 0 . After completion of the transfer, THRE returns high. TEMT remains low for at least the duration of the transmission of the data word. If a second character is transmitted to the THR, the THRE is reset low. Since the data word cannot be transferred from the THR to the TSR until the TSR is empty, THRE remains low until the TSR has completed transmission of the word. When the last word has been transmitted out of the TSR, TEMT is set high THRE is set high one THR to TSR transfer time later.

## Receiver

Serial asynchronous data is input into the SIN pin. The idle state of the line providıng the input into SIN is high. A start bit detect circuit continually searches for a high to low transition from the idle state. When the transition is detected, a counter is reset, and counts the 16X clock to 7 $1 / 2$, which is the center of the start bit. The start bit is valid if the SIN is still low at the mid bit sample of the start bit. Verifying the start bit prevents the receiver from assembling an incorrect data character due to a low going noise spike on the SIN input.

The Line Control Register determines the number of data bits in a character (LCR(0), LCR(1)), number of stop bits LCR(2), if parity is used LCR(3), and the polarity of parity LCR(4). Status information for the receiver is provided in the Line Status Register. When a character is transferred from the Receiver Shift Register to the Receiver Buffer Register, the Data Received indication in LSR(0) is set high. The CPU reads the Reciver Buffer Register through D0-D7. This read resets LSR(0). If D0-D7 are not read prior to a new character transfer from the RSR to the RBR, the overrun error status indication is set in LSR(1). The parity check tests for even or odd parity on the parity bit, which precedes the first stop bit. If there is a parity error, the parity error is set in LSR(2). There is circuitry which tests whether the stop bit is high. If it is not, a framing error indication is generated in LSR(3).

The center of the start bit is defined as clock count $71 / 2$. If the data into SIN is a symmetrical square wave, the center of the data cells will occur within $\pm 3.125 \%$ of the actual
center, providing an error margin of $46.875 \%$. The start bit can begin as much as one 16X clock cycle prior to being detected.

## Baud Rate Generator (BRG)

The BRG generates the clocking for the UART function, providing standard ANSI/CCITT bit rates. The oscillator driving the BRG may be provided either with the addition of an external crystal to the XTAL1 and XTAL2 inputs, or an external clock into XTAL1. In either case, a buffered clock output, BAUDOUT, is provided for other system clocking. If two 82C50As are used on the same board, one can use a crystal, and the buffered clock output can be routed directly into the XTAL1 of the second 82C50A.

The data rate is determined by the Divisor Latch registers DLL and DLM and the external frequency or crystal input, with the BAUDOUT providing an output 16X the data rate. The bit rate is selected by programming the two divisor latches, Divisor Latch Most Significant Byte and Divisor Latch Least Significant Byte. Setting DLL=1 and DLM=0 selects the divisor to divide by 1 (divide by 1 gives maximum baud rate for a given input frequency at XTAL 1). The on-chip oscillator is optimized for a 10 MHz crystal. Usually, higher frequency are less expensive than lower frequency crystals.

The BRG can use any of three different popular crystals to provide standard baud rates. The frequency of these three common crystals on the market are $1.8432 \mathrm{MHz}, 2.4576$ MHz , and 3.072 MHz . With these standard crystals, standard bit rates from 50 to 38.5 kbps are available. The following tables illustrate the divisors needed to obtain standard rates using these three crystal frequencies.
table 4. baud rates using 1.8432 MHz CRystal

| DESIRED <br> BAUD RATE | DIVISOR USED <br> TO GENERATE <br> $\mathbf{1 6 ~ x ~ C L O C K ~}$ | PERCENT ERROR <br> DIFFERENCE BETWEEN <br> DESIRED \& ACTUAL |
| :---: | :---: | :---: |
| 50 | 2304 | - |
| 75 | 1536 | - |
| 110 | 1047 | 0026 |
| 1345 | 857 | 0058 |
| 150 | 768 | - |
| 300 | 384 | - |
| 600 | 192 | - |
| 1200 | 96 | - |
| 1800 | 64 | - |
| 2000 | 58 | 09 |
| 2400 | 48 | - |
| 3600 | 32 | - |
| 4800 | 24 | - |
| 7200 | 16 | - |
| 9600 | 12 | - |
| 19200 | 6 | - |
| 38400 | 3 | 28 |
| 56000 | 2 |  |

TABLE 5. BAUD RATES USING 2.4576 MHz CRYSTAL

| DESIRED <br> BAUD RATE | DIVISOR USED <br> TO GENERATE <br> $16 \times$ CLOCK | PERCENT ERROR <br> DIFFERENCE BETWEEN <br> DESIRED \& ACTUAL |
| ---: | :---: | :---: |
| 50 | 3072 | - |
| 75 | 2048 | - |
| 110 | 1396 | 0.026 |
| 134.5 | 1142 | 0.0007 |
| 150 | 1024 | - |
| 300 | 512 | - |
| 600 | 256 | - |
| 1200 | 128 | - |
| 1800 | 85 | 0.260 |
| 2000 | 77 | - |
| 2400 | 64 | 0.775 |
| 3600 | 43 | - |
| 4800 | 32 | 1587 |
| 7200 | 21 | - |
| 9600 | 16 | - |
| 19200 | 8 | - |
| 38400 | 4 |  |

## Reset

After powerup, the 82C50A Master Reset schmitt trigger input (MR) should be held high for TMRW ns to reset the 82C50A circuits to an idle mode until initialization. A high on MR causes the following:

1. Initializes the transmitter and receiver internal clock counters.
2. Clears the Line Status Register (LSR), except for Transmitter Shift Register Empty (TEMT) and Transmit Holding Register Empty (THRE), which are set. The Modem Control Register (MCR) is also cleared. All of the discrete lines, memory elements

TABLE 6. BAUD RATES USING $\mathbf{3 . 0 7 2} \mathbf{~ M H z}$ Crystal

| DESIRED <br> BAUD RATE | DIVISOR USED <br> TO GENERATE <br> 16 x CLOCK | PERCENT ERROR <br> DIFFERENCE BETWEEN <br> DESIRED \& ACTUAL |
| ---: | :---: | :---: |
| 50 | 3840 | - |
| 75 | 2560 | - |
| 110 | 1745 | 0.026 |
| 134.5 | 1428 | 0.034 |
| 150 | 1280 | - |
| 300 | 640 | - |
| 600 | 320 | - |
| 1200 | 160 | - |
| 1800 | 107 | 0.312 |
| 2000 | 96 | - |
| 2400 | 80 | - |
| 3600 | 53 | 0.628 |
| 4800 | 40 | - |
| 7200 | 27 | 1.23 |
| 9600 | 20 | - |
| 19200 | 10 | - |
| 38400 | 5 | - |

and miscellaneous logic associated with these register bits are also cleared or turned off. Divisor Latches, Receiver Buffer Register, Transmitter Buffer Register are not effected.

Following removal of the reset condition (MR low), the 82C50A remains in the idle mode until programmed.

A hardware reset of the 82C50A sets the THRE and TEMT status bit in the LSR. When interrupts are subsequently enabled, an interrupt occurs due to THRE.

A summary of the effect of a Master Reset on the 82C50A is given in Table 7.

TABLE 7. 82C50A RESET OPERATIONS

| REGISTER/SIGNAL | RESET CONTROL | RESET |
| :--- | :--- | :--- |
| Interrupt Enable Register | Master Reset | All Bits Low (0-3 forced and 4-7 permanent) |
| Interrupt Identification | Master Reset | Bit 0 is High, Bits 1 and 2 Low |
| Register | Bits 3-7 are Permanently Low |  |
| Line Control Register | Master Reset | All Bits Low |
| MODEM Control Register | Master Reset | All Bits Low, Except Bits 5 and 6 are High |
| Line Status Register | Master Reset | Bit 0-3 Low |
| MODEM Status Register | Master Reset | Bits 4-7 Input Signal |
|  |  | High |
| SOUT | Low |  |
| Intrpt (RCVR Errs) | Master Reset | Low |
| Intrpt (RCVR Data Ready) | Read LSR/MR | Read RBR/MR |
| Intrpt (THRE) | Read IIR/Write THR/MR | Low |
| Intrpt (Modem Status Changes) | Read MSR/MR | High |
| Out2 | Master Reset | High |
| RTS | Master Reset | Migh |
| DTR | High |  |
| Out1 |  |  |

## Programming

The 82C50A is programmed by the control registers LCR, IER, DLL and DLM, and MCR. These control words define the character length, number of stop bits, parity, baud rate, and modem interface.

While the control registers can be written in any order, the IER should be written to last because it controls the interrupt enables. Once the 82C50A is programmed and operational, these registers can be updated any time the 82C50A is not transmitting or receiving data.

The control signals required to access 82C50A internal registers are shown below.

## Software Reset

A software reset of the 82C50A is a useful method for returning to a completely known state without a system reset. Such a reset consists of writing to the LCR, Divisor Latches, and MCR registers. The LSR and RBR registers should be read prior to enabling interrupts in order to
clear out any residual data or status bits which may be invalid for subsequent operation.

## Crystal Operation

The 82C50A crystal oscillator circuitry is designed to operate with a fundamental mode, parallel resonant crystal. Table 8 shows the required crystal parameters and crystal circuit configuration, respectively.

When using an external clock source, the XTAL1 input is driven and the XTAL2 output is left open. Power consumption when using an external clock is typically $50 \%$ of that required when using a crystal. This is due to the sinusoidal nature of the drive circuitry when using a crystal.

The maximum frequency of the the 82 C 50 A is 10 MHz with an external clock or a crystal attached to XTAL1 and XTAL2. Using the external clock or crystal, and a divide by one divisor, the maximum BAUDOUT is 10 MHz , and the maximum data rate is 625 Kbps .

TABLE 8. TYPICAL CRYSTAL OSCILLATOR CIRCUIT

| PARAMETER |  |
| :--- | :--- |
| Frequency | 10 to 10 MHz |
| Type of Operation | Parallel resonant, Fundamental mode |
| Load Capacitance(CL) | 20 or 32 pF (typ) |
| R Series (Max) | 100 ohms ( $\mathrm{f}=10 \mathrm{MHz}, \mathrm{CL}=32 \mathrm{pF}$ ) |
|  | 200 ohms ( $\mathrm{f}=10 \mathrm{MHz}, \mathrm{CL}=20 \mathrm{pF})$ |



## Specifications 82C50A

## Absolute Maximum Ratings

Supply Voltage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0V: $\quad$ jjc . . . . . . . . . . . . . . . . . . . . . . . $10.5^{\circ} \mathrm{C} / \mathrm{W}$ (Cerdip Package)
Input, Output or I/O Voltage Applied GND -0.5V to $\quad \theta \mathrm{ja}$
$\theta j a$. $26.7^{\circ} \mathrm{C} / \mathrm{W}$ (Cerdip Package) VCC +0.5 V Gate Count

1788 Gates
Storage Temperture Range . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Maximum Package Power Dissipation. 1W
$\qquad$
Lead Temperature (Soldering, 10s)
$+300^{\circ} \mathrm{C}$

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 operation section of this specification is not implied.

## Operating Conditions


I82C50A-5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $40^{\circ} \mathrm{V}$ to $+85^{\circ} \mathrm{C}$

M82C50A-5 . . . . . . . . . . . . . . . . . . . . . . . . $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
DC Electrical Specifications $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} 50 \mathrm{~A}-5)$;
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (182C50A-5);
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (M82C50A-5)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logıcal One Input Voitage | $\begin{aligned} & 2.0 \\ & 22 \end{aligned}$ |  | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & \text { I82C50A-5, C82C50A-5 } \\ & \text { M82C50A-5 } \end{aligned}$ |
| VIL | Logıcal Zero Input Voltage |  | 08 | V |  |
| VTH | Schmitt Trigger Logıc One Input Voltage | $\begin{aligned} & 20 \\ & 2.2 \end{aligned}$ |  | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | MR Input 182C50A-5, C82C50A-5 M82C50A-5 |
| VTL | Schmitt Trigger Logic Zero Input Voltage |  | 0.8 | V | MR Input |
| VIH(CLK) | Logical One Clock Voltage | vCC-0.8 |  | V | External Clock |
| VIL(CLK) | Logical Zero Clock Voltage |  | 0.8 | V | External Clock |
| VOH | Output High Voltage | $\begin{gathered} 3.0 \\ \text { VCC-0 } 4 \end{gathered}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & 1 \mathrm{OH}=-25 \mathrm{~mA} \\ & 1 O H=-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | Output Low Voltage |  | 0.4 | V | $1 \mathrm{OL}=+2.5 \mathrm{~mA}$, |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN = GND or VCC, DIP Pins } \\ & 9,10,12,13,14,18,19,21, \\ & 22,25-28,35-39 \end{aligned}$ |
| 10 | Input/Output Leakage Current | -10.0 | +100 | $\mu \mathrm{A}$ | VO = GND or VCC, DIP Pins 1-8 |
| ICCOP | Operatıng Power Supply Current |  | 6 | mA | External Clock $\mathrm{F}=2.4576 \mathrm{MHz}, \mathrm{VCC}=5.5 \mathrm{~V}$, VIN = VCC or GND, Outputs Open |
| ICCSB | Standby Supply Current |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{VCC} \text { or } \\ & \text { GND, Outputs Open } \end{aligned}$ |

Capacitance $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | 15 | pF | FREQ $=1 \mathrm{MHz}$ all measure- <br> ments are referenced to <br> device GND |
| COUT | Output Capacitance | 15 | pF |  |
| CI/O | I/O Capacitance | 20 | pF |  |

AC Specifications VCC $=5.0 \mathrm{~V} \pm 10 \%$

$$
\begin{aligned}
& T_{A}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 50 \mathrm{~A}-5) \\
& T_{A}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}(\text { (I82C50A-5) } \\
& T_{A}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\text { M82C50A-5) }
\end{aligned}
$$

Timing Requirements

| SYMBOL | PARAMETER | 82C50A-5 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| (1) TAW | Address Strobe Width | 50 |  | ns |  |
| (2) TAS | Address Setup Time | 60 |  | ns | Note 1 |
| (3) $\mathrm{T}_{\mathrm{AH}}$ | Address Hold Time | 0 |  | ns |  |
| (4) TCS | Chip Select Setup Time | 60 |  | ns | Note 1 |
| (5) T CH | Chip Select Hold Time | 0 |  | ns |  |
| (6) TDIW | DISTR $\overline{\text { DISTR }}$ Strobe Width | 150 |  | ns |  |
| (7) $T_{R C}$ | Read Cycle Delay | 270 |  | ns | Note 1 |
| (8) $\mathrm{R}_{\mathrm{C}}$ | Read Cycle $=$ TAR +TDIW +TRC | 500 |  | ns |  |
| (9) $T_{D D}$ | DISTR $\overline{\text { DISTR }}$ to Driver Disable Delay |  | 75 | ns |  |
| (10) TDDD | Delay From DISTR $\overline{\text { DISTR }}$ to Data |  | 120 | ns |  |
| (11) $\mathrm{T}_{\mathrm{HZ}}$ | DISTR $\overline{\text { DISTR }}$ to Floating Data Delay | 10 | 75 | ns |  |
| (12) TDOW | DOSTR $\overline{\text { DOSTR }}$ Strobe Width | 150 |  | ns |  |
| (13) TWC | Write Cycle Delay | 270 |  | ns | Note 1 |
| (14) $\mathrm{W}_{\mathrm{C}}$ | Write Cycle $=$ TAW + TDOW + TWC | 500 |  | ns |  |
| (15) TDS | Data Setup Time | 90 |  | ns |  |
| (16) TDH | Data Hold Time | 60 |  | ns |  |

NOTE 1: "When using the 82C50A in the multiplexed mode ( $\overline{A D S}$ operational), it will operate in 80C86/88 systems with a maxımum 3 MHz operating frequency."

AC Specifications VCC $=5.0 \mathrm{~V} \pm 10 \%$

$$
\begin{aligned}
& T_{A}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 50 \mathrm{~A}-5) \\
& \mathrm{T}_{A}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \text { (I82C50A-5) } \\
& \mathrm{T}_{A}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\text { M82C50A-5) }
\end{aligned}
$$

Timing


## A.C. Test Circuit



| IOH | IOL | V1 | R1 | C1 |
| :---: | :---: | :---: | :---: | :---: |
| -2.5 mA | +2.5 mA | 1.7 V | $520 \Omega$ | 100 pF |

TEST CONDITION DEFINITION TABLE

## A.C. Testing Input, Output Waveform


A.C Testıng• All input sıgnals must switch between VIL -0.4 V and $\mathrm{VIH}+04 \mathrm{~V}$ Input rise and fall times are driven at 1 nsec per volt

Timing Waveforms


EXTERNAL CLOCK INPUT


AC TEST POINTS


## BAUDOUT TIMING

NOTE: tBLD $(\div 1)$ is the only spec measure from XTL1 falling edge. All other tBLD's and tBHD's are measured from XTAL1 rising edge.

Timing Waveforms


* Applicable only when $\overline{A D S}$ is tied low

* Applicable only when $\overline{A D S}$ is tied low

READ CYCLE

Timing Waveforms


RECEIVER TIMING


TRANSMITTER TIMING


NOTE 1 See Write Cycle Timing
NOTE 2 See Read Cycle Tımıng

MODEM CONTROLS TIMING

REFERENCE APP NOTE 108
January 1992
CMOS Serial Controller Interface

## Features

- Single Chip UART/BRG
- DC to 16 MHz (1M Baud) Operation
- Crystal or External Clock Input
- On-Chip Baud Rate Generator - 72 Selectable Baud Rates
- Interrupt Mode With Mask Capability
- Microprocessor Bus Oriented Interface
- 80C86 Compatible
- Single +5V Power Supply
- Low Power Operation 1mA/MHz Typical
- Modem Interface
- Line Break Generation and Detection
- Operating Temperature Range:

- M82C52 .................................................. . . $-5^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The Harris 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 up to 1M baud asynchronously with a 16 X clock ( 16 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 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.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 1M BAUD |
| :---: | :---: | :---: |
| Plastic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CP82C52 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IP82C52 |
| PLCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CS82C52 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IS82C52 |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | CD82C52 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | ID82C52 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MD82C52/B |
| SMD\# |  | 8501501XA |
| LCC SMD\# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MR82C52/B |
|  |  | 85015013A |



## Block Diagram



| SYMBOL | PIN NO. | TYPE | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{RD}}$ | 1 | 1 | Low | READ: The $\overline{\mathrm{RD}}$ input causes the 82C52 to output data to the data bus (D0-D7). The data output depends upon the state of the address inputs (AO-A1). $\overline{\mathrm{CSO}}$ enables the $\overline{\mathrm{RD}}$ input. |
| $\overline{W R}$ | 2 | I | Low | WRITE: The $\overline{W R}$ input causes data from the data bus (DO-D7) to be input to the 82C52. Addressing and chip select action is the same as for read operations. |
| DO-D7 | 3-10 | 1/0 | High | DATA BITS 0-7: The Data Bus provides eight, three-state input/output lines for the transfer of data, control and status information between the 82C52 and the CPU. For character formats of less than 8 bits, the corresponding D7, D6 and D5 are considered "don't cares" for data WRITE operations and are 0 for data READ operations. These lines are normally in a high impedance state except during read operations. DO is the Least Significant Bit (LSB) and is the first serial data bit to be received or transmitted. |
| AO, A1 | 11,12 | 1 | High | ADDRESS INPUTS: The address lines select the various internal registers during CPU bus operations. |
| IX, OX | 13,14 | 1/0 |  | 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. |
| SDO | 15 | 0 | High | SERIAL DATA OUTPUT: Serial data output from the 82 C 52 transmitter circuitry. A Mark (1) is a logic one (high) and Space ( 0 ) is logic zero (low). SDO is held in the Mark condition when $\overline{\mathrm{CTS}}$ is false, when RST is true, when the Transmitter Register is empty, or when in the Loop Mode. |
| GND | 16 |  | Low | GROUND: Power supply ground connection. |
| $\overline{\text { CTS }}$ | 17 | 1 | Low | CLEAR TO SEND: The logical state of the $\overline{\mathrm{CTS}}$ line is reflected in the $\overline{\mathrm{CTS}}$ bit of the Modem Status Register. Any change of state in $\overline{\mathrm{CTS}}$ causes INTR to be set true when INTEN and MIEN are true. A false level on 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 Loop Mode operation. |
| $\overline{\text { DSR }}$ | 18 | 1 | Low | DATA SET READY: The logical state of the $\overline{D S R}$ line is reflected in the Modem Status Register. Any change of state of $\overline{D S R}$ 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 82C52. |
| $\overline{\text { DTR }}$ | 19 | 0 | 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 in the $\overline{\text { DTR }}$ bit in the MCR or whenever a reset (RST = high) is applied to the 82C52. |
| $\overline{\mathrm{RTS}}$ | 20 | 0 | 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 $\overline{\operatorname{RTS}}$ bit in the MCR or whenever a reset ( $\mathrm{RST}=$ high ) is applied to the 82C52. |
| CO | 21 | 0 |  | CLOCK OUT: This output is user programmable to provide either a 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 Baud Rate Select Register (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. On reset D7 (CO select) is reset to 0 . |
| TBRE | 22 | 0 | 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 reset (RST) to the 82C52 will also set the TBRE output. TBRE is cleared (low) whenever data is written to the TBR. |
| RST | 23 | 1 | High | RESET: The RST input forces the 82C52 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 82 C 52 remains in an "Idle" state until programmed to resume serial data activities. The RST input is a Schmitt triggered input. |
| INTR | 24 | 0 | High | INTERRUPT REQUEST: The INTR output is enabled by the INTEN bit in the Modem Control Register (MCR). The MIEN bit selectively enables modem status changes to provide an input to the INTR logic. Figure 9 in Design Information shows the overall relationship of these interrupt control signals. |
| SDI | 25 | I | High | SERIAL DATA INPUT: Serial data input to the 82C52 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 or when RST is true. |
| DR | 26 | 0 | 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 Receiver Buffer Register (RBR) or when RST is true. |
| VCC | 27 |  | High | VCC: +5 V postive power supply pin. A $0.1 \mu \mathrm{~F}$ decoupling capacitor from VCC (Pin 27) to GND (Pin 16) is recommended. |
| $\overline{\mathrm{CSO}}$ | 28 | I | Low | CHIP SELECT: The chip select input acts as an enable signal for the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ input signals. |

## Reset

During and after power-up, the 82C52 Reset Input (RST) must be held high for at least two IX clock cycles in order to initialize and drive the 82C52 circuits to an idle mode until proper programming can be done. A high on RST causes the following events to occur:

- Resets the internal Baud Rate Generator (BRG) circuit clock counters and bit counters. The Baud Rate Select Register (BRSR) is not affected (except for bit 7 which is reset to 0 ).
- Clears the UART Status Register (USR) except for Transmission Complete (TC) and Transmit Buffer Register Empty (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 82C52 remains in the idle mode until programmed to its desired system configuration.

## Programming The 82C52

The complete functional definition of the 82C52 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 82C52 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 82C52 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 82C52 is programmed and operational, these registers can be updated any time the 82C52 is not immediately transmitting or receiving data.

Table A. shows the control signals required to access 82C52 internal registers.

## 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 logic zero (0) in order to insure software compatibility 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. See Figure 1.

TABLE A.

| $\overline{\text { CSO }}$ | A1 | AO | $\overline{\text { WR }}$ | $\overline{\mathrm{RD}}$ | OPERATION |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | 1 | Data Bus $\rightarrow$ Transmitter Buffer <br> Register (TBR) |
| 0 | 0 | 0 | 1 | 0 | Receiver Buffer <br> Register (RBR) $\rightarrow$ Data Bus |
| 0 | 0 | 1 | 0 | 1 | Data Bus $\rightarrow$ UART Control <br> Register (UCR) |
| 0 | 0 | 1 | 1 | 0 | UART Status <br> Register (USR) $\rightarrow$ Data Bus |
| 0 | 1 | 0 | 0 | 1 | Data Bus $\rightarrow$ Modem Control <br> Register (MCR) |
| 0 | 1 | 0 | 1 | 0 | MCR $\rightarrow$ Data Bus |
| 0 | 1 | 1 | 0 | 1 | Data Bus $\rightarrow$ Bit Rate Select <br> Register (BRSR) |
| 0 | 1 | 1 | 1 | 0 | Modem Status <br> Register (MSR) $\rightarrow$ Data Bus |

UCR


FIGURE 1.

## Baud Rate Select Register (BRSR)

The 82C52 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 the divide ratio (one of 72) for the internal Baud Rate Generator circuitry. The internal circuitry is separated 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$.

The 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 Prescaler divide ratios of $\div 3, \div 4$, or $\div 5$ respectively, the Prescaler output will provide a constant 614.4 KHz . When this frequency is further divided by the Divisor Select counter, any of the standard baud rates from 50 Baud to 38.4 Kbaud can be selected (see Table B). Non-standard baud rates up to 1 Mbaud can be selected by using different input frequencies (crystal or an external frequency input up to 16 MHz ) and/or different Prescaler and Divisor Select ratios.

Regardless of the baud rate, the baud rate generator provides a clock which is 16 times the desired baud rate. For example, in order to operate at a 1 Mb aud data rate, a 16 MHz crystal, a Prescale rate of $\div 1$, and a Divisor Select rate of "external" would be used. This would provide a 16 MHz clock as the output of the Baud Rate Generator to the Transmitter and Receiver circuits.

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 21). 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$.


FIGURE 2.

TABLE B.

| BAUD RATE | DIVISOR |
| :---: | :---: |
| 38.4 K | External |
| 19.2 K | 2 |
| 9600 | 4 |
| 7200 | $16 / 3$ |
| 4800 | 8 |
| 3600 | $32 / 3$ |
| 2400 | 16 |
| $2000^{\star}$ | $58 / 3$ |
| $1800^{\star}$ | 22 |
| 1200 | 32 |
| 600 | 64 |
| 300 | 128 |
| 200 | 192 |
| 150 | 256 |
| $134.5^{\star}$ | 288 |
| $110^{\star}$ | 352 |
| 75 | 512 |
| 50 | 768 |

NOTE These baud rates are based upon the following input frequency/ Prescale divisor combinations
18432 MHz and Prescale $=+3$
24576 MHz and Prescale $=\div 4$
3072 MHZ and Prescale $=\div 5$
*All baud rates are exact except for:

| BAUD RATE | ACTUAL | PERCENT <br> ERROR |
| :---: | :---: | :---: |
| 1800 | 1745.45 | $3.03 \%$ |
| 2000 | 1986.2 | $0.69 \%$ |
| 134.5 | 133.33 | $0.87 \%$ |
| 110 | 109.09 | $0.83 \%$ |

## 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{\text { DTR }}$ 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 82C52 into one of four possible modes. "Normal" configures the 82C52 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 retransmitted 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 resynchronized output. Also note that normal UART transmission via the Transmitter Register is disabled when operating in the Echo mode (see Figure 4). 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{\mathrm{CTS}}, \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 82C52 operation.

MCR

| 07 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


*See Modem Status Register description for a description of register flag images with respect to output pins.

## 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 determine if errors have occurred or if other status changes in the 82C52 require 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 82C52.
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 in the

RBR contained improper stop bits. This could be caused by the 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 in the RBR contained a parity error based on the programmed parity of the receiver and the calculated parity of the received character 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{CTS}}$ or $\overline{\mathrm{DSR}}$ ). A subsequent read of the Modem Status Register will show the state of these two 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 82C52 has completed transmission of the last character it was commanded to transmit. The assertion of this bit will cause an interrupt (INTR) if the INTEN bit in the MCR register is true.
The Transmitter Buffer Register Empty (TBRE) bit indicates that the TBR register is empty and ready to receive another character.

The Data Ready (DR) bit indicates that the RBR has been loaded with a received character (including Break) and that the CPU may access this data.
Assertion of the TBRE or DR bits do not affect the INTR logic and associated INTR output pin since the 82C52 has been designed to provide separate requests via the DR and TBRE output pins. If a single interrupt for any status change in the 82C52 is desired this can be accomplished by using an 82C59A Interrupt controller with DR, TBRE, and INTR as inputs. (See Figure 11).

USR



FIGURE 5.

## Modem Status Register (MSR)

The MSR allows the CPU to read the modem signal inputs by accessing the data bus interface of the 82C52. Like all of the register images of external pins in the 82C52, 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 in any 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 Data Set Ready ( $\overline{\mathrm{DSR}}$ ) input is a status indicator from the modem to the 82C52 which indicates that the modem is ready to provide received data to the 82C52 receiver circuitry.

Clear to Send $(\overline{\mathrm{CTS}})$ is both a status and control signal from the modem that tells the 82C52 that the modem is ready to receive transmit data from the 82C52 transmitter output (SDO). A high (false) level on this input will inhibit the 82C52 from beginning transmission and if asserted in the middle of a transmission will only permit the 82C52 to finish transmission of the current character.

MSR


## FIGURE 6.

## Receiver Buffer Register (RBR)

The receiver circuitry in the 82C52 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 Least Significant Bit ( $\mathrm{LSB}=\mathrm{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 a logic zero (0) by the 82C52.

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 out-
put 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 82C52, 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


FIGURE 7.

## Transmitter Buffer Register (TBR)

The Transmitter Buffer Register (TBR) accepts parallel data from the data bus (DO-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.

TBR



FIGURE 8.

Bit 0 , which corresponds to DO at the data bus, is always the first serial data bit transmitted. Provision is 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 flag (USR register) indicates when both TBR and TR are empty.

## 82C52 Interrupt Structure

The 82C52 has provisions for software masking of interrupts generated for the INTR output pin. Two control bits in the MCR register, MIEN and INTEN, control modem status interrupts and overall 82C52 interrupts respectively. Figure 9 illustrates the logical control function provided by these signals.

The modem status inputs ( $\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.

A hardware reset of the 82C52 sets the TC status bit in the USR. When interrupts are subsequently enabled an interrupt can occur due to the fact that the positive edge detection circuitry in the interrupt logic has detected the setting of the TC bit. If this interrupt is not desired the USR should be read prior to enabling interrupts. This action resets the positive edge detection circuitry in the interrupt control logic (Figure 9).
NOTE: For USR and MSR, the setting of status bits is inhibited during status register READ operations. If a status condition is generated during a READ operation, the status bit is not set until the trailing edge of the $\overline{\mathrm{RD}}$ pulse.

If the bit was already set at the time of the READ operation, and the same status condition occurs, that status bit will be cleared at the tralling edge of the $\overline{\mathrm{RD}}$ pulse instead of being set again


FIGURE 9. 82 C 52 INTERRUPT STRUCTURE

## Software Reset

A software reset of the 82C52 is a useful method for returning to a completely known state without exercising a complete system reset. Such a reset would consist of writing to the UCR, BRSR and MCR registers. The USR and RBR registers should be read prior to enabling interrupts in order to clear out any residual data or status bits which may be invalid for subsequent operation.

## Crystal Operation

The 82C52 crystal oscillator circuitry is designed to operate with a fundamental mode, parallel resonant crystal. This circuit is the same one used in the Harris 82C84A clock generator/driver. To summarize, Table C 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 $50 \%$ of that required when using a crystal. This is due to the sinusoidal nature of the drive circuitry when using a crystal.
table C.

| PARAMETER | TYPICAL CRYSTAL <br> SPECIFICATION |
| :--- | :--- |
| Frequency | 1.0 to 16 MHz |
| Type of Operation | Parallel Resonant, Fundamental <br> Mode |
| Load Capacitance (CL) | 20 or 32 pF (Typ) |
| RSERIES(Max) | $100 \Omega(\mathrm{f}=16 \mathrm{MHz}, \mathrm{CL}=32 \mathrm{pF})$ <br> $200 \Omega(\mathrm{f}=16 \mathrm{MHz}, \mathrm{CL}=20 \mathrm{pF})$ |


${ }^{*} \mathrm{C} 1=\mathrm{C} 2=20 \mathrm{pF}$ FOR CL $=20 \mathrm{pF}$
${ }^{*} \mathrm{C} 1=\mathrm{C} 2=47 \mathrm{pF}$ FOR CL $=32 \mathrm{pF}$
FIGURE 10.

## 82C52-80C86 Interfacing

The following example (Figure 11) shows the interface for an 82C52 in an 80C86 system.
Use of the Harris CMOS Interrupt Controller (82C59A) is optional and necessary only if an interrupt driven system is desired.
By using the Harris CMOS 82C84A clock generator, the system can be built with a single crystal providing both the processor clock and the clock for the 82C52. The 82C52
has special divider circuitry which is designed to supply industry standard baud rates with a 2.4576 MHz input frequency. Using a 15 MHz crystal as shown, results in less than a $2 \%$ frequency error which is adequate for many applications. For more precise baud rate requirements, a 14.7456 MHz crystal will drive the 80 C 86 at 4.9 MHz and provide the 82C52 with the standard baud rate input frequency of 2.4576 MHz . If baud rates above 156 Kbaud are desired, the OSC output can be used instead of the PCLK $(\div 6)$ output for asynchronous baud rates up to 1 Mbaud.


FIGURE 11. 80C86/82C52 INTERFACE

| Absolute Maximum Ratings |  |  | Reliability Information |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V Input, Output or I/O Voltage . . . . . . . . . . . . GND-0.5V to VCC +0.5 V Storage Temperature Range $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |  | Thermal Resistance . . . . . . . . . . . . . . . . . $\quad \theta_{j \mathrm{ja}}$ Ceramic DIP Package $\qquad$ $45^{\circ} \mathrm{C}$ N |  |  | $\stackrel{\theta_{\kappa}}{8.4^{\circ} \mathrm{C} / W}$ |
|  |  |  |  |  |  |  |
|  |  |  | Ceramic LCC Packag |  | . $50.7{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $5.3{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ |  |  | Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |  |
| Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$ |  |  | Ceramic DIP Package |  |  | ...1.1W |
| ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1 |  |  | Ceramic L. | Packag |  | . 986 mW |
|  |  |  | Gate Count . . . . . . . . |  |  | 1500 Gates |
| CAUTION: Stresses above those listed in "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. |  |  |  |  |  |  |
| Operating Conditions |  |  |  |  |  |  |
| Operating Voltage Range . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5V |  |  | Operating Temperature Range |  |  |  |
|  |  |  | C82C52 |  |  | to $+70^{\circ} \mathrm{C}$ |
|  |  |  | ${ }^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |  |
|  |  |  | M82C52. | Co $+125^{\circ} \mathrm{C}$ |  |
| DC Electrical Specifications $\quad \mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{C} 82 \mathrm{C} 52)$; |  |  |  |  |  |  |
| DC Electrical Specifications $\quad \begin{aligned} \text { VCC }\end{aligned}$ |  |  |  |  |  |  |
| $T_{A}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \text { (M82C52) }$ |  |  |  |  |  |  |
| SYMBOL | PARAMETER | MIN |  |  |  | MAX | UNITS | TEST CONDITIONS |  |
| VIH | Logical One Input Voltage | $\begin{aligned} & 2.0 \\ & 2.2 \end{aligned}$ | $\bullet$ | V | $\begin{aligned} & \text { I82C52, C82C52 } \\ & \text { M82C52 } \end{aligned}$ |  |
| VIL | Logical Zero Input Voltage | - | 0.8 | V |  |  |
| VTH | Schmitt Trigger Logical One Input Voltage | VCC-0.5 | - | V | Reset Input |  |
| VTL | Schmitt Trigger Logical Zero Input Voltage | - | GND +0.5 | V | Reset Input |  |
| VIH (CLK) | Logical One Clock Input Voltage | VCC-0.5 | - | V | External Clock |  |
| VIL (CLK) | Logical Zero Clock Input Voltage | - | GND +0.5 | V | External Clock |  |
| VOH | Output High Voltage | $\begin{gathered} 3.0 \\ \text { vcc-0.4 } \end{gathered}$ | - | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & 1 \mathrm{IOH}=-2.5 \mathrm{~mA} \text {, Except OX, } \\ & 1 \mathrm{OH}=-100 \mu \mathrm{~A} \text {, For OX }-10 \mathrm{H}=-1.0 \mathrm{~mA} \end{aligned}$ |  |
| VOL | Output Low Voltage | - | 0.4 | V | $1 \mathrm{OL}=+2.5 \mathrm{~mA}$ |  |
| II | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VIN = GND or VCC, DIP Pins } 1,2,11 \text {, } \\ & 12,17,18,23,25,28 \end{aligned}$ |  |
| 10 | Input/Output Leakage Current | -10.0 | +10.0 | $\mu \mathrm{A}$ | VOUT = GND or VCC, DIP Pins 3-10 |  |
| ICCOP* | Operating Power Supply Current | - | 3 | mA | External Clock $F=2.4576 \mathrm{MHz}$, $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{VCC}$ or GND, Outputs Open |  |
| ICCSB | Standby Supply Current | - | 100 | $\mu \mathrm{A}$ | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{VCC}$ <br> Outputs Open | GND, |

* Guaranteed and sampled, but not $100 \%$ tested. ICCOP is typically $\leq 1 \mathrm{mAMMHz}$.

Capacitance $T_{A}=25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | 12 | pF | FREQ $=1 \mathrm{MHz}$, all measurements are <br> referenced to device GND |
| COUT | Output Capacitance | 15 | pF |  |
| CIO | I/O Capacitance | 15 | pF |  |

A.C. Electrical Specifications

```
VCC = 5.0V \pm 10%;
TA = 00 C to +700 C (C82C52)
TA = -400}\textrm{C}\mathrm{ to +850}\textrm{C}\mathrm{ (I82C52)
TA =-550}\textrm{C}\mathrm{ to +1250}\textrm{C}\mathrm{ (M82C52)
```

Timing Requirements and Responses

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (1) TSVCTL | Select Setup to Control Leading Edge | 30 |  | ns |  |
| (2) TCTHSX | Select Hold From Control Trailing Edge | 50 |  | ns |  |
| (3)TCTLCTH | Control Pulse Width | 150 |  | ns | Control Consists of $\overline{\text { RD }}$ or WR |
| (4)TCTHCTL | Control Disable to Control Enable | 190 |  | ns |  |
| (5) TRLDV | Read Low to Data Valid |  | 120 | ns | 1, See AC Test Circuit |
| (6) TRHDZ | Read Disable | 0 | 60 | ns | 2, See AC Test Circuit |
| (7) TDVWH | Data Setup Time | 50 |  | ns |  |
| (8) TWHDX | Data Hold Time | 20 |  | ns |  |
| (9) FC | Clock Frequency | 0 | 16 | MHz | $\begin{aligned} & \text { TCHCL + TCLCH must } \\ & \text { be } \geqslant 62.5 \mathrm{~ns} \end{aligned}$ |
| (10)TCHCL | Clock High Time | 25 |  | ns |  |
| (11) TCLCH | Clock Low Time | 25 |  | ns |  |
| (12) TR/TF | IX Input Rise/Fall Time (External Clock) |  | tx | ns | $\begin{aligned} & \mathrm{tx} \leqslant \frac{1}{6 \mathrm{FC}} \text { or } 50 \mathrm{~ns} \\ & \text { whichever is smaller } \end{aligned}$ |
| (13) TFCO | Clock Output Fall Time |  | 15 | ns | $\mathrm{CL}=50 \mathrm{pt}$ |
| (14) TRCO | Clock Output Rise Time |  | 15 | ns | $\mathrm{CL}=50 \mathrm{pf}$ |

## AC Testing Input, Output Waveforms

PROPAGATION DELAY ENABLE/DISABLE DELAY


AC Testing: All input signals (except IX and RST) must switch between VIL -0.4 V and VIH +0.4 V . Input rise and fall times are driven at 1 nsec per volt.
Timing Waveform


## AC Test Circuit



| 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 |

## UART Timing Characterization

All parameters listed in this table were laboratory bench characterized at room temperature on a small sample of parts. No guarantee is implied. The main intent here is to clarify functional operation of the 82C52.

## 82C52 UART TIMING Characterized with IX = External Clock

| SYMBOL | PARAMETER | MIN | MAX | UNTTS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (15)TS1 | CO(IX) Delay from IX | - | 30 | ns | BRSR Bit D7 = 0 (IX Output) |
| (16)TS2 | CO(BRG) Delay from IX | - | 80 | ns | BRSR Bit D7 = 1 (BRG Output) |
| (17)TCY | CO(BRG) Clock Cycle Time | 62.5 | - | ns | BRSR Bit D7 = 1 (BRG Output), Note 1 |
| (18)TDTX | SDO Delay from CO(BRG) Low | - | 30 | ns | Note 2 |
| (19)TWLTL | WR Low to TBRE Low | - | 50 | ns | Note 3 |
| (20)TCLTH | CO(BRG) Low to TBRE High | - | 50 | ns | Notes 3, 4 |
| (21)TIHF | INTR High on Flag | $\bullet$ | 50 | ns | Note5A, 5B |
| (22)TIHM | INTR High on MS | - | 50 | ns | Note 5 |
| (23)TRLIL | $\overline{\text { RD Low to INTR Low }}$ | - | 60 | ns |  |
| (24)TCTHX | CTS High to Disable Transmit | $4 T C Y+10$ | - | ns | TBR Full, Note 6 |
| (25)TDRH | CO(BRG) Low to DR High | - | 40 | ns | Note 7 |
| (26)TRLDL | $\overline{\text { RD Low to DR Low }}$ | - | 50 | ns | Note 7 |
| (27)TWHO | $\overline{\text { WR }}$ High to $\overline{\text { RTS } / \overline{D T R}}$ Active | - | 50 | ns |  |

NOTES:

1. Prescaler rate of divide by 1 , Divisor Select rate of "external" (divide by 1). The Baud Rate Clock (CO-BRG) operates at 16 times the user programmed bit rate. For example, at 1200 baud: $T C Y=1 /(16 \times 1200)=52.1 \mu \mathrm{~s}$.
2. A. With TR (Transmitter Register) initially empty, TDTX occurs from the 5 th falling edge of $\mathrm{CO}(B R G)$ after WR goes high.
B. With TR initially full, TDTX occurs from the trailing edge of the 16 th $C O(B R G)$ in the last Stop bit provided WR went high by the trailing edge of the 12th $\operatorname{CO}(B R G)$ in the last Stop bit.
C. With CTS high (disable transmit) and TBR full, TDTX occurs from the 5 th falling edge of $C O(B R G)$ after CTS goes low.
3. TBRE bit D6 in USR is updated each time TBRE changes state.
4. A. With TR initially empty, TCLTH(TBRE) occurs from the 4th falling edge of $\mathrm{CO}(\mathrm{BRG})$ after $\overline{W R}$ goes high.
B. With TR initially full, TCLTH(TBRE) occurs from the trailing edge of the 15th CO(BRG) in the last Stop bit provided WR went high by the trailing edge of the 12 th $\mathrm{CO}(\mathrm{BRG})$ in the last Stop bit.
C. With CTS high (disable transmit) and TBR full, TCLTH(TBRE) occurs from the 4th falling edge of CO(BRG) after CTS goes low.
5. A. INT on TC. INTEN enabled; USR bit D5(TC) is updated at this time regardless of interrupt configuration.

- INT on TC occurs from the trailing edge of the 11th CO(BRG) in the last Stop bit if TBR empty at that time.
B. INTR on receive flags OE, FE, PE, and RBRK: INTEN enabled; Respective USR bits updated at this time regardless of interrupt configuration.
- INT on OE, FE, PE, RBRK occurs from the trailing edge of the 11th $C O(B R G)$ in the last Stop bit. To avoid OE, $\mathrm{RD}(\mathrm{RBR})$ must go low by the trailing edge of the 8th CO(BRG) in the last Stop bit.
C. INTR on MS: INTEN and MIEN enabled; USR bit D4(MS) is updated at this time regardless of INTEN/MIEN.
- INTR on MS occurs whenever CTS or DSR input changes state.

6. TCTHX is time before end of last Stop bit by which CTS must be inactive (high) to prevent transmission of the character waiting in TBR.
7. DR bit D7 in USR is updated each time DR changes state. TDRH always from trailing edge of 11th $\mathrm{CO}(\mathrm{BRG})$ in last Stop bit.

## UART Timing Characterization (Continued)

CLOCK (IX) AND CO TIMING


TRANSMITTER DATA


RECEIVER DATA


## UART Timing Characterization (Continued)

## TRANSMIT TIMING



CO(BRG)





NOTES:

1. TBRE bit D6 in USR is updated each time TBRE changes state.
2. A. With TR initially empty, TCLTH(TBRE) occurs from the 4th falling edge of $C O(B R G)$ after WR goes high.
B. With TR initially full, TCLTH(TBRE) occurs from the trailing edge of the 15th CO(BRG) in the last Stop bit provided WR went high by the trailing edge of the 12th $C O(B R G)$ in the last Stop bit.
3. A. With TR (Transmitter Register) initially empty, TDTX occurs from the 5th falling edge of $C O(B R G)$ after WR goes high.
B. With TR initially full, TDTX occurs from the trailing edge of the 16th $C O(B R G)$ in the last Stop bit provided WR went
high by the trailing edge of the 12th $C O(B R G)$ in the last Stop bit.
4. TCTHX is time before end of last Stop bit by which CTS must be inactive (high) to prevent transmission of the character waiting in TBR.
5. With CTS high (disable transmit) and TBR full, TCLTH(TBRE) occurs from the 4th falling edge of $C O$ (BRG) after CTS goes low.
6. With CTS high (disable transmit) and TBR full, TDTX occurs from the 5th falling edge of CO(BRG) after CTS goes low.

## UART Timing Characterization (Continued)

## RECEIVE TIMING



OTHER TIMING


NOTES:

1. DR bit D7 in USR is updated each time DR changes state. TDRH always from trailing edge of 11th $C O(B R G)$ in last Stop bit.
2. INTR on receive flags OE, FE, PE, and RBRK: INTEN enabled; Respective USR bits updated at this time regardless of interrupt configuration.

- INT on OE, FE, PE, RBRK occurs from the trailing edge of the 11th CO(BRG) in the last Stop bit. To avoid OE, RD(RBR) must go low by the trailing edge of the 8th $C O(B R G)$ in the last Stop bit.

3. INTR on MS: INTEN and MIEN enabled; USR bit D4(MS) is updated at this time regardless of INTEN/MIEN.

- INTR on MS occurs whenever CTS or DSR input changes state.


## Burn-In Circuits



MR 82C52 CERAMIC LCC


## NOTES:

1. $\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$

GND $=0 \mathrm{~V}$
2. $\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-02 \mathrm{~V}$ to +0.4 V
3. Component Values:
$R 1=1.2 \mathrm{~K} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$R 2=47 \mathrm{~K} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$R 3=10 \mathrm{~K} \Omega, 1 / 4 \mathrm{~W}, 5 \%$
$\mathrm{C} 1=1.0 \mu \mathrm{~F}$ nominal
$\mathrm{C} 2=0.01 \mu \mathrm{~F}$ minimum
$F O=100 \mathrm{KHz} \pm 10 \%, F_{1}=F 0 / 2, F 2=F 1 / 2 \cdot \cdot F_{12}=F_{11} / 2$

## Metallization Topology

## DIE DIMENSIONS:

$178.7 \times 187.0 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Silicon - Aluminum
Thickness: $11 \mathrm{k} \AA \pm 2 k \AA$
GLASSIVATION:
Type: Nitrox
Thickness: 10k $\AA$
DIE ATTACH:
Material: Gold - Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$2.07 \times 10^{4} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout
$82 C 52$


# Programmable Universal Asynchronous Receiver/Transmitter (UART) 

## Features

- Two Operating Modes
- Mode 0 - Functionally Compatible With Industry Types Such as the TR1602A
- Mode 1 - Interfaces Directly With CDP1800-Series Microprocessors Without Additional Components
- Full or Half Duplex Operation
- Parity, Framing and Overrun Error Detection
- Baud Rate
- DC to 200K Bits/s at $V_{\text {DD }}$. . . . . . . . . . . . . . . . . . . . 5V
- DC to 400 K Bits/s at $\mathrm{V}_{\mathrm{DD}}$ .10V
- Fully Programmable with Externally Selectable Word Length (5-8 Bits), Parity Inhibit, Even/Odd Parity, and $1,1 \frac{1}{2}$, or 2 Stop Bits
- False Start Bit Detection


## Ordering Information

| PACKAGE | TEMP RANGE | 5V/200K BAUD | 10V/400K <br> BAUD |
| :--- | :--- | :--- | :---: |
| Plastic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1854ACE | CDP1854AE |
|  |  | CDP1854ACEX | CDP1854AEX |
| PLCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1854ACQ | CDP1854AQ |
| Ceramic DIP <br> Burn-In <br> 883B | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1854ACD | CDP1854AD |
|  |  | CDP1854ACDX | - |

*Respective specifications are included at the end of this data sheet.

## Description

The CDP1854A and CDP1854AC are silicon-gate CMOS Universal Asynchronous Receiver/Transmitter (UART) circuits. They are designed to provide the necessary formatting and control for interfacing between serial and parallel data. For example, these UARTs can be used to interface between a peripheral or terminal with serial $1 / O$ ports and the 8 -bit CDP1800-series microprocessor parallel data bus system. The CDP1854A is capable of full duplex operation, i.e., simultaneous conversion of serial input data to parallel output data and parallel input data to serial output data.

The CDP1854A UART can be programmed to operate in one of two modes by using the mode control input. When the input is high (MODE $=1$ ), the CDP1854A is directly compatible with the CDP1800-series microprocessor system without additional interface circuitry. When the mode input is low (MODE = 0 ), the device is functionally compatible with industry standard UART's such as the TR1602A. It is also pin compatible with these types, except that pin 2 is used for the mode control input instead of a $\mathrm{V}_{\mathrm{GG}}=-12 \mathrm{~V}$ supply connection.

The CDP1854A and the CDP1854AC are functionally identical. The CDP1854A has a recommended operating voltage range of 4 V to 10.5 V , and the CDP1854AC has a recommended operating voltage range of 4 V to 6.5 V .

The CDP1854A and CDP1854AC are supplied in hermetic 40 lead dual-in-line ceramic packages ( $D$ suffix), in 40 lead dual-in-line plastic packages ( $E$ suffix), and in 44 lead plastic chip carrier packages (Q suffix). The CDP1854AC is also available in chip form ( H suffix).

## 5

CMOS DATA
COMMUNICATIONS



Fig. 1 - Mode 1 block diagram (CDP1800-series microprocessor compatible).

Maximum Ratings, Absolute Maxımum Values

| DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ : (Voltages Referenced to $\mathrm{V}_{\text {SS }}$ Terminal) |  |
| :---: | :---: |
| CDP1854A | 0.5 V to +11 V |
| CDP1854AC | 0.5V to +7V |
| Input Voltage Range, All inputs . . . . . . . . . . . . . . . . . 0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |  |
| DC Input Current, any One Input | $\pm 10 \mathrm{~mA}$ |
| Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ ) |  |
| $T_{A}=-40$ to $+60^{\circ} \mathrm{C}$ (Package Type E) . . . . . . . . . . . . . . . . . . 500 mW <br> $\mathrm{T}_{\mathrm{A}}=+60$ to $+85^{\circ} \mathrm{C}$ (Package Type E) . . . . . . . . . Derate Linearly at |  |
|  |  |
| $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |  |
| $T_{A}=-55$ to $+100^{\circ} \mathrm{C}$ (Package Type D) . . . . . . . . . . . . . . . . 500 mW $T_{A}=+100$ to $+125^{\circ} \mathrm{C}$ (Package Type D). . . . . . . Derate Linearly at |  |
|  |  |
| $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |  |
| $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type Q) | . 500 |

Device Dissipation Per Output Transistor $T_{A}=$ Full Package Temperature Range 100 mW Operating Temperature Range ( $\mathrm{T}_{\mathrm{A}}$ )
(Package Type D. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
(Package Type E and Q
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stg }}$ ) $\ldots \ldots \ldots \ldots . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temperature (During Soldering): At distance $1 / 16 \pm 1 / 32 \mathrm{In}$.
( $1.59 \pm 0.79 \mathrm{~mm}$ ) from case for 10 s max
$+265^{\circ} \mathrm{C}$
*Printed circuit board mount: $57 \mathrm{~mm} \times 57 \mathrm{~mm}$ minımum area $\times 1.6 \mathrm{~mm}$ thick $\mathrm{G}_{10}$ epoxy glass, or equivalent

STATIC ELECTRICAL CHARACTERISTICS at TA $_{A}=\mathbf{- 4 0}$ to $+85^{\circ} \mathrm{C}$, unless otherwise noted.

| CHARACTERISTIC | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $v_{0}$(V) | VIN <br> (V) | VDD <br> (V) | CDP1854A |  |  | CDP1854AC |  |  |  |
|  |  |  |  | Min. | Typ. ${ }^{\text {a }}$ | Max. | Min. | Typ.* | Max. |  |
| Quiescent Device Current, IDD | - | $\begin{gathered} 0,5 \\ 0,10 \\ \hline \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{gathered} 0.01 \\ 1 \\ \hline \end{gathered}$ | $\begin{gathered} \hline 50 \\ 200 \\ \hline \end{gathered}$ | - | 0.02 <br> - | $200$ | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current, IOL (Except pins 24 and 25) | $\begin{aligned} & 0.4 \\ & 0.5 \\ & \hline \end{aligned}$ | $\begin{array}{\|c} 0,5 \\ 0,10 \\ \hline \end{array}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 1 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | - | 1 - | 2 | - | mA |
| Output High Drive (Source) Current, IOH | $\begin{aligned} & 4.6 \\ & 9.5 \end{aligned}$ | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{array}{\|c\|} \hline-0.55 \\ -1.3 \end{array}$ | $\begin{array}{\|} -1.1 \\ -2.6 \end{array}$ | $-$ | $\begin{gathered} -0.55 \\ - \\ \hline \end{gathered}$ | $\begin{gathered} \hline-1.1 \\ - \end{gathered}$ | - | mA |
| Output Low Drive (Sink) Current, IOL Pins 24 and 25 | $\begin{aligned} & 0.4 \\ & 0.5 \end{aligned}$ | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 1.6 \\ & 32 \end{aligned}$ | $\begin{gathered} 3.5 \\ 7 \end{gathered}$ | - | $1.6$ | $3.5$ | $-$ | mA |
| Output Voltage Low-Level, $\mathrm{V}_{\mathrm{OL}}{ }^{*}$ | - | $\begin{gathered} 0,5 \\ 0,10 \\ \hline \end{gathered}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{aligned} & 0 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0.1 \\ & 0.1 \\ & \hline \end{aligned}$ | - | 0 | 0.1 - |  |
| Output Voltage High-Level, $\mathrm{VOH}^{*}$ | - | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 4.9 \\ & 9.9 \end{aligned}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | 4.9 | 5 | - |  |
| Input Low Voltage, VIL | $\begin{aligned} & 0.5,4.5 \\ & 0.5,9.5 \end{aligned}$ | $-$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | - | $\begin{gathered} 1.5 \\ 3 \\ \hline \end{gathered}$ | - | - | 1.5 | V |
| Input High Voltage, $\mathrm{V}_{1} \mathrm{H}$ | $\begin{aligned} & 0.5,4.5 \\ & 0.5,9.5 \end{aligned}$ | $-$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 3.5 \\ 7 \end{gathered}$ | - | - | 3.5 - | - | - | $\checkmark$ |
| Input Current, IIN | $-$ | $\begin{array}{\|c\|} \hline 0,5 \\ 0,10 \\ \hline \end{array}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | - | $\begin{array}{r}  \pm 1 \\ \pm 2 \\ \hline \end{array}$ | - | - | $\pm 1$ | $\mu \mathrm{A}$ |
| 3-State Output Leakage Current, IOUT | $\begin{gathered} \hline 0,5 \\ 0,10 \\ \hline \end{gathered}$ | $\begin{array}{\|c\|} \hline 0,5 \\ 0,10 \\ \hline \end{array}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | - | - | $\begin{gathered} \pm 1 \\ \pm 10 \\ \hline \end{gathered}$ | - | - | $\pm 1$ | $\mu \mathrm{A}$ |
| Operating Current, IDD1 ${ }^{\text {\# }}$ | $-$ | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $-$ | $\begin{gathered} 1.5 \\ 6 \end{gathered}$ | $-$ | - | $1.5$ | - | mA |
| Input Capacitance, $\mathrm{ClN}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance, COUT | - | - | - | - | 10 | 15 | - | 10 | 15 | pF |

- Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} . \quad * \mathrm{IOL}^{2}=1 \mathrm{OH}=1 \mu \mathrm{~A}$.
\# Operating current is measured at 200 kHz for $\mathrm{V}_{D D}=5 \mathrm{~V}$ and 400 kHz for $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}$ in a CDP1800-series microprocessor system, with open outputs.


## RECOMMENDED OPERATING CONDITIONS at TA=Full Package Temperature Range

For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | CONDITIONS | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{V}_{\mathbf{D D}}$$\mathbf{v}$ | CDP1854A |  | CDP1854AC |  |  |
|  |  | Min. | Max. | Min. | Max. |  |
| DC Operating-Voltage Range | - | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | - | VSS | VDD | $\mathrm{V}_{\text {SS }}$ | VDD | V |
| Baud Rate (Receive or Transmit) | 5 | - | 200 | - | 200 | K bits |
| Baud Rate (Receive or Transmit) | 10 | - | 400 | - | - | /sec |

Functional Definitions for CDP1854A Terminals Mode 1

## CDP1800-Series Microprocessor Compatible

SIGNAL: FUNCTION
VDD:
Positive supply voltage
MODE SELECT (MODE):
A high-level voltage at this input selects CDP1800-series microprocessor Mode operation.
$V_{\text {Ss: }}$
Ground
$\overline{\text { CHIP SELECT } 2}$ ( $\overline{\mathrm{CS} 2):}$
A low-level voltage at this input together with CS1 and CS3 selects the CDP1854A UART.
RECEIVER BUS (R BUS 7 - R BUS 0):
Receiver parallel data outputs (may be externally connected to corresponding transmitter bus terminals).
$\overline{\text { INTERRUPT }}$ (INT):
A low-level voltage at this output indicates the presence of one or more of the interrupt conditions listed in Table I.
FRAMING ERROR (FE):
A high-level voltage at this output indicates that the received character has no valid stop bit, i.e., the bit following the parity bit (if programmed) is not a high-level voltage. This output is updated each time a character is transferred to the Receiver Holding Register.
PARITY ERROR or OVERRUN ERROR (PE/OE):
A high-level voltage at this output indicates that either the PE or OE bit in the Status Register has been set (see Status Register Bit Assignment, Table II.
REGISTER SELECT (RSEL):
This input is used to choose either the Control/Status Registers (high input) or the transmitter/receiver data registers (low input) according to the truth table in Table III.
RECEIVER CLOCK (RCLOCK):
Clock input with a frequency 16 times the desired receiver shift rate.
TPB:
A positive input pulse used as a data load or reset strobe.
$\overline{\text { DATA AVAILABLE (DA): }}$
A low-level voltage at this output indicates that an entire character has been received and transferred to the Receiver Holding Register.
SERIAL DATA IN (SDI):
Serial data received on this input line enters the Receiver Shift Register at a point determined by the character length. A high-level input voltage must be present when data is not being received.
$\overline{\text { CLEAR (CLEAR): }}$
A low-level voltage at this input resets the Interrupt FlipFlop, Receiver Holding Register, Control Register, and Status Register, and sets SERIAL DATA OUT (SDO) high.
$\overline{\text { TRANSMITTER HOLDING REGISTER EMPTY (THRE): }}$
A low-level voltage at this output indicates that the Transmitter Holding Register has transferred its contents to the Transmitter Shift Register and may be reloaded with a new character.
CHIP SELECT 1 (CS1):
A high-level voltage at this input together with $\overline{\mathrm{CS} 2}$ and CS3 selects the UART.
REQUEST TO SEND (RTS):
This output signal tells the peripheral to get ready to receive data. CLEAR TO SEND (CTS) is the response from the peripheral. RTS is set to a low-level voltage when data is latched in the Transmitter Holding Register or TR is set high, and is reset high when both the Transmitter Holding Register and Transmitter Shift Register are empty and TR is low.

SERIAL DATA OUTPUT (SDO):
The contents of the Transmitter Shift Register [start bit, data bits, parity bit, and stop bit(s)] are serially shifted out on this output. When no character is being transmitted, a high level is maintained. Start of transmission is defined as the transition of the start bit from a high-level to a low-level output voltage.
TRANSMITTER BUS (T BUS 0-T BUS 7):
Transmitter parallel data input. These may be externally connected to corresponding Receiver bus terminals.

## RD/WR:

A low-level voltage at this input gates data from the transmitter bus to the Transmitter Holding Register or the Control Register as chosen by register select. A high-level voltage gates data from the Receiver Holding Register or the Status Register, as chosen by register select, to the receiver bus.

CHIP SELECT 3 (CS3):
With high-level voltage at this input together with CS1 and $\overline{\text { CS2 }}$ selects the UART.
$\overline{\text { PERIPHERAL STATUS INTERRUPT (PSI): }}$
A high-to-low transition on this input line sets a bit in the Status Register and causes an INTERRUPT (INT=low).

## EXTERNAL STATUS ( $\overline{E S}$ ):

A low-level voltage at this input sets a bit in the Status Register.
$\overline{\text { CLEAR TO SEND }} \overline{\text { (CTS })}$ :
When this input from peripheral is high, transfer of a character to the Transmitter Shift Register and shifting of serial data out is inhibited.
TRANSMITTER CLOCK (TCLOCK):
Clock input with a frequency 16 times the desired transmitter shift rate.

Table I - Interrupt Set and Reset Conditions

| SET* (INT = LOW) | RESET (INT = HIGH) |  |
| :---: | :--- | :--- |
| CAUSE | CONDITION | TIME |
| DA <br> (Receipt of data) | Read of data | TPB leading edge |
| THRE <br> (Ability to reload) | Read of status or <br> write of character | TPB leading edge |
| THRE $\cdot$ TSRE <br> (Transmitter done) | Read of status or <br> write of character | TPB leading edge |
| $\overline{\text { PSI }}$ <br> (Negative edge) | Read of status | TPB trailing edge |
| $\overline{\text { CTS }}$ | Read of status | TPB leading edge |
| (Positive edge when THRE $\cdot$ TSRE) |  |  |

*Interrupts will occur only after the IE bit in the Control Register (see Table IV) has been set

- THRE will cause an interrupt only after the TR bit in the Control Register (see Table IV) has been set.

Table II - Status Register Bit Assignment

| Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Signal | THRE | TSRE | PSI | ES | FE | PE | OE | DA |
| Also Available at Terminal | $22^{*}$ | - | - | - | 14 | 15 | 15 | $19^{*}$ |

*Polarity reversed at output terminal.

## Bit Signal: Function

0-DATA AVAILABLE (DA):
When set high, this bit indicates that an entire character has been received and transferred to the Receiver Holding Register. This signal is also available at Term. 19 but with its polarity reversed.

## 1-OVERRUN ERROR (OE):

When set high, this bit indicates that the Data Available bit was not reset before the next character was transferred to the Receiver Holding Register. This signal OR'ed with PE is output at Term. 15.
2-PARITY ERROR (PE):
When set high, this bit indicates that the received parity bit does not compare to that programmed by the EVEN PARITY ENABLE (EPE) control. This bit is updated each time a character is transferred to the Receiver Holding Register. This signal OR'ed with OE is output at Term. 15.

## 3-FRAMING ERROR (FE):

When set high, this bit indicates that the received character has no valid stop bit, i.e., the bit following the parity bit (if programmed) is not a high-level voltage. This bit is updated each time a character is transferred to the Receiver Holding Register. This signal is also available at Term. 14.

4-EXTERNAL STATUS (ES):
This bit is set high by a low-level input at Term. 38 (ES).
5-PERIPHERAL STATUS INTERRUPT (PSI):
This bit is set high by a high-to-low voltage transition of Term. 37 (PSI). The INTERRUPT output (Term. 13) is also asserted (INT=low) when this bit is set.
6-TRANSMITTER SHIFT REGISTER EMPTY (TSRE):
When set high, this bit indicates that the Transmitter Shift Register has completed serial transmission of a full character including stop bit(s). It remains set until the start of transmission of the next character.
7-TRANSMITTER HOLDING REGISTER EMPTY (THRE): When set high, this bit indicates that the Transmitter Holding Register has transferred its contents to the Transmitter Shift Register and may be reloaded with a new character. Setting this bit also sets the THRE output (Term. 22) low and causes an INTERRUPT (INT=low), if TR is high.

## Description of Mode 1 Operation CDP1800-Series Microprocessor Compatible (Mode Input=VDD)

## 1. Initialization and Controls

In the CDP1800-series microprocessor compatible mode, the CDP1854A is configured to receive commands and send status via the microprocessor data bus. The register connected to the transmitter bus or the receiver bus is determined by the RD/WR and RSEL inputs as follows:

Table III - Register Selection Summary

| RSEL | RD/WR | Function |
| :---: | :---: | :--- |
| Low | Low | Load Transmitter Holding Register from <br> Lransmitter Bus |
| Low | High | Read Receiver Holding Register from <br> Receiver Bus |
| High | Low | Hoad Control Register from Transmitter <br> Hus |
| Read Status Register from Receiver Bus |  |  |

In this mode the CDP1854A is compatible with a bidirectional bus system. The receiver and transmitter buses are connected to the bus. CDP1800-series microprocessor I/O control output signals can be connected directly to the CDP1854A inputs as shown in Fig. 2. The CLEAR input is pulsed, resetting the Control, Status, and Receiver Holding Registers and setting SERIAL DATA OUT (SDO) high. The Control Register is loaded from the Transmitter Bus in order to determine the operating configuration for the UART. Data is transferred from the Transmitter Bus inputs to the Control Register during TPB when the UART is selected (CS1. $\overline{\text { CS2 }} \cdot \mathrm{CS} 3=1$ ) and the Control Register is designated (RSEL=H, RD/ $\overline{W R}=\mathrm{L}$ ). The CDP1854A also has a Status Register which can be read onto the Receiver Bus (R BUS 0-R BUS 7) in order to determine the status of the UART. Some of these status bits are also available at separate terminals as indicated in Table II.

## 2. Transmitter Operation

Before beginning to transmit, the TRANSMIT REQUEST (TR) bit in the Control Register (see bit assignment, Table IV) is set. Loading the Control Register with TR=1 (bit $7=$ high) inhibits changing the other control bits. Therefore two loads are required: one to format the UART, the second to set TR. When TR has been set, a TRANSMITTER HOLDING REGISTER EMPTY (THRE) interrupt will occur, signalling the microprocessor that the Transmitter Holding Register is empty and may be loaded. Setting TR also causes assertion of a low-level on the REQUEST TO SEND (RTS) output to the peripheral. It is not necessary to set TR for proper operation for the UART. If desired, it can be used to enable THRE interrupts and to generate the $\overline{R T S}$ signal. The Transmitter Holding Register is loaded from the bus by TPB during execution of an output instruction. The CDP1854A is selected by CS1 • CS2 - CS3=1, and the Holding Register is selected by RSEL=L and RD/ $\overline{W R}=L$. When the CLEAR TO SEND (CTS) input, which can be connected to a peripheral device output, goes low, the Transmitter Shift Register will be loaded from the Transmitter Holding Register and data transmission will begin. If $\overline{\text { CTS }}$ is always low, the Transmitter Shift Register will be loaded on the first high-to-low edge of the clock which occurs at least $1 / 2$ clock period after the trailing edge of TPB and transmission of a start bit will occur $1 / 2$ clock period later (see Fig. 3). Parity (if programmed) and stop bit(s) will be transmitted following the last data bit. If the word length selected is less than 8 bits, the most significant unused bits in the transmitter shift register will not be transmitted.

One transmitter clock period after the Transmitter Shift Register is loaded from the Transmitter Holding Register, the THRE signal will go low and an interrupt will occur (INT goes low). The next character to be transmitted can then be loaded into the Transmitter Holding Register for transmission with its start bit immediately following the last stop bit of the previous character. This cycle can be repeated until the last character is transmitted, at which time a final THRE•TSRE interrupt will occur. This interrupt signals the microprocessor that TR can be turned off. This is done by reloading the original control byte in the Control Register with the TR bit $=0$, thus terminating the REQUEST TO SEND (RTS) signal.
SERIAL DATA OUT (SDO) can be held low by setting the BREAK bit in the Control Register (see Table IV). SDO is held low until the BREAK bit is reset.


Fig. 2 - Recommended CDP1800-series connectıon, Mode 1 (non-interrupt driven system).

## 3. Receiver Operation

The receive operation begins when a start bit is detected at the SERIAL DATA IN (SDI) input. After detection of the first high-to-low transition on the SDI line, a valid start bit is verified by checking for a low-level input 7-1/2 receiver clock periods later. When a valid start bit has been verified, the following data bits, parity bit (if programmed) and stop bit(s) are shifted into the Receiver Shift Register by clock pulse 7-1/2 in each bit time. The parity bit (if programmed) is checked and receipt of a valid stop bit is verified. On count $7-1 / 2$ of the first stop bit, the received data is loaded into the Receiver Holding Register. If the word length is less than 8 bits, zeros (low output level) are loaded into the unused most significant bits. If DATA AVAILABLE (DA) has not been reset by the time the Receiver Holding Register is loaded, the OVERRUN ERROR (OE) status bit is set. One half clock period later, the PARITY ERROR (PE) and FRAMING ERROR (FE) status bits become valid for the character in the Receiver Holding Register. At this time, the Data Available status bit is also set and the DATA AVAILABLE (DA) and INTERRUPT (INT) outputs go low, signalling the microprocessor that a received character is
ready. The microprocessor responds by executing an input instruction. The UART's 3 -state bus drivers are enabled when the UART is selected (CS1 $\cdot \overline{\mathrm{CS} 2} \cdot \mathrm{CS3}=1$ ) and $R D / \overline{W R}=$ high. Status can be read when $R S E L=h i g h$. Data is read when RSEL=low. When reading data, TPB latches data in the microprocessor and resets DATA AVAILABLE $\overline{(D A)}$ in the UART. The preceding sequence is repeated for each serial character which is received from the peripheral.

## 4. Peripheral Interface

In addition to serial data in and out, four signals are
provided for communication with a peripheral. The REQUEST TO SEND (RTS) output signal alerts the peripheral to get ready to receive data. The CLEAR TO SEND (CTS) input signal is the response, signalling that the peripheral is ready. The EXTERNAL STATUS (ES) input latches a peripheral status level, and the PERIPHERAL STATUS INTERRUPT (PST) input senses a status edge (high-to-low) and also generates an interrupt. For example, the modem DATA CARRIER DETECT line could be connected to the $\overline{\text { PSI input on the UART in order to signal }}$ the microprocessor that transmission failed because of loss of the carrier on the communications line. The PSI and ES bits are stored in the Status Register (see Table II).

Table IV - Control Register Bit Assignment

| BIt | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Signal | TR | BREAK | IE | WLS2 | WLS1 | SBS | EPE | PI |

## Bit Signal: Function

O-PARITY INHIBIT (PI):
When set high parity generation and verification are inhibited and the PE Status bit is held low. If parity is inhibited the stop bit(s) will immediately follow the last data bit on transmission, and EPE is ignored.
1-EVEN PARITY ENABLE (EPE):
When set high, even parity is generated by the transmitter and checked by the receiver. When low, odd parity is selected.
2-STOP BIT SELECT (SBS):
See table below.
3-WORD LENGTH SELECT 1 (WLS1):
See table below.
4-WORD LENGTH SELECT 2 (WLS2):
See table below.

## 5-INTERRUPT ENABLE (IE):

When set high THRE, DA, THRE - TSRE, CTS, and PSI interrupts are enabled (see Interrupt Conditions, Table I).
6-TRANSMIT BREAK (BREAK):
Holds SDO low when set. Once the break bit in the control register has been set high, SDO will stay low until the break bit is reset low and one of the following occurs: CLEAR goes low; $\overline{\text { CTS }}$ goes high; or a word is transmitted. (The transmitted word will not be valid since there can be no start bit if SDO is already low. SDO can be set high without intermediate transitions by transmitting a word consisting of all zeros).
7-TRANSMIT REQUEST (TR):
When set high, $\overline{\text { RTS }}$ is set low and data transfer through the transmitter is initiated by the initial THRE interrupt. (When loading the Control Register from the bus, this (TR) bit inhibits changing of other control flip-flops).

| Bit 4 | Bit 3 | Bit 2 |  |
| :---: | :---: | :---: | :---: |
| WLS2 | WLS1 | SBS | Function |
| 0 | 0 | 0 | 5 data bits, 1 stop bit |
| 0 | 0 | 1 | 5 data bits, 1.5 stop bits |
| 0 | 1 | 0 | 6 data bits, 1 stop bit |
| 0 | 1 | 1 | 6 data bits, 2 stop bits |
| 1 | 0 | 0 | 7 data bits, 1 stop bit |
| 1 | 0 | 1 | 7 data bits, 2 stop bits |
| 1 | 1 | 0 | 8 data bits, 1 stop bit |
| 1 | 1 | 1 | 8 data bits, 2 stop bits |

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L}=100 \mathrm{pF}$, see Fig. 3.

| CHARACTERISTIC |  | VDD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1854A |  | CDP1854AC |  |  |
|  |  |  | Typ. ${ }^{+}$ | Max.* | Typ. ${ }^{+}$ | Max.* |  |
| Transmitter Timing - Mode 1 |  |  |  |  |  |  |  |
| Minimum Clock Period | ${ }^{\text {t }} \mathrm{CC}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 250 \\ & 125 \end{aligned}$ | $\begin{aligned} & 310 \\ & 155 \end{aligned}$ | $250$ | $310$ | ns |
| Minimum Pulse Width: <br> Clock Low Level | ${ }^{\text {t }} \mathrm{CL}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 100 \\ 75 \end{gathered}$ | $\begin{aligned} & 125 \\ & 100 \end{aligned}$ | $100$ | $125$ | ns |
| Clock High Level | ${ }^{t} \mathrm{CH}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} 100 \\ 75 \\ \hline \end{gathered}$ | $\begin{aligned} & 125 \\ & 100 \\ & \hline \end{aligned}$ | $100$ | $125$ | ns |
| TPB | t't | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} 100 \\ 50 \\ \hline \end{gathered}$ | $\begin{aligned} & 150 \\ & 75 \\ & \hline \end{aligned}$ | $100$ | $150$ | ns |
| Minimum Setup Time. TPB to Clock | tTc | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} 175 \\ 90 \\ \hline \end{gathered}$ | $\begin{aligned} & 225 \\ & 150 \\ & \hline \end{aligned}$ | 175 | $225$ | ns |
| Propagation Delay Time: <br> Clock to Data Start Bit | ${ }^{t} \mathrm{CD}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | $\begin{aligned} & 450 \\ & 225 \\ & \hline \end{aligned}$ | 300 - | 450 - | ns |
| TPB to $\overline{\text { THRE }}$ | tTTH | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | 200 <br> - | 300 <br> - | ns |
| Clock to $\overline{\text { THRE }}$ | tCTH | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | 200 - | $300$ | ns |

${ }^{\dagger}$ Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages.
*Maximum limits of mınimum characteristics are the values above which all devices function.


Fig. 3 - Transmitter timing diagram - Mode 1.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathbf{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\text {IL }}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L}=100$ pF, see Fig. 4.

| CHARACTERISTIC |  | VD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1854A |  | CDP1854AC |  |  |
|  |  |  | Typ. ${ }^{+}$ | Max.* | Typ. ${ }^{+}$ | Max.* |  |
| Receiver Timing - Mode 1 |  |  |  |  |  |  |  |
| Minimum Clock Period | ${ }^{t} \mathrm{CC}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 250 \\ & 125 \end{aligned}$ | $\begin{aligned} & 310 \\ & 155 \end{aligned}$ | $250$ | $310$ | ns |
| Minımum Pulse Width: Clock Low Level | ${ }^{\text {t }} \mathrm{CL}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 100 \\ 75 \end{gathered}$ | $\begin{aligned} & 125 \\ & 100 \end{aligned}$ | $\begin{gathered} 100 \\ - \end{gathered}$ | $125$ | ns |
| Clock High Level | ${ }^{t} \mathrm{CH}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 100 \\ & 75 \end{aligned}$ | $\begin{aligned} & 125 \\ & 100 \\ & \hline \end{aligned}$ | $100$ | $125$ | ns |
| TPB | ${ }^{\text {t }}$ T | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} 100 \\ 50 \end{gathered}$ | $\begin{gathered} 150 \\ 75 \\ \hline \end{gathered}$ | $100$ | 150 | ns |
| Mınımum Setup Time: Data Start Bit to Clock | tDC | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 100 \\ 50 \end{gathered}$ | $\begin{aligned} & 150 \\ & 75 \end{aligned}$ | 100 <br> - | 150 | ns |
| Propagation Delay Time: TPB to DATA AVAILABLE | tTDA | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 220 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 325 \\ & 175 \\ & \hline \end{aligned}$ | 220 | $325$ | ns |
| Clock to DATA AVAILABLE | ${ }^{t}$ CDA | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 220 \\ & 110 \end{aligned}$ | $\begin{aligned} & 325 \\ & 175 \end{aligned}$ | $220$ | 325 <br> - | ns |
| Clock to Overrun Error | ${ }^{\text {t COE }}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 210 \\ & 105 \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | $210$ | $300$ | ns |
| Clock to Parity Error | ${ }^{\text {t }}$ CPE | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 240 \\ & 120 \\ & \hline \end{aligned}$ | $\begin{aligned} & 375 \\ & 175 \\ & \hline \end{aligned}$ | $240$ $-$ | $375$ | ns |
| Clock to Framing Error | ${ }^{\text {t }}$ CFE | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | $\begin{gathered} 200 \\ - \end{gathered}$ | $\begin{gathered} 300 \\ - \end{gathered}$ | ns |

[^15]Fig. 4 - Mode 1 receiver timing diagram.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L}=100 \mathrm{pF}$, see Fig. 5.

| CHARACTERISTIC |  | VDD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1854A |  | CDP1854AC |  |  |
|  |  |  | Typ. $\dagger$ | Max.* | Typ. ${ }^{+}$ | Max.* |  |
| CPU Interface - WRITE Timing - Mode 1 |  |  |  |  |  |  |  |
| Minimum Pulse Width: TPB | tTT | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} 100 \\ 50 \\ \hline \end{gathered}$ | $\begin{gathered} 150 \\ 75 \\ \hline \end{gathered}$ | $100$ | $150$ | ns |
| Minimum Setup Time: RSEL to Write | trsw | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 50 \\ & 25 \end{aligned}$ | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | 50 | 75 <br> - | ns |
| Data to Write | tow | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & -30 \\ & -15 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | -30 <br> - | 0 | ns |
| Minimum Hold Time: RSEL after Write | tWRS | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 50 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | 50 | 75 | ns |
| Data after Write | tWD | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 75 \\ & 40 \end{aligned}$ | $\begin{aligned} & 125 \\ & 60 \end{aligned}$ | 75 - | $125$ | ns |

${ }^{\dagger}$ Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages.
*Maximum limitś of minimum characteristics are the values above which all devices function.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L}=100 \mathrm{pF}$, see Fig. 6.


[^16]

FIg. 5 - Mode 1 CPU interface (WRITE) tıming diagram.


* READ IS the overlap of CSI, CS3, RD/ $\overline{\mathrm{WR}}=1$ and $\overline{\mathrm{CS2}}=0$

92CM-31881
Fig. 6 - Mode 1 CPU interface (READ) tıming diagram.


Fig. 7 - Mode 0 block dıagram (ındustry standard compatıble)

## Functional Definitions for CDP1854A Terminals Standard Mode 0 <br> SIGNAL: FUNCTION

VDD:
Positive supply voltage.
MODE SELECT (MODE):
A low-level voltage at this input selects Standard Mode 0 Operation.

## $V_{\text {SS: }}$

Ground.

## RECEIVER REGISTER DISCONNECT (RRD):

A high-level voltage applied to this input disconnects the Receiver Holding Register from the Receiver Bus.
RECEIVER BUS (R BUS $7-R$ BUS 0):
Receiver parallel data outputs.
PARITY ERROR (PE):
A high-level voltage at this output indicates that the received parity does not compare to that programmed by the EVEN PARITY ENABLE (EPE) control. This output is updated each time a character is transferred to the Receiver Holding Register. PE lines from a number of arrays can be bused together since an output disconnect capability is provided by the STATUS FLAG DISCONNECT (SFD) line.

## FRAMING ERROR (FE):

A high-level voltage at this output indicates that the received character has no valid stop bit, i.e., the bit following the parity bit (if programmed) is not a high-level voltage. This output is updated each time a character is transferred to the Receiver Holding Register. FE lines from a number of arrays can be bused together since an output disconnect capability is provided by the STATUS FLAG DISCONNECT (SFD) line.
OVERRUN ERROR (OE):
A high-level voltage at this output indicates that the DATA AVAILABLE (DA) flag was not reset before the next character was transferred to the Receiver Holding Register. OE lines from a number of arrays can be bused together since an output disconnect capability is provided by the STATUS FLAG DISCONNECT (SFD) line.
STATUS FLAG DISCONNECT (SFD):
A high-level voltage applied to this input disables the 3state output drivers for PE, FE, OE, DA, and THRE, allowing these status outputs to be bus connected.

## RECEIVER CLOCK (RCLOCK):

Clock input with a frequency 16 times the desired receiver shift rate.
$\overline{\text { DATA AVAILABLE RESET }} \overline{(\overline{D A R})}$ :
A low-level voltage applied to this input resets the DA flip-flop.

## DATA AVAILABLE (DA):

A high-level voltage at this output indicates that an entire character has been received and transferred to the Receiver Holding Register.

## SERIAL DATA IN (SDI):

Serial data received at this input enters the receiver shift register at a point determined by the character length. A high-level voltage must be present when data is not being received.

## MASTER RESET (MR):

A high-level voltage at this input resets the Receiver Holding Register, Control Register, and Status Register, and sets the serial data output high.

TRANSMITTER HOLDING REGISTER EMPTY (THRE):
A high-level voltage at this output indicates that the Transmitter Holding Register has transferred its contents to the Transmitter Shift Register and may be reloaded with a new character.
TRANSMITTER HOLDING REGISTER LOAD (THRL):
A low-level voltage applied to this input enters the character on the bus into the Transmitter Holding Register. Data is latched on the trailing edge of this signal.
TRANSMITTER SHIFT REGISTER EMPTY (TSRE):
A high-level voltage at this output indicates that the Transmitter Shift Register has completed serial transmission of a full character including stop bit(s). It remains at this level until the start of transmission of the next character.

SERIAL DATA OUTPUT (SDO):
The contents of the Transmitter Shift Register (start bit, data bits, parity bit, and stop bit(s)) are serially shifted out on this output. When no character is being transmitted, a high-level is maintained. Start of transmission is defined as the transition of the start bit from a high-level to a low-level output voltage.
TRANSMITTER BUS (T BUS $0-T$ BUS 7):
Transmitter parallel data inputs.
CONTROL REGISTER LOAD (CRL):
A high-level voltage at this input loads the Control Register with the control bits (PI, EPE, SBS, WLS1, WLS2). This line may be strobed or hardwired to a high-level input voltage.
PARITY INHIBIT (PI):
A high-level voltage at this input inhibits the parity generation and verification circuits and will clamp the PE output low. If parity is inhibited the stop bit(s) will immediately follow the last data bit on transmission.

STOP BIT SELECT (SBS):
This input selects the number of stop bits to be transmitted after the parity bit. A high-level selects two stop bits, a low-level selects one stop bit. Selection of two stop bits with five data bits programmed selects 1.5 stop bits.


92Cs-34506

Fig. 8 - Mode 0 connection diagram.

WORD LENGTH SELECT 2 (WLS2):
WORD LENGTH SELECT 1 (WLS1):
These two inputs select the character length (exclusive of parity) as follows:

| WLS2 | WLS1 | Word Length |
| :---: | :---: | :---: |
| Low | Low | 5 Bits |
| Low | High | 6 Bits |
| High | Low | 7 Bits |
| High | High | 8 Bits |

EVEN PARITY ENABLE (EPE):
A high-level voltage at this input selects even parity to be generated by the transmitter and checked by the receiver. A low-level input selects odd parity.
TRANSMITTER CLOCK (TCLOCK):
Clock input with a frequency 16 times the desired transmitter shift rate.

## Description of Standard Mode 0 Operation (Mode Input=V SS)

## 1. Initialization and Controls

The MASTER RESET (MR) input is pulsed, resetting the Control, Status, and Receiver Holding Registers and setting the SERIAL DATA OUTPUT (SDO) signal high. Timing is generated from the clock inputs, Transmitter Clock (TCLOCK) and Receiver Clock (RCLOCK), at a frequency equal to 16 times the serial data bit rate. When the receiver data input rate and the transmitter data output rate are the same, the TCLOCK and RCLOCK inputs may be connected together. The CONTROL REGISTER LOAD (CRL) input is pulsed to store the control inputs PARITY INHIBIT (PI), EVEN PARITY ENABLE (EPE), STOP BIT SELECT (SBS), and WORD LENGTH SELECTs (WLS1 and WLS2). These inputs may be hardwired to the proper voltage levels ( $V_{S S}$ or $V_{D D}$ ) instead of being dynamically set and CRL may be hardwired to VDD. The CDP1854A is then ready for transmitter and/or receiver operation.

## 2. Transmitter Operation

For the transmitter timing diagram refer to Fig. 10. At the beginning of a typical transmitting sequence the Transmitter Holding Register is empty (THRE is HIGH). A character is transferred from the transmitter bus to the Transmitter
holding Register by applying a low pulse to the $\overline{\text { TRANS }}$ MITTER HOLDING REGISTER LOAD (THRL) input causing THRE to go low. If the Transmitter Shift Register is empty (TSRE is HIGH) and the clock is low, on the next high-tolow transition of the clock the character is loaded into the Transmitter Shift Register preceded by a start bit Serial data transmission begins $1 / 2$ clock period later with a start bit and $5-8$ data bits followed by the parity bit (if programmed) and stop bit(s). The THRE output signal goes high $1 / 2$ clock period later on the high-to-low transition of the clock. When THRE goes high, another character can be loaded into the Transmitter Holding Register for transmission begınnıng with a start bit ımmedıately following the last stop bit of the previous character. This process is repeated until all characters have been transmitted. When transmission is complete, THRE and Transmitter Shift Register Empty (TSRE) will both be high. The format of serial data is shown in Fig. 12 Duration of each serial output data bit is determined by the transmitter clock frequency (fCLOCK) and will be 16/f CLOCK.

## 3. Receiver Operation

The receive operation begins when a start bit is detected at the SERIAL DATA IN (SDI) input. After the detection of a high-to-low transition on the SDI line, a divide-by-16 counter is enabled and a valid start bit is verified by checking for a low-level input 7-1/2 receiver clock periods later. When a valid start bit has been verified, the following data bits, parity bit (if programmed), and stop bit(s) are shifted into the Receiver Shift Register at clock pulse 7-1/2 in each bit time. If programmed, the parity bit is checked, and receipt of a valid stop bit is verified. On count 7-1/2 of the first stop bit, the received data is loaded into the Receiver Holding Register. If the word length is less than 8 bits, zeros (low output voltage level) are loaded into the unused most significant bits. If DATA AVAILABLE (DA) has not been reset by the time the Receiver Holding Register is loaded, the OVERRUN ERROR (OE) signal is raised. One-half clock period later, the PARITY ERROR (PE) and FRAMING ERROR (FE) signals become valid for the character in the Receiver Holding Register The DA signal is also raised at this time. The 3-state output drivers for DA, OE, PE and FE are enabled when STATUS FLAG DISCONNECT (SFD) is low. When RECEIVER REGISTER DISCONNECT (RRD) goes low, the receiver bus 3-state output drivers are enabled and data is available at the RECEIVER BUS (R BUS 0-R BUS 7) outputs. Applying a negative pulse to the DATA AVAILABLE RESET (DAR) resets DA. The preceding sequence of operation is repeated for each serial character received. A receiver timing diagram is shown in Fig. 11.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L}=100 \mathrm{pF}$, see Fig. 9.

| CHARACTERISTIC |  | VDD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1854A |  | CDP1854AC |  |  |
|  |  |  | Typ. ${ }^{+}$ | Max.* | Typ. ${ }^{+}$ | Max.* |  |
| Interface Timing - Mode 0 |  |  |  |  |  |  |  |
| Minimum Pulse Width: CRL |  | $5$ | $100$ | $\begin{gathered} 150 \\ 75 \end{gathered}$ | 100 | 150 | ns |
| Minimum Pulse Width: MR | ${ }^{\text {t MR }}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 400 \\ & 200 \\ & \hline \end{aligned}$ | 200 | $400$ | ns |
| Minimum Setup Time: Control Word to CRL | tCWC | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 40 \\ & 20 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 50 \\ & \hline \end{aligned}$ | 40 | 80 | ns |
| Minimum Hold Time: <br> Control Word after CRL | tcCW | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 100 \\ 50 \end{gathered}$ | $\begin{gathered} 150 \\ 75 \end{gathered}$ | 100 | 150 <br> - | ns |
| Propagation Delay Time: SFD High to SOD | tSFDH | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | 200 | 300 | ns |
| SFD Low to SOD | tSFDL | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 120 \\ & 60 \\ & \hline \end{aligned}$ | 75 | $120$ | ns |
| RRD High to Receiver Register High Impedance | tRRDH | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | 200 | 300 | ns |
| RRD Low to Receiver Register Active | trRDL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 100 \\ 50 \end{gathered}$ | $\begin{gathered} 150 \\ 75 \end{gathered}$ | $\begin{gathered} 100 \\ - \end{gathered}$ | $150$ | ns |

$\dagger$ Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nomınal voltages.
*Maximum lımits of minımum characteristics are the values above which all devices function.


Fig. 9 - Mode 0 interface timing diagram.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L}=100$ pF, see Fig. 10.

| CHARACTERISTIC |  | VDD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1854A |  | CDP1854AC |  |  |
|  |  |  | Typ. ${ }^{+}$ | Max.* | Typ. ${ }^{+}$ | Max.* |  |
| Transmitter Timing - Mode 0 |  |  |  |  |  |  |  |
| Minimum Clock Period | ${ }^{\text {t }} \mathrm{C}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 250 \\ & 125 \end{aligned}$ | $\begin{aligned} & 310 \\ & 155 \end{aligned}$ | 250 | $310$ | ns |
| Minimum Pulse Width: Clock Low Level | ${ }^{\text {t }} \mathrm{CL}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 100 \\ 75 \end{gathered}$ | $\begin{aligned} & 125 \\ & 100 \end{aligned}$ | 100 | $125$ | ns |
| Clock High Level | ${ }^{t} \mathrm{CH}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} 100 \\ 75 \\ \hline \end{gathered}$ | $\begin{aligned} & 125 \\ & 100 \\ & \hline \end{aligned}$ | $100$ | $125$ | ns |
| $\overline{T H R L}$ | tTHTH | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{array}{r} 100 \\ 50 \\ \hline \end{array}$ | $\begin{gathered} 150 \\ 75 \\ \hline \end{gathered}$ | 100 | $150$ | ns |
| Minimum Setup Time: THRL to Clock | tTHC | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 175 \\ 90 \end{gathered}$ | $\begin{aligned} & 275 \\ & 150 \end{aligned}$ | 175 | 275 - | ns |
| Data to $\overline{\text { THRL }}$ | tDT | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} 20 \\ 0 \end{gathered}$ | $\begin{aligned} & 50 \\ & 40 \end{aligned}$ | 20 - | 50 | ns |
| Minimum Hold Time: Data after THRL | tTD | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 80 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 120 \\ & 60 \end{aligned}$ | 80 | 120 | ns |
| Propagation Delay Time: Clock to Data Start Bit | ${ }^{\text {t }}$ CD | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | $\begin{aligned} & 450 \\ & 225 \end{aligned}$ | $300$ | $450$ | ns |
| Clock to THRE | ${ }^{\text {t }} \mathrm{CT}$ | $\begin{gathered} \hline 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | $200$ | $300$ | ns |
| $\overline{\text { THRL }}$ to THRE | tTTHR | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | $200$ | 300 - | ns |
| Clock to TSRE | ttts | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | $200$ $-$ | 300 - | ns |

${ }^{\dagger}$ Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal voltages.
*Maximum limits of minimum characteristics are the values above which all devices function.


* THE HOLDING REGISTER IS LOADED ON THE TRAILING EDGE OF THRL.
** THE TRANSMITTER SHIFT REGISTER, IF EMPTY, IS LOADED ON THE FIRST HIGH-TO-LOW TRANSITION OF THE CLOCK WHICH OCCURS AT LEAST I/2 CLOCK PERIOD ${ }^{+\dagger}$ THCAFTER THE TRAILING EDGE OF THRL, AND TRANSMISSION OF A START BIT OCCURS $1 / 2$ CLOCK PERIOD $+t_{\text {CD }}$ LATER

Fig. 10 - Mode 0 transmitter timing diagram.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}$, $C_{L=100 ~ p F, ~ s e e ~ F i g . ~} 11$.

| CHARACTERISTIC |  | VDD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1854A |  | CDP1854AC |  |  |
|  |  |  | Typ. ${ }^{\text {+ }}$ | Max.* | Typ. ${ }^{+}$ | Max.* |  |
| Receiver Timing - Mode 0 |  |  |  |  |  |  |  |
| Minimum Clock Period | ${ }^{\text {t }} \mathrm{C}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 250 \\ & 125 \end{aligned}$ | $\begin{aligned} & 310 \\ & 155 \end{aligned}$ | $250$ | $310$ | ns |
| Minimum Pulse Width: <br> Clock Low Level | ${ }^{\text {t }} \mathrm{CL}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 100 \\ 75 \end{gathered}$ | $\begin{aligned} & 125 \\ & 100 \\ & \hline \end{aligned}$ | 100 - | 125 - | ns |
| Clock High Level | ${ }^{t} \mathrm{CH}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{gathered} \hline 100 \\ 75 \\ \hline \end{gathered}$ | $\begin{aligned} & \hline 125 \\ & 100 \\ & \hline \end{aligned}$ | 100 | 125 | ns |
| $\overline{\text { DATA AVAILABLE RESET }}$ | tDD | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{array}{r} 50 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 40 \\ & \hline \end{aligned}$ | 50 <br> - | 75 | ns |
| Minimum Setup Time: Data Start Bit to Clock | ${ }^{t} \mathrm{DC}$ | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 100 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 75 \end{aligned}$ | $100$ | $150$ | ns |
| Propagation Delay Time: DATA AVAILABLE RESET to Data Available | tDDA | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 150 \\ 75 \end{gathered}$ | $\begin{aligned} & 225 \\ & 125 \\ & \hline \end{aligned}$ | 150 | 225 | ns |
| Clock to Data Valid | tcDV | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 225 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 325 \\ & 175 \end{aligned}$ | 225 - | 325 - | ns |
| Clock to Data Available | tCDA | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 225 \\ & 110 \end{aligned}$ | $\begin{aligned} & 325 \\ & 175 \\ & \hline \end{aligned}$ | 225 | 325 - | ns |
| Clock to Overrun Error | tCOE | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 210 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | 210 - | 300 | ns |
| Clock to Parity Error | tCPE | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 240 \\ & 120 \\ & \hline \end{aligned}$ | $\begin{aligned} & 375 \\ & 175 \\ & \hline \end{aligned}$ | 240 <br> - | 375 - | ns |
| Clock to Framing Error | tCFE | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | 200 - | 300 <br> - | ns |

${ }^{\dagger}$ Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages.

*Maximum limits of minimum characteristics are the values above which all devices function. <br> $$
92 \mathrm{CM}-31877
$$ <br> \section*{92CM-31877} <br> \section*{92CM-31877}

IF A START BIT OCCURS AT A TIME LESS THAN tDC BEFORE A HIGH-TO-LOW TRANSITION OF THE CLOCK,
THE START BIT MAY NOT BE RECOGNIZED UNTIL THE NEXT HIGH-TO-LOW TRANSITION OF THE CLOCK THE START THE START BIT MAY NOT BE RECOGNIZED UNTIL THE NEXT HIGH-TO-LOW TRANSITION OF THE CLOCK THE STAR
BIT MAY BE COMPLETELY ASYNCHRONOUS WITH THE CLOCK
IF A PENDING DA HAS NOT BEEN CLEARED BY A READ OF THE RECEIVER HOLDING REGISTER BY THE TIME A NEW IF A PENDING DA HAS NOT WO RECEIVER HOLDING REGISTER, THE OE SIGNAL WILL COME TRUE

Fig. 11 - Mode 0 receiver timing diagram.


# High Reliability CMOS Programmable Universal Asynchronous Receiver/Transmitter (UART) 

## Features

- Two Operating Modes
- Mode 0 - Functionally Compatible With Industry Types Such as the TR1602A
- Mode 1 - Interfaces Directly With CDP1800 Series Microprocessors Without Additional Components
- Full or Half-Duplex Operation
- Parity, Framing, and Overrun Error Detection
- Fully Programmable With Externally Selectable Word Length (5-8 Bits), Parity Inhibit, Even/Odd Parity, and $1,1 \frac{1}{2}$, or 2 Stop Bits


## Description

The CDP1854AN3 and CDP1854AC/3 are high reliability silicon gate CMOS Universal Asynchronous Receiver/Transmitter (UART) circuits. They are designed to provide the necessary formatting and control for interfacing between serial and parallel data. For example, these UARTs can be used to interface between a peripheral or terminal with serial I/O ports and the 8-bit CDP1800-series microprocessor parallel data bus system. The CDP1854A 3 is capable of full duplex operation, i.e., simultaneous conversion of serial input data to parallel output data and parallel input data to serial output data.

The CDP1854A/3 UART can be programmed to operate in one of two modes by using the mode control input. When the mode input is high (MODE = 1), the CDP1854A/3 is directly compatible with the CDP1800 series microprocessor system without additional interface circuitry. When the mode input is low (MODE $=0$ ), the device is functionally compatible with industry standard UARTs such as the TR1602A. It is also pin compatible with these types, except that pin 2 is used for the mode control input instead of $\mathrm{V}_{\mathrm{GG}}=-12 \mathrm{~V}$ supply connection.
The CDP1854A/3 and the CDP1854AC/3 are functionally identical. The CDP1854A/3 has a recommended operating voltage range of 4 V to 10.5 V , and the CDP1854AC/3 has a recommended operating voltage range of 4 V to 6.5 V .

The CDP1854A/3 and CDP1854AC/3 are supplied in hermetic 40 lead Dual-In-Line Ceramic Packages (D suffix).

## Pinouts




## MAXIMUM RATINGS, Absolute-Maximum Values

```
DC SUPPLY-VOLTAGE RANGE, (VDo)
    (All voltages referenced to \(\mathrm{V}_{\text {ss }}\) terminal)
    CDP1854A/3
    -05 to +11 V
    CDP1854AC/3
    -05 to +7 V
INPUT VOLTAGE RANGE, ALL INPUTS .. . ... . .. . . . . . . . .. .. ....................... 05 to VDD 05 V
DC INPUT CURRENT, ANY ONE INPUT . . . . . . . . ... .. . . . .... . . . . .. . . .... . . . \(\pm 10 \mathrm{~mA}\)
POWER DISSIPATION PER PACKAGE ( \(P_{D}\) )
    For \(T_{A}=-55\) to \(+100^{\circ} \mathrm{C}\) (PACKAGE TYPE D)
    500 mW
    For \(T_{A}=+100\) to \(+125^{\circ} \mathrm{C}\) (PACKAGE TYPE D) . . . . ... . . . ... Derate Linearly at \(12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}\) to 200 mW
DEVICE DISSIPATION PER OUTPUT TRANSISTOR
    For \(T_{A}=F U L L\) PACKAGE-TEMPERATURE RANGE
    100 mW
OPERATING-TEMPERATURE RANGE ( \(T_{A}\) )
    PACKAGE TYPE D ... .. .... ..................... . . . ................. . . . . . . . . . . . ............................... -55 to \(+125^{\circ} \mathrm{C}\)
STORAGE TEMPERATURE ( \(T_{\text {sıq }}\) ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 to \(+150^{\circ} \mathrm{C}\)
LEAD TEMPERATURE (DURING SOLDERING)
```



STATIC ELECTRICAL CHARACTERISTICS

| CHARACTERISTIC | CONDITIONS |  |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & V_{o} \\ & \text { (V) } \end{aligned}$ | $V_{\text {IN }}$ <br> (V) | $V_{D D}$ <br> (V) | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  | Min. | Max. | Min. | Max. |  |
| Quescent Device Current, $\mathrm{I}_{\text {D }}$ | - | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 500 \\ & 500 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 1000 \\ & 1000 \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current, IoL | $\begin{aligned} & 0.4 \\ & 0.5 \end{aligned}$ | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 0.75 \\ & 1.80 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 0.5 \\ & 1.2 \end{aligned}$ | - | mA |
| Output High Drive (Source) Current, $\mathrm{I}_{\mathrm{OH}}$ | $\begin{aligned} & 46 \\ & 9.5 \end{aligned}$ | $\begin{gathered} 0,5 \\ 0,10 \\ \hline \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - |  |  | $\begin{aligned} & -035 \\ & -070 \\ & \hline \end{aligned}$ | mA |
| Output Voltage Low-Level, $\mathrm{V}_{\text {OL }}{ }^{*}$ | - | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - |  | - | $\begin{aligned} & 02 \\ & 0.2 \end{aligned}$ |  |
| Output Voltage High-Level, $\mathrm{V}_{\mathrm{OH}}{ }^{*}$ | - | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ |  | - | $\begin{aligned} & 4.8 \\ & 9.8 \end{aligned}$ | - |  |
| Input Low Voltage, $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & 0.5,4.5 \\ & 0.5,9.5 \\ & \hline \end{aligned}$ | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{gathered} 1.5 \\ 3 \end{gathered}$ | - | $\begin{gathered} 1.5 \\ 3 \end{gathered}$ |  |
| Input High Voltage, $\mathrm{V}_{1 \text { H }}$ | $\begin{aligned} & 0.5,4.5 \\ & 0.5,9.5 \end{aligned}$ | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 3.5 \\ 7 \end{gathered}$ | - | $\begin{gathered} 3.5 \\ 7 \end{gathered}$ | - |  |
| Input Leakage Current, $\mathrm{I}_{\text {IN }}$ | - | $\begin{gathered} 0,5 \\ 0,10 \\ \hline \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & \pm 1 \\ & \pm 1 \end{aligned}$ | - | $\begin{aligned} & \pm 5 \\ & \pm 5 \end{aligned}$ | $\mu \mathrm{A}$ |
| 3-State Output Leakage Current, Iout | $\begin{gathered} 0,5 \\ 0,10 \end{gathered}$ | $\begin{gathered} 0,5 \\ 0,10 \\ \hline \end{gathered}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\stackrel{-}{-}$ | $\begin{aligned} & \pm 1 \\ & \pm 1 \end{aligned}$ | - | $\begin{aligned} & \pm 10 \\ & \pm 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| Input Capacitance, $\mathrm{C}_{\text {IN }}{ }^{*}$ | - | - | - | - | 10 | - | 10 |  |
| Output Capacitance, Cout* | - | - | - | - | 15 | - | 15 | pF |

*Guaranteed but not tested

RECOMMENDED OPERATING CONDITIONS at $T_{A}=$ Full Package Temperature Range
For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | CONDITIONS | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $V_{D D}$ <br> (V) | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  | Min. | Max. | Min. | Max. |  |
| DC Operating-Voltage Range | - | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | - | $\mathrm{V}_{\text {SS }}$ | $V_{D D}$ | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |
| Baud Rate (Receive or Transmit) | 5 | - | 250 | - | 215 | K bits |
| Baud Rate (Receive or Transmit) | 10 | - | 520 | - | 430 | /sec |

Specifications CDP1854A/3, CDP1854AC/3
Dynamic Electrical Characteristics $t_{r}, t_{f}=15 \mathrm{~ns}, \mathrm{~V}_{I H}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{LL}}=\mathrm{V}_{\mathrm{SS}}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$, see Figure 1

| CHARACTERISTIC |  | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Transmitter Timing - Mode 1 |  |  |  |  |  |  |  |
| Clock Period |  | 5 | 240 | - | 280 | - | ns |
|  | $\mathrm{t}_{\mathrm{cc}}$ | 10 | 120 | - | 145 | - |  |
| Pulse Width: Clock Low Level |  | 5 | 105 | - | 125 | - | ns |
|  | $\mathrm{t}_{\mathrm{CL}}$ | 10 | 55 | - | 65 | - |  |
| Clock High Level |  | 5 | 135 | - | 155 | - | ns |
|  | $\mathrm{t}_{\mathrm{CH}}$ | 10 | 65 | - | 80 | - |  |
| TPB | $\mathrm{t}_{\mathrm{Tt}}$ | 5 | 125 | - | 165 | - | ns |
|  | $t_{\text {TT }}$ | 10 | 70 | - | 80 | - |  |
| Propagation Delay Tıme: Clock to Data Start Bit |  | 5 | - | 425 | - | 485 | ns |
|  | $\mathrm{t}_{\mathrm{CD}}$ | 10 | - | 205 | - | 235 |  |
| TPB to THRE |  | 5 | - | 315 | - | 380 | ns |
|  | $\mathrm{t}_{\text {TTH }}$ | 10 | - | 155 | - | 185 |  |
| Clock to THRE |  | 5 | - | 335 | - | 390 | ns |
|  | $\mathrm{t}_{\text {CTH }}$ | 10 | - | 160 | - | 190 |  |

Dynamic Electrical Characteristics $t_{r} t_{t}=15 n s, V_{H H}=V_{D D}, V_{H L}=V_{S S}, C_{L}=100 \mathrm{pF}$, see Figure 2

| CHARACTERISTIC |  | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Receiver Timing - Mode 1 |  |  |  |  |  |  |  |
| Clock Period | $t_{c c}$ | 5 | 240 | - | 280 | - | ns |
|  | tcc | 10 | 120 | - | 145 | - |  |
| Pulse Width: Clock Low Level |  | 5 | 105 | - | 125 | - | ns |
|  | $\mathrm{t}_{\mathrm{CL}}$ | 10 | 55 | - | 65 | - |  |
| Clock High Level | $\mathrm{t}_{\mathrm{CH}}$ | 5 | 135 | - | 155 | - | ns |
|  | $\mathrm{tcH}^{\text {che }}$ | 10 | 65 | - | 80 | - |  |
| TPB | $\mathrm{t}_{\mathrm{TT}}$ | 5 | 125 | - | 165 | - | ns |
|  | $t_{\text {TT }}$ | 10 | 70 | - | 80 | - |  |
| Setup Time: <br> Data Start Bit to Clock |  | 5 | 105 | - | 120 | - | ns |
|  | $t_{\text {dc }}$ | 10 | 65 | - | 70 | - |  |
| Propagation Delay Time: TPB to DATA AVAILABLE |  | 5 | - | 295 | - | 340 | ns |
|  | $t_{\text {tid }}$ | 10 | - | 150 | - | 170 |  |
| Clock to DATA AVAILABLE |  | 5 | - | 305 | - | 355 | ns |
|  | ICDA | 10 | - | 150 | - | 170 |  |
| Clock to Overrun Error |  | 5 | - | 305 | - | 330 | ns |
|  | $\mathrm{t}_{\text {COE }}$ | 10 | - | 150 | - | 175 |  |
| Clock to Parity Error |  | 5 | - | 305 | - | 330 | ns |
|  | ICPE | 10 | - | 150 | - | 175 |  |
| Clock to Framing Error |  | 5 | - | 280 | - | 330 | ns |
|  | $\mathrm{tcFe}^{\text {che }}$ | 10 | - | 145 | - | 165 |  |



* the holding register is loaded on the trailing edge of tpb
*     * the transmit ter shif t register is loaded on the first high-to-low transition of the CLOCK WHICH OCCURS AT LEAST $1 / 2$ CLOCK PERIOD + tTC AFTER THE TRAILING EDGE OF TPB, AND TRANSMISSION OF A START BIT OCCURS $1 / 2$ CLOCK PERIOD $+I_{\text {CD LATER }}$
1 WRITE IS THE OVERLAP OF TPB, CSI, AND CS3 $=1$ AND $\overline{C S 3}, ~ R D / \bar{W} R=0$
FIGURE 1. TRANSMITTER TIMING DIAGRAM - MODE 1

* if a start bit occurs at a time less than toc before a high-to-low transition of the clock, THE START BIT MAY NOT BE RECOGNIZED UNTIL THE NEXT HIGH-TO-LOW TRANSITION OF THE CLOCK THE START BIT MAY BE COMPLETELY ASYNCHRONOUS WITH THE CLOCK
*     * READ IS THE OVERLAP OF CSI, CS3, RD / $\overline{W R}=1$ AND $\overline{C S 2}=0$

IF A PENDING DA HAS NOT BEEN CLEARED BY A READ OF THE RECEIVER HOLDING REGISTER BY THE time a new word is loaded into the receiver holding register, the oe signal will come true

FIGURE 2. MODE 1 RECEIVER TIMING DIAGRAM

Dynamic Electrical Characteristics $t_{\mathrm{t}}, \mathrm{t}_{\mathrm{f}}=15 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=\mathrm{V}_{\mathrm{SS}}, C_{\mathrm{L}}=100 \mathrm{pF}$, see Figure 3

| CHARACTERISTIC |  | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. |  |
| CPU Interface - WRITE Timing - Mode 1 |  |  |  |  |  |  |  |
| Pulse Width |  | 5 | 125 | - | 165 | - |  |
| TPB | $t_{\text {TT }}$ | 10 | 70 | - | 80 | - | ns |
| Setup Time RSEL to Write |  | 5 | 20 | - | 10 | - | ns |
|  | $\mathrm{t}_{\text {RSW }}$ | 10 | 25 | - | 25 | - |  |
| Data to Write | tow | 5 | 65 | - | 75 | - |  |
|  |  | 10 | 45 | - | 50 | - |  |
| Hold Time RSEL after Write |  | 5 | -10 | - | -20 | - | ns |
|  | $\mathrm{t}_{\text {WRS }}$ | 10 | 5 | - | 5 | - |  |
| Data after Write |  | 5 | 95 | - | 105 | - | ns |
|  | two | 10 | 55 | - | 55 | - |  |

Dynamic Electrical Characteristics $t_{r}, t_{f}=15 n s, V_{I H}=V_{D D}, V_{I L}=V_{S S}, C_{L}=100 \mathrm{pF}$, see Figure 4

| CHARACTERISTIC |  | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. |  |
| CPU Interface - READ Timing - Mode |  |  |  |  |  |  |  |
| Pulse Width |  | 5 | 125 | - | 165 | - |  |
| TPB | $\mathrm{t}_{\text {TT }}$ | 10 | 70 | - | 80 | - | ns |
| Setup Time. |  | 5 | 15 | - | 0 | - |  |
| RSEL to TPB | $\mathrm{t}_{\text {AST }}$ | 10 | 20 | - | 10 | - | ns |
| Hold Time. |  | 5 | -10 | - | -25 | - | ns |
| RSEL after TPB | $\mathrm{t}_{\text {TRS }}$ | 10 | 5 | - | 0 | - | ns |
| Propagation Delay Time: |  | 5 | - | 360 | - | 420 | ns |
| Read to Data Valid Time | $\mathrm{t}_{\text {ROV }}$ | 10 | - | 165 | - | 195 | ns |
| RSEL to Data Valıd Tıme | trsov | 5 | - | 250 | - | 295 | ns |
|  |  | 10 | - | 125 | - | 145 |  |



* WRITE is the overlap of tpb, CSI, CS3 =1 AND $\overline{\mathrm{CS} 2}$, RD $/ \overline{W R}=0$

FIGURE 3. MODE 1 CPU INTERFACE (WRITE) TIMING DIAGRAM


FIGURE 4. MODE 1 CPU INTERFACE (READ) TIMING DIAGRAM

Dynamic Electrical Characteristics $t_{\mathrm{H}} \mathrm{t}_{\mathrm{t}}=15 \mathrm{~ns}, \mathrm{~V}_{\mathrm{H}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=\mathrm{V}_{\mathrm{SS}}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$, see Figure 5

| CHARACTERISTIC |  | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Interface Timing - Mode 0 |  |  |  |  |  |  |  |
| Pulse Width |  | 5 | 105 | - | 125 | - | ns |
| CRL | $\mathrm{t}_{\text {CRL }}$ | 10 | 55 | - | 65 | - |  |
| Pulse Width |  | 5 | 340 | - | 385 | - | ns |
| MR | $\mathrm{t}_{\text {MR }}$ | 10 | 160 | - | 175 | - |  |
| Setup Time |  | 5 | 80 | - | 85 | - | ns |
| Control Word to CRL | $\mathrm{t}_{\text {cwc }}$ | 10 | 40 | - | 60 | - |  |
| Hold Time: |  | 5 | 65 | - | 65 | - | ns |
| Control Word after CRL | $t_{\text {ccw }}$ | 10 | 45 | - | 45 | - |  |
| Propagation Delay Time: |  | 5 | - | 175 | - | 195 | ns |
| SFD High to SOD | $\mathrm{t}_{\text {SFDH }}$ | 10 | - | 105 | - | 115 |  |
| SFD Low to SOD |  | 5 | 165 | - | 195 | - | ns |
|  | $\mathrm{t}_{\text {SFDL }}$ | 10 | 90 | - | 105 | - |  |
| RRD High to Receiver Register |  | 5 | - | 185 | - | 205 | ns |
| High Impedance | $\mathrm{t}_{\text {RROH }}$ | 10 | - | 110 | - | 130 |  |
|  |  | 5 | 165 | - | 195 | - | ns |
| RRD Low to Receiver Register Active | $t_{\text {RROL }}$ | 10 | 90 | - | 105 | - |  |



FIGURE 5. MODE 0 INTERFACE TIMING DIAGRAM

Specifications CDP1854A/3, CDP1854AC/3
Dynamic Electrical Characteristics $t_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=15 \mathrm{~ns}, \mathrm{~V}_{\mathrm{H}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=\mathrm{V}_{\mathrm{SS}}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$, see Figure 6

| CHARACTERISTIC |  | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Transmitter Timing - Mode 0 |  |  |  |  |  |  |  |
| Clock Perıod |  | 5 | 240 | - | 280 | - | ns |
|  | tcc | 10 | 120 | - | 145 | - |  |
| Pulse Width. Clock Low Level |  | 5 | 105 | - | 125 | - | ns |
|  | $\mathrm{t}_{\mathrm{CL}}$ | 10 | 55 | - | 65 | - |  |
| Clock High Level |  | 5 | 135 | - | 155 | - | ns |
|  | $\mathrm{t}_{\mathrm{CH}}$ | 10 | 65 | - | 80 | - |  |
| $\overline{\text { THRL }}$ | $\dagger_{\text {thth }}$ | 5 | 140 | - | 165 | - | ns |
|  | $t_{\text {THTH }}$ | 10 | 80 | - | 85 | - |  |
| Setup Time THRL to Clock |  | 5 | 205 | - | 235 | - | ns |
|  | $\mathrm{t}_{\text {THC }}$ | 10 | 120 | - | 140 | - |  |
| Data to THRL |  | 5 | 25 | - | 30 | - | ns |
|  | tot | 10 | 20 | - | 25 | - |  |
| Hold Time Data after THRL |  | 5 | 60 | - | 95 | - | ns |
|  | $\mathrm{t}_{\text {TD }}$ | 10 | 45 | - | 75 | -- |  |
| Propagation Delay Time. Clock to Data Start Bit |  | 5 | - | 435 | - | 505 | ns |
|  | $t_{C D}$ | 10 | - | 205 | - | 235 |  |
| Clock to THRE |  | 5 | - | 345 | - | 420 | ns |
|  | $\mathrm{t}_{\text {ct }}$ | 10 | - | 175 | - | 200 |  |
| $\overline{\text { THRL }}$ to THRE |  | 5 | - | 275 | - | 325 | ns |
|  | $t_{\text {tThr }}$ | 10 | - | 145 | - | 165 |  |
| Clock to TSRE |  | 5 | - | 345 | - | 405 | ns |
|  | tits | 10 | - | 165 | - | 190 |  |



* the holding register is loaded on the trailing edge of $\overline{\text { THRL }}$
** THE TRANSMITTER SHIFT REGISTER, IF EMPTY, IS LOADED ON THE FIRST HIGH-TO-LOW TRANSITION OF THE CLOCK WHICH OCCURS AT LEAST $1 / 2$ CLOCK PERIOD $+\dagger$ THC AFTER THE TRAILING EDGE OF THRL, AND TRANSMISSION OF A START BIT OCCURS $1 / 2$ CLOCK PERIOD + ${ }^{\text {ICD }}$ LATER

FIGURE 6. MODE 0 TRANSMITTER TIMING DIAGRAM

Dynamic Electrical Characteristics $t_{r}, t_{f}=15 n s, V_{I H}=V_{D D}, V_{I L}=V_{S S}, C_{L}=100 \mathrm{pF}$, see Figure 7

| CHARACTERISTIC |  | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Receiver Timing - Mode 0 |  |  |  |  |  |  |  |
| Clock Perıod |  | 5 | 240 | - | 280 | - | ns |
|  | $t_{\text {cc }}$ | 10 | 120 | - | 145 | - |  |
| Pulse Width Clock Low Level |  | 5 | 105 | - | 125 | - | ns |
|  | $\mathrm{t}_{\mathrm{CL}}$ | 10 | 55 | - | 65 | - |  |
| Clock High Level |  | 5 | 135 | - | 155 | - | ns |
|  | $\mathrm{t}_{\mathrm{CH}}$ | 10 | 65 | - | 80 | - |  |
| DATA AVAILABLE RESET | $\mathrm{t}_{\mathrm{DD}}$ | 5 | 75 | - | 90 | - | ns |
|  |  | 10 | 45 | - | 50 | - |  |
| Setup TimeData Start Bit to Clock |  | 5 | 105 | - | 130 | - | ns |
|  | $t_{\text {d }}$ | 10 | 65 | - | 85 | - |  |
| Propagation Delay Time. DATA AVAILABLE RESET to Data Available |  |  |  |  |  |  | ns |
|  |  | 5 | - | 240 | - | 280 |  |
|  | $t_{\text {DDA }}$ | 10 | - | 130 | - | 145 |  |
| Clock to Data Valid |  | 5 | - | 360 | - | 420 | ns |
|  | tcDv | 10 | - | 175 | - | 195 |  |
| Clock to Data Avaılable |  | 5 | - | 320 | - | 375 | ns |
|  | $\mathrm{I}_{\text {CDA }}$ | 10 | - | 155 | - | 180 |  |
| Clock to Overrun Error |  | 5 | - | 365 | - | 415 | ns |
|  | tcoe | 10 | - | 170 | - | 190 |  |
| Clock to Parity Error |  | 5 | - | 275 | - | 320 | ns |
|  | $\mathrm{t}_{\text {CPE }}$ | 10 | - | 135 | - | 155 |  |
| Clock to Framing Error |  | 5 | - | 270 | - | 320 | ns |
|  | $t_{\text {cfe }}$ | 10 | - | 135 | - | 165 |  |



* if a start bit occurs at a time less than toc before a high-to-low transition of the clock, THE START BIT MAY NOT BE RECOGNIZED UNTIL THE NEXT HIGH-TO-LOW TRANSITION OF THE CLOCK THE START BIT MAY BE COMPLETELY ASYNCHRONOIJS WITH THE CLOCK
*     * if a pending da has not been cleared by a read of the receiver holding register by the time a new WORD IS LOADED INTO THE RECEIVER HOLDING REGISTER, THE OE SIGNAL WILL COME TRUE

FIGURE 7. MODE 0 RECEIVER TIMING DIAGRAM


FIGURE 8. SERIAL DATA WORD FORMAT


| Type | $\mathbf{V}_{\text {DD }}$ | Temp. | Time |
| :--- | :---: | :---: | :---: |
| CDP1854A $/ 3$ | 11 | $+125^{\circ} \mathrm{C}$ | 160 hrs. |
| CDP1854AC $/ 3$ | 7 | $+125^{\circ} \mathrm{C}$ | 160 hrs. |

FIGURE 9. BIAS/STATIC BURN-IN CIRCUIT

CDP6402 CDP6402C

## CMOS Universal Asynchronous Receiver/Transmitter (UART)

## Features

- Low Power CMOS Circuitry
7.5 mW (Typ) at
3.2 MHz (Max Freq.) at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$


## - Baud Rate

- DC to 200K Bits/s (Max) at. . . . . . . . . . . . . . 5V, $85^{\circ} \mathrm{C}$
- DC to 400K Bits/s (Max) at
$10 \mathrm{~V}, 85^{\circ} \mathrm{C}$
- 4V to 10.5 Operation
- Automatic Data Formatting and Status Generation
- Fully Programmable with Externally Selectable Word Length (5-8 Bits), Parity Inhibit, Even/Odd Parity, and $1,1 \frac{1}{2}$, or 2 Stop Bits
- Operating Temperature Range
- CDP6402D, CD $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- CDP6402E, CE . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- Replaces Industry Types IM6402 and HD6402


## Description

The CDP6402 and CDP6402C are silicon gate CMOS Universal Asynchronous Receiver/Transmitter (UART) circuits for interfacing computers or microprocessors to asynchronous serial data channels. They are designed to provide the necessary formatting and control for interfacing between serial and parallel data channels. 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 can be 5, 6, 7 or 8 bits in length. Parity may be odd, even or inhibited. Stop bits can be $1,1 \frac{1}{2}$, or 2 (when transmitting 5 bit code).

The CDP6402 and CDP6402C can be used in a wide range of applications including modems, printers, peripherals, video terminals, remote data acquisition systems, and serial data links for distributed processing systems.

The CDP6402 and CDP6402C are functionally identical. They differ in that the CDP6402 has a recommended operating voltage range of 4 V to 10.5 V , and the CDP6402C has a recommended operating voltage range of 4 V to 6.5 V . Both types are supplied in 40 lead dual-in-line ceramic packages ( $D$ suffix), and 40 lead dual-in-line plastic packages (E suffix).

## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 5V/200K BAUD | 10V/400K BAUD |
| :--- | :---: | :--- | :---: |
| Plastic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP6402CE | CDP6402E |
|  |  | CDP6402CEX | - |
| Ceramic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP6402CD | CDP6402D |
|  |  | CDP6402CDX | CDP6402DX |

## Pinout




Fig. 1 - Functional Block Diagram

## Specifications CDP6402, CDP6402C

## MAXIMUM RATINGS, Absolute-Maximum Values:

```
DC SUPPLY-VOLTAGE RANGE, (VDD)
    (Voltage referenced to VSS Terminal)
        CDP6402
                -0.5 to +11 V
                -0.5 to +7 V
        CDP6402C
INPUT VOLTAGE RANGE, ALL INPUTS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - - 0.5 to VDD +0.5 V
DC INPUT CURRENT, ANY ONE INPUT . ............................................................................... . 土 . 100 \muA
POWER DISSIPATION PER PACKAGE (PD):
    For TA = -40 to +60}\textrm{C}\mathrm{ (PACKAGE TYPE E ..................................................................... }500.\textrm{mW
    For TA = +60 to +85' C (PACKAGE TYPE E) .................................. Derate Lineary at 12 mW/`. C to 200 mW
    For TA = -55 to 100
    For TA = + 100 to +125*` (PACKAGE TYPE D) ............................. . Derate Lineary at 12 mW/` C to 200 mW
DEVICE DISSIPATION PER OUTPUT TRANSISTOR
    For TA = FULL PACKAGE-TEMPERATURE RANGE (All Package Types) ................................... 100 mW
OPERATING-TEMPERATURE RANGE (TA):
    PACKAGE TYPE D
        -55 to +125*}\textrm{C
    PACKAGE TYPE E . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 to +855` C
STORAGE TEMPERATURE RANGE (Tstg) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - 65 to +150``
LEAD TEMPERATURE (DURING SOLDERING):
    At distance 1/16\pm1/32 inch (1.59 \pm0.79 mm) from case for 10 s max.
    +265}\mp@subsup{}{}{\circ}\textrm{C
```

OPERATING CONDITIONS at $T_{A}$ = Full Package-Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP6402 |  | CDP6402C |  |  |
|  | Min. | Max. | Min. | Max. |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | VSS | VDD | VSS | VDD |  |

## STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-\mathbf{4 0}$ to $+\mathbf{8 5} 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm \mathbf{1 0 \%}$, Except as noted



- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$.
$\ddagger 1 \mathrm{OL}=1 \mathrm{OH}=1 \mu \mathrm{~A}$.
\#Operating current is measured at 200 kHz or $\mathrm{V}_{D D}=5 \mathrm{~V}$ and 400 kHz for $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}$, with open outputs (worst-case frequencies for CDP1802A system operating at maximum speed of 3.2 MHz ).


## DESCRIPTION OF OPERATION

## Initialization and Controls

A positive pulse on the MASTER RESET (MR) input resets the control, status, and receiver buffer registers, and sets the serial output (TRO) High. Timing is generated from the clock inputs RRC and TRC at a frequency equal to 16 times the serial data bit rate. The RRC and TRC inputs may be driven by a common clock, or may be driven independently by two different clocks. The CONTROL REGISTER LOAD (CRL) input is strobed to load control bits for PARITY INHIBIT (PI), EVEN PARITY ENABLE (EPE), STOP BIT SELECTS (SBS), and CHARACTER LENGTH SELECTS (CLS1 and CLS2). These inputs may be hand wired to $V_{S S}$ or VDD with CRL to VDD. When the initialization is completed, the UART is ready for receiver and/or transmitter operations.

## Transmitter Operation

The transmitter section accepts parallel data, formats it, and transmits it in serial form (Fig. 2) on the TRO terminal.


92Cs-34554
Fig. 2 - Serial data format.
Transmitter timing is shown in Fig. 3. (A) Data is loaded into the transmitter buffer register from the inputs TBR1 through TBR8 by a logic low on the TBRL input. Valid data must be present at least tDT prior to, and tTD 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, TBR1. (B) The rising edge of TBRL clears TBRE. $1 / 2$ to $11 / 2$ cycles later, depending on when the TBRL pulse occurs with respect to TRC, data is transferred to the transmitter register and TRE is cleared. TBRE is set to a logic High one cycle after that.
Output data is clocked by TRC. The clock rate is 16 times the data rate. (C) A second pulse on TBRL 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.


92CS-38054R1
Fig. 3 - Transmitter timing waveforms.

## Receiver Operation

Data is received in serial form at the RRI input. When no data is being received, RRI input must remain high. The data is clocked through the RRC. The clock rate is 16 times the data rate. Receiver timing is shown in Fig. 4.


Fig. 4 - Receiver timing waveforms.
(A) A low level on $\overline{\text { DRR clears the DR 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 OE indicates overruns. An overrun occurs when DR has not been cleared before the present character was transferred to the RBR. (C) $1 / 2$ clock cycle later DR is set to a logic high and FE is evaluated. A logic high on FE indicates an invalid stop bit was received. A logic high on PE indicates a parity error.

## Start Bit Detection

The receiver uses a 16X clock for timing (Fig. 5). 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 $71 / 2$. If the receiver clock is a symmetrical square wave, the center of the start bit will be located within $\pm 1 / 2$ clock cycle, $\pm 1 / 32$ bit or $\pm 3.125 \%$. The receiver begins searching for the next start bit at 9 clocks into the first stop bit.


Fig. 5 - Start bit timing waveforms.

Table I-Control Word Function

| CONTROL WORD |  |  |  |  | DATA BITS | PARITY BIT | STOP BIT(S) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLS2 | CLS 1 | PI | EPE | SBS |  |  |  |
| L | L | L | L | L | 5 | ODD | 1 |
| L | L | L | L | H | 5 | ODD | 1.5 |
| L | L | L | H | L | 5 | EVEN | 1 |
| L | L | L | H | H | 5 | EVEN | 1.5 |
| L | L | H | X | L | 5 | DISABLED | 1 |
| L | L | H | X | H | 5 | DISABLED | 1.5 |
| L | H | L | L | L | 6 | ODD | 1 |
| L | H | L | L | H | 6 | ODD | 2 |
| L | H | L | H | L | 6 | EVEN | 1 |
| L | H | L | H | H | 6 | EVEN | 2 |
| L | H | H | X | L | 6 | DISABLED | 1 |
| L | H | H | X | H | 6 | DISABLED | 2 |
| H | L | L | L | L | 7 | ODD | 1 |
| H | L | L | L | H | 7 | ODD | 2 |
| H | L | L | H | L | 7 | EVEN | 1 |
| H | L | L | H | H | 7 | EVEN | 2 |
| H | L | H | $x$ | L | 7 | DISABLED | 1 |
| H | L | H | X | H | 7 | DISABLED | 2 |
| H | H | L | L | L | 8 | ODD | 1 |
| H | H | L | L | H | 8 | ODD | 2 |
| H | H | L | H | L | 8 | EVEN | 1 |
| H | H | L | H | H | 8 | EVEN | 2 |
| H | H | H | $x$ | L | 8 | DISABLED | 1 |
| H | H | H | X | H | 8 | DISABLED | 2 |

X = Don't Care

Table II - Function Pin Definition

| PIN | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: |
| 1 | VDD | Positive Power Supply |
| 2 | N/C | No Connection |
| 3 | GND | Ground (VSS) |
| 4 | RRD | A high level on RECEIVER REGISTER DISABLE forces the receiver holding register ouputs 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 7 | RBR7 RBR6 |  |
| 8 | RBR5 |  |
| 9 10 | RBR4 <br> RBR3 | See Pin 5 - RBR8 |
| 11 | RBR2 |  |
| 12 | RBR1 |  |
| 13 | PE | A high level on PARITY ERROR indicates that the received parity does not match parity programmed by control bits The output is active until parity matches on a succeeding character When parity is inhibited, this output is low |
| 14 | FE | A high level on FRAMING ERROR indicates the first stop bit was invalid FE will stay active untıl the next valid character's stop bit is received |


| PIN | SYMBOL | DESCRIPTION |
| :---: | :---: | :--- |
| 15 | OE | $\begin{array}{l}\text { A high level on OVERRUN ERROR } \\ \text { indicates the data received flag was not } \\ \text { cleared before the last character was } \\ \text { transferred to the receiver buffer } \\ \text { register. The Error is reset at the next } \\ \text { character's stop bit if DRR has been } \\ \text { performed (i.e., DRR; active low). } \\ \text { A high level on STATUS FLAGS } \\ \text { DISABLE forces the outputs PE, FE, OE, } \\ \text { DR, TBRE to a high impedance state. }\end{array}$ |
| 16 | SFD |  |
| The RECEIVER REGISTER CLOCK is |  |  |
| 16X the receiver data rate. |  |  |
| A low level on DATA RECEIVED RESET |  |  |
| clears the data received output (DR), to |  |  |
| a low level. |  |  |
| A high level on DATA RECEIVED |  |  |
| indicates a character has been received |  |  |
| and transferred to the receiver buffer |  |  |
| register. |  |  |
| Serial data on RECEIVER REGISTER |  |  |
| INPUT is clocked into the receiver |  |  |
| register. |  |  |
| A high level on MASTER RESET (MR) |  |  |
| clears PE, FE, OE and DR, and sets TRE, |  |  |\(\left.\} \begin{array}{l}TBRE, and TRO. TRE is actually set on <br>

the first rising edge of TRC after MR <br>
goes high. MR should be strobed after <br>
power-up. <br>
A high level on TRANSMITTER BUFFER <br>
REGISTER EMPTY indicates the <br>
transmitter buffer register has <br>
transferred its data to the transmitter <br>
register and is ready for new data.\end{array}\right]\)

Table II - Function Pin Definition (Cont'd)

| PIN | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: |
| 23 | $\overline{\text { 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 requests data transfer to the transmitter register. If 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 | ) |
| 29 | TBR4 |  |
| 30 | TBR5 | ¢ See Pin 26-TBR1 |
| 32 | TBR7 |  |
| 33 | TBR8 | $)$ |


| PIN | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: |
| 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 a 5 character format and 2 stop bits for other lengths. |
| 37 | CLS2* | These inputs program the CHARACTER LENGTH SELECTED (CLS1 Iow 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 |

[^17]DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm \mathbf{5} \%, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=\mathbf{2 0} \mathrm{ns}$,
$V_{I H}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, C_{L}=100 \mathrm{pF}$

| Characteristic ${ }^{\dagger}$ | $\begin{gathered} V_{D D} \\ \text { (V) } \end{gathered}$ | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP6402 |  | CDP6402C |  |  |
|  |  | Typ.* | Max. ${ }^{\text {- }}$ | Typ.* | Max. ${ }^{\text {s }}$ |  |

System Timing (See Fig. 6)

| Minimum Pulse Width. CRL | tCRL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 50 \\ & 40 \end{aligned}$ | $\begin{aligned} & 150 \\ & 100 \end{aligned}$ | 50 | 150 - | n |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Minimum Setup Time Control Word to CRL | tcwC | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 20 \\ 0 \end{gathered}$ | $\begin{aligned} & 50 \\ & 40 \end{aligned}$ | 20 |  |  |
| Minimum Hold Tıme Control Word after CRL | tccw | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 40 \\ & 20 \end{aligned}$ | $\begin{aligned} & 60 \\ & 30 \end{aligned}$ | 40 |  |  |
| Propagation Delay Time SFD High to SOD | tsFDH | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ | $\begin{aligned} & 200 \\ & 150 \end{aligned}$ | 130 | 200 |  |
| SFD Low to SOD | tSFDL | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 130 \\ 40 \end{gathered}$ | $\begin{gathered} 200 \\ 60 \end{gathered}$ | 130 | 200 |  |
| RRD High to Receiver Register High Impedance | $t_{\text {RRDH }}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 80 \\ & 40 \end{aligned}$ | $\begin{array}{r} 150 \\ 70 \end{array}$ | 80 | 150 |  |
| RRD Low to Receiver Register Active | ${ }^{\text {t RRDL }}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 80 \\ & 40 \end{aligned}$ | $\begin{aligned} & 150 \\ & 70 \end{aligned}$ | 80 | 150 |  |
| Minimum Pulse Width: MR |  | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \end{aligned}$ | $\begin{aligned} & 400 \\ & 200 \end{aligned}$ | 200 | 400 |  |

- Typical values for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
$\Delta_{\text {Maximum }}$ limits of minimum characteristics are the values above which all devices function.
$\dagger$ All measurements are made at the $50 \%$ point of the transition except tri-state measurements.


Fig. 6 - System timing waveforms.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm \mathbf{5 \%} \%, \mathrm{t}_{\mathbf{r}}, \mathrm{tf}_{\mathrm{f}}=\mathbf{2 0} \mathrm{ns}$,
$V_{I H}=0.7 V_{D D}, V_{I L}=0.3 V_{D D}, C_{L}=100 \mathrm{pF}$

| CHARACTERISTIC ${ }^{\dagger}$ |  | VDD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP6402 | CDP6402C |  |  |
|  |  | Typ.* | Max. ${ }^{\text {d }}$ | Typ.* | Max. $\Delta$ |  |
| Transmitter Timing (See Fig. 7) |  |  |  |  |  |  |  |
| Minimum Clock Period (TRC) | ${ }^{t} \mathrm{CC}$ |  | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{array}{r} 250 \\ 125 \\ \hline \end{array}$ | $\begin{array}{r} 310 \\ 155 \\ \hline \end{array}$ | 250 - | $\begin{array}{r}310 \\ - \\ \hline\end{array}$ | ns |
| Minimum Pulse Width: Clock Low Level | ${ }^{\text {t }} \mathrm{CL}$ |  | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 100 \\ & 75 \end{aligned}$ | $\begin{aligned} & 125 \\ & 100 \end{aligned}$ | 100 | 125 <br> - |  |
| Clock High Level | ${ }^{\text {t }} \mathrm{CH}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 100 \\ & 75 \end{aligned}$ | $\begin{aligned} & 125 \\ & 100 \end{aligned}$ | 100 | 125 |  |  |
| $\overline{\text { TBRL }}$ | ${ }^{\text {t }}$ HTH | $\begin{gathered} 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 80 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | 80 | 200 - |  |  |
| Minimum Setup Time: TBRL to Clock | ${ }^{\text {t }}$ HC | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 175 \\ 90 \end{gathered}$ | $\begin{aligned} & 275 \\ & 150 \end{aligned}$ | 175 | 275 |  |  |
| Data to $\overline{\text { TBRL }}$ | tD | $\begin{gathered} 5 \\ 10 \end{gathered}$ | 20 0 | $\begin{aligned} & 50 \\ & 40 \end{aligned}$ | 20 | 50 |  |  |
| Minimum Hold Time: Data after TBRL | tTD | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 40 \\ & 20 \end{aligned}$ | $\begin{aligned} & 60 \\ & 30 \end{aligned}$ | 40 | 60 |  |  |
| Propagation Delay Time: Clock to Data Start Bit | ${ }^{\text {t }}$ CD | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | $\begin{aligned} & 450 \\ & 225 \end{aligned}$ | 300 | 450 |  |  |
| Clock to TBRE | ${ }^{\text {t }} \mathrm{CT}$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 330 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 400 \\ & 150 \\ & \hline \end{aligned}$ | 330 | 400 |  |  |
| $\overline{\text { TBRL }}$ to TBRE | ${ }^{\text {t }}$ TTHR | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \end{aligned}$ | 200 | 300 |  |  |
| Clock to TRE | ${ }^{\text {t }}$ TTS | $\begin{gathered} 5 \\ 10 \end{gathered}$ | 330 100 | $\begin{aligned} & 400 \\ & 150 \end{aligned}$ | 330 | 400 |  |  |

${ }^{\bullet}$ Typical values for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
$\Delta_{\text {Maximum }}$ limits of minimum characteristics are the values above which all devices function.
$\dagger$ All measurements are made at the $50 \%$ point of the transition except tri-state measurements.


Fig. 7 - Transmitter timing waveforms.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm \mathbf{5 \%}, \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=\mathbf{2 0} \mathbf{n s}$,
$V_{I H}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, C_{L}=100 \mathrm{pF}$


| Minimum Clock Period (RRC) | ${ }^{t} \mathrm{CC}$ | 5 10 | $\begin{array}{r} 250 \\ 125 \end{array}$ | $310$ | 250 | 310 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Minımum Pulse Width: Clock Low Level | ${ }^{1} \mathrm{CL}$ | 5 | 100 | 125 | 100 | 125 |  |
|  |  | 10 | 75 | 100 |  |  |  |
| Clock High Level | ${ }^{\mathrm{t}} \mathrm{CH}$ | 510 | 100 | 125 | 100 | - |  |
|  |  |  | 75 | 100 |  |  |  |
| DATA RECEIVED RESET | tDD | 510 | 5025 | 75 | 50 | 75 |  |
|  |  |  |  | 40 | - | - |  |
| Minimum Setup Time Data Start Bit to Clock | عס | 510 | $\begin{gathered} 100 \\ 50 \end{gathered}$ | $\begin{aligned} & 150 \\ & 75 \\ & \hline \end{aligned}$ | 100 | 150 |  |
| Data Start Bit to Clock |  |  |  |  | - | - |  |
| $\frac{\text { Propagation Delay Time: }}{\text { DATA RECEIVED RESET to }}$ |  |  |  |  |  |  |  |
| DATA RECEIVED RESET to Data Received | tDDA | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{gathered} 150 \\ 75 \end{gathered}$ | $\begin{aligned} & 250 \\ & 125 \\ & \hline \end{aligned}$ | 150 | 250 |  |
| Clock to Data Valid | tCDV | 5 <br> 10 | $\begin{aligned} & 275 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{array}{r} 400 \\ 175 \\ \hline \end{array}$ | 275 | 400 |  |
|  |  |  |  |  | - |  |  |
| Clock to DR | ${ }^{\text {t CDA }}$ | 510 | $\begin{aligned} & 275 \\ & 110 \\ & \hline \end{aligned}$ |  | 275 | 400 |  |
|  |  |  |  | $\begin{aligned} & 400 \\ & 175 \\ & \hline \end{aligned}$ |  |  |  |
| Clock to Overrun Error | tcoe | $\begin{gathered} \hline 5 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & 275 \\ & 100 \\ & \hline \end{aligned}$ | 400150 | 275 | 400 |  |
|  |  |  |  |  | - | - |  |
| Clock to Parity Error | tCPE | 510 | $\begin{aligned} & 240 \\ & 120 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 375 \\ & 175 \\ & \hline \end{aligned}$ | 240 | 375 |  |
|  |  |  |  |  | - | - |  |
| Clock to Framing Error | tCFE | $\begin{gathered} \hline 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 200 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 150 \\ & \hline \end{aligned}$ | 200 | 300 |  |
|  |  |  |  |  |  |  |  |

${ }^{-}$Typical values for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
$\Delta$ Maximum limits of minimum characteristics are the values above which all devices function.
$\dagger$ All measurements are made at the $50 \%$ point of the transition except tri-state measurements.


Fig. 8 - Receiver timing waveforms.

## Features

- HD-4702 Provides 13 Commonly Used Bit Rates
- Uses a 2.4576MHz Crystal/Input for Standard Frequency Output (16 Times Bit Rate)
- Low Power Dissipation
- 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


## Ordering Information

| PACKAGE | TEMP. RANGE | ORDER CODE |
| :--- | :--- | :--- |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD3-4702-9 |
| Ceramic DIP <br> $/ 883$ <br>  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD1-4702-9 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HD1-4702/883 |
| Leaded Chip <br> Carrier | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD4-4702-9 |

*Respective $/ 883$ specifications are included at the end of this data sheet

## 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 onchip 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 +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 +8 prescaler outputs Q0, Q1, Q2 available externally. All signals have a 50\% duty cycle except 1800 Baud, which has less than $0.39 \%$ distortion.
The four rate select inputs (S0-S3) select which bit rate is at the output (Z). See Truth Table for Rate Select Inputs for select code and output bit rate. Two of the 16 select codes 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 rates 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 master reset for the scan counter. This signal is derived from a digital differentiator that senses the first high level on the CP input after the ĒCP input goes low. When ĒCP is high, selecting the crystal input, CP must be low. A high level on CP would apply a continuous reset. See Clock Modes and Initialization below.

## Truth Tables

TRUTH TABLE FOR RATE SELECT INPUTS
(Using 2.4576MHz Crystal)

| S3 | S2 | S1 | S0 | OUTPUT RATE (Z) |
| :--- | :--- | :--- | :--- | :--- |
| L | L | L | L | MUX Input (IM) |
| L | L | L | H | MUX Input (IM) |
| L | L | H | L | 50 Baud |
| L | L | H | H | 75 Baud |
| L | H | L | L | 1345 Baud |
| L | H | L | H | 200 Baud |
| L | H | H | L | 600 Baud |
| L | H | H | H | 2400 Baud |
| H | L | L | L | 9600 Baud |
| H | L | L | H | 4800 Baud |
| H | L | H | L | 1800 Baud |
| H | L | H | H | 1200 Baud |
| H | H | L | L | 2400 Baud |
| H | H | L | H | 300 Baud |
| H | H | H | L | 150 Baud |
| H | H | H | H | 110 Baud |

NOTE. 19200 Baud by connecting Q2 to IM

## Pinout



## CLOCK MODES AND INITIALIZATION

| $\mathbf{I X}$ | ECP | $\mathbf{C P}$ | OPERATION |
| :---: | :---: | :---: | :--- |
| $\Omega \Omega$ | H | L | Clocked from IX |
| X | L | $\Omega \Omega$ | Clocked from CP |
| X | H | H | Continuous Reset |
| X | L | $\boxed{L}$ | Reset During 1st CP = High Time |

NOTE: Actual output frequency is 16 times the indicated Output Rate, assuming a clock frequency of 2.4576 MHz .

NOTE: Actual output frequency is 16 times the indicated Output Rate, assuming a clock frequency of 2.4576 MHz .
$H=H I G H$ Level
L = LOW Level
X = Don't Care
$\Omega \Omega=$ Clock Pulse
$\longrightarrow=1$ st HIGH Level Clock Pulse after ĒCP goes LOW

## Pin Description

| PIN NUMBER | TYPE | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :--- |
| 16 |  | $V_{C C}$ | $V_{C C}:$ Is the +5V power supply pin. A 0.1mF capacitor between pins 16 and 8 is <br> recommended for decoupling |
| 8 | 1 | GND | GROUND |
| 5 | 1 | $\bar{E}_{C P}$ | EXTERNAL CLOCK ENABLE: A low signal on this input allows the baud rate to be <br> generated from the CP input. |
| 4 | 1 | $I_{X}$ | CRYSTAL INPUT |
| 7 | 0 | $O_{x}$ | CRYSTAL DRIVE OUTPUT |
| 6 | 1 | $I_{M}$ | MULTIPLEXED INPUT |
| $11,12,13,14$ | 1 | $S_{0}-S_{3}$ | BAUD RATE SELECT INPUTS |
| 9 | $O$ | $C O$ | CLOCK OUTPUT |
| $1,2,3$ | $O$ | $Q_{0}-Q_{2}$ | SCAN COUNTER OUTPUTS |
| 10 | $O$ | $Z$ | BIT RATE OUTPUT |

## Block Diagram



## Application Information

## 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 (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 Baud. For many low cost terminals, these five bit rates are adequate.


See Figure 4

| SWITCH POSITION | HD-4702 BIT RATE |
| :---: | :---: |
| 1 | 110 Baud |
| 2 | 150 Baud |
| 3 | 300 Baud |
| 4 | 1200 Baud |
| 5 | 2400 Baud |

figure 1. SWITCH SELECTABLE bit rate generator CONFIGURATION PROVIDING FIVE BIT RATES.

## 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 93 L 34 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 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:

| Q0: 110 Baud | Q1: 9600 Baud | Q2: 4800 Baud |
| :--- | :--- | :--- |
| Q3: 1800 Baud | Q4: 1200 Baud | Q5: 2400 Baud |
| Q6: 300 Baud | Q7: 150 Baud |  |

Q1: 9600 Baud
Q2: 4800 Baud
Q3: 1800 Baud
Q7: 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.


FIGURE 2. BIT RATE GENERATOR CONFIGURATION WITH EIGHT SIMULTANEOUS FREQUENCIES. * See Figure 4

## 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 $Q_{2}$ output to $I 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).


OUTPUT
FIGURE 3. FIGURE 3. 19200 BAUD OPERATION

* See Figure 4

| 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$ |

FIGURE 4. CRYSTAL SPECIFICATIONS

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output or I/O Voltage | .GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |
| Typical Derating Factor | Hzz Increase in ICCOP |

Input, Output or I/O Voltage . . . . . . . . . . . . . . GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
Typical Derating Factor . . . . . . . . . . . . 1mA/MHz Increase in ICCOP

## Reliability Information

| Thermal Resistance | $\theta_{j a}$ | $\theta_{j \mathrm{jc}}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . . . . . . . . . . . | $17.1^{\circ} \mathrm{C} / \mathrm{N}$ | $75.7^{\circ} \mathrm{C} / \mathrm{W}$ |

Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$
Ceramic DIP Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . 660 mW
Gate Count
. 720 Gates

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range. . +4.5 V to +5.5 V

Operating Temperature Range HD-4702-9 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ HD-4702-8 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HD}-4702-9), \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HD-4702-8)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | $\mathrm{V}_{\mathrm{cc}} 70 \%$ | - | V | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | - | $\mathrm{V}_{\text {cc }} 30 \%$ | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage | $\mathrm{v}_{\mathrm{cc}}-0.1$ | - | V | $\mathrm{I}_{\mathrm{OH}} \leq-1 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, (Note 1) |
| $\mathrm{V}_{\mathrm{OL1}}$ | Output Low Voltage | - | 0.1 | V | $\mathrm{l}_{\mathrm{OL}} \leq+1 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, (Note 1 ) |
| $\mathrm{I}_{\mathrm{H}}$ | Input High Current | -1 | +1 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$. All Other Pins $=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| ILLX | Input Low Current (IX Input) | -1 | +1 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$, All Other Pins $=\mathrm{V}_{\mathrm{Cc}}, \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| IIL | Input Low Current (All Other Inputs) | $\bullet$ | -100 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0 \mathrm{~V} \text {, All Other Pins }=\mathrm{V}_{\mathrm{CC}}, \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { (Note 2) } \end{aligned}$ |
| $\mathrm{I}_{\text {OHX }}$ | Output High Current ( $\mathrm{O}_{\mathrm{x}}$ ) | -0.1 | - | mA | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\mathrm{CC}}-0.5, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Input at 0 V or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table |
| $\mathrm{l}_{\mathrm{OH} 1}$ | Output High Current (All Other Outputs) | -1.0 | $\bullet$ | mA | $V_{\text {OUT }}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Input at 0 V or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table |
| $\mathrm{I}^{\mathrm{OH} 2}$ | Output High Current (All Other Outputs) | -0.3 | - | mA | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\mathrm{CC}}-0.5, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Input at 0 V or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table |
| Ioux | Output Low Current $(0 x)$ | 0.1 | - | mA | $V_{\text {OUT }}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, Input at 0 V or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table |
| loL | Output Low Current <br> (All Other Outputs) | 1.6 | - | mA | $\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ Input, at 0 V or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table |
| $I_{\text {cc }}$ | Supply Current (Static) |  | $\begin{aligned} & 1500 \\ & 1000 \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ | $\begin{aligned} & \bar{E}_{C P}=V_{C C}, C P=0 \mathrm{~V}, \mathrm{~V}_{C C}=5.5 \mathrm{~V}, \\ & \text { All Other Inputs }=G N D,(\text { Note } 2) . \\ & \bar{E}_{C P}=\mathrm{V}_{\mathrm{Cc}}, C P=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \\ & \text { All Other Inputs }=\mathrm{V}_{\mathrm{Cc}},(\text { Note 2). } \end{aligned}$ |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Input Current and Quiescent Power Supply Current are relatively higher for this device because of active pull-up circuits on all inputs except $\mathrm{I}_{\mathrm{X}}$.

AC Electrical Specifications $V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HD}-4702-9), \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{HD}-4702-8)$

| SYMBOL | A.C. PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| $\mathrm{t}_{\text {PLH }}$ | Propagation Delay, $\mathrm{I}_{\mathrm{x}}$ to CO | - | 350 | ns | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ \mathrm{C}_{\mathrm{L}} \leq 7 \mathrm{pF} \text { on } \mathrm{O}_{\mathrm{x}} \\ \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ \text { (Note 1) } \end{gathered}$ |
| $\mathrm{t}_{\text {PHL }}$ |  | - | 275 | ns |  |
| $t_{\text {PLH }}$ | Propagation Delay, CP to CO | - | 260 | ns |  |
| $\mathrm{t}_{\text {PHL }}$ |  | - | 220 | ns |  |
| tPLH | Propagation Delay, CO to Qn | - | (Note 2) | ns |  |
| $t_{\text {PHL }}$ |  | - | (Note 2) | ns |  |
| $t_{\text {PLH }}$ | Propagation Delay, CO to Z | - | 85 | ns |  |
| $\mathrm{t}_{\text {PHL }}$ |  | - | 75 | ns |  |
| ${ }_{\text {tiLH }}$ | Output Transition Time (Except $\mathrm{O}_{\mathrm{x}}$ ) | - | 160 | ns |  |
| ${ }_{\text {thL }}$ |  | - | 75 | ns |  |
| $\mathrm{t}_{3}$ | Set-Up Time, Select to CO | 350 | - | ns |  |
| $t_{n}$ | Hold Time, Select to CO | 0 | - | ns |  |
| $\mathrm{t}_{\text {s }}$ | Set-Up Time, $\mathrm{I}_{\text {M }}$ to CO | 350 | - | ns |  |
| $t_{n}$ | Hold Time, $\mathrm{I}_{\mathrm{M}}$ to CO | 0 | - | ns |  |
| $\mathrm{t}_{\text {wCP }}(\mathrm{L})$ | Minimum Clock Pulse Width, Low (Notes 3, 4) | 120 | - | ns |  |
| $\mathrm{t}_{\text {wCP }}(\mathrm{H})$ | Minimum Clock Pulse Width, High (Notes 3, 4) | 120 | - | ns |  |
| $\mathrm{t}_{\text {wCP }}(\mathrm{L})$ | Minimum IX Pulse Width, Low (Note 4) | 160 | - | ns |  |
| $\mathrm{t}_{\text {wCP }}(\mathrm{H})$ | Minimum $\mathrm{I}_{\mathrm{X}}$ Pulse Width, High (Note 4) | 160 | - | ns |  |
| $t_{\text {PLH }}$ | Propagation Delay $\mathrm{I}_{\mathrm{x}}$ to CO | - | 300 | ns | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ \mathrm{C}_{\mathrm{L}} \leq 7 \mathrm{pF} \text { on } \mathrm{O}_{\mathrm{x}} \\ \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ \text { (Note 1) } \end{gathered}$ |
| $\mathrm{t}_{\text {PHL }}$ |  | - | 250 | ns |  |
| $\mathrm{t}_{\text {PLH }}$ | Propagation Delay CP to CO | - | 215 | ns |  |
| $\mathrm{t}_{\text {PHL }}$ |  | - | 195 | ns |  |
| $t_{\text {PLH }}$ | Propagation Delay CO to Qn | - | (Note 2) | ns |  |
| $\mathrm{t}_{\text {PHL }}$ |  | - | (Note 2) | ns |  |
| tplH | Propagation Delay CO to Z | - | 75 | ns |  |
| $\mathrm{t}_{\text {PHL }}$ |  | - | 65 | ns |  |
| ${ }_{\text {tiLH }}$ | Output Transition Time (Except $\mathrm{O}_{\mathrm{x}}$ ) | - | 80 | ns |  |
| $\mathrm{t}_{\text {THL }}$ |  | - | 40 | ns |  |

NOTES:

1. Propagation Delays ( $\mathrm{t}_{\mathrm{PLH}}$ and $\mathrm{t}_{\mathrm{PHL}}$ ) and Output Transition Times ( $\mathrm{t}_{\mathrm{TLH}}$ and $\mathrm{t}_{\mathrm{THL}}$ ) will change with Output Load Capacitance ( $\mathrm{C}_{\mathrm{L}}$ ). Setup Times ( $\mathrm{t}_{\mathrm{s}}$ ), Hold Times ( $\mathrm{t}_{\mathrm{n}}$ ), and Minimum Pulse Widths $\left(t_{w}\right)$ do not vary with load capacitance.
2. For multichannel operation, Propagation Delay (CO to Qn) plus Set-Up Time, Select to CO, is guaranteed to be $\leq 367 \mathrm{~ns}$.
3. The first High Level Clock Pulse after $\bar{E}_{\mathrm{CP}}$ goes Low 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, $I_{x}$ ) be less than $15 n s$.

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$; Frequency $=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | CONDITIONS |
| :---: | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 7 | pF | All measurements are referenced the <br> device GND |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 15 | pF |  |

## Switching Waveforms



NOTE: Set-Up and Hold Times are shown as positive values but may be specified as negative values.
AC Testing Input, Output Waveform


NOTE: AC Testing: All input signals must switch between $\mathrm{V}_{\mathrm{IL}}$ and $\mathrm{V}_{\mathrm{IH}}$. Input rise and fall times are driven at 1 nsec per volt.

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1. 2. 1.
- HD-4702/883 Provides 13 Commonly Used Bit Rates
- Uses a 2.4576 MHz Crystal/Input for Standard Frequency Output (16 Times Bit Rate)
- Low Power Dissipation
- Conforms to EIA RS-404
- One HD-4702/883 Controls up to Eight Transmission Channels
- Initialization Circuit Facilitates Diagnostic Fault Isolation
- On-Chip Input Pull-Up Circuit


## Description

The HD-4702/883 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/883 can provide multi-channel operation with a minimum of external logic by having the clock frequency CO and the $\div 8$ prescaler outputs $\mathrm{Q}_{0}, \mathrm{Q}_{1}, \mathrm{Q}_{2}$ available externally. All signals have a $50 \%$ duty cycle except 1800 Baud, which has less than $0.39 \%$ distortion.
The four rate select inputs $\left(\mathrm{S}_{0}-\mathrm{S}_{3}\right)$ select which bit rate is at the output (Z). See Truth Table for Rate Select Inputs for

## Pinout



## Truth Tables <br> TRUTH TABLE FOR RATE SELECT INPUTS

(Using 2.4576 MHz Crystal)

| $S_{3}$ | $\mathrm{S}_{2}$ | $\mathrm{S}_{1}$ | So | OUTPUT <br> RATE (Z) |
| :---: | :---: | :---: | :---: | :---: |
| L | L | L | L | MUX Input (IM) |
| L | L | L | H | MUX Input ( $\mathrm{I}_{\mathrm{M}}$ ) |
| L | L | H | L | 50 Baud |
| $L$ | L | H | H | 75 Baud |
| $L$ | H | L | L | 134.5 Baud |
| L | H | $L$ | H | 200 Baud |
| $L$ | H | H | L | 600 Baud |
| L | H | H | H | 2400 Baud |
| H | L | L | L | 9600 Baud |
| H | $L$ | $L$ | H | 4800 Baud |
| H | L | H | L | 1800 Baud |
| H | $L$ | H | H | 1200 Baud |
| H | H | L | L | 2400 Baud |
| H | H | L | H | 300 Baud |
| H | H | H | L | 150 Baud |
| H | H | H | H | 110 Baud |

NOTE. 19200 Baud by connecting $Q_{2}$ to $I_{M}$
select code and output bit rate. Two of the 16 select codes for the HD-4702/883 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 rates 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/883, which is easily achieved with a single 5-position switch.

The HD-4702/883 has an initialization circuit which generates a master reset for the scan counter. This signal is derived from a digital differentiator that senses the first high level on the CP input after the $\bar{E}_{C P}$ input goes low. When $\bar{E}_{C P}$ is high, selecting the crystal input, CP must be low. A high level on CP would apply a continuous reset. See Clock Modes and Initialization below.

| $I_{X}$ | $\bar{E}_{C P}$ | $C P$ | OPERATION |
| :---: | :---: | :---: | :--- |
| $\Gamma \Pi$ | $H$ | $L$ | Clocked from $I_{X}$ |
| $X$ | $L$ | $\Gamma$ | Clocked from CP |
| $X$ | $H$ | $H$ | Continuous Reset |
| $X$ | $L$ |  | Reset During 1st CP = High Time |

NOTE: Actual output frequency is 16 times the indicated Output Rate, assuming a clock frequency of 2.4576 MHz .
$H=H I G H$ Level
L = LOW Level
X = Don't Care
$\Omega \Omega=$ Clock Pulse
$\checkmark$ = 1st HIGH Level Clock Pulse after $\bar{E}_{C P}$ goes LOW

```
Absolute Maximum Ratings
Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0V
Input, Output or
    I/O Voltage Applied ................GND - 0.5V to V CCC + 0.5V
Storage Temperature Range .................. -65'.
Junction Temperature ................................ +1750
Lead Temperature (Soldering, 10 Seconds) .............. +300}\mp@subsup{}{}{\circ}\textrm{C
ESD Classfficatıon ....................................... . Class 1
Typical Derating Factor . . . . . . . . . . 1mA/MHz Increase in ICCOP
Typical Derating Factor . . . . . . . . . . . . . 1mA/MHz Increase in ICCOP
```

Reliability Information
Thermal Resistance, Junction-to-Case ( $0_{\text {jc }}$ ) Ceramic DIP Package ..... $+17.1^{\circ} \mathrm{C} / \mathrm{W}$
Thermal Resistance, Junction-to-Ambient $\left(0_{\mathrm{ja}}\right)$ Ceramic DIP Package ............................... . $+75.7^{\circ} \mathrm{C} / \mathrm{W}$ Maximum Package Power Dissipation @ $+125^{\circ} \mathrm{C}$ Ceramic DIP Package ..... 660mW
Gate Count ..... 720

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 operation section of this specification is not implied

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| D.C. PARAMETERS | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input High Voltage | VIH | $V_{C C}=45 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\mathrm{V}_{\mathrm{CC}} 70 \%$ | - | $\checkmark$ |
| Input Low Voltage | VIL | $\mathrm{V}_{\mathrm{CC}}=45 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | $\mathrm{V}_{\text {CC }} 30 \%$ | V |
| Output High Voltage | VOH 1 | $10 \mathrm{H} \leq-1 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=45 \mathrm{~V}$, (Note 1) | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $\mathrm{v}_{\mathrm{CC}^{-01}}$ | - | V |
| Output Low Voltage | VOL1 | $1 \mathrm{OL} \leq+1 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=45 \mathrm{~V}$, (Note 1) | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 01 | V |
| Input High Current | 1 H | $\mathrm{V}_{I N}=\mathrm{V}_{\mathrm{CC}}$ All Other Pins $=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=55 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1 | +1 | $\mu \mathrm{A}$ |
| Input Low Current (IX Input) | IILX | $\begin{aligned} & V_{I N}=0 \mathrm{~V}, \text { All Other Pins }=V_{C C} \\ & V_{C C}=55 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | -1 | +1 | $\mu \mathrm{A}$ |
| Input Low Current (All Other Inputs) | IIL | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$, All Other Pins $=\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{CC}}=55 \mathrm{~V}$ (Note 2) | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | -100 | $\mu \mathrm{A}$ |
| Output High Current (OX) | IOHX | $V_{O U T}=V_{C C}-05, V_{C C}=4.5 \mathrm{~V}$ Input at OV or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -01 | - | mA |
| Output High Current (All Other Outputs) | OH 1 | $V_{O U T}=25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=45 \mathrm{~V}$ Input at OV or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | - | mA |
| Output High Current (All Other Outputs) | 1 OH 2 | $V_{\text {OUT }}=V_{C C}-05, V_{C C}=45 \mathrm{~V}$ Input at OV or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -03 | - | mA |
| Output Low Current (OX) | IOLX | $\mathrm{V}_{\mathrm{OUT}}=04 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=45 \mathrm{~V}$ Input at $O V$ or $V_{C C}$ per Logic Function or Truth Table | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 01 | - | mA |
| Output Low Current (All Other Outputs) | IOL | $\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=45 \mathrm{~V}$ Input at OV or $\mathrm{V}_{\mathrm{CC}}$ per Logic Function or Truth Table | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 16 | - | mA |
| Supply Current (Static) | ICC | $\begin{aligned} & \bar{E}_{C P}=V_{C C}, C P=0 \mathrm{~V}, \mathrm{~V}_{C C}=5.5 \mathrm{~V} \\ & \text { All Other Inputs }=G N D,(\text { Note } 2) \\ & \bar{E}_{C P}=V_{C C}, C P=0 \mathrm{~V}, \mathrm{~V}_{C C}=55 \mathrm{~V} \\ & \text { All Other Inputs }=\mathrm{V}_{\mathrm{CC}},(\text { Note } 2) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | - | $\begin{aligned} & 1500 \\ & 1000 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |

## NOTES

1. Interchanging of force and sense conditions is permitted
2. Input Current and Quiescent Power Supply Current are relatively higher for this device because of active pull-up circuits on all inputs except ${ }^{\prime} \mathrm{X}$

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested.

| A.C. PARAMETERS | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LImits |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Propagation Delay, IX to CO | tPLH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 350 | ns |
|  | tPHL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 275 | ns |
| Propagation Delay, CP to CO | tPLH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 260 | ns |
|  | tPHL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 220 | ns |
| Propagation Delay, CO to Qn | tPLH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | (Note 2) | ns |
|  | tPHL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | (Note 2) | ns |
| Propagation Delay, CO to Z | tPLH | $\left\{\begin{array}{c} \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ \mathrm{CL} \leq 7 \mathrm{pF} \text { on } \mathrm{OX} \\ \mathrm{CL}=50 \mathrm{pF} \\ \text { (Note } 1 \text { ) } \end{array}\right.$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | - | 85 | ns |
|  | tPHL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | - | 75 | ns |
| Output Transition Time (Except Ox) | tTLH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 160 | ns |
|  | tTHL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 75 | ns |
| Set-Up Time, Select to CO | ts |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 350 | - | ns |
| Hold Time, Select to CO | th |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | ns |
| Set-Up Time, IM to CO | ts |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 350 | - | ns |
| Hold Time, IM to CO | th |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | ns |
| Minimum Clock Pulse Width, Low (Notes 3, 4) | twCP(L) |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 120 | - | ns |
| Minimum Clock Pulse Width, High (Notes 3, 4) | twCP(H) |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 120 | - | ns |
| Minimum IX Pulse Width, Low (Note 4) | twCP(L) |  | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\text {A }} \leq+125^{\circ} \mathrm{C}$ | 160 | - | ns |
| Minimum IX Pulse Width, High (Note 4) | twCP(H) |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 160 | - | ns |

## NOTES:

1. Propagation Delays ( tPLH and tPHL) and Output Transition Tımes (tTLH and tTHL) will change with Output Load Capacitance (CL). Set-up Times (ts), Hold Times (th), and Minimum Pulse Widths (tw) do not vary with load capacitance.
2. For multichannel operation, Propagation Delay (CO to $\mathrm{Qn}_{\mathrm{n}}$ ) plus Set-Up Time, Select to CO , is guaranteed to be $\leq 367 \mathrm{~ns}$.
3. The first High Level Clock Pluse after $\bar{E}_{C P}$ goes Low 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 n \mathrm{~ns}$.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| A.C. PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | CIN | All Measurements are referenced to device ground, $f=1 \mathrm{MHz}$. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 7.0 | pF |
| Output Capacitance | CO |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15.0 | pF |
| Propagation Delay IX to CO | tPLH | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ \mathrm{CL} \leq 7 \mathrm{pF} \text { on } \mathrm{OX} \\ \mathrm{CL}=15 \mathrm{pF} \end{gathered}$ | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 300 | ns |
|  | tPHL |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 250 | ns |
| Propagation Delay CP to CO | tPLH |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 215 | ns |
|  | tPHL |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 195 | ns |
| Propagation Delay CO to Qn | tPLH |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | (Note 2) | ns |
|  | tPHL |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | (Note 2) | ns |
| Propagation Delay CO to Z | tPLH |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 75 | ns |
|  | tPHL |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 65 | ns |
| Output Transition Time (Except Ox) | tTLH |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 80 | ns |
|  | tTHL |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 40 | ns |

NOTES: 1. The parameters listed in table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterızed upon initial design and after major process and/or design changes.
2. For multichannel operation, Propagation Delay ( CO to Qn ) plus Set-Up Tıme, Select to CO , is guaranteed to be $\leq 367 \mathrm{~ns}$.
3. Propagation Delays (tPLH and tPHL) and Output Transition Tımes ( t TLH and tTHL ) will change with Output Load Capacitance (CL). Set-up Times (ts), Hold Times (th), and Minimum Pulse Widths (tw) do not vary with load capacitance.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

## Burn-In Circuit

HD-4702/883 CERAMIC DIP


NOTES. $F_{0}=100 \mathrm{KHz} \pm 10 \%, F_{1}=F_{0 / 2}, F_{2}=F_{1 / 2}, \ldots$
$\mathrm{R}_{1}=10 \mathrm{k} \Omega, 1 / 4 \mathrm{~W}, \pm 10 \%$
$\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}$
$\mathrm{C}_{1}=0.01 \mu \mathrm{~F}$ minimum

Packaging


## Metallization Topology

DIE DIMENSIONS:
$100 \times 97 \times 19$ mils
METALLIZATION:
Type: Si - Al
Thickness: $10 \mathrm{k} \AA-12 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $7 \mathrm{k} \AA-9 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold/Silicon Eutectic Alloy
Temperature: Ceramic DIP - 460 ${ }^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$7.1 \times 10^{4} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout
HD-4702/883


## CMOS Universal Asynchronous Receiver Transmitter (UART)

## Features

- 8.0MHz Operating Frequency (HD-6402B)
- 2.0MHz Operating Frequency (HD-6402R)
- Low Power CMOS Design
- Programmable Word Length, Stop Bits and Parity
- Automatic Data Formatting and Status Generation
- Compatible with Industry Standard UARTs
- Single +5V Power Supply
- CMOS/TTL Compatible Inputs

Ordering Information

| PACKAGE | TEMP. RANGE | $2 \mathrm{MHz}=$ 125K BAUD | $\begin{gathered} 8 \mathrm{MHz}= \\ 500 \mathrm{~K} \text { BAUD } \end{gathered}$ |
| :---: | :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD3-6402R-9 | HD3-6402B-9 |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD1-6402R-9 | HD1-6402B-9 |
| */883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \text { HD1-6402R/ } \\ & 883 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { HD1-6402B/ } \\ & 883 \end{aligned}$ |
| SMD\# |  | $\begin{aligned} & \text { 5962-9052501 } \\ & \text { MQA } \end{aligned}$ | $\begin{aligned} & \text { 5962-9052502 } \\ & \text { MQA } \end{aligned}$ |

* Respective $/ 883$ specrications are included at the end of this data sheet


## Description

The HD-6402 is a CMOS UART for interfacing computers or microprocessors to an asynchronous serial data channel. The receiver converts serial start, data, 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 acquisition systems. Utilizing the Harris advanced scaled SAJI IV CMOS process permits operation clock frequencies up to 8.0 MHz ( 500 K Baud). Power requirements, by comparison, are reduced from 300 mW to 10 mW . Status logic increases flexibility and simplifies the user interface.

|  | (10) | Control Definition |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CONTROL WORD |  |  |  |  |  | HARAC | R FORMA |  |
|  |  | $\begin{gathered} \hline \text { CLS } \\ 2 \end{gathered}$ | $\begin{gathered} \hline \text { CLS } \\ 1 \end{gathered}$ | PI | EPE | SBS | $\begin{array}{\|c} \text { START } \\ \text { BIT } \end{array}$ | $\begin{aligned} & \text { DATA } \\ & \text { BITS } \end{aligned}$ | PARITY BIT | $\begin{aligned} & \text { STOP } \\ & \text { BITS } \end{aligned}$ |
|  |  | 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 | x | 0 | 1 | 8 | NONE | 1 |
|  |  | 1 | 1 | 1 | X | 1 | 1 | 8 | NONE | 2 |

## Functional Diagram



## Pin Description

| PIN | TYPE | SYMBOL | DESCRIPTION | PIN | TYPE | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 2 3 |  | VCC** NC GND | Positive Voltage Supply No Connection Ground | 16 | 1 | SFD | A high level on STATUS FLAGS DISABLE forces the outputs PE, FE, OE, DR, TBRE to a high impedance state. |
| 4 | 1 | RRD | A high level on RECEIVER REGISTER DISABLE forces the receiver holding outputs RBR1-RBR8 to high impedance state. | 17 18 | 1 | RRC $\overline{\text { DRR }}$ | The Receiver register clock is 16 X the receiver data rate. <br> A low level on DATA RECEIVED RESET |
| 5 | 0 | RBR8 | puts RBR1-RBR8 to high impedance state. <br> The contents of the RECEIVER BUFFER REGISTER appear on these three-state outputs. Word formats less than 8 characters are right justified to RBR1. | 18 19 | 0 | DR | clears the data received output DR to a low level. <br> A high level on DATA RECEIVED indicates a character has been received and transferred to the receiver buffer register. |
| 6 | 0 | RBR7 | See Pin 5-RBR8 | 20 | 1 | RRI | Serial data on RECEIVER REGISTER IN- |
| 8 | 0 | RBR65 | See Pin 5-RBR8 |  |  |  | PUT is clocked into the receiver register. |
| 9 | 0 | RBR4 | See Pin 5-RBR8 | 21 | 1 | MR | A high level on MASTER RESET clears PE, FE, OE and DR to a low level and sets the |
| 10 | 0 | RBR3 | See Pin 5-RBR8 |  |  |  | transmitter register empty (TRE) to a |
| 11 | 0 | RBR2 | See Pin 5-RBR8 |  |  |  | high level 18 clock cycles after MR falling edge. MR does not clear the receiver buffer |
| 12 | 0 | RBR1 | See Pin 5-RBR8 |  |  |  | register. This input must be pulsed at least |
| 13 | 0 | 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. |  |  |  | once after power up. The HD-6402 must be master reset after power up. The reset pulse should meet VIH and tMR $^{2}$. Wait 18 clock cycles after the falling edge of MR |
| 14 | 0 | FE | A high level on FRAMING ERROR indicates the first stop bit was invalid. | 22 | 0 | TBRE | before beginning operation. <br> A high level on TRANSMITTER BUFFER |
| 15 | 0 | OE | A high level on OVERRUN ERROR indicates the data received flag was not cleared before the last character was transferred to the receiver buffer register. |  |  |  | REGISTER EMPTY indicates the transmitter buffer register has transferred its data to the transmitter register and is ready for new data. |

* A $0.1 \mu \mathrm{~F}$ decoupling capacitor from the VCC pin to the GND is recommended.


| PIN | TYPE | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 23 | 1 | 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 initiates data transfer to the transmitter register. If busy, transfer is automatically delayed so that the two characters are transmitted end to end. |
| 24 | 0 | TRE | A high level on TRANSMITTER REGISTER EMPTY indicates completed transmission of a character including stop bits. |
| 25 | 0 | TRO | Character data, start data and stop bits appear serially at the TRANSMITTER REGISTER OUTPUT. |
| 26 | 1 | TRB1 | 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 their programmed word length. |
| 27 | 1 | TBR2 | See Pin 26-TBR1. |
| 28 | 1 | TBR3 | See Pin 26-TBR1. |
| 29 | 1 | TBR4 | See Pin 26-TBR1. |
| 30 | 1 | TBR5 | See Pin 26-TBR1. |


| PIN | TYPE | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 31 | 1 | TBR6 | See Pin 26-TBR1. |
| 32 | 1 | TBR7 | See Pin 26-TBR1. |
| 33 | 1 | TBR8 | See Pin 26-TBR1. |
| 34 | 1 | CRL | A high level on CONTROL REGISTER LOAD loads the control register with the control word. The control word is latched on the falling edge of CRL. CRL may be tied high. |
| 35 | 1 | PI | A high level on PARITY INHIBIT inhibits parity generation, parity checking and forces PE output low. |
| 36 | 1 | 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 | 1 | 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 | 1 | CLS1 | See Pin 37-CLS2. |
| 39 | 1 | EPE | When PI is low, a high level on EVEN PARITY ENABLE generates and checks even parity. A low level selects odd parity. |
| 40 | 1 | TRC | The TRANSMITTER REGISTER CLOCK is 16X the transmit data rate. |

## Transmitter Operation

The transmitter section accepts parallel data, formats the data and transmits the data in serial form on the Transmitter Register Output (TRO) terminal (See serial data format). Data is loaded from the inputs TBR1-TBR8 into the Transmitter Buffer Register by applying a logic low on the Transmitter Buffer Register Load (TBRL) input (A). Valid data must be present at least $\mathrm{t}_{\text {set }}$ prior to and thold following the rising edge of TBRL. If words less than 8 bits are used, only the least significant bits are transmitted. The character is right justified, so the least significant bit corresponds to TBR1 (B).

The rising edge of TBRL clears Transmitter Buffer Register Empty (TBRE). 0 to 1 Clock cycles later, data is transferred to the transmitter register, the Transmitter Register Empty (TRE) pin goes to a low state, TBRE is set high and serial data information is transmitted. The output data is clocked by Transmitter Register Clock (TRC) at a clock rate 16 times the data rate. A second low level pulse on TBRL loads data into the Transmitter Buffer Register (C). Data transfer to the transmitter register is delayed until transmission of the current data is complete (D). Data is automatically transferred to the transmitter register and transmission of that character begins one clock cycle later.

TRANSMITTER TIMING
(NOT TO SCALE)


## Receiver Operation

Data is received in serial form at the Receiver Register Input (RRI). When no data is being received, RRI must remain high. The data is clocked through the Receiver Register Clock (RRC). The clock rate is 16 times the data rate. A low level on Data Received Reset ( $\overline{\mathrm{DRR}}$ ) clears the Data Receiver (DR) line (A). During the first stop bit data is transferred from the Receiver Register to the Receiver Buffer Register (RBR) (B). 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 Overrun Error (OE) indicates overruns. An overrun occurs when DR has not been cleared before the present character was transferred to the RBR. One clock cycle later DR is reset to a logic high, and Framing Error (FE) is evaluated (C). A logic high on FE indicates an invalid stop bit was received, a framing error. A logic high on Parity Error (PE) indicates a parity error.

RECEIVER TIMING
(NOT TO SCALE)


## Start Bit Detection

The receiver uses a 16 X clock timing. The start bit could have occurred as much as one clock cycle before it was detected, as indicated by the shaded portion (A). The center of the start bit is defined as clock count $7 \mathbf{1 / 2}$. If the receiver clock is a symmetrical square wave, the center of the start
bit will be located within $\pm 1 / 2$ clock cycle, $\pm 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.


## Interfacing With The HD-6402



TYPICAL SERIAL DATA LINK

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output or I/O VoltageApplied | GND-0.5V to VCC +0.5 V |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature . | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {j }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $48.3{ }^{\circ} \mathrm{CN}$ | $14.8{ }^{\circ} \mathrm{CM}$ |
| Maximum Package Powe | $125^{\circ} \mathrm{C}$ |  |
| Ceramic DIP Package |  | WW |
| Gate Count |  | 43 G |

Typical Derating Factor . . . . . . . . . . . . . 1mAMHz Increase in ICCOP
CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range +4.5 V to +5.5 V

Operating Temperature Range HD-6402R-9, HD6402B-9
$40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

DC Electrical Specifications $V C C=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HD-6402R-9, HD-6402B-9)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| VIH | Logical "1" Input Voltage | 2.0 | - | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VIL | Logical "0" Input Voltage | - | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| 11 | Input Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{GND}$ or VCC, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOH | Logical "1" Output Voltage | $\begin{gathered} 3.0 \\ \operatorname{vcc}-0.4 \end{gathered}$ | - | V | $\begin{aligned} & 1 \mathrm{OH}=-2.5 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V} \\ & \mathrm{IOH}=-100 \mu \mathrm{~A} \end{aligned}$ |
| VOL | Logical "0" Output Voltage | - | 0.4 | V | $1 \mathrm{OL}=+2.5 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| 10 | Output Leakage Current | -1.0 | 1.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{GND}$ or VCC, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCSB | Standby Supply Current | - | 100 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{GND}$ or VCC; $\mathrm{VCC}=5.5 \mathrm{~V}$, Output Open |
| ICCOP | Operating Supply Current* | - | 2.0 | mA | VCC $=5.5 \mathrm{~V}$, Clock Freq. $=2 \mathrm{MHz}$, VIN = VCC or GND, Outputs Open |

*Guaranteed, but not $100 \%$ tested
Capacitance $T A=+25^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | CONDITIONS | LIMIT |  |
| :--- | :---: | :--- | :---: | :---: |
|  | CIN | Freq. $=1 \mathrm{MHz}$, all measurements are referenced to de- <br> vice GND | 25 | pF |
| Input Capacitance | COUT |  | 25 | pF |
| Output Capacitance |  |  |  |  |

AC Electrical Specifications $\quad V C C=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HD-6402R-9, HD6402B-9)

| SYMBOL | PARAMETER | LIMITS HD-6402R |  | LIMITS HD-6402B |  | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) fCLOCK | Clock Frequency | D. C. | 2.0 | D. C. | 8.0 | MHz | $C L=50 \mathrm{pF}$ <br> See Switching Waveform |
| (2) tPW | Pulse Widths, CRL, DRR, TBRL | 150 | - | 75 | - | ns |  |
| (3) TMR | Pulse Width MR | 150 | - | 150 | - | ns |  |
| (4) tSET | Input Data Setup Time | 50 | - | 20 | - | ns |  |
| (5) tHOLD | Input Data Hold Time | 60 | - | 20 | - | ns |  |
| (6) IEN | Output Enable Time | - | 160 | - | 35 | ns |  |

## Switching Waveforms



DATA INPUT CYCLE

CLS1, CLS2, SBS, PI, EPE


CONTROL REGISTER LOAD CYCLE

status flag output enable time OR DATA OUTPUT ENABLE TIME
A.C. Testing Input, Output Waveform

INPUT
OUTPUT


A C. Testing: All input signals must switch between VIL - 50\% VIL and VIH + 20\% VIH. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{N}$.

Test Circuit


* Includes stray and jig capacitance, $C L=50 \mathrm{pF}$

HARRIS

# CMOS Universal Asynchronous <br> Receiver Transmitter (UART) 

## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- 8.0MHz Operating Frequency (HD-6402B/883)
- 2.0MHz Operating Frequency (HD-6402R/883)
- Low Power CMOS Design
- Programmable Word Length, Stop Bits and Parity
- Automatic Data Formatting and Status Generation
- Compatible with Industry Standard UARTs
- Single +5V Power Supply
- CMOS/TTL Compatible Inputs


## Description

The HD-6402/883 is a CMOS UART for interfacing computers or microprocessors to an asynchronous serial data channel. The receiver converts serial start, data, 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/883 can be used in a wide range of applications including modems, printers, peripherals and remote data acquisition systems. Utilizing the Harris advanced scaled SAJI IV CMOS process permits operation clock frequencies up to 8.0 MHz ( 500 K Baud). Power requirements, by comparison, are reduced from 300 mW to 10 mW . Status logic increases flexibility and simplifies the user interface.

## Pinout

HD1-6402/883 (CERAMIC DIP)
TOP VIEW


## Control Definition

| CONTROL WORD |  |  |  |  | CHARACTER FORMAT |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \hline C \\ & L \\ & S \\ & 2 \end{aligned}$ | $\begin{aligned} & \hline \mathbf{C} \\ & \mathrm{L} \\ & \mathbf{S} \\ & \mathbf{1} \end{aligned}$ | $\begin{aligned} & \mathbf{P} \\ & \mathbf{I} \end{aligned}$ | $\begin{aligned} & \mathbf{E} \\ & \mathbf{P} \\ & \mathbf{E} \end{aligned}$ | $\begin{array}{\|l} \mathbf{S} \\ \mathbf{B} \\ \mathbf{S} \end{array}$ | $\left.\right\|_{\text {SIT }} ^{\text {START }}$ | DATA BITS | PARITY BIT | STOP 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 | x | 0 | 1 | 8 | NONE | 1 |
| 1 | 1 | 1 | X | 1 | 1 | 8 | NONE | 2 |

\author{
Absolute Maximum Ratings <br> Supply Voltage <br> . +8.0 V <br> Input, Output or I/O Voltage Applied .... GND-0.5V to VCC +0.5 V <br> Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ <br> Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ <br> Lead Temperature (Soldering 10 sec ) . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$ <br> ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1 <br> Typical Derating Factor . . . . . . . . . . . . $1 \mathrm{~mA} / \mathrm{MHz}$ Increase in ICCOP <br> CAUTION: Stresses above those listed in "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. <br> Reliability Information <br> 

## Operating Conditions

Operating Voltage Range $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots+4.5 \mathrm{~F}$ to +5.5 V
Operating Temperature Range . ................. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HD-6402/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested.

| D.C. PARAMETERS | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical "1" Input Voltage | VIH | $\mathrm{VCC}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.3 | - | $v$ |
| Logical "0" Input Voltage | VIL | $\mathrm{VCC}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Input Leakage Current | II | $\begin{aligned} & \mathrm{VIN}=\mathrm{GND} \text { or } \mathrm{VCC}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Logical "1" Output Voltage | VOH | $\begin{aligned} & 1 O H=-2.5 \mathrm{~mA}, \\ & \mathrm{VCC}=4.5 \mathrm{~V},(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Logical "1" Output Voltage | VOH | $\begin{aligned} & \mathrm{IOH}=-100 \mu \mathrm{~A}, \\ & \mathrm{VCC}=4.5 \mathrm{~V},(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \leq \underline{125}{ }^{\circ} \mathrm{C}$ | $\begin{aligned} & \hline \text { VCC } \\ & -0.4 \end{aligned}$ | - | V |
| Logical "0" Output Voltage | VOL | $\begin{aligned} & \mathrm{IOL}=+2.5 \mathrm{~mA}, \\ & \mathrm{VCC}=4.5 \mathrm{~V},(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Output Leakage Current | 10 | $\begin{aligned} & \mathrm{VO}=\mathrm{GND} \text { or } \mathrm{VCC}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB | $\begin{aligned} & \text { VIN = GND or VCC; } \\ & \text { VCC }=5.5 \mathrm{~V} \\ & \text { Output Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 100 | $\mu \mathrm{A}$ |

TABLE 2. HD-6402/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

|  |  |  |  |  | LIMITSHD-6402R/883 |  | $\begin{gathered} \text { LIMITS } \\ \text { HD-6402B/883 } \end{gathered}$ |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PARAMETERS | SYMBOL | CONDITIONS | SUBGROUPS | TEMPERATURE | MIN | MAX | MIN | MAX |  |
| Clock Frequency | (1) fCLOCK | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \mathrm{CL}=50 \mathrm{pF} \end{aligned}$ | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 2.0 | - | 8.0 | MHz |
| Pulse Widths, CRL, DRR, TBRL | (2) tpW |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 150 | - | 75 | - | ns |
| Pulse Width MR | (3) $t_{M R}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 150 | - | 150 | - | ns |
| Input Data Setup Time | (4) tSET |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | - | 20 | - | ns |
| Input Data Hold Time | (5) tHOLD |  | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 60 | - | 20 | - | ns |
| Output Enable Time | (6) tEN |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 160 | - | 35 | ns |

## NOTES:

1. Interchanging of force and sense conditions is permitted.

TABLE 3. HD-6402/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| A.C. PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | CIN | $f=1 \mathrm{MHz}$ <br> All Measurements are Referenced to Device GND | 3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 25.0 | pF |
| Output Capacitance | CO |  | 3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 25.0 | pF |
| Operating Supply Current | ICCOP | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V}, \\ & \text { Clock Freq. }=2 \mathrm{MHz} \\ & \text { VIN }=\text { VCC or GND, } \\ & \text { Outputs Open } \end{aligned}$ | 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 2.0 | mA |

NOTE• 3. The Parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Burn-In Circuits

## HD-6402/883 CERAMIC DIP



NOTES:
$\mathrm{VCC}=55 \mathrm{~V} \pm 05 \mathrm{~V}$
$F O=100 \mathrm{kHz} \pm 10 \%$
$R 1=47 \mathrm{k} \Omega, 1 / 4 \mathrm{~W} \pm 10 \%$
$\mathrm{C}=0.01 \mu \mathrm{~F}$ minimum
** One socket per board should not be loaded, but rather have pin 24 go the " $C$ " of the 4011.

## Metallization Topology

DIE DIMENSIONS: $126.4 \times 134.3 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si-Al
Thickness: $10 k \AA-12 k \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $7 \mathrm{k} \AA-9 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold/Silicon Eutectic Alloy
Temperature: Ceramic DIP - 4600 ${ }^{\circ}$ (Max)
WORST CASE CURRENT DENSITY: $1.42 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout
HD-6402/883


## Packaging

40 PIN CERAMIC DIP


LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, MATERIALS: Compliant to MIL-M-38510

> CMOS Asynchronous Serial Manchester Adapter (ASMA)

Features

- Low Bit Error Rate
- Data Rate $\qquad$ $1 \mathrm{MBIt} / \mathrm{s}$
- Sync Identification and Lock-In
- Clock Recovery
- Manchester II Encoder, Decoder
- Separate Encode and Decode
- Low Operating Power . . . . . . . . . . . . . . . . . . . . . . . . . 50mW at 5V
- Single Power Supply
- 24 Pin Package


## Ordering Information

| PACKAGE | TEMP. RANGE | 1M BIT/s |
| :--- | :--- | :--- |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD3-6408-9 |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD1-6408-9 |

## Pinout

|  | 24 LEAD DIP TOP VIEW |  |
| :---: | :---: | :---: |
| vw 1 |  | 24 Vcc |
| Esc 2 |  | 23) EC |
| to 3 |  | 22 SCl |
| SDO 4 |  | 2 VD |
| DC 5 |  | 20 ss |
| BzI 6 |  | 198E |
| BOI 7 |  | 18 SDI |
| Udi 8 |  | 17 B00 |
| DSC 9 |  | 16 व |
| CDS 10 |  | 15 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 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. The 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 $12 \times$ clock and achieves data rates of up to one million bits per second with a very minimum ovemead of only 4 bits out of 20 , leaving 16 bits for data.

## Block Diagrams



| PIN | TYPE | SYMBOL | SECTION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | VW | Decoder | Output high indicates receipt of a VALID WORD. |
| 2 | 0 | ESC | Encoder | ENCODER SHIFT CLOCK is an output for shifting data into the Encoder. The Encoder samples SDI on the low-to-high transition of ESC. |
| 3 | 0 | TD | Decoder | TAKE DATA output is high during receipt of data after identification of a sync pulse and two valid manchester data bits. |
| 4 | 0 | SDO | Decoder | SERIAL DATA OUT delivers received data in correct NRZ format. |
| 5 | 1 | DC | Decoder | DECODER CLOCK input drives the transition finder, and the synchronizer which in turn supplies the clock to the balance of the Decoder. Input a frequency equal to 12 X the data rate. |
| 6 | 1 | 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 | 1 | 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 | 1 | 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 | 0 | DSC | Decoder | DECODER SHIFT CLOCK output delivers a frequency (DECODER CLOCK + 12), synchronized by the recovered serial data stream. |
| 10 | 0 | 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 | 1 | 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 | 1 | GND | Both | GROUND supply pin. |
| 13 | 1 | MR | Both | A high on MASTER RESET clears the 2:1 counters in both the encoder and decoder and the +6 counter. |
| 14 | 0 | DBS | Encoder | DIVIDE BY SIX is an output from 6:1 divider which is driven by the ENCODER CLOCK. |
| 15 | 0 | $\overline{\text { BZO }}$ | Encoder | $\overline{\text { BIPOLAR }} \overline{\text { ZERO }} \overline{O U T}$ is a active low output designed to drive the zero or negative sense of a bipolar line driver. |
| 16 | 1 | $\overline{\mathrm{O}}$ | Encoder | A low on OUTPUT $\overline{\text { INHIBIT }}$ forces pin 15 and 17 high, their inactive states. |
| 17 | 0 | $\overline{\mathrm{BOO}}$ | Encoder | $\overline{\text { BIPOLAR }} \overline{\text { ONE }} \overline{\text { OUT }}$ is an active low output designed to drive the one or positive sense of a bipolar line driver. |
| 18 | 1 | SDI | Encoder | SERIAL DATA IN accepts a serial data stream at a data rate equal to ENCODER SHIFT CLOCK. |
| 19 | 1 | EE | Encoder | A high on ENCODER ENABLE initiates the encode cycle. (Subject to the preceding cycle being complete.) |
| 20 | 1 | SS | Encoder | SYNC SELECT actuates a Command sync for an input high and data sync for an input low. |
| 21 | 0 | SD | Encoder | SEND DATA is an active high output which enables the external source of serial data. |
| 22 | 0 | SCl | Encoder | SEND CLOCK IN is 2 X the Encoder data rate. |
| 23 | 1 | EC | Encoder | ENCODER CLOCK is the input to the $6: 1$ divider. |
| 24 | 1 | $\mathrm{V}_{\mathrm{cc}}$ | Both | $\mathrm{V}_{\mathrm{CC}}$ is the +5 V power supply pin. $\mathrm{A} 0.1 \mu \mathrm{~F}$ decoupling capacitor from $\mathrm{V}_{\mathrm{CC}}$ (pin 24) to GND (pin 12) is recommended. |

## 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). If ENCODER ENABLE is held high continuously, consecutive words will be encoded without an interframe gap. ENCODER ENABLE must go low by time (5) as shown to prevent a consecutive word from being encoded. At any time a low on OI 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-tohigh transition on SCI 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 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{BOO}}$ of an Encoder through an inverter to UDI).

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 be shifted into
an external register on every low-to-high transition of this clock (2) - (3). Note that DECODER SHIFT CLOCK may adjust its phase up until the time that TAKE DATA goes high.

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.VALID WORD will go low approximately 20 DECODER SHIFT CLOCK periods after it goes high if not reset low sooner by a valid sync and two valid Manchester bits as shown (1).
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.


## Absolute Maximum Ratings <br> Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 V <br> Input, Output or I/O Voltage . . . . . . . . . . . . . . GND-0.3V to $\mathrm{V}_{\mathrm{cc}}+0.3 \mathrm{~V}$ <br> Storage Temperature Range $\ldots . . . . . . . . . . . . . . . . . . .5^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ <br> Junction Temperature <br> $+175^{\circ} \mathrm{C}$ <br> Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$ <br> ESD Classification <br> CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range +4.5 V to +5.5 V

Operating Temperature Range HD-6408-9
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

DC Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | TYP | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical "1" Input Voltage | $70 \% \mathrm{~V}_{\mathrm{CC}}$ |  |  | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical "0" Input Voltage |  | $20 \% \mathrm{VCC}$ |  | V |  |
| $\mathrm{V}_{\mathrm{IHC}}$ | Logical "1" Input Voltage (Clock) | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  |  | V |  |
| $\mathrm{~V}_{\mathrm{ILC}}$ | Logical "0" Input Voltage (Clock) |  | GND +0.5 |  | V |  |
| II | Input Leakage | -1.0 |  | +1.0 | $\mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND, DIP Pins <br> $5-8,11,13,16,18,19,20,22,23$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Logical "1" Output Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Logical "0" Output Voltage |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CCSB}}$ | Supply Current Standby |  | 0.5 | 2 | mA | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ Outputs Open |
| $\mathrm{I}_{\mathrm{CCOP}}$ | Supply Current Operating* |  |  | 8.0 | 10.0 | mA |
| $\mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{f}=15 \mathrm{MHz}$ |  |  |  |  |  |  |

AC Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | TYP | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ENCODER TIMING |  |  |  |  |  |  |
| (1) $\mathrm{F}_{\mathrm{EC}}$ | Encoder Clock Frequency | 0 |  | 12 | MHz | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (2) $\mathrm{F}_{\text {ESC }}$ | Send Clock Frequency | 0 |  | 2.0 | MHz | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (3) $\mathrm{T}_{\mathrm{ECR}}$ | Encoder Clock Rise Time |  |  | 8 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (4) $T_{E C F}$ | Encoder Clock Fall Time |  |  | 8 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (5) $\mathrm{F}_{\mathrm{ED}}$ | Data Rate | 0 |  | 1.0 | MHz | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (6) $\mathrm{T}_{\text {MR }}$ | Master Reset Pulse Width | 150 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (7) $\mathrm{T}_{\mathrm{E}_{1}}$ | Shift Clock Delay |  |  | 125 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (8) $\mathrm{T}_{\mathrm{E}_{2}}$ | Serial Data Setup | 75 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (9) $\mathrm{T}_{\mathrm{E}_{3}}$ | Serial Data Hold | 75 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (10) $T_{E 4}$ | Enable Setup | 90 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (11) $\mathrm{T}_{\text {E5 }}$ | Enable Pulse Width | 100 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (12) $T_{E 6}$ | Sync Setup | 55 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (13) $\mathrm{T}_{\mathrm{EF}}$ | Sync Pulse Width | 150 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (14) $\mathrm{T}_{\text {E8 }}$ | Send Data Delay | 0 |  | 50 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (15) $\mathrm{T}_{\text {E9 }}$ | Bipolar Output Delay |  |  | 130 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (16) $T_{E 10}$ | Enable Hold | 10 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (17) $T_{E 11}$ | Sync Hold | 95 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |

AC Electrical Specifications (Continued) $V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | TYP | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DECODER TIMING |  |  |  |  |  |  |
| (18) $F_{D C}$ | Decoder Clock Frequency | 0 |  | 12 | MHz | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (19) $T_{D C R}$ | Decoder Clock Rise Time |  |  | 8 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (20) $T_{\text {DCF }}$ | Decoder Clock Fall Time |  |  | 8 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (21) $F_{D D}$ | Data Rate | 0 |  | 1.0 | MHz | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (22) $\mathrm{T}_{\mathrm{DR}}$ | Decoder Reset Pulse Width | 150 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (23) $\mathrm{T}_{\text {DRS }}$ | Decoder Reset Setup Time | 75 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (24) $\mathrm{T}_{\text {DRH }}$ | Decoder Reset Hold Time | 10 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (25) $\mathrm{T}_{\text {MR }}$ | Master Reset Pulse Width | 150 |  |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (26) $T_{D_{1}}$ | Bipolar Data Pulse Width | $\mathrm{T}_{\mathrm{DC}}+10$ |  |  | ns | Note 1, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (27) $\mathrm{T}_{\mathrm{D} 2}$ | Sync Transition Span |  | ${ }^{18 T_{D C}}$ |  | ns | Note 1, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (28) $\mathrm{T}_{\mathrm{D} 3}$ | One Zero Overlap |  |  | $\mathrm{T}_{\mathrm{DC}}$-10s | ns | Note 1, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (29) $T_{D 4}$ | Short Data Transition Span |  | 6TDC |  | ns | Note 1, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (30) $\mathrm{T}_{\mathrm{D5}}$ | Long Data Transition Span |  | 12TDC |  | ns | Note 1, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (31) $T_{D 6}$ | Sync Delay (ON) | -20 |  | 110 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (32) $T_{D 7}$ | Take Data Delay (ON) | 0 |  | 110 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (33) $\mathrm{T}_{\mathrm{DB}}$ | Serial Data Out Delay |  |  | 80 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (34) $T_{D 9}$ | Sync Delay (OFF) | 0 |  | 110 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (35) $T_{010}$ | Take Data Delay (OFF) | 0 |  | 110 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| (36) $\mathrm{T}_{\mathrm{D} 11}$ | Valid Word Delay | 0 |  | 110 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |

NOTE:

1. $T_{D C}=$ Decoder Clock Period $=1 / F_{D C}$.
(These parameters are guaranteed but not $100 \%$ tested).

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | TYP | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | - | 15 | - | pF | FREQ $=1$ MHz, all mea- <br> surements are referenced <br> to device GND |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance | - | 15 | - | pF |  |

## AC Testing Input, Output Waveform



AC TESTING: All input signals must switch between VIL and VIH. Input rise and fall times are driven at ins per volt.

Encoder Timing

$\overline{\text { BOO OR } \overline{B Z O}}$


## Decoder Timing

NOTE UI © 0 FOR NEXT DIAGRAM


## CMOS Manchester Encoder-Decoder

## 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
- Low Operating Power: 50mW Typical at +5V
- Available in $\mathbf{2 0}$ Pin Dual-In-Line and 20 Pad LCC Package


## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 1 MEGABIT/SEC |
| :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD3-6409-9 |
| SOIC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD9P6409-9 |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD1-6409 |
| */883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HD1-6409/883 |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD4-6409-9 |
| */883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HD4-6409/883 |

*Respective $/ 883$ specifications are included at the end of this data sheet.

## Description

The HD-6409 Manchester Encoder-Decoder (MED) is a high speed, low power device manufactured using selfaligned 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-toZero 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.

Pinouts

20 LEAD DIP 20 LEAD SOIC TOP VIEW


20 LEAD LCC TOP VIEW


## Block Diagram



## Logic Symbol



## Pin Description

| PIN NUMBER | TYPE | SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 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 | I | 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(\mathrm{BZI})$ and pin $2(\mathrm{BOI})$ for data input, UDI must be held low. |
| 4 | 1/0 | 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 falling edge 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{R S T}$ is low. |
| 6 | 0 | $\overline{\text { SRST }}$ | $\overline{\text { Serial }} \overline{\text { Reset }}$ | In the converter mode, $\overline{\text { SRST }}$ follows $\overline{\operatorname{RST}}$. In the repeater mode, when $\overline{\operatorname{RST}}$ goes low, $\overline{\text { SRST goes low and remains low after } \overline{\mathrm{RST}} \text { goes }}$ high. $\overline{\text { SRST }}$ goes high only when $\overline{R S T}$ is high, the reset bit is zero, and a valid synchronization sequence is received. |
| 7 | 0 | $\overline{\text { NVM }}$ | $\overline{\text { Nonvalid }} \overline{\text { 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{\text { RST }}$, and remains low after $\overline{\text { 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 BOI to synchronously output received NRZ data (SDO). |
| 9 | 1 | $\overline{\mathrm{RST}}$ | $\overline{\text { Reset }}$ | In the converter mode, a low on $\overline{R S T}$ forces SDO, DCLK, $\overline{\text { NVM }}$, and $\overline{\text { SRST }}$ low. A high on $\overline{\operatorname{RST}}$ enables SDO and DCLK, and forces $\overline{\text { SRST }}$ high. $\overline{\text { NVM }}$ remains low 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{N V M}$ as in the converter mode. When $\overline{R S T}$ goes low, $\overline{\text { 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 Description (Continued)

| PIN NUMBER | TYPE | SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| 10 | 1 | GND | Ground | Ground |
| 11 | O | $\mathrm{C}_{0}$ | Clock Output | Buffered output of clock input IX. May be used as clock signal for other peripherals. |
| 12 | 1 | 'x | Clock Input | I X is the input for an external clock or, if the internal oscillator is used, IX and OX are used for the connection of the crystal. |
| 13 | - | $\mathrm{O}^{\text {x }}$ | Clock Drive | If the internal oscillator is used, $\mathrm{OX}_{\mathrm{X}}$ and I X are used for the connection of the crystal. |
| 14 | 1 | MS | Mode Select | MS must be held low for operation in the converter mode, and high for operation in the repeater mode. |
| 15 | 1 | $\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 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{C T S}$ 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 | 1 | 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 }} \overline{\text { Zero }} \overline{\overline{\text { 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 | $\bigcirc$ | $\overline{\mathrm{BOO}}$ | $\overline{\text { Bipolar }} \overline{\mathrm{One}} \overline{\mathrm{Out}}$ | See pin 18. |
| 20 | 1 | vcc | vcc | VCC is the +5 V power supply pin. A $0.1 \mu \mathrm{~F}$ decoupling capacitor from VCC (pin-20) to GND (pin-10) is recommended. |

(I) Input
(O) Output

## 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. CTS is used to control the encoder outputs, ECLK, $\overline{\mathrm{BOO}}$ and $\overline{\mathrm{BZO}}$. A free running 1 X 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 $\overline{\mathrm{CTS}}$ forces $\overline{\mathrm{BZO}}, \overline{\mathrm{BOO}}$ high and holds ECLK low. When $\overline{\mathrm{CTS}}$ 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 $11 / 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{B O O}$ and $\overline{B Z O}$ 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.


## Decoder Operation

The decoder requires a single clock with a frequency 16 X or $32 X$ the desired data rate. The rate is selected on the speed select with SS low producing a 16X clock and high a 32X 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 Bipolar 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 One Out through an inverter to Unipolar Data Input. The decoder continuously monitors this data input for 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 RST pin. When $\overline{\text { RST }}$ is low, SDO, DCLK and $\overline{\text { NVM }}$ are forced low. When $\overline{\mathrm{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, $\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.


## Repeater Operation

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 16X with Speed Select low and 32X 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 CTS enables ECLK, $\overline{\mathrm{BOO}}$, and BZO. In contrast to the converter mode, a transition on $\overline{\mathrm{CTS}}$ does not initiate a synchronization sequence of eight 0 's and a command sync. The repeater mode does recogize 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{\mathrm{RST}}$ is low, the outputs SDO, DCLK, and $\overline{\text { NVM }}$ are low, and $\overline{S R S T}$ is set low. $\overline{S R S T}$ remains low after $\overline{\text { RST }}$ goes high and is not reset until a sync pulse and two valid manchester bits are received with the reset bit low. The reset bit is the first data bit after the sync pulse. With RST high, NRZ Data is transmitted out of Serial Data Out synchronously with the $1 \times$ DCLK.

## 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 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 incomming 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.


## Crystal Oscillator Mode



LC Oscillator Mode


## Using the 6409 as a Manchester Encoded UART



| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +7.0V |
| Input, Output or I/O Voltage | GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Absolute Maximum Ratings

## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $83^{\circ} \mathrm{C} / \mathrm{W}$ | $23^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $84^{\circ} \mathrm{C} / \mathrm{W}$ | $24^{\circ} \mathrm{C}$ |

Ceramic DIP Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 602mW
Ceramic LCC Package . . . . . . . . . . . . . . . . . . . . . . . . . . . 595mW
Gate Count . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 250 Gates

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Temperature Range . . . . . . . . . . . . . . . . . . . . $-45^{\circ} \mathrm{C}$ 部 to $+85^{\circ} \mathrm{C}$ to +5.5 V
Operating Voltage Range . . . . . . . . . . . . . . .

NOTES:

1. DBP-Data Bit Period, Clock Rate $=16 \mathrm{X}$, one DBP $=16$ Clock Cycles; Clock Rate $=32 \mathrm{X}$, one DBP $=32$ Clock Cycles.
2. The input conditions specified are nominal values, the actual input waveforms transition spans may vary by $\pm 2 I_{X}$ clock cycles ( 16 X mode) or $\pm 6 \mathrm{I}_{\mathrm{X}}$ clock cycles ( 32 X mode).

Sync. Transition Span (t2) . . . . . . . . . . 1.5 DBP Typical, (Notes 1, 2) Short Data Transition Span (t4). . . . . . . . . 5 DBP Typical, (Notes 1, 2) Long Data Transition Span (t5) . . . . . . . 1.0DBP Typical, Notes 1, 2) Zero Crossing Tolerance (tCD5) . Note 3)
3. The maximum zero crossing tolerance is $\pm 21_{x}$ clock cycles ( $16 X$ mode) or $\pm 61_{\mathrm{x}}$ clock cycles ( 32 mode) from the nominal.

DC Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ}$ (HD-6409-9)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | (NOTE 1) TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{H}}$ | Logical "1" Input Voltage | $70 \% \mathrm{~V}_{\mathrm{Cc}}$ | - | V | $\mathrm{V}_{\mathrm{cC}}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Logical "0" Input Voltage | - | 20\% V ${ }_{\text {c }}$ | V | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IHR }}$ | Logic "1" Input Voltage ( $\overline{\text { Reset }}$ ) | $\mathrm{V}_{\mathrm{cc}}-0.5$ | - | V | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {ILR }}$ | Logic "0" Input Voltage (Reset) | - | GND +0.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{HC}}$ | Logical "1" Input Voltage (Clock) | $\mathrm{V}_{\mathrm{CC}}-0.5$ | - | V | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {ILC }}$ | Logical "0" Input Voltage (Clock) | - | GND +0.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| 1 | Input Leakage Current (Except $\mathrm{I}_{\mathrm{x}}$ ) | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| 1 | Input Leakage Current (1x) | -20 | +20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{CND}, \mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$ |
| 10 | I/O Leakage current | -10 | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage (All except $\mathrm{O}_{\mathrm{x}}$ ) | $\mathrm{V}_{\mathrm{CC}}-0.4$ | - | V | $\mathrm{l}_{\mathrm{OH}}=-2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ (Note 2) |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage (All except $\mathrm{O}_{\mathrm{x}}$ ) | - | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ (Note 2) |
| Iccse | Standby Power Supply Current | - | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{iN}}=\mathrm{V}_{\mathrm{CC}} \text { or GND, } \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \text {, } \\ & \text { Outputs Open } \end{aligned}$ |
| Iccop | Operating Power Supply Current | $\bullet$ | 18.0 | mA | $\begin{aligned} & f=16.0 \mathrm{MHz}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \end{aligned}$ |
| $\mathrm{F}_{T}$ | Functional Test | - | - | - | (Note 1) |

NOTES:

1. Tested as follows: $f=16 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=70 \% \mathrm{~V}_{\mathrm{cc}}, \mathrm{V}_{\mathrm{IL}}=20 \% \mathrm{~V}_{\mathrm{CC}}$, $\mathrm{V}_{\mathrm{OH}} \geq \mathrm{V}_{\mathrm{Cd}}{ }^{2}$, and $\mathrm{V}_{\mathrm{OL}} \leq \mathrm{V}_{\mathrm{CC}}{ }^{2} 2, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V .
2. Interchanging of force and sense conditions is permitted

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$, Frequency $=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | TYP | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 10 | pF | All measurements are referenced to device GND |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 12 | pF |  |

AC Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( $\mathrm{HD}-6409-9$ )

| SYMBOL | PARAMETER | MIN | MAX | UNITS | (NOTE 1) TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{c}}$ | Clock Frequency | - | 16 | MHz | - |
| $\mathrm{t}_{\mathrm{c}}$ | Clock Period | $1 /{ }_{c}$ | - | Sec | - |
| $t_{1}$ | Bipolar Pulse Width | $\mathrm{t}_{\mathrm{C}+10}$ | - | ns | - |
| $\mathrm{t}_{3}$ | One-Zero Overlap | - | $\mathrm{tc}_{\mathrm{c}-10}$ | ns | - |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock High Time | 20 | - | ns | $\mathrm{f}=16.0 \mathrm{MHz}$ |
| $\mathrm{t}_{\mathrm{CL}}$ | Clock Low Time | 20 | - | ns | $\mathrm{f}=16.0 \mathrm{MHz}$ |
| $\mathrm{t}_{\mathrm{CE} 1}$ | Serial Data Setup Time | 120 | - | ns | - |
| $\mathrm{t}_{\text {CE2 }}$ | Serial Data Hold Time | 0 | - | ns | - |
| $\mathrm{t}_{\mathrm{CD} 2}$ | DCLK to SDO, $\overline{\text { NVM }}$ | - | 40 | ns | - |
| $\mathrm{t}_{\mathrm{R} 2}$ | ECLK to BZO | - | 40 | ns | - |
| $\mathrm{t}_{\mathrm{r}}$ | Output Rise Time (All except Clock) | - | 50 | ns | From 1.0V to 3.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$, Note 2 |
| $t_{\text {f }}$ | Output Fall Time (All except Clock) | $\cdot$ | 50 | ns | From 3.5V to $1.0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$, Note 2 |
| $\mathrm{t}_{\mathrm{r}}$ | Clock Output Rise Time | - | 11 | ns | From 1.0V to $3.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$, Note 2 |
| $t_{4}$ | Clock Output Fall Time | - | 11 | ns | From 3.5V to $1.0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$, Note 2 |
| $\mathrm{t}_{\text {ce3 }}$ | ECLK to $\overline{\mathrm{BZO}}, \overline{\mathrm{BOO}}$ | 0.5 | 1.0 | DBP | Notes 2, 3 |
| $\mathrm{t}_{\text {CE4 }}$ | $\overline{\mathrm{CTS}}$ Low to $\overline{\mathrm{BZO}}, \overline{\mathrm{BOO}}$ Enabled | 0.5 | 1.5 | DBP |  |
| $\mathrm{t}_{\text {ce5 }}$ | $\overline{\text { CTS }}$ Low to ECLK Enabled | 10.5 | 11.5 | DBP |  |
| $\mathrm{t}_{\text {ce6 }}$ | $\overline{\text { CTS }}$ High to ECLK Disabled | - | 1.0 | DBP |  |
| $\mathrm{t}_{\text {CE7 }}$ | $\overline{\text { CTS }}$ High to $\overline{\mathrm{BZO}}, \overline{\mathrm{BOO}}$ Disabled | 1.5 | 2.5 | DBP |  |
| $\mathrm{t}_{\mathrm{CD} 1}$ | UDI to SDO, $\overline{\text { NVM }}$ | 2.5 | 3.0 | DBP |  |
| $\mathrm{t}_{\mathrm{CO3}}$ | $\overline{\text { RST }}$ Low to CDLK, SDO, $\overline{\text { NVM }}$ Low | 0.5 | 1.5 | DBP |  |
| $\mathrm{t}_{\mathrm{CD} 4}$ | RST High to DCLK, Enabled | 0.5 | 1.5 | DBP |  |
| $\mathrm{t}_{\mathrm{R} 1}$ | UDI to $\overline{\text { BZO, }} \overline{\text { BOO }}$ | 0.5 | 1.0 | DBP |  |
| $\mathrm{t}_{\mathrm{R}}$ | UDI to SDO, $\overline{\text { NVM }}$ | 2.5 | 3.0 | DBP |  |

NOTES:

1. AC testing as follows: $f=4.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=70 \% \mathrm{~V}_{\mathrm{Cc}}, \mathrm{V}_{\mathrm{IL}}=20 \% \mathrm{~V}_{\mathrm{CC}}$, Speed Select $=16 \mathrm{X}, \mathrm{V}_{\mathrm{OH}} \geq \mathrm{V}_{\mathrm{C}} 2, \mathrm{~V}_{\mathrm{OL}} \leq \mathrm{V}_{\mathrm{Cd}} 2, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V , Input rise and fall times driven at $1 \mathrm{~ns} / \mathrm{V}$, Output load $=50 \mathrm{pF}$.
2. Guaranteed via characteristics at initial device design and after major process and/or design changes, not tested.
3. DBP-Data Bit Period, Clock Rate $=16 \mathrm{X}$, one DBP $=16$ Clock Cycles; Clock Rate $=32 \mathrm{X}$, one DBP $=32$ Clock Cycles.

Timing Waveforms


CLOCK TIMING
OUTPUT WAVEFORMS


ENCODER TIMING


## Timing Waveforms (Continued)

ENCODER TIMING (Continued)


DECODER TIMING


NOTE: Manchester Data In is not synchronous with Decoder Clock.
Decoder Clock is synchronous with decoded NRZ out of SDO.

$\overline{\mathrm{B}} \overline{\mathbf{S}} \mathbf{T}$


## Timing Waveforms (Continued)

repeater timing


Test Load Circuit


* INCLUDES STRAY AND JIG CAPACITANCE

HD-6409/883

## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- 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
- Low Operating Power: 50mW Typical at +5V
- Available in 20 Pin Dual-In-Line and 20 Pad LCC Package


## Description

The HD-6409/883 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/883 easily interfaces to protocol controllers.

## Pinouts

HD1-6409/883 (CERAMIC DIP) TOP VIEW


HD4-6409/883 (CERAMIC LCC) TOP VIEW


## Block Diagram



## Logic Symbol




## Reliability Information

| hermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\mathrm{jc}}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $83^{\circ} \mathrm{C} / \mathrm{W}$ | $23^{\circ} \mathrm{C}$ |
| Ceramic LCC Package | $84^{\circ} \mathrm{C} / \mathrm{W}$ | $24^{\circ} \mathrm{C}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . 602m |  |  |
| Ceramic LCC Package |  |  |
|  |  |  |

CAUTION: Stresses above those listed in "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 operatıonal sections of this specification is not implied.

## Operating Conditions

Operating Temperature Range
Operating Voltage Range
Input Rise and Fall Times
$\qquad$ $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ +4.5 V to +5.5 V .50ns Max

Sync. Transition Span (t2) $\qquad$ 1.5 DBP Typical, (Notes 1, 2) Short Data Transition Span (t4) $\qquad$ 0.5 DBP Typical, (Notes 1, 2) Long Data Transition Span (t5). D5) 1.0 DBP Typical, (Notes 1, 2) Zero Crossing Tolerance (tCD5) (Note 3)

NOTES: 1. DBP-Data Bit Period, Clock Rate $=16 \mathrm{X}$, one DBP $=16$ Clock Cycles; Clock Rate $=32 \mathrm{X}$, one DBP $=32$ Clock Cycles.
2. The input conditions specfied are nominal values, the actual input waveforms transition spans may vary by $\pm 2 I_{X}$ clock cycles ( 16 X mode) or $\pm 6$ IX clock cycles ( 32 X mode).
3. The maximum zero crossing tolerance is $\pm 2 I_{X}$ clock cycles ( 16 X mode) or $\pm 6 I_{X}$ clock cycles ( 32 mode) from the nominal.

TABLE 1. HD-6409/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logic '1' Input Voltage | VIH | $\mathrm{VCC}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & 70 \% \\ & \text { VCC } \end{aligned}$ | - | V |
| Logic '0' Input Voltage | VIL | $\mathrm{VCC}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20\%VCC | V |
| Logic ' 1 ' Input Voltage (Reset) | VIHR | $\mathrm{VCC}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \text { VCC } \\ & -0.5 \end{aligned}$ | - | V |
| Logic '0' Input Voltage (Reset) | VILR | $\mathrm{VCC}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | $\begin{aligned} & \text { GND } \\ & +0.5 \end{aligned}$ | v |
| Logic '1' Input Voltage (Clock) | VIHC | $\mathrm{VCC}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \text { VCC } \\ & -0.5 \end{aligned}$ | - | V |
| Logic '0' Input Voltage (Clock) | VILC | $\mathrm{VCC}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | $\begin{aligned} & \text { GND } \\ & +0.5 \end{aligned}$ | v |
| Input Leakage Current (Exceptlx) | II | $\begin{aligned} & \mathrm{VIN}=\mathrm{VCC} \text { or GND } \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Input Leakage Current (IX) | II | $\begin{aligned} & \mathrm{VIN}=\mathrm{VCC} \text { or GND } \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -20 | +20 | $\mu \mathrm{A}$ |
| I/O Leakage Current | 10 | $\begin{aligned} & \mathrm{VOUT}=\mathrm{VCC} \text { or GND } \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output HIGH Voltage (All except OX) | VOH | $\begin{aligned} & \mathrm{IOH}=-2.0 \mathrm{~mA} \\ & \mathrm{VCC}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \text { VCC } \\ & -0.4 \end{aligned}$ | - | v |
| Output LOW Voltage (All except Ox) | VOL | $\begin{aligned} & \mathrm{IOL}=+2.0 \mathrm{~mA} \\ & \mathrm{VCC}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| Standby Power Supply Current | ICCSB | $\begin{aligned} & \text { VIN = VCC or GND, } \\ & \text { VCC }=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 100 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & \mathrm{f}=16.0 \mathrm{MHz}, \\ & \mathrm{VIN}=\mathrm{VCC} \text { or } \mathrm{GND} \\ & \mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{CL}=50 \mathrm{pF} \end{aligned}$ | $\overline{1,2,3}$ | ${ }^{-55}{ }^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 18.0 | mA |
| Functional Test | FT | ( Note 2) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES: 1. Interchanging of force and sense conditions is permitted.
2. Tested as follows: $f=16 \mathrm{MHz}, \mathrm{VIH}=70 \% \mathrm{VCC}, \mathrm{VIL}=20 \% \mathrm{VCC}, \mathrm{VOH} \geq \mathrm{VCC} / 2$, and $\mathrm{VOL} \leq \mathrm{VCC} / 2, \mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .

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

TABLE 2. HD-6409/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Clock Frequency | ${ }^{\text {f }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 16 | MHz |
| Clock Period | ${ }^{\text {t }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1/fc | - | sec |
| Bipolar Pulse Width | $\mathrm{t}_{1}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $t^{t}+10$ | - | ns |
| One-Zero Overlap | $\mathrm{t}_{3}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | $\mathrm{t}_{\mathrm{C}}-10$ | ns |
| Clock High Time | ${ }^{\text {t }} \mathrm{CH}$ | $\mathrm{f}=16.0 \mathrm{MHz}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | ns |
| Clock Low Time | ${ }^{\text {t CL }}$ | $\mathrm{f}=16.0 \mathrm{MHz}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | ns |
| Serial Data Setup Time | ${ }^{\text {t CE1 }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | ns |
| Serial Data Hold Time | tCE2 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | ns |
| DCLK to SDO, $\overline{\text { NVM }}$ | ${ }^{\text {t }}$ CD2 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 40 | ns |
| ECLK to BZO | tR2 |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 40 | ns |

NOTES 1 AC Testıng as follows $f=40 \mathrm{MHz}, \mathrm{VIH}=70 \% \mathrm{VCC}, \mathrm{VIL}=20 \% \mathrm{VCC}$, Speed Select $=16 \mathrm{X}, \mathrm{VOH} \geq \mathrm{VCC} / 2, \mathrm{VOL} \leq \mathrm{VCC} / 2, \mathrm{VCC}=45 \mathrm{~V}$ and 5.5 V , Input rise and fall tımes driven at $1 \mathrm{~ns} N$, Output load $=50 \mathrm{pF}$

TABLE 3. HD-6409/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITONS | NOTES | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | CIN | $\mathrm{VCC}=\text { Open }, \mathrm{f}=1 \mathrm{MHz}$ <br> All Measurements are referenced to device GND | 1,2 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| I/O Capacitance | $\mathrm{Cl} / \mathrm{O}$ |  | 1,2 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | pF |
| Output Rise Time (All except Clock) | $t_{r}$ | $\begin{aligned} & \text { From } 1.0 \text { to } 3.5 \mathrm{~V} \\ & C L=50 \mathrm{pF} \end{aligned}$ | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |
| Output Fall Time (All except Clock) | ${ }_{\text {f }}$ | $\begin{aligned} & \text { From } 3.5 \text { to } 1.0 \mathrm{~V} \\ & C L=50 \mathrm{pF} \end{aligned}$ | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |
| Clock Output Rise Time | $\mathrm{tr}_{r}$ | $\begin{aligned} & \text { From } 1.0 \text { to } 3.5 \mathrm{~V} \\ & C L=20 \mathrm{pF} \end{aligned}$ | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 11 | ns |
| Clock Output Fall Time | $\mathrm{tf}^{\text {f }}$ | $\begin{aligned} & \text { From } 3.5 \text { to } 1.0 \mathrm{~V} \\ & C L=20 \mathrm{pF} \end{aligned}$ | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 11 | ns |
| ECLK to $\overline{\text { BZO, }}$ BOO | ${ }^{\text {t Ce3 }}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | 0.5 | 1.0 | DBP |
| $\overline{\mathrm{CTS}}$ Low to $\overline{\mathrm{BZO}}$ $\overline{\mathrm{BOO}}$ Enabled | ${ }^{\text {t CE }} 4$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0.5 | 1.5 | DBP |
| $\overline{\mathrm{CTS}}$ Low to ECLK Enabled | ${ }^{\text {t CEE5 }}$ |  | 1,3 | ${ }^{-55^{\circ} \mathrm{C}} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 10.5 | 11.5 | DBP |
| $\overline{\text { CTS }}$ High to ECLK Disabled | ${ }^{\text {t CEE }}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 1.0 | DBP |
| $\begin{aligned} & \overline{\text { CTS }} \text { High to } \overline{\text { BZO }} \\ & \overline{\text { BOO } \text { Disabled }} \end{aligned}$ | ${ }^{\text {t CEE }}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 1.5 | 2.5 | DBP |
| UDI to SDO, $\overline{\text { NVM }}$ | ${ }^{\text {t CD1 }}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.5 | 3.0 | DBP |
| $\overline{\text { RST }}$ Low to DCLK, SDO, NVM Low | ${ }^{\text {t }}$ CD3 |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0.5 | 1.5 | DBP |
| $\overline{\text { RST High to DCLK, }}$ \|Enabled | tcD4 |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0.5 | 1.5 | DBP |
| UDI to $\overline{\mathrm{BZO}}, \overline{\mathrm{BOO}}$ | ${ }^{\text {tR1 }}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0.5 | 1.0 | DBP |
| UDI to SDO, $\overline{\text { NVM }}$ | tr3 |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.5 | 3.0 | DBP |

NOTES 1. The parameters listed in table 3 are controlled via design or process parameters and are not directly tested.
2 Guaranteed via characteristics at initial device design and after major process and/or design changes
3 DBP-Data Bit Period, Clock Rate $=16 \mathrm{X}$, one DBP $=16$ Clock Cycles, Clock Rate $=32 \mathrm{X}$, one DBP $=32$ Clock Cycles.

CAUTION. These devices are sensitive to electrostatic discharge Proper 1 C . handling procedures should be followed

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Burn-In Circuits

HD-6409/883 CERAMIC DIP


HD-6409/883 CERAMIC LCC


NOTES:
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to 0.4 V
$R 1=47 \mathrm{k} \Omega \pm 5 \%$
$F O=100 \mathrm{kHz} \pm 10 \%$
F4 $=$ F0/16

NOTES:
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to 0.4 V
$R 1=47 \mathrm{~K} \Omega \pm 5 \%$
$F O=100 \mathrm{kHz} \pm 10 \%$
$F 4=F 0 / 16$

## Metallization Topology

DIE DIMENSIONS:
$88 \times 78 \times 19 \pm 1$ mils
METALLIZATION:
Type: Silicon - Aluminum
Thickness: Metal 1: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
Metal 2: $16 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{Si}_{3} \mathrm{~N}_{4} \cdot \mathrm{SiO}_{x}$ Thickness: $10 k \AA \pm 2 k \AA$
DIE ATTACH:
Material: Gold - Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY: $0.8 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout


## Packaging



LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M-38510

COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T20

20 PAD CERAMIC LCC


LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M-38510

COMPLIANT OUTLINE: MIL-STD-1835, CQCC1-N2O

## Features

- Support of MIL-STD-1553
- Data Rate
1.25 MBit/s
- Sync Identification and Lock-In
- Clock Recovery
- Manchester II Encode, Decode
- Separate Encode and Decode
- Low Operating Power $\qquad$


## 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 protocols. 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 functions.
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 of fiber optic cable throughout the building.

## Ordering Information

| PACKAGE | TEMP RANGE | 1.25 MEGABIT/s |
| :--- | :---: | :---: |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+855^{\circ} \mathrm{C}$ | HD1-15530-9 |
| SMD \# | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HD1-15530-8 |
|  |  | 7802901 JA |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD4-15530-9 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HD4-15530-8 |
|  |  | 78029013 A |

## Pinouts

| 24 LEAD DIP TOP VIEW |  |  |
| :---: | :---: | :---: |
| Valid word 1 |  |  |
| encoder shirt cle 2 |  | encoder clk |
| take data 3 |  | send cle in |
| serial data out 4 |  | send data |
| decoder clu 5 |  | sYnc select |
| bipolar zero in 6 | 18 | encoder enable |
| BIPOLAR ONE IN 7 | 18 | serial data in |
| Unipolar data in 8 | 17 | bipolar one out |
| decoder shift clu 9 | 18 | OUTPUT INHIBTI |
| COMMAND / DATA SYNC 10 |  | bipolar zero out |
| decoder reset 11 |  | $\div$ в оит |
| GND 12 | 13 | master reset |

## 28 LEAD LCC TOP VIEW




Block Diagrams

## ENCODER



DECODER


## Pin Description

| PIN NUMBER | TYPE | NAME | SECTION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | VALID WORD | Decoder | Output high indicates receipt of a valid word, (valid parity and no Manchester errors). |
| 2 | 0 | ENCODER SHIFT CLOCK | Encoder | Output for shifting data into the Encoder. The Encoder samples SDI on the low-to-high transition of Encoder Shift Clock. |
| 3 | 0 | TAKE DATA | Decoder | Output is high during receipt of data after identification of a sync pulse and two valid Manchester data bits. |
| 4 | 0 | SERIAL DATA OUT | Decoder | Delivers received data in correct NRZ format. |
| 5 | 1 | DECODER CLOCK | Decoder | Input drives the transition finder, and the synchronizer which in turn supplies the clock to the balance of the decoder, input a frequency equal to 12 X the data rate. |
| 6 | 1 | BIPOLAR ZERO IN | Decoder | 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 | 1 | BIPOLAR ONE IN | Decoder | 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 | 1 | UNIPOLAR DATA IN | Decoder | With pin 6 high and pin 7 low, this pin enters unipolar data into the transtition finder circuit. If not used this input must be held low. |
| 9 | 0 | DECODER SHIFT CLOCK | Decoder | Output which delivers a frequency (DECODER CLOCK $\div 12$ ), synchronized by the recovered serial data stream. |
| 10 | 0 | COMMAND SYNC | Decoder | 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 | 1 | DECODER RESET | Decoder | 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 | 1 | GROUND | Both | Ground Supply pin. |
| 13 | 1 | MASTER RESET | Both <br> - | A high on this pin clears 2:1 counters in both Encoder and Decoder, and resets the $\div 6$ circuit. |
| 14 | 0 | $\div 6$ OUT | Encoder | Output from 6:1 divider which is driven by the ENCODER CLOCK. |
| 15 | O | $\begin{aligned} & \overline{\overline{\text { BIPOLAR } \overline{Z E R O}}} \overline{\overline{O U T}} \end{aligned}$ | Encoder | An active low output designed to drive the zero or negative sense of a bipolar line driver. |
| 16 | 1 | OUTPUT INHIBIT | Encoder | A low on this pin forces pin 15 and 17 high, the inactive states. |
| 17 | O | $\overline{\text { BIPOLAR }} \overline{\text { ONE }} \overline{\text { OUT }}$ | Encoder | An active low output designed to drive the one or positive sense of a bipolar line driver. |
| 18 | 1 | SERIAL DATA IN | Encoder | Accepts a serial data stream at a data rate equal to ENCODER SHIFT CLOCK. |
| 19 | 1 | ENCODER ENABLE | Encoder | A high on this pin initiates the encode cycle. (Subject to the preceeding cycle being complete.) |
| 20 | 1 | SYNC SELECT | Encoder | Actuates a Command sync for an input high and Data sync for an input low. |
| 21 | 0 | SEND DATA | Encoder | An active high output which enables the external source of serial data. |
| 22 | 1 | SEND CLOCK IN | Encoder | Clock input at a frequency equal to the data rate X 2 , usually driven by $\div 6$ output. |
| 23 | 1 | ENCODER CLOCK | Encoder | Input to the 6:1 divider, a frequency equal to the data rate X 12 is usually input here. |
| 24 | 1 | $\mathrm{V}_{\mathrm{CC}}$ | Both | $\mathrm{V}_{\mathrm{CC}}$ is the +5 V power supply pin. A $0.1 \mu \mathrm{~F}$ decoupling capacitor from $\mathrm{V}_{\mathrm{CC}}(\operatorname{pin} 24)$ to GROUND (pin 12) is recommended. |

## 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 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 SYNC SELECT input actuates a command sync or a low will produce a data sync for the word (2). When the Encoder is ready to accept data, the SEND DATA 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 high-to-low transition of the

ENCODER SHIFT CLOCK so it can be sampled on the low-to-high transition (3) - (4). After the sync and Manchester II coded data are transmitted through the BIPOLAR ONE and $\overline{\text { BIPOLAR }} \overline{\text { ZERO }}$ outputs, the Encoder adds on an additional bit which is the parity for that word (5). If ENCODER ENABLE is held high continuously, consecutive words will be encoded without an interframe gap. ENCODER ENABLE must go low by time (5) as shown to prevent a consecutive word from being encoded. 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 ONE OUT of an Encoder through an inverter to Unipolar Data Input).

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/DATA SYNC output. If the sync character was a command sync, this output will go high (2) and remain high for sixten 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 NRZ format. The DECODER SHIFT CLOCK is provided so that the decoded bits can be shifted into an external register on every low-to-high transition of this clock (2) - (3). Note that DECODER SHIFT CLOCK may adjust its phase up until the time that TAKE DATA goes high.

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. VALID WORD will go low approximately 20 DECODER SHIFT CLOCK periods after it goes high if not reset low sooner by a valid sync and two valid Manchester bits as shown (1).

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.


How to Make Our MTU Look Like a Manchester Encoded UART


Typical Timing Diagrams for a Manchester Encoded UART


DECODER TIMING


## MIL-STD-1553

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 accomodated.

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


FIGURE 1. SIMPLIFIED MIL-STD-1553 DRIVER


FIGURE 3. MIL-STD-1553 CHARACTER FORMATS

Words. Terminals respond with Status 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 \quad$ Receive on logical zero, transmit on ONE.
ME Message Error if logical 1.
TF Terminal Flat, 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 2. SIMPLIFIED MIL-STD-1553 RECEIVER


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.0V |
| Input, Output or I/O Voltage Applied | . GND-0.3V to $\mathrm{V}_{\mathrm{CC}}+0.3$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $+175{ }^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10 sec ) | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class |

Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $50.4{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $11.7^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $71.1^{\circ} \mathrm{C} / \mathrm{W}$ | $16.8^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | 992 mW |
| Ceramic LCC Package |  | 703 mW |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

| Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5V | Sync Transition Span (TD2) . . . . . . . . . . . . 18 TDC Typical (Note1) |
| :---: | :---: |
| Temperature Range ( $\mathrm{T}_{\mathrm{A}}$ ) | Short Data Transition Span (TD4) . . . . . . . . 6 TDC Typical (Note1) |
| HD-15530-9 . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | Long Data Transition Span (TD5) . . . . . . . . 12 TDC Typical (Note1) |
| HD-15530-8 . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
| Encoder/Decoder Clock Rise Time . . . . . . . . . . . . . . . . . . 8ns Max |  |
| Encoder/Decoder Clock Fall Time . . . . . . . . . . . . . . . . . . . 8ns Max |  |

DC Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( $\mathrm{HD}-15530-9$ )
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HD-15530-8)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage | - | $0.2 \mathrm{~V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | $0.7 \mathrm{~V}_{\mathrm{CC}}$ | - | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V |
| VILC | Input LOW Clock Voltage | - | GND +0.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V |
| $\mathrm{V}_{\text {IHC }}$ | Input HIGH Clock Voltage | $v_{\text {cc }}-0.5$ | - | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA}$ (Note 2), $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.4 | - | V | $\mathrm{I}^{\mathrm{OH}}=-3 \mathrm{~mA}$ ( Note 2), $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| 1 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=\mathrm{GND}$ or $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| ICcsb | Standby Supply Current | - | 2 | mA | $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ Output Open |
| ICCOP | Operating Power Supply Current | - | 10 | mA | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}, f=15 \mathrm{MHz}, \\ & \text { Outputs Open } \end{aligned}$ |
| $\mathrm{F}_{T}$ | Function Test | - | - | - | (Note 3) |

1. $T D C=$ Decoder clock period $=1 /$ FDC
2. Interchanging of force and sense conditions is permitted.
3. Tested as follows: $=\mathrm{f}=15 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=70 \% \mathrm{~V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{IL}}=20 \% \mathrm{~V}_{\mathrm{CC}}$.
$\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$; Frequency $=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | TYPICAL | UNITS | CONDITIONS |
| :---: | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 15 | pF | All measurements are referenced <br> to device GND |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance | 15 | pF |  |

AC Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HD-15530-9)
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ( $\mathrm{HD}-15530-8$ )

| SYMboL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS (NOTE 2) |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | max |  |  |

## ENCODER TIMING

| FEC | Encoder Clock Frequency | - | 15 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| :---: | :--- | :---: | :---: | :---: | :---: |
| FESC | Send Clock Frequency | - | 2.5 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| FED | Encoder Data Rate | - | 1.25 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TMR | Master Reset Pulse Width | 150 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE1 | Shift Clock Delay | - | 125 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE2 | Serial Data Setup | 75 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE3 | Serial Data Hold | 75 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE4 | Enable Setup | 90 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE5 | Enable Pulse Width | 100 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE6 | Sync Setup | 55 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE7 | Sync Pulse Width | 150 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE8 | Send Data Delay | 0 | 50 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE9 | Bipolar Output Delay | - | 130 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE10 | Enable Hold | 10 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE11 | Sync Hold | 95 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |

## DECODER TIMING

| FDC | Decoder Clock Frequency | - | 15 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| :---: | :--- | :---: | :---: | :---: | :--- |
| FDD | Decoder Data Rate | - | 1.25 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TDR | Decoder Reset Pulse Width | 150 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TDRS | Decoder Reset Setup Time | 75 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TDRH | Decoder Reset Hold Time | 10 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TMR | Master Reset Pulse | 150 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD1 | Bipolar Data Pulse Width | TDC +10 <br> (Note 1) | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD3 | One Zero Overlap | - | TDC -10 <br> $(N o t e ~ 1)$ | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD6 | Sync Delay (ON) | -20 | 110 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD7 | Take Data Delay (ON) | 0 | 110 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD8 | Serial Data Out Delay | - | 80 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD9 | Sync Delay (OFF) | 0 | 110 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD10 | Take Data Delay (OFF) | 0 | 110 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD11 | Valid Word Delay | 0 | 110 | ns | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5V, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |

## NOTES:

1. TDC $=$ Decoder clock period $=1 /$ FDC
2. $A C$ Testing as follows: Input levels: $V_{I H}=70 \% V_{C C}, V_{I L}=20 \%$
$\mathrm{V}_{\mathrm{cc}}$; Input rise/fall times driven at 1 ns N ; Timing Reference levels: 1.5 V ; Output load: $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.

## Timing Waveforms

ENCODER TIMING


## DECODER TIMING





DECODER SHIFT CLOCK

## DECODER RESET


$\rightarrow 1+$ TDRH

## HD-15530

## Timing Waveforms (Continued)

DECODER TIMING (Continued)


## Test Load Circuit


*Includes stray and jig capacitance

AC Testing Input, Output Waveform


AC Testing: All input signals must switch between $\mathrm{V}_{\mathrm{IL}}$ and $\mathrm{V}_{\mathrm{IH}}$. Input rise and fall times are driven at ins per volt.

## Burn-In Circuits

HD1-15530 CERAMIC DIP


NOTES
$V_{C C}=55 \mathrm{~V} \pm 05 \mathrm{~V}$
$\mathrm{V}_{\mathrm{IH}}=45 \mathrm{~V} \pm 10 \%$
$\mathrm{V}_{\mathrm{IL}}=-02 \mathrm{~V}$ to +04 V
$R 1=47 \mathrm{~K} \Omega \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$\mathrm{C} 1=001 \mu \mathrm{~F}$ Mın

NOTES
$V_{C C}=55 \mathrm{~V} \pm 05 \mathrm{~V}$
$V_{I H}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{V}_{\mathrm{IL}}=-02 \mathrm{~V}$ to +04 V
$R 2=18 K \Omega \pm 5 \%$
FO $=100 \mathrm{KHz} \pm 10 \%$
$\mathrm{C} 1=00 \mu \mathrm{FMin}$


## CMOS Manchester Encoder-Decoder

## Features

- Support of MIL-STD-1553
- Data Rate (15531B) . . . . . . . . . . . . . . . 2.5 Megabit/Sec
- Data Rate (15531). . . . . . . . . . . . . . . . 1.25 Megabit/Sec
- Variable Frame Length to 32 -Bits
- Sync Identification and Lock-In
- Separate Manchester II Encode, Decode
- Low Operating Power

50 mW @ 5 Volts

## Ordering Information

| PACKAGE | TEMP. RANGE | 1.25MBIT/SEC | 2.5MBIT/SEC |
| :--- | :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | - | HD3-15531B-9 |
| $1883^{*}$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HD1-15531-8 | HD1-15531B-8 |
|  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HD1-15531-9 | HD1-15531B-9 |
|  |  | HD1-15531/ <br> 883 | HD1-15531B/ <br> 883 |

*Respective $/ 883$ specifications are included at the end of this datasheet

## 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 protocols. 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 word 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 word length to be programmable (from 2 to 28 data bits). A frame consists of three bits for sync followed by the data word ( 2 to 28 data bits) followed by one bit of parity, thus the frame length will vary from 6 to 32 bit periods. 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. For high speed applications the 15531B will support a 2.5 Megabit/sec data rate.

The HD-15531 can also be used in many party line digital data communications applications, such as a local area network or an environmental control system driven from a single twisted pair of fiber optic cable throughout a building.

| Pinout |  |  |
| :---: | :---: | :---: |
|  | $\square$ $\square$ <br> Vallo word $\square$ take data' $\square$ take data $\square$ <br> serial data out $\square$ sYnchr data $\square$ SYNCHR DATA SEL $\square$ SYNCHR CLK $\square$ decoder clk $\square$ SYNCHR CLK SEL $\square$ bipolar zero in 11 BIPOLAR ONE IN $\square$ UNIPOLAR DATA IN 13 DECODER SHIFT CLK $\square$ transition sel $\square$ NC 16 COMmAND SYNC $\square$ DECODER PARITY SEL 18 DECODER RESET 19 COUNT $\mathrm{C}_{0} 20$ | 40 COUNT C 4 <br> 39 COUNT $C_{4}$ <br> 38 DATA SYNC <br> 37 ENCODER CLK <br> 36 COUNT $C_{3}$ <br> 35 NC <br> 34 ENCODER SHIFT CLK <br> 33 SEND CLK IN <br> 32 SEND DATA <br> 31 ENCODER PARITY SEL <br> 30 SYNC SEL <br> 29 ENCODER ENABLE <br> 28 SERIAL DATA IN <br> 27 BIPOLAR ONE OUT <br> 26 OUTPUT INHIBIT <br> 25 BIPOLAR ZERO OUT <br> 24 +6 OUT <br> 23 COUNT 2 <br> 22 MASTER RESET <br> 21 GND |

## Block Diagrams

ENCODER


DECODER


| PIN <br> NUMBER | TYPE | NAME | SECTION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}$ | Both | Positive supply pin. A $0.1 \mu \mathrm{~F}$ decoupling capacitor from $\mathrm{V}_{\mathrm{CC}}$ (pin 1) to GROUND (pin 21) is recommended. |
| 2 | 0 | VALID WORD | Decoder | Output high indicates receipt of a valid word, (valid parity and no Manchester errors). |
| 3 | 0 | TAKE DATA' | Decoder | 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 | 0 | TAKE DATA | Decoder | Output is high during receipt of data after identification of a valid sync pulse and two valid Manchester bits. |
| 5 | 0 | SERIAL DATA OUT | Decoder | Delivers received data in correct NRZ format. |
| 6 | 1 | SYNCHRONOUS DATA | Decoder | 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 must be held high. |
| 7 | 1 | SYNCHRONOUS DATA SELECT | Decoder | In high state allows the synchronous data to enter the character identification logic. Tie this input low for asynchronous data. |
| 8 | 1 | SYNCHRONOUS CLOCK | Decoder | Input provides externally synchronized clock to the decoder, for use when receiving synchronous data. This input must be tied high when not in use. |
| 9 | 1 | DECODER CLOCK | Decoder | Input drives the transition finder, and the synchronizer which in turn supplies the clock to the balance of the decoder. Input a frequency equal to 12 X the data rate. |
| 10 | 1 | SYNCHRONOUS CLOCK SELCT | Decoder | In high state directs the SYNCHRONOUS CLOCK to control the decoder character identification logic. A low state selects the DECODER CLOCK. |
| 11 | 1 | BIPOLAR ZERO IN | Decoder | 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 | 1 | BIPOLAR ONE IN | Decoder | 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 | 1 | UNIPOLAR DATA IN | Decoder | 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 | 0 | $\begin{aligned} & \text { DECODER SHIFT } \\ & \text { CLOCK } \end{aligned}$ | Decoder | Output which delivers a frequency (DECODER CLOCK $\div 12$ ), synchronous by the recovered serial data stream. |
| 15 | 1 | TRANSITION SELECT | Decoder | 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 |  | N.C. | Blank | Not connected. |
| 17 | 0 | COMMAND SYNC | Decoder | Output of a high from this pin occurs during output of decoded data which was preceded by a Command (or Status) synchronizing character. |
| 18 | 1 | DECODER PARITY SELECT | Decoder | An input for parity sense, calling for even parity with input high and odd parity with input low. |
| 19 | 1 | DECODER RESET | Decoder | 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 | 1 | COUNT CO | Both | One of five binary inputs which establish the total bit count to be encoded or decoded. |
| 21 |  | GROUND | Both | Supply pin. |
| 22 | 1 | MASTER RESET | Both | A high on this pin clears 2:1 counters in both encoder and decoder, and resets the $\div 6$ circuit. |
| 23 | 1 | COUNT C2 | Both | See pin 20. |
| 24 | 0 | $\div 6$ OUT | Encoder | Output from 6:1 divider which is driven by the ENCODER CLOCK. |
| 25 | 0 | $\overline{\text { BIPOLAR }} \overline{\text { ZERO }}$ OUT | Encoder | An active low output designed to drive the zero or negative sense of a bipolar line driver. |
| 26 | 1 | OUTPUT INHIBIT | Encoder | A low on this pin forces pin 25 and 27 high, the inactive states. |
| 27 | 0 | $\begin{aligned} & \overline{\text { BIPOLAR ONE }} \overline{\overline{O U T}} \end{aligned}$ | Encoder | An active low output designed to drive the one or positive sense of a bipolar line driver. |
| 28 | 1 | SERIAL DATA IN | Encoder | Accepts a serial data stream at a data rate equal to ENCODER SHIFT CLOCK. |
| 29 | 1 | ENCODER ENABLE | Encoder | A high on this pin initiates the encode cycle. (Subject to the preceding cycle being complete.) |
| 30 | 1 | SYNC SELECT | Encoder | Actuates a Command sync for an input high and Data sync for an input low. |
| 31 | 1 | ENCODER PARITY SELECT | Encoder | Sets transmit parity odd for a high input, even for a low input. |
| 32 | 0 | SEND DATA | Encoder | Is an active high output which enables the external source of serial data. |
| 33 | 1 | SEND CLOCK IN | Encoder | Clock input at a frequency equal to the data rate X 2 , usually driven by $\div 6$ output. |
| 34 | 0 | ENCODER SHIFT CLOCK | Encoder | Output for shifting data into the Encoder. The Encoder samples SDI pin-28 on the low-to-high transition of ESC. |
| 35 |  | N.C. | Blank | Not connected. |
| 36 | 1 | COUNT C3 | Both | See pin 20. |
| 37 | 1 | ENCODER CLOCK | Encoder | Input to the 6:1 divider, a frequency equal to 12 times the data rate is usually input here. |
| 38 | 0 | DATA SYNC | Decoder | Output of a high from this pin occurs during output of decoded data which was preceded by a data synchronizing character. |
| 39 | 1 | COUNT C4 | Both | See pin 20. |
| 40 | 1 | COUNT C1 | Both | 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 SYNC SELECT input actuates a Command sync or a low will produce a Data sync for the 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 high-tolow transition of the ENCODER SHIFT CLOCK (3) - (4) so it can be sampled on the low-to-high transition. After the sync and Manchester II encoded data are transmitted through the BIPOLAR ONE and BIPOLAR ZERO outputs, the Encoder adds on an additional bit with the parity for that word (5). If ENCODER ENABLE is held high continuously, consecutive words will be encoded without an interframe gap. ENCODER ENABLE must go low by time (5) (as shown) to prevent a consecutive word from being encoded. 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 CLK 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 BIPOLAR $\overline{O N E} \overline{O U T}$ on an Encoder through an inverter to Unipolar Data Input).

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). Note that DECODER SHIFT CLOCK may adjust its phase up until the time that TAKE DATA goes high.

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. VALID WORD will go low approximately K + 4 DECODER SHIFT CLOCK periods after it goes high if not reset low sooner by a valid sync and two valid Manchester bits as shown (1).

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 Counter

| DATA BITS | FRAME LENGTH (BIT PERIODS) | PIN WORD |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $C_{4}$ | $\mathrm{C}_{3}$ | $\mathrm{C}_{2}$ | $C_{1}$ | $\mathrm{C}_{0}$ |
| 2 | 6 | L | L | H | L | H |
| 3 | 7 | L | $L$ | H | H | L |
| 4 | 8 | L | L | H | H | H |
| 5 | 9 | L | H | L | L | L |
| 6 | 10 | L | 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 | L. |
| 12 | 16 | $L$ | H | H | H | H |
| 13 | 17 | H | L | L | L | L |
| 14 | 18 | H | L | L | L | H |
| 15 | 19 | H | L | L | H | L |
| 16 | 20 | H | L | L | H | H |
| 17 | 21 | H | L | H | L | L |
| 18 | 22 | H | L | H | L | H |
| 19 | 23 | H | L | H | H | L |
| 20 | 24 | H | L | H | H | H |
| 21 | 25 | H | H | L | L | L |
| 22 | 26 | H | H | L | L | H |
| 23 | 27 | H | H | L | H | L |
| 24 | 28 | H | H | L | H | H |
| 25 | 29 | H | H | H | L | L |
| 26 | 30 | H | H | H | L | H |
| 27 | 31 | H | H | H | H | $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

HD-15531
How to Make Our MTU Look Like a Manchester Encoded UART


## DECODER TIMING



## MIL-STD-1553

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 selftest 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 2. SIMPLIFIED MIL-STD-1553 RECEIVER

\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



FIGURE 3. MIL-STD-1553 CHARACTER FORMATS
NOTE: This page is a summary of MIL-STD-1553 and is not intended to describe the operation of the HD-15531.


## Operating Conditions

| Supply Voltage | +4.5V to +5.5V | Sync. Transition Span (TD2) . . . . . . . . . . 18 TDC Typical, (Note 1) |
| :---: | :---: | :---: |
| Operating Temperature Range ( $T_{A}$ ) |  | Short Data Transition Span (TD4) . . . . . . . 6 TDC Typical, (Note 1) |
| HD-15531-9 | . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | Long Data Transition Span (TD5) . . . . . . 12 TDC Typical, (Note 1) |
| HD-15531-8 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
| Encoder/Decoder Clock Rise Time (TECR, TDCR) | . 8 ns Max |  |
| Encoder/Decoder Clock Fall Time (TECF, TDCF) | 8ns Max |  |

DC Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ}(\mathrm{HD}-15531-9)$ $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ}$ (HD-15531-8)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage | - | 0.2 V cc | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Voltage | 0.7 Vcc | - | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V |
| $\mathrm{V}_{\text {ILC }}$ | Input LOW Clock Voltage | - | GND +0.5 | v | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V |
| $\mathrm{V}_{\text {IHC }}$ | Input HIGH Clock Voltage | $\mathrm{v}_{\mathrm{cc}}-0.5$ | - | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | - | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=+1.8 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ (Note 2) |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.4 | - | V | $\mathrm{I}_{\mathrm{OH}}=-3.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ (Note 2) |
| 1 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\text {ccsb }}$ | Standby Supply Current | - | 2 | mA | $V_{I N}=V_{C C}=5.5 \mathrm{~V},$ Outputs Open |
| ICCOP | Operating Power Supply Current | - | 10 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{f}=15 \mathrm{MHz}, \\ & \text { Outputs Open } \end{aligned}$ |
| $\mathrm{F}_{\mathrm{T}}$ | Functional Test | - | - | - | (Note 3) |

NOTES:

1. TDC $=$ Decoder clock period $=1 /$ FDC
2. Interchanging of force and sense conditions is permitted.
3. Tested as follows: $f=15 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=70 \% \mathrm{~V}_{\mathrm{Cc}}, \mathrm{V}_{\mathrm{IL}}=20 \% \mathrm{~V}_{\mathrm{CC}}$, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{V}_{\mathrm{OH}} \geq \mathrm{V}_{\mathrm{C}} / 2$ and $\mathrm{V}_{\mathrm{OL}} \leq \mathrm{V}_{\mathrm{C}} \mathrm{d}^{2}$.

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$, Frequency $=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | TYP | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 25 | pF | All measurements are referenced to device GND |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 25 | pF |  |

AC Electrical Specifications $V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( $\mathrm{HD}-15530-9$ )
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HD-15530-8)

| SYMBOL | PARAMETER | HD-15531 |  | HD-15531B |  | UNITS | TEST CONDITIONS (NOTE 2) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| ENCODER TIMING |  |  |  |  |  |  |  |
| FEC | Encoder Clock Frequency | $\bullet$ | 15 | - | 30 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| FESC | Send Clock Frequency | - | 2.5 | - | 5.0 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| FED | Encoder Data Rate | - | 1.25 | - | 2.5 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TMR | Master Reset Pulse Width | 150 | - | 150 | - | ns | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE1 | Shift Clock Delay | - | 125 | - | 80 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE2 | Serial Data Setup | 75 | - | 50 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE3 | Serial Data Hold | 75 | - | 50 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE4 | Enable Setup | 90 | - | 90 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE5 | Enable Pulse Width | 100 | - | 100 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE6 | Sync Setup | 55 | - | 55 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE7 | Sync Pulse Width | 150 | - | 150 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE8 | Send Data Delay | 0 | 50 | 0 | 50 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE9 | Bipolar Output Delay | - | 130 | - | 130 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE10 | Enable Hold | 10 | - | 10 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TE11 | Sync Hold | 95 | - | 95 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| DECODER TIMING |  |  |  |  |  |  |  |
| FDC | Decoder Clock Frequency | - | 15 | - | 30 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| FDS | Decoder Sync Clock | - | 2.5 | - | 5.0 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| FDD | Decoder Data Rate | - | 1.25 | - | 2.5 | MHz | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TDR | Decoder Reset Pulse Width | 150 | - | 150 | - | ns | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TDRS | Decoder Reset Setup Time | 75 | - | 75 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TDRH | Decoder Reset Hold Time | 10 | - | 10 | $\cdot$ | ns | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TMR | Master Reset Pulse | 150 | - | 150 | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD1 | Bipolar Data Pulse Width | $\begin{array}{\|c\|} \hline \text { TDC + } 10 \\ \text { (Note 1) } \end{array}$ | $\bullet$ | $\begin{array}{\|c\|} \hline \text { TDC + 10 } \\ \text { (Note 1) } \\ \hline \end{array}$ | - | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD3 | One Zero Overlap | - | $\begin{array}{\|l\|} \hline \text { TDC - } 10 \\ \text { (Note 1) } \end{array}$ | - | $\begin{array}{\|c\|} \hline \text { TDC - } 10 \\ \text { (Note 1) } \end{array}$ | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD6 | Sync Delay (ON) | -20 | 110 | -20 | 110 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD7 | Take Data Delay (ON) | 0 | 110 | 0 | 110 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD8 | Serial Data Out Delay | - | 80 | - | 80 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD9 | Sync Delay (OFF) | 0 | 110 | 0 | 110 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD10 | Take Data Delay (OFF) | 0 | 110 | 0 | 110 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD11 | Valid Word Delay | 0 | 110 | 0 | 110 | ns | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD12 | Sync Clock to Shift Clock Delay | - | 75 | - | 75 | ns | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| TD13 | Sync Data Setup | 75 | - | 75 | ns |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |

NOTES:

1. TDC $=$ Decoder clock period $=1 /$ FDC
2. $A C$ Testing as follows: Input levels: $\mathrm{V}_{\mathrm{IH}}=70 \% \mathrm{~V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{IL}}=20 \%$ $\mathrm{V}_{\mathrm{cc}}$; Input rise/fall times driven at 1 ns N ; Timing Reference
levels: $\mathrm{V}_{\mathrm{Cd}}{ }^{2}$; Output load: $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.

## Timing Waveforms



DECODER TIMING
DECODER TIMING NOTE: UNIPOLAR IN = O, FOR NEXT DIAGRAMS



SEMICONDUCTOR

## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Support of MIL-STD-1553
- Data Rate (15531B)
2.5 Megabit/Sec
- Data Rate (15531).
1.25 Megabit/Sec
- Variable Frame Length to 32-Bits
- Sync Identification and Lock-In
- Separate Manchester II Encode, Decode
- Low Operating Power

50 mW © 5 Volts

## Description

The Harris HD-15531/883 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 protocols. 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 word 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/883 also surpasses the requirements of MIL-STD-1553 by allowing the word length to be programmable (from 2 to 28 data bits). A frame consists of three bits for sync followed by the data word (2 to 28 data bits) followed by one bit of parity, thus the frame length will vary from 6 to 32 bit periods. 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. For high speed applications the 15531B will support a $2.5 \mathrm{Megabit} / \mathrm{sec}$ data rate.
The HD-15531/883 can also be used in many party line digital data communications applications, such as a local area network or an environmental control system driven from a single twisted pair of fiber optic cable throughout a building.


Block Diagrams



## Reliability Information

| Thermal Resistance . . . | $\begin{gathered} \theta_{\mathrm{\jmath a}} \\ 34.8^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ | $\begin{gathered} \theta_{\mathrm{cc}} \\ 7.9^{\circ} \mathrm{CN} \end{gathered}$ |
| :---: | :---: | :---: |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | .44W |
| Gate Count |  | 250 Gates |

CAUTION: Stresses above those IIsted in "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.

## Operating Conditions

Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range $\left(\mathrm{T}_{\mathrm{A}}\right) \ldots \ldots \ldots \ldots . . .5^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Encoder/Decoder Clock Rise Time (TECR, TDCR) ...... . 8ns Max Encoder/Decoder Clock Fall Time (TECF, TDCF)

Sync. Transition Span (TD2) 18 TDC Typical, (Note 1) Short Data Transition Span (TD4) 6 TDC Typical, (Note 1) Long Data Transition Span (TD5) 12 TDC Typical, (Note 1)

TABLE 1. HD-15531/883, HD-15531B/883 DC ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | TEST CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input LOW Volt- age | VIL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.2 VCC | V |
| Input HIGH Voltage | VIH | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0.7 VCC | - | V |
| Input LOW Clock Voltage | VILC | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | $\begin{aligned} & \text { GND } \\ & +0.5 \end{aligned}$ | V |
| Input HIGH Clock Voltage | VIHC | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\begin{gathered} \text { VCC } \\ 0.5 \end{gathered}$ | - | V |
| Output LOW Voltage | VOL | $\begin{aligned} & \mathrm{IOL}=+1.8 \mathrm{~mA}, \mathrm{VCC}= \\ & 4.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Output HIGH Voltage | VOH | $\begin{aligned} & 1 \mathrm{OH}=-3.0 \mathrm{~mA}, \mathrm{VCC}= \\ & 4.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Input Leakage Current | 11 | $\begin{aligned} & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \mathrm{VCC}= \\ & 5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB | $\mathrm{VIN}=\mathrm{VCC}=5.5 \mathrm{~V},$ Outputs Open | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 2 | mA |
| Functional Test | FT | (Note 3) | 7, 8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES:

1. TDC $=$ Decoder clock period $=1 /$ FDC
2. Interchanging of force and sense conditions is permitted.
3. Tested as follows: $\mathrm{f}=15 \mathrm{MHz}, \mathrm{VIH}=70 \% \mathrm{VCC}, \mathrm{VIL}=20 \% \mathrm{VCC}$, $\mathrm{CL}=50 \mathrm{pF}, \mathrm{VOH} \geq \mathrm{VCC} / 2$ and $\mathrm{VOL} \leq \mathrm{VCC} / 2$.

Specifications HD-15531/883

TABLE 2. HD-15531/883, HD-15531B/883 AC ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | (NOTE 2) CONDI TIONS | GROUP A SUBGROUPS | TEMPERATURE | HD-15531/883 |  | HD-15531B/883 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| ENCODER TIMING |  |  |  |  |  |  |  |  |  |
| Encoder Clock Frequency | FEC | $\mathrm{VCC}=4.5 \mathrm{~V}$ <br> and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 15 | - | 30 | MHz |
| Send Clock Frequency | FESC | $\mathrm{VCC}=4.5 \mathrm{~V}$ <br> and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 2.5 | - | 5.0 | MHz |
| Encoder Data Rate | FED | $\mathrm{VCC}=4.5 \mathrm{~V}$ <br> and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 1.25 | - | 2.5 | MHz |
| Master Reset Pulse Width | TMR | $\mathrm{VCC}=4.5 \mathrm{~V}$ $\text { and } 5.5 \mathrm{~V}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 150 | - | 150 | $\bullet$ | ns |
| Shift Clock Delay | TE1 | $\mathrm{VCC}=4.5 \mathrm{~V}$ $\text { and } 5.5 \mathrm{~V}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 125 | - | 80 | ns |
| Serial Data Setup | TE2 | $\mathrm{VCC}=4.5 \mathrm{~V}$ $\text { and } 5.5 \mathrm{~V}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 75 | - | 50 | - | ns |
| Serial Data Hold | TE3 | $V C C=4.5 \mathrm{~V}$ and 5.5V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 75 | - | 50 | - | ns |
| Enable Setup | TE4 | $\mathrm{VCC}=4.5 \mathrm{~V}$ $\text { and } 5.5 \mathrm{~V}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 90 | - | 90 | $\bullet$ | ns |
| Enable Pulse Width | TE5 | $\mathrm{VCC}=4.5 \mathrm{~V}$ <br> and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 100 | - | ns |
| Sync Setup | TE6 | $\mathrm{VCC}=4.5 \mathrm{~V}$ <br> and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 55 | - | 55 | - | ns |
| Sync Pulse Width | TE7 | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 150 | $\cdot$ | 150 | - | ns |
| Send Data Delay | TE8 | $\mathrm{VCC}=4.5 \mathrm{~V}$ <br> and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | 50 | 0 | 50 | ns |
| Bipolar Output Delay | TE9 | $\mathrm{VCC}=4.5 \mathrm{~V}$ $\text { and } 5.5 \mathrm{~V}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 130 | - | 130 | ns |
| Enable Hold | TE10 | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | 10 | $\bullet$ | ns |
| Sync Hold | TE11 | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 95 | - | 95 | - | ns |
| DECODER TIMING |  |  |  |  |  |  |  |  |  |
| Decoder Clock Frequency | FDC | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 15 | - | 30 | MHz |
| Decoder Sync Clock | FDS | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \\ & \hline \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 2.5 | - | 5.0 | MHz |
| Decoder Data Rate | FDD | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 1.25 | - | 2.5 | MHz |
| Decoder Reset Pulse Width | TDR | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 150 | $\cdot$ | 150 | - | ns |
| Decoder Reset Setup Time | TDRS | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 75 | $\cdot$ | 75 | - | ns |
| Decoder Reset Hold Time | TDRH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | $\cdot$ | 10 | $\cdot$ | ns |
| Master Reset Pulse | TMR | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 150 | - | 150 | $\cdot$ | ns |
| Bipolar Data Pulse Width | TD1 | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\begin{array}{\|l\|} \hline \text { TDC }+10 \\ \text { (Note 1) } \\ \hline \end{array}$ | - | $\begin{array}{\|l\|} \hline \text { TDC }+10 \\ \text { (Note 1) } \\ \hline \end{array}$ | $\bullet$ | ns |
| One Zero Overlap | TD3 | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | $\begin{array}{\|l\|} \hline \text { TDC-10 } \\ \text { (Note 1) } \end{array}$ | - | $\begin{aligned} & \hline \text { TDC-10 } \\ & \text { (Note 1) } \end{aligned}$ | ns |

TABLE 2. HD-15531/883, HD-15531B/883 AC ELECTRICAL PERFORMANCE CHARACTERISTICS (Continued)

| PARAMETER | SYMBOL | (NOTE 2) <br> CONDF <br> TIONS | GROUP A <br> SUB- <br> GROUPS | TEMPERATURE | MIN | MAX | MIN | MAX | UNITS |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Sync Delay (ON) | TD6 | VCC $=4.5 \mathrm{~V}$ <br> and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -20 | 110 | -20 | 110 | ns |
| Take Data Delay (ON) | TD7 | VCC $=4.5 \mathrm{~V}$ <br> and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | 110 | 0 | 110 | ns |
| Serial Data Out Delay | TD8 | VCC $=4.5 \mathrm{~V}$ <br> and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 80 | - | 80 | ns |
| Sync Delay (OFF) | TD9 | VCC $=4.5 \mathrm{~V}$ <br> and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | 110 | 0 | 110 | ns |
| Take Data Delay <br> (OFF) | TD10 | VCC $=4.5 \mathrm{~V}$ <br> and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | 110 | 0 | 110 | ns |
| Valid Word Delay | TD11 | VCC $=4.5 \mathrm{~V}$ <br> and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | 110 | 0 | 110 | ns |
| Sync Clock to Shift <br> Clock Delay | TD12 | VCC $=4.5 \mathrm{~V}$ <br> and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 75 | - | 75 | ns |
| Sync Data Setup | TD13 | VCC $=4.5 \mathrm{~V}$ <br> and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 75 | - | 75 | - | ns |

## NOTES:

1. TDC $=$ Decoder Clock Period $=1 /$ FDC
rise/fall times driven at $1 \mathrm{~ns} / \mathrm{V}$; Timing reference levels: VCC/2;
2. AC Testing as follows: $\mathrm{VIH}=70 \% \mathrm{VCC}, \mathrm{VIL}=20 \% \mathrm{VCC}$; Input Output load: CL $=50 \mathrm{pF}$

TABLE 3. HD-15531/883, HD-15531B/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | Cl | $\mathrm{VCC}=\mathrm{OPEN}, \mathrm{f}=1 \mathrm{MHz}$, All measurements referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | $\bullet$ | 25 | pF |
| Input/Output Capacitance | ClO | VCC $=$ OPEN, $\mathrm{f}=1 \mathrm{MHz}$, All measurements referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 25 | pF |
| Operating Power Supply Current | ICCOP | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}$ | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | mA |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters are characterized upon initial design and after major process and/or design changes.
2. Guaranteed but not $100 \%$ tested.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5c05 | $1,7,9$ |

## Burn-In Circuit

HD1-15531/883 CERAMIC DIP


NOTES
$\mathrm{VCC}=55 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=45 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-02 \mathrm{~V}$ to +04 V
$R=47 \mathrm{k} \Omega \pm 5 \%$
$F O=100 \mathrm{kHz} \pm 10 \%$

## Metallization Topology

DIE DIMENSIONS:
$155 \times 195 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si-Al
Thickness: $11 \mathrm{k} \AA \pm 2 k \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$

DIE ATTACH:
Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP - 460 ${ }^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$2.0 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

## Metallization Mask Layout



## Packaging



LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M-38510

NOTE: All Dimensions are $\frac{\mathrm{Min}}{\mathrm{Max}}$, Dimensions are in inches.

## Features

- TTL and CMOS Compatible Inputs
- Adjustable Rise and Fall Times Via Two External Capacitors
- Programmable Output Differential Voltage Via VREF Input
- Operates at Data Rates Up to 100 Kilobits/Sec
- Output Short Circuit Proof and Contains Overvoltage Protection
- Outputs are Inhibited (0 Volts) If DATA (A) and DATA (B) Inputs are Both in the "Logic One" State
- DATA (A) and DATA (B) Signals are "AND'd" with Clock and Sync Signals
- Full Military Temperature Range


## Ordering Information

| PACKAGE | TEMP. RANGE | ORDER CODE |
| :---: | :---: | :---: |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | HS1-3182-5 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HS1-3182-8 |
| SMD\# |  | Pending |
| LCC | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HS4-3182-8 |
| SMD\# |  | Pending |

## Description

The HS-3182 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 TTL and CMOS compatible. In addition to the DATA (A) and DATA (B) inputs, there are also inputs for CLOCK and SYNC signals which are AND'd with the DATA inputs. This feature enchances system performance and allows the HS-3182 to be used with devices other than the HS-3182.

Three power supplies are necessary to operate the HS-3182: $+\mathrm{V}=+15 \mathrm{~V} \pm 10 \%,-\mathrm{V}=-15 \mathrm{~V} \pm 10 \%$, and $\mathrm{V}_{1}=5 \mathrm{~V}$ $\pm 5 \%$. $V_{\text {REF }}$ is used to program the differential output voltage swing such that $\mathrm{V}_{\text {OUT }}$ (DIFF) $= \pm 2 \mathrm{~V}_{\text {REF }}$. Typically, $\mathrm{V}_{\text {REF }}=\mathrm{V}_{1}$ $=5 \mathrm{~V} \pm 5 \%$, but a separate power supply may be used for $\mathrm{V}_{\text {REF }}$ which should not exceed 6 V .
The driver output impedance is $75 \Omega \pm 20 \%$ at $25^{\circ} \mathrm{C}$. Driver output rise and fall times are independently programmed through the use of two external capacitors connected to the $C_{A}$ and $C_{B}$ inputs. Typical capacitor values are $C_{A}=C_{B}=$ 75 pF for high-speed operation (100KBPS), and $\mathrm{C}_{\mathrm{A}}=\mathrm{C}_{\mathrm{B}}=$ 300 pF for low-speed operation ( 12 to 14.5 KBPS ). The outputs are protected against overvoltage and short circuit as shown in the Block Diagram. The HS-3182 is designed to operate with a case temperature range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$, or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$.

## Pinouts



## Truth Table

| SYNC | CLOCK | DATA <br> (A) | DATA <br> (B) | $A_{\text {out }}$ | $\mathrm{B}_{\text {OUT }}$ | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | L | X | X | OV | OV | Null |
| L | X | X | X | OV | OV | Null |
| H | H | L | L | OV | OV | Null |
| H | H | L | H | - $\mathrm{V}_{\text {REF }}$ | $+\mathrm{V}_{\text {REF }}$ | Low |
| H | H | H | L | $+\mathrm{V}_{\text {REF }}$ | - $\mathrm{V}_{\text {REF }}$ | High |
| H | H | H | H | OV | OV | Null |

## Block Diagram



## Typical Application

* The rise and fall time of the outputs are set to ARINIC specified values by $C_{A}$ and $C_{B}$. Typical $C_{A}=$ $\mathrm{C}_{\mathrm{B}}=75 \mathrm{pF}$ for high speed and 300pF for low speed operation. The output HI and low levels are set to ARINC specifications by $\mathrm{V}_{\text {REF }}$

| Absolute Maximum Ratings | Reliability Information |
| :---: | :---: |
| Voltage Between +V and -V Terminals . . . . . . . . . . . . . . . . . . . 40V | Thermal Resistance $\quad \theta_{\mathrm{ja}} \quad \theta_{\mathrm{jc}}$ |
|  | Ceramic DIP Package . . . . . . . . . . . . $73.5^{\circ} \mathrm{C}$ W ${ }^{\text {W }} 10.9^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | Ceramic LCC Package . . . . . . . . . . . $54.0^{\circ} \mathrm{CN} \quad 6.1^{\circ} \mathrm{CN}$ |
| Logic Input Voltage. . . . . . . . . . . . . . . . . . GND -0.3 V to $\mathrm{V}_{1}+0.3 \mathrm{~V}$ | Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |
| Storage Temperature Range . . . . . . . . . . . . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Ceramic DIP Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0.8 s W |
| Junction Temperature. . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ | Ceramic LCC Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.0 W |
| Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$ | Transistor Count . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133 |
| ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1 |  |
| Output Short Circuit Duration . . . . . . . . . . . . . . . . . . . . See Note 1 |  |
| Output Overvoltage Protection . . . . . . . . . . . . . . . . . . . . See Note 2 |  |
| NOTES: |  |
| 1. Heat sink may be required for 100 K bits $/ \mathrm{s}$ at $+125^{\circ} \mathrm{C}$ and output short circuit at $+125^{\circ} \mathrm{C}$. | 2. The fuses used for output overvoltage protection may be blown by a fault at each output of greater than $\pm 6.5 \mathrm{~V}$ relative to GND. |
| CAUTION: Stresses above those listed in "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. |  |
| Recommended Operating Conditions |  |
| Operating Voltage: | Operating Temperature Range: |
| +V . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15.15 V £ 10\% | HS-3182-5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ 的 $0+70^{\circ} \mathrm{C}$ |
|  | HS-3182-8. . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
|  |  |
| $V_{\text {REF }}$ (For ARINC 429) . . . . . . . . . . . . . . . . . . . . . . . . . $5 \mathrm{5V} \pm 5 \%$ |  |

TABLE 1. D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| D.C. PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | MIN | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Current +V (Operating) | I $\mathrm{Ccop}(+\mathrm{V}$ ) | No Load (0-100K bits/s) | - | 16 | mA |
| Supply Current -V (Operating) | I $\operatorname{ccop}(-\mathrm{V})$ | No Load (0-100K bits/s) | -16 | - | mA |
| Supply Current $\mathrm{V}_{1}$ (Operating) | $\mathrm{I}_{\operatorname{ccop}}\left(\mathrm{V}_{1}\right)$ | No Load (0-100K bits/s) | - | 975 | $\mu \mathrm{A}$ |
| Supply Current $\mathrm{V}_{\text {REF }}$ (Operating) | $\mathrm{I}_{\text {CCOP }}\left(\mathrm{V}_{\text {REF }}\right)$ | No Load (0-100K bits/s) | -1.0 | - | mA |
| Logic "1" Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ |  | 2.0 | - | V |
| Logic "0" Input Voltage | $\mathrm{V}_{\text {IL }}$ |  | - | 0.5 | V |
| Output Voltage High (Output to GND) | $\mathrm{V}_{\mathrm{OH}}$ | No Load (0-100K bits/s) | $\begin{gathered} \mathrm{V}_{\mathrm{REF}} \\ (-250 \mathrm{mV}) \end{gathered}$ | $\begin{gathered} \mathrm{V}_{\mathrm{REF}} \\ (+250 \mathrm{mV}) \end{gathered}$ |  |
| Output Voltage Low (Output to GND) | $\mathrm{V}_{\mathrm{OL}}$ | No Load (0-100K bits/s) | $\begin{gathered} -V_{\text {REF }} \\ (-250 \mathrm{mV}) \end{gathered}$ | $\begin{gathered} -V_{\text {REF }} \\ (+250 \mathrm{mV}) \end{gathered}$ |  |
| Output Voltage Null | $\mathrm{V}_{\text {NULL }}$ | No Load (0-100K bits/s) | -250 | +250 | mV |
| Input Current (Input Low) | ILL |  | -20 | - | $\mu \mathrm{A}$ |
| Input Current (Input High) | IIH |  | - | 10 | $\mu \mathrm{A}$ |
| Output Short Circuit Current (Output High) | IOHSC | Short to GND | - | -80 | mA |
| Output Short Circuit Current (Output Low) | lolsc | Short to GND | 80 | - | mA |
| Output Impedance | $\mathrm{z}_{0}$ | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 60 | 90 | $\Omega$ |

NOTE:

1. $+\mathrm{V}=+15 \mathrm{~V} \pm 10 \%,-\mathrm{V}=-15 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{1}=\mathrm{V}_{\text {REF }}=5 \mathrm{~V} \pm 5 \%$, unless
otherwise specified $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ for $\mathrm{HS}-3182-5$ and $\mathrm{T}_{\mathrm{A}}=$
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ for $\mathrm{HS}-3182-8$.

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| A.C. PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | MIN | MAX | UNTTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Rise Time ( $\mathrm{A}_{\text {OUt }}, \mathrm{B}_{\text {Out }}$ ) | $t_{\text {R }}$ | $\mathrm{C}_{\mathrm{A}}=\mathrm{C}_{\mathrm{B}}=75 \mathrm{pF}$, Note 2 | 1 | 2 | $\mu \mathrm{S}$ |
|  |  | (at $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ Only) | 0.9 | 2.4 | $\mu \mathrm{S}$ |
|  |  | $\mathrm{C}_{\mathrm{A}}=\mathrm{C}_{\mathrm{B}}=300 \mathrm{pF}$, Note 2 | 3 | 9 | $\mu \mathrm{S}$ |
| Fall Time ( $A_{\text {OUT }}, \mathrm{B}_{\text {OUT }}$ ) | $t_{F}$ | $\mathrm{C}_{\mathrm{A}}=\mathrm{C}_{\mathrm{B}}=75 \mathrm{pF}$, Note 3 | 1 | 2 | $\mu \mathrm{S}$ |
|  |  | (at $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ Only) | 0.9 | 2.4 | $\mu \mathrm{S}$ |
|  |  | $\mathrm{C}_{\mathrm{A}}=\mathrm{C}_{\mathrm{B}}=300 \mathrm{pF}$, Note 3 | 3 | 9 | $\mu \mathrm{S}$ |
| Propagation Delay Input to Output | $t_{\text {PLH }}$ | $\mathrm{C}_{\mathrm{A}}=\mathrm{C}_{\mathrm{B}}=75 \mathrm{pF}$, No Load | - | 3.3 | $\mu \mathrm{S}$ |
| Propagation Delay Input to Output | $\mathrm{t}_{\text {PHL }}$ | $\mathrm{C}_{A}=\mathrm{C}_{\mathrm{B}}=75 \mathrm{pF}$, No Load | - | 3.3 | $\mu \mathrm{S}$ |

## NOTES:

1. $+\mathrm{V}=+15 \mathrm{~V},-\mathrm{V}=-15 \mathrm{~V}, \mathrm{~V}_{1}=\mathrm{V}_{\text {REF }}=5 \mathrm{~V}$, unless otherwise specified $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ for $\mathrm{HS}-3182-5$ and $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ for HS-3182-8.
2. $t_{R}$ measured $50 \%$ to $90 \%$ times 2 , no load.
3. $t_{F}$ measured $50 \%$ to $10 \%$ times 2 , no load.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | (NOTE 1) <br> CONDITIONS | MIN | MAX | UNITS |  |
| :--- | :---: | :--- | :---: | :---: | :---: |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | pF |
| Supply Current +V (Short Circuit) | $\mathrm{I}_{\mathrm{SC}}(+\mathrm{V})$ | Short to $\mathrm{GND}, \mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 150 | mA |
| Supply Current -V (Short Circuit) | $\mathrm{I}_{\mathrm{SC}}(-\mathrm{V})$ | Short to $\mathrm{GND}, \mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | -150 | - | mA |

NOTE:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters
are characterized upon initial design and after major process and/or design changes affecting these parameters.

Power Characteristics Nominal Power at $+25^{\circ} \mathrm{C},+\mathrm{V}=+15 \mathrm{~V},-\mathrm{V}=-15 \mathrm{~V}, \mathrm{~V}_{1}=\mathrm{V}_{\text {REF }}=5 \mathrm{~V}$, Notes 1,3

| DATA RATE <br> (K BTTS/s) | LOAD | $+\mathbf{V}$ | $\mathbf{V}-$ | $\mathbf{V}_{\mathbf{1}}$ | CHIP POWER | POWER DISSIPATION <br> IN LOAD |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $0-100$ | No Load | 11 mA | -10 mA | $600 \mu \mathrm{~A}$ | 325 mW | 0 |
| $12.5-14$ | Full Load, Note 2 | 24 mW | -24 mW | $600 \mu \mathrm{~A}$ | 660 mW | 60 mW |
| 100 | Full Load, Note 2 | 46 mW | -46 mW | $600 \mu \mathrm{~A}$ | 1 Watt | 325 mW |

## NOTES:

1. Heat sink may be required for 100 K bits $/ \mathrm{s}$ at $+125^{\circ} \mathrm{C}$ and output short circuit at $+125^{\circ} \mathrm{C}$.
Thermal characteristics: $T_{\text {(CASE) }}=T_{\text {(Junction) }}-\theta_{\text {(Junction }}$ - Case)
$\mathrm{P}_{\text {(Disspation) }}$
Where: $T_{\text {(Junction Max) }}=+175^{\circ} \mathrm{C}$
$\theta_{\text {(Juncton - Case) }}=10.9^{\circ} \mathrm{C} / \mathrm{W}\left(6.1^{\circ} \mathrm{C} / \mathrm{W}\right.$ for LCC $)$
$\theta_{\text {(Junction }- \text { Ambient) }}=73.5^{\circ} \mathrm{C} / \mathrm{W}\left(54.0^{\circ} \mathrm{C} / \mathrm{W}\right.$ for LCC $)$
2. Full Load for ARINC 429: $R_{L}=400 \Omega$ and $C_{L}=30,000 \mathrm{pF}$ in parallel between $A_{\text {OUT }}$ and $B_{\text {OUT }}$ (see block diagram).
3. Output Overvoltage Protection: The fuses used for output overvoltage protection may be blown by a fault at each output of greater than $\pm 6.5 \mathrm{~V}$ relative to GND.

## Driver Waveforms



NOTES: t , measured $50 \%$ to $90 \%$ times 2
$t_{f}$ measured $50 \%$ to $10 \%$ times 2

$$
\begin{array}{ll}
\mathrm{V}_{\mathrm{IH}}=5 \mathrm{~V} & \mathrm{~V}_{\mathrm{O}}=-4.75 \mathrm{~V} \text { to }-5.25 \mathrm{~V} \\
\mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V} & \mathrm{~V}_{\mathrm{OH}}=4.75 \mathrm{~V} \text { to } 5.25 \mathrm{~V}
\end{array}
$$

When the Data (A) input is in the Logic One state and the Data (B) input is in the Logic Zero state, $A_{\text {OUT }}$ is equal to $V_{\text {REF }}$ and $B_{\text {OUT }}$ is equal to- $\mathrm{V}_{\text {REF }}$ This constitutes the Output High state. Data ( A ) and Data (B) both in the Logic Zero state causes both AOUT and Bout to be equal to OV which designates the output Null state. Data (A) in the Logic Zero state and Data ( $B$ ) in the Logic One state causes $A_{\text {OUT }}$ to be equal to- $V_{\text {REF }}$ and $B_{\text {OUT }}$ to be equal to $V_{\text {REF }}$ which is the Output Low state.

## Burn-In Schematic



NOTES: $R=400 \Omega \pm 5 \%$
$\mathrm{C}_{1}=0.03 \mu \mathrm{~F} \pm 20 \%$
$\mathrm{C}_{2}=\mathrm{C}_{3}=500 \mathrm{pF}, \mathrm{NPO}$
$+\mathrm{V}=+15.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$-V=-15.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$V_{1}=+5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
A $0.0 \mu \mathrm{~F}$ decoupling capacitor is required on each of the three supply lines ( $+\mathrm{V},-\mathrm{V}$ and $\mathrm{V}_{1}$ ) at every 3rd Burn-in socket.


Ambient Temp. Max. $=+125^{\circ} \mathrm{C}$.
Package $=16$ Lead Side Brazed DIP.
Pulse Conditions $=A \& B=6.25 \mathrm{kHz} \pm 10 \%$. $B$ is delayed one-half cycle and in sync with $A$.
$\mathrm{V}_{\mathrm{IH}}=2.0 \mathrm{~V}$ Min.
$\mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}$ Max.

REFERENCE AN400
January 1992
CMOS ARINC Bus Interface Circuit

## Features

- ARINC Specification 429 Compatible
- Data Rates of 100 Kilobits or $\mathbf{1 2 . 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


## Description

The 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. This device is intended to be used with the HS-3182, a monolithic DI bipolar differential line driver designed to meet the specifications of ARINC 429. The ARINC 429 bus interface circuit consists of two (2) receivers and a transmitter operating independently as shown in Figure 7. 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 up to 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 output on Pin BD08 during the 1 st 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 used in the output data stream.
Versatility is provided in both the transmitter and receiver by the external clock input which allows the bus interface circuit to operate at data rates from 0 to 100 kilobits. The 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 5 \%$ ) and full military temperature range. It interfaces with TTL, CMOS or NMOS support circuitry, and uses the standard 5 -volt VCC supply.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | ORDER CODE |
| :---: | :---: | :---: |
| Ceramic DIP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $\mathrm{HS} 1-3282-5$ |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $\mathrm{HS} 1-3282-8$ |
|  |  | $5962-8688001 \mathrm{QA}$ |
| LCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $\mathrm{HS4}-3282-5$ |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $\mathrm{HS4-3282-8}$ |
|  |  | $5962-8688001 \mathrm{XA}$ |



## Pin Assignment and Functions

| PIN | SYMBOL | SECTION | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | $\mathrm{V}_{\mathrm{CC}}$ | Recs/Trans | Supply pin 5 volts $\pm 5 \%$ |
| 2 | 429 D11 (A) | Receiver | ARINC 429 data input to Receiver 1. |
| 3 | 429 DI1 (B) | Receiver | ARINC 429 data input to Receiver 1. |
| 4 | 429 DI2 (A) | Receiver | ARINC 429 data input to Receiver 2. |
| 5 | 429 DI2 (B) | Receiver | ARINC 429 data input to Receiver 2. |
| 6 | $\overline{\mathrm{D} / \mathrm{R} 1}$ | Receiver | Device ready flag output from Receiver 1 indicating a valid data word is ready to be fetched. |
| 7 | $\overline{\mathrm{D} / \mathrm{R} 2}$ | Receiver | Device ready flag output from Receiver 2 indicating a valid data word is ready to be fetched. |
| 8 | SEL | Receiver | Bus Data Selector - Input signal to select one of two 16 -bit words from either Receiver 1 or 2. |
| 9 | EN1 | Receiver | Input signal to enable data from Receiver 1 onto the data bus |
| 10 | EN2 | Receiver | Input signal to enable data from Receiver 2 onto the data bus. |
| 11 | BD15 | Recs/Trans | Bi-directional data bus for fetching data from etther of the Receivers, or for loading data into the Transmitter memory or control word register. See Control Word Table for description of Control Word bits. |
| 12 | BD14 | Recs/Trans | See Pin 11. |
| 13 | BD13 | Recs/Trans | See Pin 11. |
| 14 | BD12 | Recs/Trans | See Pin 11. |
| 15 | BD11 | Recs/Trans | See Pin 11. |
| 16 | BD10 | Recs/Trans | See Pin 11. |
| 17 | BD09 | Recs/Trans | See Pin 11. |
| 18 | BD08 | Recs/Trans | See Pin 11. |
| 19 | BD07 | Recs/Trans | See Pin 11. |
| 20 | BD06 | Recs/Trans | See Pin 11. |
| 21 | GND | Recs/Trans | Circuit Ground. |
| 22 | BD05 | Recs/Trans | See Pin 11. |
| 23 | BD04 | Recs/Trans | See Pin 11. Control Word function not applicable. |
| 24 | BD03 | Recs/Trans | See Pin 11. Control Word function not applicable. |


| PIN | SYMBOL | SECTION | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 25 | BD02 | Recs/Trans | See Pin 11. Control Word function not applicable. |
| 26 | BD01 | Recs/Trans | See Pin 11. Control Word function not applicable. |
| 27 | BD00 | Recs/Trans | See Pin 11. Control Word function not applicable. |
| 28 | $\overline{\text { PL1 }}$ | Transmitter | Parallel load input signal loading the first 16 -bit word into the Transmitter memory. |
| 29 | $\overline{\text { PL2 }}$ | Transmitter | Paraliel load input signal loading the second 16-Bit word into the Transmitter memory and initiates data transfer into the memory stack. |
| 30 | TX/R | Transmitter | Transmitter flag output to indicate the memory is empty. |
| 31 | 429D0 | Transmitter | Data output from Transmitter. |
| 32 | $\overline{429 D 0}$ | Transmitter | Data output from Transmitter. |
| 33 | ENTX | Transmitter | Transmitter Enable input signal to initate data transmission from FIFO memory. |
| 34 | $\overline{\text { CWSTR }}$ | Recs/Trans | Control word input strobe signal to latch the control word from the databus into the control word register. |
| 35 | - | $\bullet$ | No connection Must be left open. |
| 36 | - | - | No connection. May be left open or tied low but never tied high. |
| 37 | CLK | Recs/Trans | External clock input. May be either ten (10) or eighty (80) tumes the data rate. If using both ARINC data rates it must be ten (10) times the highest data rate, (typically 1 MHz ). |
| 38 | TXCLK | Transmitter | Transmitter Clock output. Delivers a clock frequency equal to the transmitter data rate. |
| 39 | MR | Recs/Trans | Master Reset. Active low pulse used to reset FIFO, bit counters, gap timer, word count signal, TX/R and various other flags and controls. Master reset does not reset the control word register. Usually only used on Power-Up or System Reset. |
| 40 | - | - | No Connection. |

Pinout


## Operational Description

The HS-3282 is designed to support ARINC Specification 429 and other serial data protocols that use a similar format by collecting the receiving, transmitting, synchronizing, timing and parity functions on a single, low power LSI circuit. It goes beyond the ARINC requirements by providing for either odd or even parity, and giving the user a choice of either 25 or 32 bit word lengths. The receiver and transmitter sections operate independently of each other. The seri-al-to-parallel conversion required of the receiver and the parallel-to-serial conversion requirements of the transmitter have been incorporated into the bus interface circuit.

Provisions have been made through the external clock input to provide data rate flexibility. This requires an external clock that is 10 times the data rate.

To obtain the flexibility discussed above, a number of external control signals are required, To reduce the pin count requirements, an internal control word register is used. The control word is latched from the data bus into the register by the Control Word Strobe (CWSTR) signal going to a logic "1". Eleven (11) control functions are used, and along with the Bus Data (BD) line are listed below:

## Control Word

| PIN NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: |
| BD05 | SLFTST | Connects the self test signal from the transmitter directly to the receiver shift registers, bypassing the input receivers. Receiver 1 receives Data True and Receiver 2 receives Data Not. Note that the transmitter output remains active. (Logic "0" on SLFTST Enables Self Test). |
| BD06 | SDENB1 | Signal to Activate the Source/Destination (S/D) Decoder for Receiver 1. (Logic "1" activates S/D Decoder). |
| BD07 | X1 | If SDENB1 = " 1 " then this bit is compared with ARINC Data Bit \#9. If Y 1 also matches (see Y 1 ), the word will be accepted by the Receiver 1 . If SDENB1 $=$ " 0 " this bit becomes a don't care. |
| BD08 | Y1 | If SDENB1 = " 1 " then this bit is compared with ARINC Data Bit \#10. If X1 also matches (see X1), the word will be accepted by the Receiver 1 . If SDENB1 = " 0 " this bit becomes a don't care. |
| BD09 | SDENB2 | Signal to activate the Source/Destination (S/D) Decoder for Receiver 2. (Logic "1" activates S/D Decoder). |
| BD10 | X2 | If SDENB2 = "1" then this bit is compared with ARINC Data Bit \#9. If Y2 also matches (see Y2), the word will be accepted by the Receiver 2. If SDENB2 $=$ " 0 " this bit becomes a don't care. |
| BD11 | Y2 | If SDENB2 $=$ " 1 " then this bit is compared with ARINC Data Bit \#10. If X2 also matches (see X2), the word will be accepted by the Receiver 2. If SDENB2 = " 0 " this bit becomes a don't care. |
| BD12 | PARCK | Signal used to invert the transmitter parity bit for test of parity circuits. Logic " 0 " selects normal odd parity. Logic " 1 " selects even parity. |
| BD13 | TXSEL | Selects high or low Transmitter data rate. If TXSEL $=$ " 0 " then transmitter data rate is equal to the clock rate divided by ten (10). If TXSEL $=$ " 1 " then transmitter data rate is equal to the clock rate divided by eighty ( 80 ). |
| BD14 | RCVSEL | Selects high or low Receiver data rate. If RCVSEL $=$ " 0 " then the received data rate should be equal to the clock rate divided by ten (10), if RCVSEL $=$ " 1 " then the received data rate should be equal to the clock rate divided by eighty (80). |
| BD15 | WLSEL | Selects word length. If WLSEL = "0" a 32-bit word format will be selected. If WLSEL = "1" a 25-Bit word format will be selected. |

ARINC 429 DATA FORMAT as input to the Receiver and output from the Transmitter is as follows:

TABLE 1. ARINC 42932 BIT DATA FORMAT

| ARINC BIT \# | FUNCTION |
| :---: | :--- |
| $1-8$ | Label |
| $9-10$ | SDI or Data |
| 11 | LSB |
| $12-27$ | Data |
| 28 | MSB |
| 29 | Sign |
| 30,31 | SSM |
| 32 | Parity Status |

This format is shuffled when seen on the sixteen bidirectional input/outputs. The format shown below is used from the receivers and input to the transmitter:

TABLE 2A. WORD 1 FORMAT

| BI-DIRECTIONAL <br> BIT \# | FUNCTION | ARINC |
| :---: | :--- | :---: |
| 15,14 | Data | 13,12 |
| 13 | LSB | 11 |
| 12,11 | SDI or Data | 10,9 |
| 10,9 | SSM Status | 31,30 |
| 8 | Parity Status | 32 |
| $7-00$ | Label | $1-8$ |

TABLE 2B. WORD 2 FORMAT

| BI-DIRECTIONAL <br> BIT \# | FUNCTION | ARINC |
| :---: | :--- | :---: |
| BIT \# |  |  |
| 15 | Sign | 29 |
| 14 | MSB | 28 |
| $13-00$ | Data | $27-14$ |

## Receiver Parity Status:

0 = Odd Parity
$1=$ Even Parity
If the receiver input data word string is broken before the entire data word is received, the receiver will reset and ignore the partially received data word.

If the transmitter is used to transmit consecutive data words, each word will be separated by a four (4) bit "null" state (both positive and negative outputs will maintain a zero (0) volt level.)

TABLE 3. ARINC 25-BIT DATA FORMAT

| ARINC BIT \# | FUNCTION |
| :---: | :--- |
| $1-8$ | Label |
| 9 | LSB |
| $11-23$ | Data |
| 24 | MSB |
| 25 | Parity Status |

TABLE 4A. WORD 1 FORMAT

| BI-DIRECTIONAL <br> BIT \# | FUNCTION | ARINC |
| :---: | :--- | :---: |
| $15-9$ | Don't Care | XIT \# |
| 8 | Parity Status | 25 |
| $7-0$ | Label | $1-8$ |

TABLE 4B. WORD 2 FORMAT

| BI-DIRECTIONAL <br> BIT \# | FUNCTION | ARINC |
| :---: | :--- | :---: |
| 15 | MSB | 24 |
| $14-1$ | Data | $23-10$ |
| 0 | LSB | 9 |

## Recelver Parity Status:

0 = Odd Parity
$1=$ Even Parity
No Source/Destination (S/D) in 25-Bit format.

## Receiver Operation

Since the two receivers are functionally identical, only one will be discussed in detail, and the block diagram will be used for reference in this discussion. The receiver consists of the following circuits:

- The Line Receiver functions as a voltage level translator. It transforms the 10 volt differential line voltage, ARINC 429 format, into 5 volt internal logic level.
- The output of the Line Receiver is one of two inputs to the Self-Test Data Selector (SEL). The other input to the Data Selector is the Self-Test Signal from the Transmitter section.
- The incoming data, either Self-Test or ARINC 429 is double sampled by the Word Gap Timer to generate a Data Clock. The Receiver sample frequency (RCVCLK), 1 MHz , or 125 kHz , is generated by the Receiver/Transmitter Timing Circuit. This sampling frequency is ten times the Data Rate to ensure no data ambiguity.
- The derived data clock then shifts the data down a 32Bit long Data Shift Register (Data S/R1). The Data Word Length is selectable for either 25-Bits or 32-Bits long by the Control Signal (WLSEL). As soon as the data word is completely received, an internal signal (WDCNT1) is generated by the Word Gap Timer Circuit.
- The Source/Destination (S/D) Decoder compares the user set code ( X and Y ) with Bits 9 and 10 of the Data Word. If the two codes are matched, a positive signal is generated to enable the WDCNT1 signal to latch in the received data. Otherwise, the data word is ignored and no latching action takes place. The S/D Decoder can be Enabled and Disabled by the control signal S/D ENB. If the data word is latched, an indicator flag (D/R1) is set This indicates a valid data word is ready to be fetched by the user.
- After the receiver data has been shifted down the shift register, it is placed in a holding register. The device ready flag will then be set indicating that data is ready to be fetched. If the data is ignored and left in the holding register, it will be written over when the next data word is received.

The received data in the 32 bit holding register is placed on the bus in the form of two (2) 16 bit words regardless of whether the format is for 32 or 25 bit data words. Either word can be accessed first or repeatedly until the next received data word falls into the holding register.

- The parity of the incoming word is checked and the status (i.e., logic "0" for odd parity and logic " 1 " for even parity) stored in the receiver latch and output on BD08 during the Word No. 1.
- Assuming the user desires to access the data, he first sets the Data Select Line (SEL) to a Logic "0" level and pulses the Enable ( (EN1) line. This action causes the Data Selector (SEL1) to select the first-data word, which contains the label field and Enable it onto the Data Bus. To obtain the second data word, the user sets the SEL line to a Logic " 1 " level and pulse the Enable (EN1) line again. The Enable pulse duration is matched to the user circuit requirement needed to read the Data Word from the Data Bus. The second Enable pulse is also used to reset the Device Ready (D/R1) flip-flop. This completes a receiving cycle.


## Transmitter Operation

The Transmitter section consists of an 8-word deep by 31Bit long FIFO Memory, Parity Generator, Transmitter Word Gap Timing Circuit and Driver Circuit.

- The FIFO Memory is organized in such a way that data loaded in the input register is automatically transferred to the output register for Serial Data Transmission. This eliminates a large amount of data managing time since the data need not be clocked from the input register to the output register. The FIFO input register is made up of two sets of 16 D-type flip-flops, which are clocked by the two parallel load signals ( $\overline{\mathrm{PL} 1}$ and $\overline{\mathrm{PL} 2) .} \overline{\mathrm{PL1}}$ must always precede PL2. Multiple PL1's may occur and data will be written over. As soon as $\overline{\mathrm{PL} 2}$ is received, data is transferred to the FIFO. The data from the Data Bus is
clocked into the D-type flip-flop on the positive going edge of the PL signals. If the FIFO memory is initially empty, or the stack is not full, the data will be automatically transferred down the Memory Stack and into the output register or to the last empty FIFO storage register. If the Transmitter Enable signal (ENTX) is not active, a Logic " 0 ", the data remains at the output register. The FIFO Memory has storage locations to hold eight 31-bit words. If the memory is full and the new data is again strobed with $\overline{\mathrm{PL}}$, the old data at the input register is written over by the new data. Data will remain in the Memory until ENTX goes to a Logic " 1 ". This activates the FIFO Clock and data is shifted out serially to the Transmitter Driver. Data may be loaded into the FIFO only while ENTX is inactive (low). It is not possible to write data into the FIFO while transmitting. WARNING: If $\overline{\mathrm{PL} 1}$ or $\overline{\mathrm{PL} 2}$ is applied while ENTX is high, i.e., while transmitting, the FIFO may be disrupted such that it would require a $\overline{\mathrm{MR}}$ (Master Reset) signal to recover.
- The Output Register of the FIFO is designed such that it can shift out a word of 24-Bits long or 31-Bits long. This word length is again controlled by the WLSEL bit. The TX word Gap Timer Circuit also automatically inserts a gap equivalent to 4-Bit Times between each word. This gives a minimum requirement of 29-Bit time or 36-Bit time for each word transmission. Assuming the signal, ENTX, remains at a Logic "1", a transfer to stack signal is generated to transfer the data down the Memory Stack one position. This action is continued until the last word is shifted out of the FIFO memory. At this time a Transmitter Ready (TX/R) flag is generated to signal the user that the Transmitter is ready to receive eight more data words. During transmission, if ENTX is taken low then high again, transmission will cease leaving a portion of the word untransmitted, and the data integrity of the FIFO will be destroyed.
- A Bit Counter is used to detect the last Bit shifted out of the FIFO memory and appends the Parity Bit generated by the Parity Generator. The Parity Generator has a control signal, Parity Check (PARCK), which establishes whether odd or even parity is used in the output data word. PARCK set to a logic " 0 " will result in odd parity and when set to a logic 1 " will result in even parity.


## Sample Interface Technique

From Figure 7, one can see that the Data Bus is time shared between the Receiver and Transmitter. Therefore, bus controlling must be synchronously shared between the Receiver and the Transmitter.

Figure 1 shows the typical interface timing control of the ARINC Chip for Receiving function and for Transmitting function. Timing sequence for loading the Transmitter FIFO Memory is shown in Timing Interval A. A transmitter Ready (TX/R) Flag signals the user that the Transmitter Memory is empty. The user then Enables the Transmitter Data, a 16-Bit word, on the Data Bus and strobes the Transmitter with a Parallel Load (PL1) Signal. The second part of the 32-Bit word is similarly loaded into the Transmitter with $\overline{\mathrm{PL} 2}$, which also initiates data transfer to stack. This is continuous until the Memory is full, which is eight 31-Bit words. The user must keep track of the number of words loaded into the Memory to ensure no data is written over by other data. During the time the user is loading the Transmitter, he does not have to service the Receiver, even if the Receiver flags the user with the signal $\overline{D / R 1}$ that a valid received word is ready to be fetched. This is shown by the Timing interval B. If the user decides to obtain the received data before the Transmitter is completely loaded, he sets the two parallel load signals (PL1 and PL2) at a Logic "1" state, and strobes EN1 while the signal SEL is at a Logic " 0 " state. After the negative edge of EN1, the first 16 -Bit segment of the received word becomes valid on the Data Bus. At the positive edge of EN1, the user should toggle the signal SEL to ready the Receiver for the second 16-Bit word. Strobing the Receiver
with EN1, the second time, enables the second 16-Bit word and resets the Receiver Ready Flag $\overline{\mathrm{D} / \mathrm{R} 1 .}$. The user should now reset the signal SEL to a Logic " 0 " state to ready the Receiver for another Read Cycle. During the time period that the user is fetching the received words, he can load the transmitter. This is done by interlacing the PL signals with the $\overline{\mathrm{EN}}$ signals as shown in the Timing Interval B . Servicing the Receiver 2 is similar and is illustrated by Timing interval C. Timing interval $D$ shows the rest of the Transmitter loading sequence and the beginning of the transmission by switching the signal TX Enable to a Logic " 1 " state. Timing interval $E$ is the time it takes to transmit all data from the FIFO Memory, either 288 Bit times or 232 Bit times.

## Repeater Operation

This mode of operation allows a data word that has been received to be placed directly in the FIFO for transmission. A timing diagram is shown in Figure 6. A 32 bit word is used in this example. The data word is shifted into the shift register and the $\overline{D / R}$ flag goes low. A logic " 0 " is placed on the SEL line and EN1 is strobed. This is the same as the normal receiver operation and places half the data word ( 16 bits) on the data bus. By strobing $\overline{\text { PL1 }}$ at the same time as EN1, these 16 bits will be taken off the bus and placed in the FIFO. SEL is brought back high and EN1 is strobed again for the second 16 bits of the data word. Again by strobing $\overline{\text { PL2 }}$ at the same time the second 16 bits will be placed in the FIFO. The parity bit will have been stripped away leaving the 31 bit data word in the FIFO ready for transmission as shown in Figure 5.


FIGURE 7. SINGLE CHIP ARINC 429 INTERFACE FUNCTIONAL BLOCK DIAGRAM

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | 7.0V |
| Input, Output or I/O Voltage Applied (Except Pins 2-5). $\qquad$ | GND -0.3V to VDD +0.3 V |
| Input Voltage Applied (Pins 2-5) | . -29 V to +29V |
| Junction Temperature | $\ldots . . .175{ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| ESD Classification | Class "1" |
| Lead Temperature (Soldering 10 se | . $+300{ }^{\circ} \mathrm{C}$ |

Thermal Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $72^{\circ} \mathrm{C} / \mathrm{W}$ | $12^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $65^{\circ} \mathrm{C} / \mathrm{W}$ | $10.3{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Package Power Dissipation at $+125{ }^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 695mW |
| Ceramic LCC Package |  | 769mW |
| Gate Count |  | 632 Gates |

CAUTION: Stresses in excess of those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and operation of the device at these or any other conditions in excess of those indicated in the operational sections of this specification is not implied.

## Recommended Operating Conditions



DC ELECTRICAL PERFORMANCE CHARACTERISTICS $V_{D D}=5 \mathrm{~V} \pm 5 \% ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (HS-3282-5),

$$
\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{HS}-3282-8)
$$

| D.C. PARAMETERS | SYMBOL | CONDITIONS | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |
| ARINCINPUTS Pins 2-3,4-5 |  |  |  |  |  |
| Logic " 1 " Input Voltage | VIH | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}$ | 6.7 | 13.0 | V |
| Logic "0" Input Voltage | VIL | $V_{D D}=5.25 \mathrm{~V}$ | -13.0 | -6.7 | V |
| Null Input Voltage | VNUL | $\mathrm{V}_{\mathrm{DD}}=4.75 \mathrm{~V}, 5.25 \mathrm{~V}$ | -2.5 | +2.5 | v |
| Common Mode Voltage | VCH | $\mathrm{V}_{\mathrm{DD}}=4.75 \mathrm{~V}, 5.25 \mathrm{~V}$ | -5.0 | +5.0 | v |
| Input Leakage | IIH | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}, \\ & \mathrm{VIN}= \pm 6.5 \mathrm{~V} \end{aligned}$ | - | 200 | $\mu \mathrm{A}$ |
| Input Leakage | IIL | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}, \mathrm{VIN}=0.0 \mathrm{~V}$ | -450 | - | $\mu \mathrm{A}$ |
| Differential Input Impedance | RI | $\begin{aligned} & \mathrm{VDD}=5.25 \mathrm{~V}, \\ & \mathrm{VIN}=+5 \mathrm{~V},-5 \mathrm{~V} \end{aligned}$ | 12 | - | k $\Omega$ |
| Input Impedance to VDD | RH | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ | 12 | - | k $\Omega$ |
| Input Impedance to GND | RG | $\mathrm{V}_{\mathrm{DD}}=$ Open, $\mathrm{VIN}=5.0 \mathrm{~V}$ | 12 | - | $\mathrm{k} \Omega$ |
| BIDIRECTIONAL INPUTS Pins 11-20, 22-27 |  |  |  |  |  |
| Logic "1" Input Voltage | VIH | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}$ | 2.1 | - | V |
| Logic "0" Input Voltage | VIL | $V_{D D}=4.75 \mathrm{~V}$ | - | 0.7 | v |
| Input Leakage | IIH | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}, \mathrm{VIN}=5.25 \mathrm{~V}$ | - | 1.5 | $\mu \mathrm{A}$ |
| Input Leakage | IIL | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}, \mathrm{VIN}=0.0 \mathrm{~V}$ | -1.5 | - | $\mu \mathrm{A}$ |
| ALL OTHER INPUTS Pins 8-10, 28, 29, 33, 34, 37, 39 |  |  |  |  |  |
| Logic "1" Input Voltage | VIH | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}$ | 3.5 | - | v |
| Logic "0" Input Voltage | VIL | $V_{D D}=4.75 \mathrm{~V}$ | - | 0.7 | V |
| Input Leakage | IIH | $V_{D D}=5.25 \mathrm{~V}, \mathrm{VIN}=5.25 \mathrm{~V}$ | - | 10 | $\mu \mathrm{A}$ |
| Input Leakage | IIL | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}, \mathrm{VIN}=0.0 \mathrm{~V}$ | -75 | - | $\mu \mathrm{A}$ |
| OUTPUTS Pins 6, 7, 11-20, 22-27, 30-32, 38, Supply Pin 1 |  |  |  |  |  |
| Logic "1" Output Voltage | VOH | $\begin{aligned} & \mathrm{VDD}=4.75 \mathrm{~V}, \\ & 10 \mathrm{OH}=-1.5 \mathrm{~mA} \end{aligned}$ | 2.7 | - | V |
| Logic "0" Output Voltage | vol | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=4.75 \mathrm{~V} \\ & \mathrm{IOL}=1.8 \mathrm{~mA} \end{aligned}$ | - | 0.4 | v |
| Standby Supply Current | ICC1 | $\mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ Except 9, 10, $29=5.25 \mathrm{~V}$ | - | 20 | mA |
| Operating Supply Current | ICC2 | $\begin{aligned} & V_{D D}=5.25 \mathrm{~V}, \mathrm{VIN}=5.25 \mathrm{~V} \\ & \text { Except } 8,33=0.0 \mathrm{~V}, \\ & \mathrm{CLK}=1 \mathrm{MHz} \end{aligned}$ | - | 20 | mA |

AC ELECTRICAL PERFORMANCE CHARACTERISTICS $V_{D D}=5 \mathrm{~V} \pm 5 \% ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (HS-3282-5),

$$
\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}(\mathrm{HS}-3282-8)
$$

| A.C. PARAMETERS | SYMBOL | CONDITIONS | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |
| Clock Frequency | FC | $\mathrm{V}_{\mathrm{DD}}=4.75 \mathrm{~V}, 5.25 \mathrm{~V}$ | - | 1 | MHz |
| Data Rate 1/ | FD |  | - | 100 | kHz |
| Data Rate 2/ | FD | , | - | 12.5 | kHz |
| Master Reset Pulse Width | TMR | $\cdots$ | 200 | - | ns |
| RECEIVER TIMING |  |  |  |  |  |
| Receiver Ready Time From 32nd Bit 1/ | TD/R2 | $V_{D D}=4.75 \mathrm{~V}, 5.25 \mathrm{~V}$ | - | 16 | $\mu \mathrm{s}$ |
| Receiver Ready Time From 32nd Bit 2/ | TD/R2 |  | - | 128 | $\mu s$ |
| Device Ready to Enable Time | TD/REN |  | 0 | - | ns |
| Data Enable Pulse Width | TEN |  | 200 | - | ns |
| Data Enable to Data Enable Time | TENEN |  | 50 | - | ns |
| Data Enable to Device Ready Reset Time | TEND/R |  | - | 200 | ns |
| Output Data Valid to Enable Time | TENDATA |  | - | 200 | ns |
| Data Enable to Data Select Time | TENSEL |  | 20 | - | ns |
| Data Select to Data <br> Enable Time | TSELEN |  | 20 | - | ns |
| Output Data Disable Time | TDATAEN | 1 | - | 30 | ns |
| CONTROL WORD TIMING |  |  |  |  |  |
| Control Word Strobe Pulse Width | TCWSTR | $\mathrm{V}_{\text {DD }}=4.75 \mathrm{~V}, 5.25 \mathrm{~V}$ | 130 | - | ns |
| Control Word Setup Time | TCWSET |  | 130 | - | ns |
| Control Word Hold Time | TCWHLD | 1 | 0 | - | ns |
| TRANSMITTER FIFO Write Timing |  |  |  |  |  |
| Parallel Load Pulse Width | TPL | $V_{D D}=4.75 \mathrm{~V}, 5.25 \mathrm{~V}$ | 200 | - | ns |
| Parallel Load to Parallel Load 2 Delay | TPL12 |  | 0 | - | ns |
| Transmitter Ready Delay Time | TTX/R |  | - | 840 | ns |
| Data Word Setup Time | TDWSET |  | 110 | - | ns |
| Data Word Hold Time | TDWHLD | 1 | 0 | - | ns |
| TRANSMITTER Output Timing |  |  |  |  |  |
| Enable Transmit to Output Data Valid Time 1/ | TENDAT | $\mathrm{V}_{\mathrm{DD}}=4.75 \mathrm{~V}, 5.25 \mathrm{~V}$ | - | 25 | $\mu \mathrm{s}$ |
| Enable Transmit to Output Data Valid Time 2/ | TENDAT |  | - | 200 | $\mu s$ |
| Output Data Bit Time 1/ | TBIT |  | 4.95 | 5.05 | $\mu \mathrm{s}$ |
| Output Data Bit Time 2/ | TBIT |  | 39.6 | 40.4 | $\mu \mathrm{s}$ |
| Output Data Null Time 1/ | TNULL |  | 4.95 | 5.05 | $\mu \mathrm{s}$ |
| Output Data Null Time 2/ | TNULL |  | 39.6 | 40.4 | $\mu \mathrm{s}$ |
| Data Word Gap Time 1/ | TGAP |  | 39.6 | 40.4 | $\mu \mathrm{s}$ |
| Data Word Gap Time 2/ | TGAP |  | 316.8 | 323.2 | $\mu \mathrm{s}$ |
| Data Transmission Word to TX/R Set Time | TDTX/R |  | - | 400 | ns |
| Enable Transmit Turnoff Time | TENTX/R | 1 | 0 | - | ns |
| REPEATER OPERATION TIMING |  |  |  |  |  |
| Data Enable to Parallel Load Delay Time | TENPL | $\mathrm{V}_{\mathrm{DD}}=4.75 \mathrm{~V}, 5.25 \mathrm{~V}$ | 0 | - | ns |
| Data Enable Hold for Parallel Load Time | TPLEN |  | 0 | - | ns |
| Enable Transmit Delay Time | TTX/REN |  | 0 | - | ns |

NOTES: 1. 100 kHz Data Rate. 2. 12.5 kHz Data Rate.

ELECTRICAL PERFORMANCE CHARACTERISTICS $V_{D D}=5 \mathrm{~V} \pm 5 \% ; T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}(\mathrm{HS}-3282-5)$,
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HS-3282-8)

| PARAMETERS | SYMBOL | (Note 1) <br> CONDITIONS | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |
| Differential Input Capacitance | CD | $\mathrm{V}_{\mathrm{DD}}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$, Note 2, 3 | - | 20 | pF |
| Input Capacitance to VDD | CH | $V_{D D}=G N D, f=1 \mathrm{MHz}$, Note 2, 3 | - | 20 | pF |
| Input Capacitance to GND | CG | $V_{\text {DD }}=$ Open, $f=1 \mathrm{MHz}$, Note 2, 3 | - | 20 | pF |
| Input Capacitance | Cl | $V_{D D}=$ Open, $f=1 \mathrm{MHz}$, Note 2, 4 | - | 15 | pF |
| Output Capacitance | CO | $V_{\text {DD }}=$ Open, $f=1 \mathrm{MHz}$, Note 2,5 | - | 15 | pF |
| Clock Rise Time | TLHC | $\mathrm{CLK}=1 \mathrm{MHz}$, From 0.7 V to 3.5 V | - | 10 | ns |
| Clock Fall Time | THLC | $\mathrm{CLK}=1 \mathrm{MHz}$, From 3.5 V to 0.7 V | - | 10 | ns |
| Input Rise Time | TLHI | From 0.7 V to 3.5 V , Note 6 | - | 15 | ns |
| Input Fall Time | THLI | From 3.5V to 0.7V, Note 6 | - | 15 | ns |

NOTES

1. The parameters listed in this table are controlied via design or process parameters and are not directly tested These parameters are characterized upon initial design and after major process and/or design changes affecting these parameters.
2 All measurements are referenced to device GND

3 Pins 2-3, 4-5.
4 Pins 8-10, 28, 29, 33, 34, 37, 39.
5. Pins 6, 7, 11-20, 22-27, 30-32, 38.
6. Pins 8-20, 22-29, 33, 34.

## Timing Waveforms



FIGURE 1. TYPICAL INTERFACE TIMING SEQUENCE


FIGURE 2. RECEIVER TIMING


FIGURE 3. CONTROL WORD TIMING

Timing Waveforms (Continued)


FIGURE 4. TRANSMITTER FIFO WRITE TIMING


FIGURE 5. TRANSMITTER OUTPUT TIMING


FIGURE 6. REPEATER OPERATION TIMING

## Burn-In Circuit



HS-3282 CERAMIC LCC


## Metallization Topology

DIE DIMENSIONS:
$246 \times 224 \times 19$ mils ( $6250 \times 5700 \times 483 \mu \mathrm{~m}$ )
METALLIZATION:
Type: Si-Al
Thickness: $11 \mathrm{kA} \pm 2 \mathrm{kA}$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{kA} \pm 1 \mathrm{kA}$
DIE ATTACH:
Material: Gold/Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
LEAD TEMPERATURE (10 sec soldering)
$<300^{\circ} \mathrm{C}$

Metallization Mask Layout
HS-3282


## +5 Volt Powered Dual RS-232 Transmitter/Receiver

## GENERAL DESCRIPTION

The ICL232 is a dual RS-232 transmitter/receiver interface circuit that meets all EIA RS-232C specifications. It requires a single +5 V power supply, and features two onboard charge pump voltage converters which generate +10 V and -10 V supplies from the 5 V supply.
The drivers' feature true TTL/CMOS input compatibility, slew-rate-limited output, and 300 ohms power-off source impedance. The receivers can handle up to $\pm 30$ volts, and have a 3 to 7 kilohms input impedance. The receivers also have hysteresis to improve noise rejection.

## Typical Applications

Any System Requiring RS-232 Communications Port:

- Computers-Portable and Mainframe
- Peripherals-Printers and Terminals
- Portable Instrumentation
- Modems
- Dataloggers


## ORDERING INFORMATION

| Part | Temperature Range | Package |
| :---: | :---: | :---: |
| ICL232CPE | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 16 Pin Plastic DIP |
| ICL232CJE |  | 16 Pin CERDIP |
| ICL232CBE |  | 16 Pin SOIC (WB) |
| ICL2321PE | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 16 Pin Plastic DIP |
| ICL2321JE |  | 16 Pin CERDIP |
| ICL2321BE |  | 16 Pin SOIC (WB) |
| ICL232MJE | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 16 Pin CERDIP |

## FEATURES

- Meets All RS-232C Specifications
- Requires Only Single +5V Power Supply
- Onboard Voltage Quadrupler
- Low Power Consumption
- 2 Drivers
$- \pm 9 \mathrm{~V}$ Output Swing for +5 V Input
- 300 Ohms Power-off Source Impedance
-Output Current Limiting
-TTL/CMOS Compatible
-30 V/us Maximum Slew Rate
- 2 Receivers
$- \pm 30 \mathrm{~V}$ Input Voltage Range
-3 to 7 kohms Input Impedance
-0.5V Hysteresis to Improve Noise Rejection
- All Critical Parameters are Guaranteed Over the Entire Commercial, Industrial and Military Temperature Ranges


0100-1

Figure 2: ICL232 Functional Diagram


Figure 1: Pin Configurations

## ABSOLUTE MAXIMUM RATINGS



## Short Circuit Duration

T1 out, T2out
.Continuous

R1out, R2out
Continuous
Continuous Total Power Dissipation ( $\mathrm{T}_{\mathrm{a}}=25^{\circ} \mathrm{C}$ )


Plastic Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . 375 mW derate $-7.0 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ above $70^{\circ} \mathrm{C}$

SO Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 375 mW derate $-7.0 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ above $70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temperature (Soldering, 10 sec ) . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$ Operating Temperature Range


NOTE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions above those indicated in the operational sections of the specifications is not implied Exposure to absolute maximum rating conditions for extended penods may affect device reliability.

ELECTRICAL CHARACTERISTICS Test Conditions: $\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{a}}=$ operating temperature range, Test Circuit as in Figure 3 (unless otherwise specified)

| Symbol | Parameter | Test Conditions | Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| TOUT | Transmitter Output Voltage Swing | T1 OUt and T2 OUT loaded with $3 \mathrm{k} \Omega$ to ground | $\pm 5$ | $\pm 9$ | $\pm 10$ | V |
| ICC | Power Supply Current | Outputs Unloaded, $\mathrm{T}_{\mathrm{a}}=25^{\circ} \mathrm{C}$ |  | 5 | 10 | mA |
| $\mathrm{V}_{\text {IL }}$ | Tin, Input Logic Low |  |  |  | 0.8 | V |
| $\mathrm{V}_{\text {IH }}$ | Tin, Input Logic High |  | 2.0 |  |  | V |
| $I_{p}$ | Logic Pullup Current | $\mathrm{T} 1_{\mathrm{in},} \mathrm{T} 2_{\text {in }}=0 \mathrm{~V}$ |  | 15 | 200 | $\mu \mathrm{A}$ |
| $V_{\text {in }}$ | RS-232 Input Voltage Range |  | -30 |  | +30 | $V$ |
| $\mathrm{R}_{\mathrm{In}}$ | Receiver Input Impedance | $\mathrm{V}_{\mathrm{in}}= \pm 3 \mathrm{~V}$ | 3.0 | 5.0 | 7.0 | k $\Omega$ |
| $\mathrm{V}_{\text {IN }}(\mathrm{H}-\mathrm{L})$ | Receiver Input Low Threshold | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{a}}=25^{\circ} \mathrm{C}$ | 0.8 | 1.2 |  | V |
| $\mathrm{V}_{\text {IN }}(\mathrm{L}-\mathrm{H})$ | Receiver Input High Threshold | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{a}}=25^{\circ} \mathrm{C}$ |  | 1.7 | 2.4 | V |
| $V_{\text {hyst }}$ | Receiver Input Hysteresis |  | 0.2 | 0.5 | 1.0 | V |
| $\mathrm{V}_{\mathrm{OL}}$ | TTL/CMOS Receiver Output Voltage Low | $\mathrm{l}_{\text {out }}=3.2 \mathrm{~mA}$ |  | 0.1 | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | TTL/CMOS Receiver Output Voltage High | $\mathrm{l}_{\text {out }}=-1.0 \mathrm{~mA}$ | 3.5 | 4.6 |  | V |
| $t_{\text {pd }}$ | Propagation Delay | RS-232 to TTL or TTL to RS-232 |  | 0.5 |  | $\mu \mathrm{s}$ |
| SR | Instantaneous Slew Rate | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=10 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=3 \mathrm{k} \Omega, \\ & \mathrm{~T}_{\mathrm{a}}=25^{\circ} \mathrm{C}(\text { Note } 1,2) \end{aligned}$ |  |  | 30 | $\mathrm{V} / \mu \mathrm{s}$ |
| $\mathrm{SR}_{\mathrm{t}}$ | Transition Region Slew Rate | $\begin{aligned} & R_{L}=3 \mathrm{k} \Omega, C_{L}=2500 \mathrm{pF} \text { Measured } \\ & \text { from }+3 V \text { to }-3 V \text { or }-3 V \text { to }+3 V \end{aligned}$ |  | 3 |  | $\mathrm{V} / \mu \mathrm{s}$ |
| $\mathrm{R}_{\text {out }}$ | Output Resistance | $\mathrm{V}_{\mathrm{cc}}=\mathrm{V}+=\mathrm{V}-=0 \mathrm{~V}, \mathrm{~V}_{\text {out }}= \pm 2 \mathrm{~V}$ | 300 |  |  | $\Omega$ |
| Isc | RS-232 Output Short Circuit Current | T1 ${ }_{\text {out }}$ or T2 ${ }_{\text {out }}$ shorted to GND |  | $\pm 10$ |  | mA |

NOTE 1: Guaranteed by design.
2: See Figure 5 for definition.


## TYPICAL PERFORMANCE CHARACTERISTICS




0100-6

## DETAILED DESCRIPTION

The ICL232 is a dual RS-232 transmitter/receiver powered by a single +5 V power supply which meets all EIA RS232C specifications and features low power consumption. The functional diagram (Figure 2) illustrates the major elements of the ICL232. The circuit is divided into three sections: a voltage quadrupler, dual transmitters, and dual receivers.

## Voltage Converter

An equivalent circuit of the dual charge pump is illustrated in Figure 5.

The voltage quadrupler contains two charge pumps which use two phases of an internally generated clock to generate +10 V and -10 V . The nominal clock frequency is 16 kHz . During phase one of the clock, capacitor C1 is charged to $V_{c c}$. During phase two, the voltage on $C 1$ is added to $V_{c c}$, producing a signal across C 2 equal to twice $\mathrm{V}_{\mathrm{cc}}$. At the same time, C 3 is also charged to $2 \mathrm{~V}_{\mathrm{cc}}$, and then during phase one, it is inverted with respect to ground to produce a signal across C 4 equal to $-2 \mathrm{~V}_{\mathrm{cc}}$. The voltage converter accepts input voltages up to 5.5 V . The output impedance of the doubler $\left(\mathrm{V}^{+}\right)$is approximately 200 ohms, and the output impedance of the inverter $\left(\mathrm{V}^{-}\right)$is approximately 450 ohms. Typical graphs are presented which show the voltage converters output vs input voltage and output voltages vs load characteristics. The test circuit (Figure 3) uses 22 uF capacitors for $\mathrm{C} 1-\mathrm{C} 4$, however, the value is not critical. Increasing the values of C 1 and C 2 will lower the output impedance of the voltage doubler and inverter, and increasing the values of the reservoir capacitors, C3 and C4, lowers the ripple on the $\mathrm{V}^{+}$and $\mathrm{V}^{-}$supplies.


Figure 6: Slew Rate Definition

## Transmitters

The transmitters are TTL/CMOS compatible inverters which translate the inputs to RS-232 outputs. The input logic threshold is about $26 \%$ of $V_{c c}$, or 1.3 V for $\mathrm{V}_{c c}=5 \mathrm{~V}$. A logic 1 at the input results in a voltage of between -5 V and $\mathrm{V}^{-}$at the output, and a logic 0 results in a voltage between +5 V and $(\mathrm{V}+-0.6 \mathrm{~V})$. Each transmitter input has an internal 400 kilohm pullup resistor so any unused input can be left unconnected and its output remains in its low state. The output voltage swing meets the RS-232C specification of $\pm 5 \mathrm{~V}$ minimum with the worst case conditions of: both transmitters driving 3 kohm minimum load impedance, $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$, and maximum allowable operating temperature. The transmitters have an internally limited output slew rate which is less than $30 \mathrm{~V} / \mathrm{us}$. The outputs are short circuit protected and can be shorted to ground indefinitely. The powered down output impedance is a minimum of 300 ohms with $\pm 2 \mathrm{~V}$ applied to the outputs and $\mathrm{V}_{\mathrm{cc}}=0 \mathrm{~V}$.


0100-12

Figure 5: Dual Charge Pump


## Receivers

The receiver inputs accept up to $\pm 30 \mathrm{~V}$ while presenting the required 3 to 7 kilohms input impedance even if the power is off $\left(\mathrm{V}_{\mathrm{cc}}=0 \mathrm{~V}\right)$. The receivers have a typical input threshold of 1.3 V which is within the $\pm 3 \mathrm{~V}$ limits, known as the transition region, of the RS-232 specification. The receiver output is VV to $\mathrm{V}_{\mathrm{cc}}$. The output will be low whenever the input is greater than 2.4 V and high whenever the input is floating or driven between +0.8 V and -30 V . The receivers feature 0.5 V hysteresis to improve noise rejection.


0100-14
Figure 8: Receiver


0100-8
Average Propagation Delay $=\frac{\mathrm{t}_{\text {ph1 }}+\mathrm{t}_{\text {plh }}}{2}$
Figure 9: Propagation Delay Definition

## APPLICATIONS

The ICL232 may be used for all RS-232 data terminal and communication links. It is particularly useful in applications where $\pm 12 \mathrm{~V}$ power supplies are not available for conventional RS-232 interface circuits. The applications presented represent typical interface configurations.
A simple duplex RS-232 port with CTS/RTS handshaking is illustrated in Figure 10. Fixed output signals such as DTR (data terminal ready) and DSRS (data signaling rate select) is generated by driving them through a $5 \mathrm{k} \Omega$ resistor connected to $\mathrm{V}^{+}$.
In applications requiring four RS-232 inputs and outputs (Figure 11), note that each circuit requires two charge pump capacitors (C1 and C2) but can share common reservoir capacitors (C3 and C4). The benefit of sharing common reservoir capacitors is the elimination of two capacitors and the reduction of the charge pump source impedance which effectively increases the output swing of the transmitters.


Figure 10: Simple Duplex RS-232 Port with CTS/RTS Handshaking


0100-10
Figure 11: Combining Two ICL232's for 4 Pairs of RS-232 Inputs and Outputs

## CMOS MEMORY

PAGE
LOW VOLTAGE DATA RETENTION ..... 6-3
INDUSTRY CMOS RAM CROSS REFERENCE ..... 6-4
CMOS MEMORY DATASHEETS
S1K - ASYNCHRONOUS RAMs
CDP1821C/3 $1 \mathrm{~K} \times 1$ Asynchronous RAM ..... 6-5
CDP1822, C $256 \times 4$ Asynchronous RAM ..... 6-10
CDP1822C/3 High-Reliability $256 \times 4$ Asynchronous RAM ..... 6-16
CDP1823, C $128 \times 8$ Asynchronous RAM. ..... 6-21
CDP1823C/3 High-Reliabilty $128 \times 8$ Asynchronous RAM ..... 6-27
CDP1824, C $32 \times 8$ Asynchronous RAM. ..... 6-32
CDP1824/3, C/3 High-Reliability $32 \times 8$ Asynchronous RAM ..... 6-37
CDP1826C $64 \times 8$ Asynchronous RAM ..... 6-42
MWS5101, A $256 \times 4$ Asynchronous RAM ..... 6-49
1K - SYNCHRONOUS RAMs
HM-6508 1K $\times 1$ Synchronous RAM ..... 6-54
HM-6508/883 $1 \mathrm{~K} \times 1$ Synchronous RAM ..... 6-59
HM-6518 $1 K \times 1$ Synchronous RAM ..... 6-67
HM-6518/883 1K x 1 Synchronous RAM ..... 6-72
HM-6551 $256 \times 4$ Synchronous RAM ..... 6-80
HM-6551/883 $256 \times 4$ Synchronous RAM ..... 6-85
HM-6561 $256 \times 4$ Synchronous RAM ..... 6-93
HM-6561/883 $256 \times 4$ Synchronous RAM ..... 6-98
4K - SYNCHRONOUS RAMs
HM-6504 4K $\times 1$ Synchronous RAM ..... 6-106
HM-6504/883 4K $\times 1$ Synchronous RAM ..... 6-112
HM-6514 1K x 4 Synchronous RAM ..... 6-120
HM-6514/883 1K x 4 Synchronous RAM ..... 6-126
4K - ASYNCHRONOUS RAM
MWS5114 1K x 4 Asynchronous RAM ..... 6-134
16K - SYNCHRONOUS RAM
HM-6516 2K x 8 Synchronous RAM ..... 6-138
HM-6516/883 $2 \mathrm{~K} \times 8$ Synchronous RAM ..... 6-144
16K - ASYNCHRONOUS RAMs
HM-65162 2K x 8 Asynchronous RAM ..... 6-152
HM-65162/883 2K $\times 8$ Asynchronous RAM ..... 6-159
HM-65262 16K $\times 1$ Asynchronous RAM ..... 6-169
HM-65262/883 16K x 1 Asynchronous RAM ..... 6-175
64K - ASYNCHRONOUS RAM
HM-65642 8K $\times 8$ Asynchronous RAM ..... 6-183
HM-65642/883 8K x 8 Asynchronous RAM ..... 6-190
CMOS RAM MODULES
HM-6564 64K Synchronous RAM Module ..... 6-199
HM-8808, A 8K x 8 Asynchronous RAM Modules ..... 6-205
HM-8816H 16K $\times 8$ Asynchronous RAM Module ..... 6-213
HM-8832 $32 \mathrm{~K} \times 8$ Asynchronous RAM Module ..... 6-218
HM-92560 256K Synchronous RAM Module ..... 6-222
HM-92570 256K Buffered Synchronous RAM Module. ..... 6-227
HM-91M2 1M-Bit Asynchronous RAM Module ..... 6-232
CMOS PROMs
HM-6642 $512 \times 8$ Fuse Link PROM ..... 6-239
HM-6642/883 $512 \times 8$ Fuse LinkPROM ..... 6-246
HM-6617 $2 \mathrm{~K} \times 8$ Fuse Link PROM. ..... 6-254
HM-6617/883 $2 \mathrm{~K} \times 8$ Fuse Link PROM. ..... 6-261
IM6654 $512 \times 8$ UV EPROM ..... 6-268

## HM-XXXX Series Low Voltage Data Retention

HARRIS HM-XXXX Series 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}})$ 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. $\overline{\mathrm{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 $>5$ ns (for asynchronous RAMs) after VCC reaches the minimum operating voltage ( 4.5 volts).

## DATA RETENTION TIMING

Industry CMOS RAM Cross Reference
HARRIS CMOS RAMs

| DESCRIPTION | HARRIS | AMD | EDI | $\begin{aligned} & \text { FUJI- } \\ & \text { TSU } \end{aligned}$ | $\begin{aligned} & \text { HIT- } \\ & \text { ACHI } \end{aligned}$ | IDT | $\begin{aligned} & \text { MITSU- } \\ & \text { BISHI } \end{aligned}$ | MOTOROLA | NATIONAL | NEC | OKI | $\begin{gathered} \text { HARRIS/ } \\ \text { RCA } \end{gathered}$ | SMOS | $\begin{gathered} \text { TOSH- } \\ \text { IBA } \end{gathered}$ | NMOS, OTHER |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IKCMOS RANA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1kx1,16 Pin Synchronous | HM-6508 | - | - | 8401 | - | - | - | 6508 | $\begin{gathered} 6508 \\ 74 \mathrm{C} 929 \end{gathered}$ | 443 | - | $\begin{aligned} & 6508 \\ & 1821 \end{aligned}$ | - | 5508 | 2125, 4015 |
| 1K $\times 1,18$ Pin Synchronous | HM-6518 | - | - | - | - | $\bullet$ | - | 6518 | $\begin{gathered} 6518 \\ 74 \mathrm{C} 930 \end{gathered}$ | - | - | - | - | - | - |
| $256 \times 4,22$ Pin Synchronous | HM-6551 | - | - | - | - | - | - | - | $\begin{gathered} 6551 \\ 74 \mathrm{C} 920 \end{gathered}$ | - | - | $\begin{aligned} & 1822 \\ & 5101 \end{aligned}$ | - | 5101 | 2101 |
| $256 \times 4,18$ Pin Synchronous | HM-6561 | - | - | - | - | - | - | - | - | - | - | - | - | - | 2111 |
| 4K CMOS RAMs |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $4 \mathrm{~K} \times 1,18$ Pin Synchronous | HM-6504 | 92L44 | - | 8404 | $\begin{aligned} & 4315 \\ & 6147 \end{aligned}$ | - | - | 6504 | 6504 | - | 5104 | - | 6504 | 5504 | $\begin{gathered} \hline 2141,2147, \\ 315 \mathrm{D}, 4104, \\ 4404 \end{gathered}$ |
| 1K x 4, 18 Pin Synchronous | HM-6514 | $\begin{aligned} & \hline 91 L 14 \\ & 91 L 24 \end{aligned}$ | - | 8414 | $\begin{aligned} & 4334 \\ & 6148 \end{aligned}$ | $\cdot$ | 58981 | 6514 | 6514 | 444 | $\begin{aligned} & 5114 \\ & 5115 \end{aligned}$ | 5114 | 6514 | 5514 | $\begin{gathered} 2114,2148, \\ 2149,4045, \\ 314 \mathrm{~A} \end{gathered}$ |
| 16K CMOS RAMs |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $2 \mathrm{~K} \times 8,24$ Pin Synchronous | HM-6516 | - | - | - | - | - | - | - | 6516 | - | - | - | - | - | - |
| 2K x 8, 24 Pin Asynchronous | HM-65162 | - | - | 8416 | 6116 | 6116 | 5117 | 65116 | 6116 | 446 | 5128 | 6116 | 2016 | 5517 | $\begin{aligned} & \hline 4802,2116, \\ & 2016,4016 \end{aligned}$ |
| 16K x 1, 20 Pin Asynchronous | HM-65262 | - | - | 8167 | 6167 | 6167 | - | - | - | - | - | - | $\begin{aligned} & 2267 \\ & 2367 \end{aligned}$ | - | $\begin{gathered} 2167, \\ 8167,1400 \end{gathered}$ |
| 64K CMOS RAMs |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8K x 8, 28 Pin Asynchronous | $\begin{aligned} & \text { HM-65642 } \\ & \text { HM-8808A* } \\ & \text { HM-8808* } \end{aligned}$ | 99C88 | $\begin{gathered} \hline 8808 \mathrm{~A} \\ 8808 \end{gathered}$ | 8464 | 6264 | $\begin{gathered} 7164 \\ 7 M 864 \\ 8 \mathrm{M} 864 \end{gathered}$ | 5164 | 6164 | 6164 | 4464 | $\bullet$ | 6264 | $\begin{aligned} & 2064 \\ & 2264 \end{aligned}$ | $\begin{aligned} & 5564 \\ & 5565 \end{aligned}$ |  |
| 128K CMOS RAM MODULE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $16 \mathrm{~K} \times 8,28$ Pin Asynchronous | HM-8816H | - | 8816 H |  |  |  |  |  |  |  |  |  |  |  |  |
| 256K CMOS RAM MODULE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $32 \mathrm{~K} \times 8 / 16 \mathrm{~K} \times 1648 \mathrm{Pin}$ Module Asynchronous | $\begin{aligned} & \text { HM-92560 } \\ & \text { HM-92570 } \end{aligned}$ | - | - | - | $\bullet$ | - | $\bullet$ | - | $\bullet$ | - | - | - | - | - | - |
| $32 \mathrm{~K} \times 828$ Pin Module Asynchronous | HM-8832 | - | 8832 | - | - | $\bullet$ | - | - | $\bullet$ | - | $\bullet$ | - | - | - | $\bullet$ |
| 1 M CMOS MODULE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $128 \times 8 / 64 \mathrm{~K} \times 16$ | HM-91M2 | - | - | - | - | - | - | - | - | - | - | - | - | $\bullet$ | - |

# High-Reliability CMOS 1024-Word x 1-Bit Static RAM 

## Features

- Static CMOS Silicon-On-Sapphire Circuitry-CD4000Series compatible
- Compatible with CDP1800-Series Microprocessors at Maximum Speed
- Fast Access Time
.100 ns Typ. © $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$
- Single voltage Supply
- No Precharge or External Clocks Required
- Low Quiescent and Operating Power
- Separate Data Inputs and Outputs
- High Noise Immunity $\qquad$ $30 \%$ of $V_{D D}$
- Memory Retention for

Standby Battery Voltage Down to $\mathbf{2 V}$ © $+\mathbf{2 5}^{\circ} \mathrm{C}$

- Latch-Up-Free Transient-Radiation Tolerance


## Ordering Information

| PACKAGE | TEMP. RANGE | ORDER CODE |
| :--- | :---: | :---: |
| Ceramic DIP | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | CDP1821CD3 |

## Description

The CDP1821C/3 is a 1024 -word $\times 1$ bit CMOS silicon-onsapphire (SOS), fully static, random-access memory designed for use in CDP1800 microprocessor systems. This device has a recommended operating voltage range of 4 to 6.5 volts.

The output state of the CDP $1821 \mathrm{C} / 3$ is a function of the input address and chip-select states only. Valid data will appear at the output in one access time following the latest address change to a selected chip. After valid data appears, the address may be changed immediately. It is not necessary to clock the chip-select input or any other input terminal for fully static operation; therefore the chip-select input may be used as an additional address input. When the device is in an unselected state ( $\overline{\mathrm{CS}}=1$ ), the internal write circuitry and output sense amplifier are disabled. This feature allows the three-state data outputs from many arrays to be OR-tied to a common bus for easy memory expansion.
The CDP1821C/3 is supplied in the 16 -lead hermetic dual-in-line side-brazed ceramic package ( $D$ suffix) that conforms to MIL-M-38510 Case Outline D-2.

## Pinout

## 16-LEAD DIP TOP VIEW

| Cs 1 | $16 \mathrm{v}_{\mathrm{DD}}$ |
| :---: | :---: |
| AO 2 | 15 DI |
| A1 3 | 14. RD/ $\overline{\mathrm{WR}}$ |
| A2 4 | 13 A 9 |
| A3 5 | 12 AB |
| A4 6 | $11{ }^{\text {A7 }}$ |
| Do 7 | 10 Ac |
| $\mathrm{V}_{\text {SS }} 8$ | 9] A 5 |

Functional Block Diagram


Absolute Maximum Ratings
DC Supply Voltage Range, ( $V_{D D}$ )
(All Voltages Referenced to $\mathrm{V}_{\text {ss }}$ Terminal) ........ -0.5 V to +7 V Input Voltage Range, All Inputs ................ -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$
DC Input Current, Any One Input. . . . . . . . . . . . . . . . . . . . . . . . $\pm 10 \mathrm{~mA}$
Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ )
$T_{A}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$.
......... . 500 mW
$T_{A}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Derate Linearly at $12 \mathrm{~mW}{ }^{\circ} \mathrm{C}$ to 200 mW

Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range
(All Package Types).
100 mW
Operating Temperature Range $\left(T_{A}\right) \ldots \ldots . . . . .-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {sto }}$ ) . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering): At distance $1 / 16 \pm 1 / 32 \mathrm{In}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10 s max.
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions $T_{A}=$ Full Package-Temperature Range, For maximum reliability, nominal operating conditions should be selected so that operation is always within the following ranges:

|  | LIMITS |  |  |
| :--- | :---: | :---: | :---: |
|  | CDP1821CD/3 |  |  |
| CHARACTERISTIC | MIN | MAX | UNITS |
| DC Operating Voltage Range | 4 | 6.5 | $V$ |
| Input Voltage Range | $V_{S S}$ | $V_{D D}$ | $V$ |

Static Electrical Characteristics $V_{D D}=5 \mathrm{~V} \quad 5 \%$

| CHARACTERISTIC | SYMBOL | CONDITIONS | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Quiescent Device Current (Note 1) | ID | $V_{I N}=O V$ or $V_{D D}$ | - | 260 | - | 1000 | $\mu \mathrm{A}$ |
| Output Low Drive (Sink) Current (Note 1) | loL | $\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}$ | 2.7 | - | 1.6 | - | mA |
| Output High Drive (Source) Current (Note 1) | $\mathrm{I}_{\mathrm{OH}}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {DD }}-0.4 \mathrm{~V}$ | -1.3 | - | -0.8 | - | mA |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.1 | - | 0.5 | V |
| Output Voltage High-Level | $\mathrm{V}_{\mathrm{OH}}$ | - | $V_{D D}-0.1$ | - | $V_{D D}-0.5$ | - | V |
| Input Low Voltage | $\mathrm{V}_{1 \mathrm{~L}}$ | - | - | 0.3 VDD | - | $0.3 \mathrm{~V}_{\mathrm{DD}}$ | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | - | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | $0.7 \mathrm{~V}_{\text {D }}$ | - | V |
| Input Current (Note 1) | IN | $\mathrm{V}_{\mathrm{IN}}=O \mathrm{~V}$ or $\mathrm{V}_{\mathrm{DD}}$ | - | 2.6 | - | 10 | $\mu \mathrm{A}$ |
| 3-State Output Leakage Current (Note 1) | lout | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{DD}}$ | - | 2.6 | - | 10 | $\mu \mathrm{A}$ |
| Operating Current (Note2) | $\mathrm{I}_{\mathrm{DD} 1}$ | - | - | 5 | - | 10 | mA |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | 7.5 | - | 7.5 | pF |
| Output Capacitance | $\mathrm{Cout}^{\text {O }}$ | - | - | 15 | - | 15 | pF |

## NOTES:

1. Limits designate $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent 100\% testings
2. Measured with $1-\mu \mathrm{s}$ read-cycle time and outputs floating.

Specifications CDP1821C/3
Read Cycle Dynamic Electrical Characteristics $t_{n} t_{4}=10 n s, C_{L}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | $V_{D D}$ <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Data Access Time (Note 1) | $t_{\text {DA }}$ | 5 | - | 190 | - | 255 | ns |
| Read Cycle Time | $t_{\text {PC }}$ | 5 | 190 | - | 255 | - | ns |
| Output Enable Time | $t_{E N}$ | 5 | 65 | - | 90 | - | ns |
| Output Disable Time | $\mathrm{t}_{\text {DIS }}$ | 5 | - | 65 | - | 90 | ns |

NOTE: 1. $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing.


NOTES:

1. Chip-Select ( $\overline{\mathrm{CS}}$ ) permitted to change from high to low level or remain low on a selected device.
2. Chip-Select ( $\overline{\mathrm{CS}})$ permitted to change from low to high level or remain low.
3. Read/Write $(R / \bar{W})$ must be at a high level during all address transitions.
4. Don't care.
5. Data-Out (DO) is a high impedance within $t_{D I S} n s$ after the falling edge of $R \bar{W}$ or the rising edge of $\overline{C S}$.

FIGURE 2. READ CYCLE TIMING DIAGRAM

Specifications CDP1821C/3
Write Cycle Dynamic Electrical Characteristics $t_{n} t_{L}=10 \mathrm{~ns}, C_{L}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBEL | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | LIMrTS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Write Cycle Time | twc | 5 | 300 | $\bullet$ | 420 | $\bullet$ | ns |
| Address Setup Time (Note 1) | $t_{\text {As }}$ | 5 | 60 | - | 84 | - | ns |
| Address Hold Time (Note 1) | $t_{\text {AH }}$ | 5 | 130 | - | 180 | - | ns |
| Input Data Setup Time (Note 1) | $t_{\text {DS }}$ | 5 | 90 | - | 125 | - | ns |
| Input Data Hold TIme (Note 1) | $\mathrm{t}_{\mathrm{DH}}$ | 5 | 60 | - | 84 | - | ns |
| Read/Write Pulse Width Low (Note 1) | ${ }^{\text {W }}$ L | 5 | 110 | - | 155 | - | ns |

NOTE: 1. $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing.


NOTES:

1. Chip-Select (CS) permitted to change from high to low level or remain low on a selected device.
2. Chip-Select (CS) permitted to change from low to high level or remain low.
3. Don't care.

FIGURE 3. WRITE CYCLE TIMING DIAGRAM

## Data Retention Characteristics

| CHARACTERISTIC | SYMBOL | TEST CONDITIONS |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  | $\begin{aligned} & V_{D R} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | MIN | MAX | MIN | MAX |  |
| Minimum Data Retention Voltage (Note 1) | $\mathrm{V}_{\mathrm{DD}}$ | - | - | - | 2 | - | 2.5 | v |
| Data Retention Quiescent Current (Note 1) | $I_{\text {D }}$ | 2 | - | - | 50 | - | 200 | $\mu \mathrm{A}$ |
| Chip Deselect to Data Retention Time | $t_{\text {codr }}$ | - | 5 | 450 | - | 650 | - | ns |
| Recovery to Normal Operation Time | $t_{\text {RC }}$ | - | 5 | 450 | - | 650 | - | ns |

NOTE: 1. $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing


FIGURE 4. LOW V $V_{D D}$ DATA RETENTION WAVEFORMS AND TIMING DIAGRAM.

## Burn-in Circuit


$R=8.2 \mathrm{k} \Omega \mathbf{2 0 \%}$ $R_{1}=\mathbf{2 k} \Omega \mathbf{2 0 \%}$


| PACKAGE | $\mathbf{V}_{\mathrm{DD}}$ | TEMPERATURE | DURATION |
| :--- | :---: | :---: | :--- |
| D | 7 V | $+125^{\circ} \mathrm{C}$ | 160 Hrs. |

FIGURE 5. DYNAMIC/OPERATING BURN-IN CIRCUIT AND TIMING DIAGRAM.

## 256-Word x 4-Bit LSI Static RAM

## Features

- Low Operating Current
- $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$, Cycle Time $1 \mu \mathrm{~s}$.

8 mA

- Industry Standard Pinout
- Two Chip-Select Inputs-Simple Memory Expansion
- Memory Retention for Standby Battery Voltage of 2V Minimum
- Output-Disable for Common VO Systems
- 3-State Data Output for Bus-Oriented Systems
- Separate Data Inputs and Outputs


## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 5V | 10V |
| :---: | :---: | :---: | :---: |
| Plastic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1822CE | CDP1822E |
|  |  | CDP1822CEX | CDP1822EX |
| Ceramic DIP <br> Burn-In <br> *883B | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1822CD | CDP1822D |
|  |  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | CDP1822CD3 |

*Respective specifications are included at the end of this datasheet.

## Description

The CDP 1822 and CDP1822C are 256 -word by 4 -bit static random-access memories designed for use in memory systems where high speed, low operating current, and simplicity in use are desirable. The CDP1822 features high speed and a wide operating voltage range. Both types have separate data inputs and outputs and utilize single power supplies of 4 volts to 6.5 volts for the CDP1822C and 4 volts to 10.5 volts for the CDP1822.

Two Chip-Select inputs are provided to simplify system expansion. An Output Disable control provides Wire-OR capability and is also useful in common Input/Output systems. The Output Disable input allows these RAMs to be used in common data Input/Output systems by forcing the output into a high-impedance state during a write operation independent of the Chip-Select input condition. The output assumes a high-impedance state when the Output Disable is at high level or when the chip is deselected by $\overline{\mathrm{CS} 1}$ and/or CS2.

The high noise immunity of the CMOS technology is preserved in this design. For TTL interfacing at 5 V operation, excellent system noise margin is preserved by using an external pull-up resistor at each input.

The CDP1822 and CDP1822C types are supplied in 22-lead hermetic dual-in-line sidebrazed ceramic packages (D suffix), in 22-lead dual-in-line plastic packages (E suffix). The CDP1822C is also available in chip form (H suffix).

## Pinout

## 22 LEAD DIP

 TOP VIEW

OPERATIONAL MODES

| MODE | INPUTS |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\frac{\overline{\text { CHIP }}}{\operatorname{SELECT}_{1}^{\overline{C S}_{1}}}$ | $\begin{aligned} & \text { CHIP } \\ & \text { SELECT } 2 \\ & \text { CS }_{2} \end{aligned}$ | $\begin{gathered} \hline \text { OUTPUT } \\ \text { DISABLE } \\ \text { OD } \end{gathered}$ | $\begin{aligned} & \text { READ } / \\ & \hline \text { WRITE } \end{aligned}$ $\mathrm{R} / \overline{\mathrm{W}}$ |  |
| Read | 0 | 1 | 0 | 1 | Read |
| Write | 0 | 1 | 0 | 0 | Data In |
| Write | 0 | 1 | 1 | 0 | High Impedance |
| Standby | 1 | X | X | X | High Impedance |
| Standby | X | 0 | X | X | High Impedance |
| Output Disable | X | X | 1 | X | High Impedance |

Logic $1=$ High, Logic $0=$ Low, $X=$ Don't Care

## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ):
(All Voltages Referenced to $\mathrm{V}_{\text {SS }}$ Terminal)
CDP1822................................. V to +11 V
CDP1822C.................................... V to +7 V
Input Voltage Range, All Inputs $\ldots . . . . . . . . . .$.
DC Input Current, Any One Input. . . . . . . . . . . . . . . . . . . . . . . $\pm 10 \mathrm{~mA}$
Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ )


Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range
(All Package Types)
100 mW
Operating Temperature Range $\left(T_{A}\right)$ :
Package Type D.
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Package Type E. . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stg }}$ ) $\ldots \ldots \ldots . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{In} .(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10s max
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions at $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | SYMBOL | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1822 |  | CDP1822C |  |  |
|  |  | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range |  | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range |  | $\mathrm{V}_{\mathrm{ss}}$ | $V_{D D}$ | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |

Static Electrical Characteristics At $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Except as Noted:

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{0} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1822 |  |  | CDP1822C |  |  |  |
|  |  |  |  |  | MIN | $\begin{gathered} \text { (Note 1) } \\ \text { TYP } \end{gathered}$ | MAX | MIN | (Note 1) TYP | MAX |  |
| Quescent Device Current | ID | - | 0,5 | 5 | - | - | 500 | - | - | 500 | $\mu \mathrm{A}$ |
|  |  | - | 0,10 | 10 | - | $\bullet$ | 1000 | - | - | - | $\mu \mathrm{A}$ |
| Output Low (Sink) Current | 1 OL | 0.4 | 0,5 | 5 | 2 | 4 | - | 2 | 4 | - | mA |
|  |  | 0.5 | 0,10 | 10 | 4.5 | 9 | - | - | - | - | mA |
| Output High (Source) Current | $\mathrm{IOH}^{\text {I }}$ | 4.6 | 0,5 | 5 | -1 | -2 | - | -1 | -2 | - | mA |
|  |  | 9.5 | 0,10 | 10 | -2.2 | -4.4 | - | - | - | - | mA |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  |  | - | 0,10 | 10 | - | 0 | 0.1 | - | - | - | V |
| Output Voltage High-Level | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - | V |
|  |  | - | 0,10 | 10 | 9.9 | 10 | - | - | - | - | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 0.5, 9.5 | - | 10 | - | $\cdot$ | 3 | - | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 9.5 | - | 5 | 3.5 | - | - | 3.5 | - | - | V |
|  |  | 0.5, 9.5 | - | 10 | 7 | $\cdot$ | $\cdot$ | - | - | - | V |
| Input Leakage Current | $\mathrm{I}_{\mathrm{IN}}$ | - | 0,5 | 5 | - | - | $\pm 5$ | - | - | $\pm 5$ | $\mu \mathrm{A}$ |
|  |  | $\cdot$ | 0,10 | 10 | - | - | $\pm 10$ | - | - | - | $\mu \mathrm{A}$ |
| Operating Current (Note 2) | ${ }^{\text {DD1 }}$ | $\cdot$ | 0,5 | 5 | - | 4 | 8 | - | 4 | 8 | mA |
|  |  | - | 0,10 | 10 | - | 8 | 16 | - | - | - | mA |
| 3-State Output Leakage Current | Iout | 0,5 | 0,5 | 5 | - | - | $\pm 5$ | - | - | $\pm 5$ | $\mu \mathrm{A}$ |
|  |  | 0, 10 | 0,10 | 10 | - | - | $\pm 10$ | - | - | - | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance | Cout | - | - | - | - | 10 | 15 | $\bullet$ | 10 | 15 | pF |

## NOTES:

1. Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
2. Outputs open circuited; Cycle time $=1 \mu \mathrm{~s}$

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$, Input $t_{r}, \mathbf{t}_{f}=\mathbf{2 0} \mathbf{n s}, V_{I H}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, \mathrm{C}_{\mathrm{L}}=\mathbf{1 0 0} \mathrm{pF}$


[^18]

Fig. 1-Read cycle tıming waveforms.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$,
Input $t_{r}, t_{f}=\mathbf{2 0} \mathbf{n s}, V_{I H}=0.7 \mathrm{~V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0.3 \mathrm{~V}_{\mathrm{DD}}, \mathrm{C}_{\mathrm{L}}=\mathbf{1 0 0} \mathrm{pF}$

| CHARACTERISTIC |  | TEST CONDITIONS | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | VDD <br> (V) | CDP1822 |  |  | CDP1822C |  |  |  |
|  |  | Min. ${ }^{\dagger}$ | Typ.* | Max. | Min. ${ }^{\dagger}$ | Typ.* | Max. |  |
| Write Cycle Times (Fig. 2) |  |  |  |  |  |  |  |  |  |
| Write Cycle | twc |  | 5 | 500 | - | - | 500 | - | - | ns |
|  |  | 10 | 300 | - | - | - | - | - |  |  |
| Address Set-Up | $t_{\text {AS }}$ | 5 | 200 | - | - | 200 | - | - |  |  |
|  |  | 10 | 110 | - | - | - | - | - |  |  |
| Write Recovery | $t_{\text {wr }}$ | 5 | 50 | - | - | 50 | - | - |  |  |
|  |  | 10 | 40 | - | - | - | - | - |  |  |
| Write Width | twaw | 5 | 250 | - | - | 250 | - | - |  |  |
|  |  | 10 | 150 | - | - | - | - | - |  |  |
| Input Data Set-Up Time | tos | 5 | 250 | - | - | 250 | - | - |  |  |
|  |  | 10 | 150 | - | - | - | - | - |  |  |
| Data In Hold | $\mathrm{t}_{\mathrm{DH}}$ | 5 | 50 | - | - | 50 | - | - |  |  |
|  |  | 10 | 40 | - | - | - | - | - |  |  |
| $\overline{\text { Chip-Select }} 1$ Set-Up | tesis | 5 | 200 | - | - | 200 | - | - |  |  |
|  |  | 10 | 110 | - | - | - | - | - |  |  |
| Chip-Select 2 Set-Up | $t_{\text {cses }}$ | 5 | 200 | - | - | 200 | - | - |  |  |
|  |  | 10 | 110 | - | - | - | - | - |  |  |
| Chip-Select 1 Hold | tesith | 5 | 0 | - | - | 0 | - | - |  |  |
|  |  | 10 | 0 | - | - | 0 | - | - |  |  |
| Chip-Select 2 Hold | ${ }_{\text {tcs2H }}$ | 5 | 0 | - | - | 0 | - | - |  |  |
|  |  | 10 | 0 | - | - | 0 | - | - |  |  |
| Output Disable Set-Up | tods | 5 | 200 | - | - | 200 | - | - |  |  |
|  |  | 10 | 110 | - | - | - | - | - |  |  |

[^19]

* ${ }^{\text {tod }}$ ods is required for common i/o

OPERATION ONLY, FOR SEPARATE I/O
OPERATIONS, OUTPUT DISABLE IS DON'T CARE

Fig 2-Write cycle tıming waveforms.

## DATA RETENTION CHARACTERISTICS at TA $_{\mathbf{A}}=\mathbf{- 4 0}$ to $\mathbf{+ 8 5}{ }^{\circ} \mathrm{C}$, see Fig. 3

| CHARACTERISTIC |  | TEST CONDITIONS |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | VDR <br> (V) | VDD (V) | CDP1822 |  |  | CDP1822C |  |  |  |
|  |  | Min. |  | Typ.* | Max. | Min. | Typ.* | Max. |  |
| Min Data Retention Voltage, | $V_{D R}$ |  | - | - | - | 1.5 | 2 | - | 1.5 | 2 | V |
| Data Retention Quiescent Current, | lod | 2 | - | - | 30 | 100 | - | 30 | 100 | $\mu \mathrm{A}$ |
| Chip Deselect to Data Retention Time, | $t_{\text {cod }}$ | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 600 \\ & 300 \end{aligned}$ | - | - | 600 - | - | - |  |
| Recovery to Normal Operation Time, | $t_{\text {te }}$ | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 600 \\ & 300 \end{aligned}$ | - | - | 600 | - | - | ns |
| $V_{D D}$ to $V_{D R}$ RIse and Fall Time | $t_{\text {r }}, t_{t}$ | 2 | 5 | 1 | - | - | 1 | - | - | $\mu \mathrm{s}$ |

*Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$


Fig. 3 - Low $V_{D D}$ data retention timing waveforms.


Fig. 4 - Memory cell configuration.


Fig. 5 - Functional block diagram for CDP1822 and CDP1822C.


Fig. 6 - Logic diagram of controls for CDP1822 and CDP1822C.

February 1992

## Features

- For Applications in Aerospace, Military, and Critical Industrial Equipment
- Interfaces Directly with CDP1802 Microprocessor
- Very Low Operating Current
- At $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{v}$ and Cycle Time $=1 \mu \mathrm{~s}$

4mA (Typ)

- Static CMOS Silicon-On-Sapphire Circuitry
- CD4000 Series Compatible
- Industry Standard Pinout
- Two Chip Select Inputs - Simple Memory Expansion
- Memory Retention for Standby. . . . . . . . . . . . . 2V (Min) Battery Voltage
- Single Power Supply Operation 4 V to 6.5 V
- High Noise Immunity $30 \%$ of $V_{D D} \ldots . .$. . . 4V to 6.5 V
- Output Disable for Common VO Systems
- 3-State Data Output for Bus Oriented Systems
- Separate Data Inputs and Outputs
- Latch-Up-Free Transient Radiation Tolerance


## Description

The CDP1822C/3 is a 256 word by 4 bit random access memory designed for use in memory systems where high speed, low operating current, and simplicity in use are desirable. The CDP1822 features high speed and excellent noise immunity. It has separate data inputs and outputs and utilizes a single power supply of 4 to 6.5 volts.

Two Chip Select inputs simplify system expansion. An output Disable control provides Wire-OR-capability and is also useful in common Input/Output systems. The Output Disable input allows this RAM to be used in common data Input/Output systems by forcing the output into a high impedance state during a write operation independent of the Chip Select input condition. The output assumes a high impedance state when the Output Disable is at high level or when the chip is deselected by $\overline{\mathrm{CS} 1}$ and/or CS2.
The high noise immunity of the CMOS technology is preserved in this design. For TTL interfacing at 5 V operation, excellent system noise margin is preserved by using an external pull-up resistor at each input.

The CDP1822C/3 is supplied in the 22 lead hermetic dual-in-line sidebrazed ceramic package ( D Suffix) that meets the specifications of MIL-M-38510 Case Outline D-7.


| OPERATIONAL MODES |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | INPUTS |  |  |  |  |
| MODE | $\frac{\overline{\text { CHIP }}}{\overline{\text { SELCT }}_{1}}$ | $\begin{gathered} \text { CHIP } \\ \text { SELECT } 2 \\ \text { CS }_{2} \end{gathered}$ | OUTPUT disable OD | $\frac{\text { READ } /}{\frac{\text { WRITE }}{R}}$ | OUTPUT |
| Read | 0 | 1 | 0 | 1 | Read |
| Write | 0 | 1 | 0 | 0 | Data In |
| Write | 0 | 1 | 1 | 0 | High Impedance |
| Standby | 1 | X | X | X | High Impedance |
| Standby | X | 0 | X | X | High Impedance |
| Output Disable | X | X | 1 | X | High Impedance |

Logic $1=$ High, Logic $0=$ Low, $X=$ Don't Care

## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ): (All Voltages Referenced to $\mathrm{V}_{\mathrm{SS}}$ Terminal) CDP1822C/3 $\qquad$
$\qquad$ . -0.5 V to +7 V
Input Voltage Range, All Inputs $\ldots \ldots \ldots \ldots . .$.
Operating Temperature Range $\left(T_{A}\right)$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |
| :--- | :---: | :---: | :---: |
|  | MIN | MAX | UNITS |
| DC Operating Voltage Range | 4 | 6.5 | $V$ |
| Input Voltage Range | $V_{S S}$ | $V_{D D}$ | $V$ |

## Static Electrical Characteristics

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{0} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | $\begin{gathered} \text { TEMP. }-55^{\circ} \mathrm{C}, \\ +25^{\circ} \mathrm{C} \end{gathered}$ |  | TEMP. $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Quiescent Device Current (Note 1) | IDD | - | 0,5 | 5 | - | 390 | - | 1000 | $\mu \mathrm{A}$ |
| Output Low (Sink) Current (Note 1) | loL | 0.4 | 0,5 | 5 | 2.6 | - | 1.6 | - | mA |
| Output High (Source) Current (Note 1) | IOH | 4.6 | 0,5 | 5 | - | -1.2 | - | -0.8 | mA |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0.1 | - | 0.5 | V |
| Output Voltage High-Level | $\mathrm{V}_{\mathrm{OH}}$ | $\bullet$ | 0,5 | 5 | $\begin{gathered} \hline \mathrm{V}_{\mathrm{DD}}{ }^{-} \\ 0.1 \end{gathered}$ | - | $\begin{gathered} \hline \mathrm{V}_{\mathrm{DD}}- \\ 0.5 \end{gathered}$ | - | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | 0.5, 4.5 | - | 5 | - | $0.3 \mathrm{~V}_{\mathrm{DD}}$ | - | $0.3 \mathrm{~V}_{\mathrm{DD}}$ | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 4.5 | - | 5 | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | V |
| Input Leakage Current (Note 1) | In | - | 0,5 | 5 | - | $\pm 3.2$ | - | $\pm 10$ | $\mu \mathrm{A}$ |
| Operating Current (Note 1) | $\mathrm{I}_{\mathrm{DD} 1}$ | - | 0,5 | 5 | - | 6.5 | $\bullet$ | $\pm 10$ | mA |
| 3-State Output Leakage Current | lout | 0,5 | 0,5 | 5 | - | $\pm 3.2$ | - | $\pm 19$ | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 7.5 | - | 7.5 | pF |
| Output Capacitance | $\mathrm{Cout}^{\text {O }}$ | - | - | - | - | 7.5 | - | 7.5 | pF |

NOTE:

1. Limits designate $100 \%$ testing, all other limits are designer's parameters under given test ocnditions and do not represent $100 \%$ testing.

Read Cycle Dynamic Electrical Characteristics $t_{n} t_{4}=10 \mathrm{~ns}, C_{L}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | VDD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $+25^{\circ} \mathrm{C},-55^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Read Cycle (Note 1) | $t_{\text {RC }}$ | 5 | 370 | - | 500 | - | ns |
| Access from Address (Note 1) | $\mathrm{t}_{\text {ADA }}$ | 5 | - | 370 | - | 500 | ns |
| Output Valid from Chip Select 1 (Note 1) | $\mathrm{t}_{\text {DOA }}$ | 5 | - | 370 | - | 500 | ns |
| Output Valid from Chip Select 2 (Note 1) | $\mathrm{t}_{\text {DOA } 2}$ | 5 | - | 370 | - | 500 | ns |
| Output Active from Output Disable (Note 1) | $\mathrm{t}_{\text {DOA3 }}$ | 5 | - | 170 | - | 225 | ns |
| Output Hold from $\overline{\text { Chip Select } 1}$ | ${ }^{\text {DOOH1 }}$ | 5 | 10 | - | 20 | - | ns |
| Output Hold from Chip Select 2 | $\mathrm{t}_{\mathrm{DOH} 2}$ | 5 | 10 | - | 20 | - | ns |
| Output Hold from Output Disable | $\mathrm{t}_{\text {DOH3 }}$ | 5 | 10 | - | 20 | - | ns |

NOTE:

1. Limits designate $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing


* Minimum timing for valid data output. Longer times will initiate an earlier but invalid output.

FIGURE 2. READ CYCLE WAVEFORMS AND TIMING DIAGRAM


FIGURE 3. MEMORY CELL CONFIGURATION

Write Cycle Dynamic Electrical Characteristics $t_{\square} t_{4}=10 \mathrm{~ns}, C_{L}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | LIMrTS |  |  |  | UNTTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $+25^{\circ} \mathrm{C},-55^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Write Cycle (Note 1) | twc | 5 | 400 | - | 560 | $\bullet$ | ns |
| Address Setup (Note 1) | $t_{\text {AS }}$ | 5 | 160 | - | 225 | $\bullet$ | ns |
| Address Hold (Note 1) | $\mathrm{t}_{\text {AH }}$ | 5 | 40 | - | 55 | $\bullet$ | ns |
| Write Pulse Width (Note 1) | $t_{\text {wrw }}$ | 5 | 200 | - | 280 | - | ns |
| Data in Setup (Note 1) | $\mathrm{t}_{\text {DIS }}$ | 5 | 200 | - | 280 | - | ns |
| Data in Hold (Note 1) | $\mathrm{t}_{\text {DIH }}$ | 5 | 40 | - | 55 | - | ns |
| Chip Select 1 Setup | tcss 1 | 5 | 200 | - | 280 | $\bullet$ | ns |
| Chip Select 2 Setup | $\mathrm{t}_{\text {css }}$ | 5 | 200 | - | 280 | - | ns |
| Output Disable Setup | toos | 5 | 140 | - | 225 | $\bullet$ | ns |

NOTE:

1. Limits designate $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing


* toos is required for common I/O operation only; for separate I/O operations, output disable is don't care.

FIGURE 4. WRITE CYCLE TIMING WAVEFORMS

Data Retention Characteristics

| CHARACTERISTIC | SYMBOL | TEST CONDITIONS |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{D R} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | $+25^{\circ} \mathrm{C},-55^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  | MIN | MAX | MIN | MAX |  |
| Minimum Data Retention Voltage (Note 1) | $V_{\text {DR }}$ | - | - | - | 2 | - | 2.5 | V |
| Data Retention Quiescent Current (Note 1) | ID | 2 | - | - | 70 | - | 380 | $\mu \mathrm{A}$ |
| Chip Deselect to Data Retention Time | $\mathrm{t}_{\text {con }}$ | - | 5 | 450 | $\bullet$ | 650 | - | ns |
|  |  | - | 10 |  |  |  |  |  |
| Recovery to Normal Operation Time | $\mathrm{t}_{\mathrm{RC}}$ | 5 | 5 | 450 | - | 650 | - | ns |

NOTE:

1. Limits designate $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing


FIGURE 5. LOW VDD DATA RETENTION TIMING WAVEFORMS


FIGURE 6. DYNAMIC/OPERATING BURN-IN CIRCUIT AND TIMING DIAGRAM

# CDP1823 CDP1823C 

## Features

- Fast Access Time
- $V_{D D}=5 V$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 450 ns
- $V_{D D}=10 \mathrm{~V}$

250ns

- Common Data Inputs and Outputs
- Multiple Chip Select Inputs to Simplify Memory System Expansion


## Ordering Information

| PACKAGE | TEMP. <br> RANGE | 5V | 10V |
| :--- | :---: | :--- | :---: |
| Plastic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1823CE | CDP1823E |
|  |  | CDP1823CEX | CDP1823EX |
| Ceramic DIP <br> Burn-In <br> *883B | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1823CD | CDP1823D |
|  |  | $-55^{\circ} \mathrm{C}$ to <br> $+125^{\circ} \mathrm{C}$ | CDP1823CDX |

*Respective specifications are included at the end of this datasheet.

## Description

The CDP1823 and CDP1823C are 128-word by 8-bit CMOS SOS static random-access memories. These memories are compatible with general-purpose microprocessors. The two memories are functionally identical. They differ in that the CDP1823 has a recommended operating voltage range of 4 volts to 10.5 volts, and the CDP1823C has a recommended operating voltage range of 4 volts to 6.5 volts.

The CDP1823 memory has 8 common data input and data output terminals for direct connection to a bidirectional data bus and is operated from a single voltage supply. Five chipselect inputs are provided to simplify memory-system expansion. In order to enable the CDP1823, the chip-select inputs $\overline{\mathrm{CS} 2}, \overline{\mathrm{CS} 3}$ and $\overline{\mathrm{CS} 5}$ require a low input signal, and the chipselect inputs CS1 and CS4 require a high input signal.
The $\overline{M R D}$ signal enables all 8 output drivers when in the low state and should be in a high state during a write cycle.
After valid data appear at the output, the address inputs may be changed immediately. Output data will be valid until either the $\overline{M R D}$ signal goes high, the device is deselected, or $t_{A A}$ (access time) after address changes.
The CDP1823 and CDP1823C types are supplied in 24-lead dual-in-line ceramic packages ( $D$ suffix), and in 24-lead dual-in-line plastic packages ( $E$ suffix).

## Pinout

## 24 LEAD DIP

 TOP VIEWOPERATIONAL MODES

| FUNCTION | $\overline{\text { MRD }}$ | $\overline{M W R}$ | CS1 | $\overline{\text { CS2 }}$ | $\overline{\text { CS3 }}$ | CS4 | $\overline{\text { CS5 }}$ | BUS TERMINAL STATE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | 0 | X | 1 | 0 | 0 | 1 | 0 | Storage State of Addressed Word |
| Write | 1 | 0 | 1 | 0 | 0 | 1 | 0 | Input High-Impedance |
| Stand-By (Active) | 1 | 1 | 1 | 0 | 0 | 1 | 0 | High Impedance |
| Not Selected | X | X | 0 | X | X | X | X | High Impedance |
|  | X | X | X | 1 | X | X | X | High Impedance |
|  | X | X | X | X | 1 | X | X | High Impedance |
|  | $x$ | X | X | X | X | 0 | X | High Impedance |
|  | X | X | X | X | X | X | 1 | High Impedance |

Logic $1=$ High, Logic $0=$ Low, $X=$ Don't Care

## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ):

| (All Voltages Referenced to $\mathrm{V}_{\text {ss }}$ Terminal) |  |
| :---: | :---: |
| CDP1823 | -0.5 V to +11V |
| CDP1823C. | -0.5 V to +7V |
| Input Voltage Range, All Inputs | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, Any One Input. | $\pm 10 \mathrm{~mA}$ |
| Operating Temperature Range ( $\mathrm{T}_{\mathrm{A}}$ ): |  |
| Package Type D | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Package Type E | $-40^{\circ} \mathrm{C}$ to $+85^{\circ}$ |

CDP1823
-0.5 V to +11 V
$\ldots .-0.5 \mathrm{~V}$ to +7 V
Input Voltage Range, All Inputs $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Package Type E $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

Storage Temperature Range ( $T_{\text {stg }}$ )
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temperature (During Soldering): At distance $1 / 16 \pm 1 / 32 \mathrm{In}$. $(1.59 \pm 0.79 \mathrm{~mm})$
from case for 10s max.
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1823D |  | CDP1823CD |  |  |
|  | MIN | MAX | MIN | MAX |  |
| Supply Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Recommended Input Voltage Range | $\mathrm{V}_{\mathrm{ss}}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{ss}}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |

Static Electrical Characteristics At $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Except as Noted:

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{0} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & \left(V^{\prime}\right. \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1823 |  |  | CDP1823C |  |  |  |
|  |  |  |  |  | MIN | (Note 1) TYP | MAX | MIN | (Note 1) TYP | MAX |  |
| Quiescent Device Current | $\mathrm{I}_{\mathrm{DD}}$ | - | 0,5 | 5 | - | - | 500 | - | - | 500 | $\mu \mathrm{A}$ |
|  |  | - | 0, 10 | 10 | - | - | 1000 | $\bullet$ | - | - | $\mu \mathrm{A}$ |
| Output Low (Sink) Current | ${ }^{1} \mathrm{OL}$ | 0.4 | 0,5 | 5 | 2 | 4 | - | 2 | 4 | - | mA |
|  |  | 0.5 | 0,10 | 10 | 4.5 | 9 | - | - | - | - | mA |
| Output High (Source) Current | $\mathrm{IOH}^{\text {r }}$ | 4.6 | 0,5 | 5 | -1 | -2 | - | -1 | -2 | - | mA |
|  |  | 9.5 | 0, 10 | 10 | -2.2 | -4.4 | - | - | - | - | mA |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  |  | - | 0,10 | 10 | - | 0 | 0.1 | - | - | - | V |
| Output Voltage High-Level | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - | V |
|  |  | - | 0, 10 | 10 | 9.9 | 10 | - | - | - | - | V |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 0.5, 9.5 | - | 10 | - | - | 3 | - | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 9.5 | - | 5 | 3.5 | - | - | 3.5 | - | $\cdot$ | V |
|  |  | 0.5, 9.5 | - | 10 | 7 | - | - | - | - | - | V |
| Input Leakage Current | $\mathrm{I}_{\mathrm{N}}$ | Any | 0,5 | 5 | - | - | $\pm 5$ | - | - | $\pm 5$ | $\mu \mathrm{A}$ |
|  |  | Input | 0,10 | 10 | - | - | $\pm 10$ | - | $\cdot$ | - | $\mu \mathrm{A}$ |
| Operating Current (Note 2) | $\mathrm{I}_{\text {DD1 }}$ | - | 0,5 | 5 | - | 4 | 8 | - | 4 | 8 | mA |
|  |  | $\cdot$ | 0,10 | 10 | - | 8 | 16 | - | - | - | mA |
| 3-State Output Leakage Current | Iout | 0,5 | 0,5 | 5 | - | - | $\pm 5$ | - | - | $\pm 5$ | $\mu \mathrm{A}$ |
|  |  | 0, 10 | 0, 10 | 10 | - | - | $\pm 10$ | - | - | - | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance | $\mathrm{Cout}^{\text {O }}$ | - | - | - | - | 10 | 15 | $\cdot$ | 10 | 15 | pF |

## NOTES:

1. Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
2. Outputs open circuited; Cycle time $=1 \mu$.

DYNAMIC ELECTRICAL CHARACTERISTICS at TA $=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{VDD} \pm 5 \%$, $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=\mathbf{2 0} \mathbf{n s}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.

| CHARACTERISTIC | VDD <br> (V) | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1823 |  |  | CDP1823C |  |  |  |
|  |  | Min. $\dagger$ | Typ.* | Max. | Min. $\dagger$ | Typ.* | Max. |  |
| Read Cycle (See Fig. 1) |  |  |  |  |  |  |  |  |
| Access Time From | 5 | - | 275 | 450 | - | 275 | 450 | ns |
| Address Change, $\mathrm{t}_{\text {AA }}$ | 10 | - | 150 | 250 | - | - | - |  |
| Access Time From | 5 | - | 150 | 250 | - | 150 | 250 |  |
| Chip Select, tDOA | 10 | - | 100 | 150 | - | - | - |  |
| MRD to Output | 5 | - | 150 | 250 | - | 150 | 250 |  |
| Active, ${ }_{\text {A }}$ M | 10 | - | 100 | 150 | - | - | - |  |
| Data Hold Time | 5 | 25 | 50 | 75 | 25 | 50 | 75 |  |
| After Read, $\mathrm{t}_{\mathrm{DOH}}$ | 10 | 15 | 25 | 40 | - | - | - |  |

*Typical values are at $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltage.
tTime required by a limit device to allow for the indicated function.


Fig, 1 - Read cycle tıming diagram

DYNAMIC ELECTRICAL CHARACTERISTICS at TA $=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{VDD} \pm 5 \%$, $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=\mathbf{2 0} \mathrm{ns}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.

| CHARACTERISTIC | VDD <br> (V) | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CDP1823 |  |  | CDP1823C |  |  |  |
|  |  | Min. $\dagger$ | Typ.* | Max. | Min. $\dagger$ | Typ.* | Max. |  |
| Write Cycle (See Fig. 2) |  |  |  |  |  |  |  |  |
| Write Recovery, tWR | 5 | 75 | - | - | 75 | - | - | ns |
|  | 10 | 50 | - | - | - | - | - |  |
| Write Cycle, twC | 5 | 400 | - | - | 400 | - | - |  |
|  | 10 | 225 | - | - | - | - | - |  |
| Write Pulse | 5 | 200 | - | - | 200 | - | - |  |
| Width, tWRW | 10 | 100 | - | - | - | - | - |  |
| Address | 5 | 125 | - | - | 125 | - | - |  |
| Setup Time, tAS | 10 | 75 | - | - | - | - | - |  |
| Data | 5 | 100 | - | - | 100 | - | - |  |
| Setup Time, tDS | 10 | 75 | - | - | - | - | - |  |
| Data Hold Time | 5 | 75 | - | - | 75 | - | - |  |
| From $\overline{\text { MWR }}$, tDH | 10 | 50 | - | - | - | - | - |  |

*Typical values are at $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltage.
tTime required by a limit device to allow for the indicated function.


Fig. 2 - Write cycle tıming diagram.

DATA RETENTION CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}$; see Fig. 3

| CHARACTERISTIC | TEST CONDITIONS |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CDP1823 |  |  | CDP1823C |  |  |  |
|  | $V_{D R}$ <br> (V) | $V_{D D}$ <br> (V) | Min. | Typ.* | Max. | Min. | Typ.* | Max. |  |
| Min. Data Retention Voltage, $V_{D A}$ | - | - | - | 1.5 | 2 | - | 1.5 | 2 | V |
| Data Retention Quiescent Current, IDo | 2 | - | - | 30 | 100 | - | 30 | 100 | $\mu \mathrm{A}$ |
| Chip Deselect to Data Retention Time, $t_{\text {cor }}$ | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 600 \\ & 300 \end{aligned}$ | $-$ | - | $600$ $-$ | $-$ | - | ns |
| Recovery to Normal Operation Time, $t_{\text {rc }}$ | $-$ | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 600 \\ & 300 \end{aligned}$ | $-$ | $-$ | $\begin{gathered} 600 \\ - \end{gathered}$ | - | - |  |
| $V_{D D}$ to $V_{D R}$ Rise and <br> Fall Time | 2 | 5 | 1 | - | - | 1 | - | - | $\mu \mathrm{s}$ |

*Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.


FIg 3-Low VD data retention tıming waveforms


Fig. 4 - Functıonal dıagram


Fig. 5 - CDP1823 (128 $\times 8$ ) mınımum system ( $128 \times 8$ )

# High-Reliability CMOS 128-Word x 8-Bit Static RAM 

## Features

- For Applications in Aerospace, Military, and Critical Industrial Equipment
- Compatible with CDP1800-Series Microprocessors at Maximum Speed
- Interfaces with CDP1800-Series Microprocessors without Additional Components
- Fast Access Time
- At $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V},+25^{\circ} \mathrm{C}$

275ns

- Single Voltage Supply
- Common Data Inputs and Outputs
- Multiple Chip Select Inputs to Simplify Memory System Expansion
- High Noise Immunity
. $30 \%$ of VDD
- Memory Retention for Standby Battery Voltage Down to 2 V at $25^{\circ} \mathrm{C}$
- Latch-Up-Free Transient Radiation Tolerance


## Description

The CDP1823C/3 is a 128 word $\times 8$ bit CMOS/SOS static random access memory. It is compatible with the CDP1802, CDP1804, CDP1805, and CDP1806 microprocessors, and will interface directly without additional components. The CDP1823C has a recommended operating voltage range of 4 to 6.5 volts.

The CDP1823C memory has 8 common data input and data output terminals for direct connection to a bidirectional data bus and is operated from a single voltage supply. Five chip select inputs are provided to simplify memory system expansion. In order to enable the CDP1823C, the chip select inputs $\overline{\mathrm{CS} 2}, \overline{\mathrm{CS} 3}$, and $\overline{\mathrm{CS} 5}$ require a low input signal, and the chip select inputs CS1 and CS4 require a high input signal.
The $\overline{M R D}$ signal enables all 8 output drivers when in the low state and should be in a high state during a write cycle.

After valid data appear at the output, the address inputs may be changed immediately. Output data will be valid until either the MRD signal goes high, the device is deselected, or $\mathrm{t}_{\mathrm{AA}}$ (access time) after address changes.
The CDP1823C/3 is supplied in hermetic 24 lead dual-in-line sidebrazed ceramic packages ( $D$ suffix) that meet the specifications of Mil-M-38510 Case Outline D3.


Logic $1=$ High, Logic $0=$ Low, $X=$ Don't Care

## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ):
(All Voltages Referenced to $\mathrm{V}_{s s}$ Terminal)
CDP1823C/3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.5 V to +7 V
Input Voltage Range, All Inputs ................ -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$
DC Input Current, Any Oneinput

Operating Temperature Range $\left(T_{A}\right)$. . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\mathrm{stg}}$ ). $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{In}$. $(1.59 \pm 0.79 \mathrm{~mm})$
from case for 10 s max.
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions at $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |
| :--- | :---: | :---: | :---: |
|  | MIN | MAX | UNITS |
| Supply Voltage Range | 4 | 6.5 | V |
| Recommended Input Voltage Range | $\mathrm{V}_{\mathrm{SS}}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |

Static Electrical Characteristics $\quad V_{D D}=5 V \pm 5 \%$

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{0} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{\mathbb{I N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Quiescent Device Current (Note 1) | IDD | - | 0,5 | 5 | - | 270 | - | 1000 | $\mu \mathrm{A}$ |
| Output Low (Sink) Current (Note 1) | $\mathrm{l}_{\mathrm{OL}}$ | 0.4 | 0,5 | 5 | 2.7 | - | 1.5 | - | mA |
| Output High (Source) Current (Note 1) | IOH | 4.6 | 0,5 | 5 | - | -1.3 | - | -0.7 | mA |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | $\cdot$ | 0.1 | - | 0.1 | V |
| Output Voltage High-Level | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | $\begin{gathered} \hline \mathrm{V}_{\mathrm{DD}}- \\ 0.1 \end{gathered}$ | - | $\begin{gathered} \hline \mathrm{V}_{\mathrm{DD}}- \\ 0.1 \end{gathered}$ | - | V |
| Input Low Voltage | $\mathrm{V}_{1 \mathrm{~L}}$ | 0.5, 4.5 | - | 5 | - | $0.3 \mathrm{~V}_{\mathrm{DD}}$ | - | $0.3 \mathrm{~V}_{\mathrm{DD}}$ | V |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 0.5, 4.5 | - | 5 | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | V |
| Input Leakage Current (Note 1) | $\mathrm{I}_{\text {IN }}$ | - | 0,5 | 5 | - | $\pm 2.6$ | - | $\pm 10$ | $\mu \mathrm{A}$ |
| Operating Current (Note 1) | $\mathrm{I}_{\mathrm{DD} 1}$ | - | 0,5 | 5 | - | 5 | - | 10 | mA |
| 3-State Output Leakage Current | Iout | 0,5 | 0,5 | 5 | - | $\pm 2.6$ | - | $\pm 10$ | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 7.5 | - | 7.5 | pF |
| Output Capacitance | $\mathrm{Cout}^{\text {O }}$ | - | - | - | - | 15 | - | 15 | pF |

NOTE:

1. Limits designate $100 \%$ testing, all other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing.

Read Cycle Dynamic Electrical Characteristics $t_{n} t_{L}=10 \mathrm{~ns}, C_{L}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | VDD <br> (V) | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $+25^{\circ} \mathrm{C},-55^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Read Cycle | $t_{\text {RC }}$ | 5 | 360 | - | 505 | - | ns |
| Access Time from Address Change (Note 1) | $t_{\text {AA }}$ | 5 | - | 360 | - | 505 | ns |
| Access Time from Chip Select | $t_{A C}$ | 5 | - | 360 | - | 505 | ns |
| Access Time from $\overline{\text { MRD }}$ (Note 1) | $t_{\text {AM }}$ | 5 | - | 310 | - | 435 | ns |
| Data Hold Time After Read | ${ }^{\text {D }}$ H | 5 | 50 | - | 70 | - | ns |

NOTE:

1. Limits designate $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing

*Minimum timing for valid data output. Longer times will initiate an earlier but invalid output NOTE: $\overline{M W R}$ is high during read opration. Timing measurement reference is $0.5 \mathrm{~V}_{\mathrm{DD}}$.

FIGURE 1. READ CYCLE TIMING DIAGRAM

Write Cycle Dynamic Electrical Characteristics $\mathrm{t}_{\mathrm{n}} \mathrm{t}_{\mathrm{L}}=10 \mathrm{~ns}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $+25^{\circ} \mathrm{C},-55^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | (NOTE 2) MIN | MAX | (NOTE 2) MIN | MAX |  |
| Write Cycle | ${ }^{\text {twc }}$ | 5 | 280 | - | 400 | - | ns |
| Address Setup Time (Note 1) | $t_{\text {AS }}$ | 5 | 70 | - | 100 | - | ns |
| Address Hold Time | $t_{\text {AH }}$ | 5 | 70 | - | 100 | - | ns |
| Write Pulse Width (Note 1) | $t_{\text {ww }}$ | 5 | 140 | - | 200 | - | ns |
| Data to $\overline{\text { MWR }}$ Setup Time (Note 1) | $t_{\text {ds }}$ | 5 | 70 | $\bullet$ | 100 | - | ns |
| Data Hold Time from MWR (Note 1) | $\mathrm{t}_{\mathrm{DH}}$ | 5 | 50 | - | 70 | $\bullet$ | ns |
| Chip Select Setup | tcs | 5 | 210 | - | 300 | - | ns |

NOTE:

1. Limits designate $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing
2. Minimum timing to allow the indicated function to occur.


NOTE: $\overline{M R D}$ must be high during write operation
FIGURE 2. WRITE CYCLE TIMING WAVEFORMS

## Data Retention Characteristics

| CHARACTERISTIC | SYMBOL | TEST CONDITIONS |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $V_{D R}$ <br> (V) | $V_{D D}$ <br> (V) | $+25^{\circ} \mathrm{C},-55^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  | MIN | MAX | MIN | MAX |  |
| Minimum Data Retention Voltage (Note 1) | $V_{\text {DR }}$ | - | - | - | 2 | - | 2.5 | V |
| Data Retention Quiescent Current | IDD | 2 | - | - | 100 | - | 400 | $\mu \mathrm{A}$ |
| Chip Deselect to Data Retention Time | $t_{\text {con }}$ | - | 5 | 450 | - | 650 | - | ns |
| Recovery to Normal Operation Time | $t_{\text {RC }}$ | - | 5 | 450 | - | 650 | - | ns |

NOTE:

1. Limits designate $100 \%$ testing. All other limits are designer's parameters under given test conditions and do not represent $100 \%$ testing


FIGURE 3. LOW V $V_{D D}$ DATA RETENTION WAVEFORMS
$\frac{\text { PACKAGE }}{D} \frac{\text { TEMPERATURE }}{125^{\circ} \mathrm{C}} \quad \frac{\text { TIME }}{160 \mathrm{hrs}} \frac{V_{D D}}{7 V}$



FIGURE 4. DYNAMIC/OPERATING BURN-IN CIRCUIT AND TIMING DIAGRAM

## 32-Word x 8-Bit <br> Static RAM

## Features

- Fast Access Time
- $V_{D D}=5 \mathrm{~V}$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 310 ns . $\mathrm{V}_{\mathrm{DD}}=10 \mathrm{~V}$
- No Precharge or Clock Required


## Ordering Information

| PACKAGE | TEMP. <br> RANGE | 5V | 10V |
| :---: | :---: | :--- | :---: |
| Plastic DIP <br> Burn-In | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1824CE | CDP1824E |
|  |  | CDP1824CEX | CDP1824EX |
| Ceramic DIP <br> Burn-In <br> *883B | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | CDP1824CD | CDP1824D |
|  |  | CDP1824CDX | - |
|  | $-55^{\circ} \mathrm{C}$ to <br> $+125^{\circ} \mathrm{C}$ | CDP1824CD3 | CDP1824D3 |

*Respective specifications are included at the end of this datasheet.

## Description

The CDP 1824 and CDP1824C are 32-word $\times 8$-bit fully static CMOS random-access memories for use in CDP-1800 series microprocessor systems. These parts are compatible with the CDP1802 microprocessor and will interface directly without additional components.

The CDP1824 is fully decoded and does not require a precharge or clocking signal for proper operation. It has common input and output and is operated from a single voltage supply. The $\overline{M R D}$ signal (output disable control) enables the three-state output drivers, and overrides the $\overline{M W R}$ signal. A $\overline{\mathrm{CS}}$ input is provided for memory expansion.
The CDP1824C is functionally identical to the CDP1824. The CDP1824 has an operating range of 4 volts to 10.5 volts, and the CDP1824C has an operating voltage range of 4 volts to 6.5 volts. The CDP 1824 and CDP1824C are supplied in 18 lead hermetic dual-in-line ceramic packages ( $D$ suffix), and in 18 lead dual-in-line plastic packages ( $E$ suffix).

Pinout

## 18 LEAD DIP

 TOP VIEW

## OPERATIONAL MODES

| FUNCTION | $\overline{\mathbf{C S}}$ | $\overline{\text { MRD }}$ | $\overline{\text { MWR }}$ | DATA PINS STATUS |
| :--- | :---: | :---: | :---: | :--- |
| Read | 0 | 0 | X | Output: High/Low Dependent on Data |
| Write | 0 | 1 | 0 | Input: Output Disabled |
| Not Selected | 1 | X | X | Output Disabled: High Impedance State |
| Standby | 0 | 1 | 1 | Output Disabled: High Impedance State |

Logic $1=$ High, Logic $0=$ Low, $X=$ Don't Care

## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ): (All Voltages Referenced to $\mathrm{V}_{\text {SS }}$ Terminal)

| CDP1824 | -0.5 V to +11V |
| :---: | :---: |
| CDP1824C. | -0.5 V to +7V |
| Input Voltage Range, All Inputs | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, Any One Input. | $\pm 10 \mathrm{~mA}$ |
| Operating Temperature Range ( $\mathrm{T}_{\mathrm{A}}$ ): |  |
| Package Type D | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Package Type E | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

Storage Temperature Range ( $\mathrm{T}_{\text {sto }}$ ) . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{In}$. $(1.59 \pm 0.79 \mathrm{~mm})$
from case for 10s max
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | CONDITION | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{V}_{\mathrm{DD}}(\mathrm{V})$ | CDP1824D |  | CDP1824CD |  |  |
|  |  | MIN | MAX | MIN | MAX |  |
| Supply Voltage Range | - | 4 | 10.5 | 4 | 6.5 | V |
| Recommended Input Voltage Range | $\cdot$ | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {S }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |
| Input Signal Rise or Fall Time (Note 1) | 5 | - | 5 | $\cdot$ | 5 | $\mu s$ |
| $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{t}}$ | 10 | - | 2 | - | - | $\mu \mathrm{s}$ |

NOTE:

1. Input signal rise or fall times longer than these maxima can cause loss of stored data in either the selected or deselected mode.

Static Electrical Characteristics At $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Except as Noted:

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{0} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & \mathbf{V}_{\mathbb{N}} \\ & \mathbf{( N )} \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1824 |  |  | CDP1824C |  |  |  |
|  |  |  |  |  | MIN | $\begin{gathered} \text { (Note 1) } \\ \text { TYP } \end{gathered}$ | MAX | MIN | (Note 1) TYP | MAX |  |
| Quiescent Device Current | IDD | - | - | 5 | - | 25 | 50 | - | 100 | 200 | $\mu \mathrm{A}$ |
|  |  | - | - | 10 | - | 250 | 500 | - | - | - | $\mu \mathrm{A}$ |
| Output Low (Sink) Current | $\mathrm{IOL}^{\text {L }}$ | 0.4 | 0,5 | 5 | 1.8 | 2.2 | - | 1.8 | 2.2 | - | mA |
|  |  | 0.5 | 0, 10 | 10 | 3.6 | 4.5 | - | - | - | - | mA |
| Output High (Source) Current | $\mathrm{IOH}^{\text {O}}$ | 4.6 | 0,5 | 5 | -0.9 | -1.1 | - | -0.9 | -1.1 | - | mA |
|  |  | 9.5 | 0,10 | 10 | -1.8 | -2.2 | - | - | - | - | mA |
| Output Voltage Low-Level | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
|  |  | $\bullet$ | 0, 10 | 10 | - | 0 | 0.1 | - | $\cdot$ | - | V |
| Output Voltage High-Level | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - | V |
|  |  | - | 0, 10 | 10 | 9.9 | 10 | - | - | - | - | V |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | 0.5, 4.5 | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 1.9 | - | 10 | - | - | 3 | - | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 9.5 | - | 5 | 3.5 | - | - | 3.5 | - | - | V |
|  |  | 1.9 | - | 10 | 7 | - | - | - | - | - | V |
| Input Leakage Current | $\mathrm{I}_{\mathrm{N}}$ | Any Input | 0,5 | 5 | - | $\pm 0.1$ | $\pm 1$ | - | $\pm 0.1$ | $\pm 1$ | $\mu \mathrm{A}$ |
|  |  |  | 0,10 | 10 | - | $\pm 0.1$ | $\pm 1$ | - | - | - | $\mu \mathrm{A}$ |
| Operating Current (Note 2) | $\mathrm{I}_{\mathrm{DD} 1}$ | - | 0,5 | 5 | - | 4 | 8 | - | 4 | 8 | mA |
|  |  | - | 0,10 | 10 | - | 8 | 16 | $\bullet$ | - | - | mA |
| 3-State Output Leakage Current | Iout | 0,5 | 0,5 | 5 | - | $\pm 0.2$ | $\pm 2.0$ | - | $\pm 0.2$ | $\pm 2$ | $\mu \mathrm{A}$ |
|  |  | 0, 10 | 0,10 | 10 | - | $\pm 0.2$ | $\pm 2.0$ | $\bullet$ | - | - | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance | $\mathrm{Cout}^{\text {coin }}$ | - | - | - | - | 10 | 15 | - | 10 | 15 | pF |

## NOTES:

1. Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
2. Outputs open circuited; Cycle time $=1 \mu$.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$, Input $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=\mathbf{1 0} \mathrm{ns}, \mathrm{C}_{\mathrm{L}}=\mathbf{5 0} \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=\mathbf{2 0 0} \mathrm{k} \Omega$; See Fig. 1.

| CHARACTERISTIC | TEST CONDITIONS VDD <br> (V) | LIMITS |  |  |  |  |  | $\begin{aligned} & \mathrm{U} \\ & \mathrm{~N} \\ & \mathrm{I} \\ & \mathrm{~T} \\ & \mathrm{~S} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { CDP1824D } \\ & \text { CDP1824E } \end{aligned}$ |  |  | $\begin{aligned} & \text { CDP1824CD } \\ & \text { CDP1824CE } \end{aligned}$ |  |  |  |
|  |  | Min.\# | Typ. ${ }^{\bullet}$ | Max. | Min.\# | Typ. ${ }^{\bullet}$ | Max. |  |
| Read Operation |  |  |  |  |  |  |  |  |
| Access Time From Address Change, t AA | $\begin{gathered} 5 \\ 10 \end{gathered}$ | - | $\begin{aligned} & 400 \\ & 200 \end{aligned}$ | $\begin{aligned} & 710 \\ & 320 \end{aligned}$ | - | 400 | 710 - | ns |
| Access Time From Chip Select, tDOA | $\begin{array}{r} 5 \\ 10 \end{array}$ | - | 300 150 | 710 320 | - | 300 | 710 | ns |
| Output Active From $\overline{M R D},{ }^{t} A M$ | $\begin{array}{r} 5 \\ 10 \end{array}$ | - | 300 150 | $\begin{aligned} & 710 \\ & 320 \end{aligned}$ | - | 300 | 710 | ns |

$=$ Time required by a limit device to allow for the indicated function

- Time required by a typical device to allow for the indicated function Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nomınal $V_{D D}$


Fig 1 - Read cycle tıming diagram.

## Note:

The dynamic characteristics and timing diagrams indicate maximum performance capability of the CDP1824. When used directly with the CDP1802 microprocessor, timing will be determined by the clock frequency and internal delays of the microprocessor.

The following general timing relationships will hold when the CDP1824 is used with the CDP1802 microprocessor.

$$
\begin{aligned}
& \mathrm{t}_{\mathrm{WW}}=2 \mathrm{t}_{\mathrm{c}} \\
& \mathrm{t}_{\mathrm{AH}}=1.0 \mathrm{t}_{\mathrm{c}}
\end{aligned}
$$

$$
\left.\begin{array}{l}
{ }^{{ }^{\mathrm{ASS}}} \mathrm{AS}=4.5 \mathrm{t}_{\mathrm{c}} \\
\mathrm{t}_{\mathrm{DH}}=1.0 \mathrm{t}_{\mathrm{c}} \\
\mathrm{t}_{\mathrm{DS}}=5.5 \mathrm{t}_{\mathrm{c}}
\end{array}\right\} \begin{aligned}
& \text { Data transfers from } \\
& \text { CDP1802 to memory }
\end{aligned}
$$

$$
\text { MRD occurs one clock period }\left(\mathrm{t}_{\mathrm{c}}\right) \text { earlier }
$$ than the address bits MAO-MA7.

where $t_{c}=\frac{1}{\text { CDP1802 clock frequency }}$
The CDP1824 is capable of operating at the maximum clock frequency of the CDP1802 microprocessor.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}} \pm 5 \%$, Input $t_{r}, t_{f}=10 \mathrm{~ns}, C_{L}=50 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=200 \mathrm{k} \Omega$; See Fig. 2.

| CHARACTERISTIC | TEST CONDITIONS VDD (V) | LIMITS |  |  |  |  |  | $\left\{\begin{array}{l} \mathrm{U} \\ \mathrm{~N} \\ \mathrm{I} \\ \mathbf{T} \\ \mathrm{~S} \end{array}\right.$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { CDP1824D } \\ & \text { CDP1824E } \end{aligned}$ |  |  | $\begin{aligned} & \text { CDP1824CD } \\ & \text { CDP1824CE } \end{aligned}$ |  |  |  |
|  |  | Min.\# | Typ. ${ }^{\bullet}$ | Max. | Min.\# | Typ. ${ }^{\bullet}$ | Max. |  |
| Write Operation |  |  |  |  |  |  |  |  |
| Write Pulse Width, t WRW | $\begin{array}{r} 5 \\ 10 \end{array}$ | $\begin{aligned} & 390 \\ & 180 \end{aligned}$ | $\begin{aligned} & 200 \\ & 150 \end{aligned}$ | - | 390 - | 200 - | - | ns |
| Data Setup Time, tDS | $\begin{array}{r} 5 \\ 10 \end{array}$ | $\begin{aligned} & 390 \\ & 180 \end{aligned}$ | $\begin{array}{r} 100 \\ 50 \end{array}$ | - | 390 | 100 | - | ns |
| Data Hold Time, tDH | $\begin{array}{r} 5 \\ 10 \end{array}$ | $\begin{aligned} & 70 \\ & 35 \end{aligned}$ | $\begin{aligned} & 40 \\ & 20 \end{aligned}$ | - | 70 | 40 - | - | ns |
| Chip Select Setup Time, ${ }^{t}$ CS | $\begin{array}{r} 5 \\ 10 \end{array}$ | $\begin{aligned} & 425 \\ & 215 \end{aligned}$ | $\begin{aligned} & 210 \\ & 110 \end{aligned}$ | - | 425 | 210 | - | ns |
| Address Setup Time, tAS | $\begin{array}{r} 5 \\ 10 \end{array}$ | $\begin{aligned} & 640 \\ & 390 \end{aligned}$ | $\begin{aligned} & 500 \\ & 300 \end{aligned}$ | - | 640 | 500 | - | ns |

= Time required by a limit device to allow for the indicated function

- Time required by a typical device to allow for the indicated function Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$



Fig 3-Low VDD data retentıon waveforms and tıming dıagram

## CDP1824, CDP1824C

DATA RETENTION CHARACTERISTICS at TA $_{A}=-40$ to $+85^{\circ} \mathrm{C}$; See Fig. 3.

| CHARACTERISTIC | TEST CONDITIONS |  | CDP1824 |  | CDP1824C |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $V_{D D}$ (V) |  |  |  |  |  |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Data Retention Voltage, $\mathrm{V}_{\mathrm{DR}}$ |  | - | 2.5 | - | 2.5 | - | V |
| Data Retention Quiescent Current, IDD | $\mathrm{V}_{\mathrm{DR}}=2.5 \mathrm{~V}$ | - | - | 10 | - | 40 | $\mu \mathrm{A}$ |
| Chip Deselect to Data <br> Retention Time, ${ }^{\mathrm{t}} \mathrm{CDR}$ | $V_{D R}=2.5 \mathrm{~V}$ | $\begin{array}{r} 5 \\ 10 \end{array}$ | $\begin{array}{\|l\|} \hline 600 \\ 300 \end{array}$ | - | 600 | - | ns |
| Recovery to Normal Operation Time, $t_{\text {RC }}$ | $V_{D R}=2.5 \mathrm{~V}$ | $\begin{array}{r} 5 \\ 10 \end{array}$ | $\begin{array}{\|l\|} \hline 600 \\ 300 \end{array}$ | - | 600 | - |  |



Fig 5-CDP1824 (128 $\times 8$ ) mınımum system $(128 \times 8)$

$$
\begin{array}{r}
\text { High-Reliability CMOS 32-Word x } 8 \text { Bit } \\
\text { Static Random-Access Memory }
\end{array}
$$

February 1992

## Features

- Access Time:

320ns. . . . . . . . . . . . . . © $V_{D D}=10 \mathrm{~V}$
- No Precharge or Clock Required


## Description

The CDP1824/3 and CDP1824C/3 types are high-reliability CMOS 32-word $\times 8$ bit fully static random-access memories for use in CDP1800-series microprocessor systems. These parts are compatible with the CDP1802 microprocessor and will interface directly without additional components.

The CDP1824/3 is fully decoded and does not require a precharge or clocking signal for proper operation. It has common input and output and is operated from a single voltage supply. The $\overline{M R D}$ signal (output disable control) enables the three-state output drivers, and overrides the MWR signal. A $\overline{\mathrm{CS}}$ input is provided for memory expansion.
The CDP1824C/3 is functionally identical to the CDP1824/3. The CDP1824/3 has a recommended operating voltage range of 4 to 10.5 volts, and the CDP1824C/3 has an operating voltage range of 4 to 6.5 volts.
The CDP1824/3 and CDP1824C/3 are supplied in 18-lead, dual-in-line sidebrazed ceramic packages ( $D$ suffix) that conform to the requirements and dimensions specified in MIL-M-38510 Case Outline D-6.

## Pinout



## Funtional Diagram



OPERATIONAL MODES

| FUNCTION | $\overline{\mathbf{C S}}$ | $\overline{\text { MRD }}$ | $\overline{\text { MWR }}$ | DATA PINS STATUS |
| :--- | :---: | :---: | :---: | :--- |
| READ | 0 | 0 | X | Output: High/Low Dependent on Data |
| WRITE | 0 | 1 | 0 | Input: Output Disabled |
| Not Selected | 1 | X | X | Output Disabled: High-Impedance State |
| Standby | 0 | 1 | 1 | Output Disabled: High-Impedance State |

Logic $1=$ High Logic $0=$ Low $X=$ Don't Care

## Absolute Maximum Ratings

| DC Supply Voltage Range, (VD) <br> (All Voltages Referenced to $\mathrm{V}_{\text {ss }}$ Terminal) |  |
| :---: | :---: |
| CDP1824/3. | -0.5 V to +11V |
| CDP1824C/3. | -0.5 to +7V |
| Input Voltage Range, All Inputs | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, Any One Input. | . $\pm 10 \mathrm{~mA}$ |
| Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ ) |  |
| $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$. | 500 mW |
| $\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | . Derate Linearly at $2 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |

(All Voltages Referenced to $\mathrm{V}_{\mathbf{S S}}$ Terminal)

```
CDP1824/3
CDP1824C/3.
Input Voltage Range, All Inputs
DC Input Current, Any One Input.
Power Dissipation Per Package (PD)
TA}=+10\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to + 125
12mW/}\textrm{C}\mathrm{ to 200mW
```

Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range
(All Package Types)
100 mW
Operating Temperature Range ( $T_{A}$ )
Package Type D.
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {sto }}$ ) . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{in}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10s max.
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions $T_{A}=$ Full Package-Temperature Range. For maximum reliability, nominal operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | CDP1824/3 |  | CDP1824C/3 |  |  |
|  | MIN | MAX | MIN | MAX |  |
| DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | V |
| Input Voltage Range | $\mathrm{V}_{\text {ss }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {Ss }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |

## Static Electrical Characteristics

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{0} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Quiescent Device Current (Note 1) | ID | - | 0,5 | 5 | - | 50 | - | 500 | $\mu \mathrm{A}$ |
|  |  | - | 0, 10 | 10 | - | 500 | - | 1000 | $\mu \mathrm{A}$ |
| Output Voltage Low-Level (Note 2) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | 5 | - | 0.1 | - | 0.2 | V |
|  |  | - |  | 10 | - | 0.1 | - | 0.2 | V |
| Output Voltage High-Level (Note 2) | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.9 | - | 4.8 | - | V |
|  |  | - | - | 10 | 9.9 | - | 4.8 | - | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | 0.5, 4.5 | - | 5 | - | 1.5 | - | 1.5 | V |
|  |  | 1,9 | - | 10 | - | 3 | - | - | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.5, 4.5 | - | 5 | 3.5 | - | 3.5 | - | V |
|  |  | 1,9 | - | 10 | 7 | - | 7 | - | V |
| Output Low Drive (Sink) Current | ${ }^{1} \mathrm{~L}$ | 0.4 | 0,5 | 5 | 4 | $\bullet$ | 1.5 | - | mA |
|  |  | 0.5 | 0, 10 | 10 | 4 | - | 2.9 | - | mA |
| Output High Drive (Source) Current | $\mathrm{IOH}^{\text {O}}$ | 4.6 | 0,5 | 5 | - | -1 | - | -0.75 | mA |
|  |  | 9.5 | 0,10 | 10 | - | -2 | - | -1.5 | mA |
| Input Current | $\mathrm{I}_{1}$ | Any Input | 0,5 | 5 | - | 1 | - | 5 | $\mu \mathrm{A}$ |
|  |  |  | 0, 10 | 10 | - | 1 | - | 5 | $\mu \mathrm{A}$ |
| 3-State Output Leakage Current | Iout | 0,5 | 0,5 | 5 | - | 2 | - | 5 | $\mu \mathrm{A}$ |
|  |  | 0,10 | 0,10 | 10 | - | 2 | - | 5 | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | (Note 2) |  |  | - | 10 | - | 10 | pF |
| Output Capacitance | Cout | (Note 2) |  |  | - | 15 | - | 15 | pF |

## NOTES:

1. The CDP $1824 \mathrm{C} / 3$ meets all 5 volt Static Electrical Characteristics of the CDP1824/3 except Quiescent Device Current for which the limits are $I_{D D}=200 \mu \mathrm{~A}$ at $+25^{\circ} \mathrm{C} /-55^{\circ} \mathrm{C}$; $I_{D D}=1000 \mu \mathrm{~A}$ at $+125^{\circ} \mathrm{C}$.
2. Guaranteed, but not tested.

Specifications CDP1824/3, CDP1824C/3
Read Cycle Dynamic Electrical Characteristics input $t_{r} t_{4} \leq 15 n s, C_{L}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | TEST <br> CONDITIONS <br> $V_{D D}$ <br> $(V)$ | LIMTS |  |  |  | UNTTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Access Time From Address Change | $t_{A A}$ | 5 | - | 610 | - | 825 | ns |
|  |  | 10 | - | 320 | - | 375 | ns |
| Access Time From Chip Select | $t_{\text {DOA }}$ | 5 | - | 610 | - | 825 | ns |
|  |  | 10 | - | 320 | - | 375 | ns |
| Output Active From MRD | $t_{\text {AM }}$ | 5 | - | 610 | - | 825 | ns |
|  |  | 10 | - | 320 | - | 375 | ns |



Write Cycle Dynamic Electrical Characteristics Input $t_{T} t_{4} \leq 15 n s, C_{L}=50 \mathrm{pF}$

| CHARACTERISTIC | SYMBOL | TEST CONDITIONS <br> $V_{D D}$ <br> (V) | LIMTS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$ |  | $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  | (Note 1) MIN | MAX | (Note 1) MIN | MAX |  |
| Write Pulse Width | $t_{\text {WRW }}$ | 5 | 350 | - | 475 | - | ns |
|  |  | 10 | 180 | - | 220 | - | ns |
| Data Setup Time | $t_{\text {DS }}$ | 5 | 400 | - | 560 | - | ns |
|  |  | 10 | 190 | - | 260 | - | ns |
| Data Hold Time | $t_{\text {DH }}$ | 5 | 70 | - | 90 | - | ns |
|  |  | 10 | 35 | - | 45 | - | ns |
| Chip Select Setup Time | $\mathrm{t}_{\mathrm{cs}}$ | 5 | 550 | - | 775 | - | ns |
|  |  | 10 | 340 | - | 475 | - | ns |
| Address Setup Time | $t_{\text {AS }}$ | 5 | 550 | - | 775 | - | ns |
|  |  | 10 | 340 | - | 475 | - | ns |

NOTE: 1. Time required by a device to allow for the indicated function.


WRITE CYCLE TIMING DIAGRAM

## Data Retention Characteristics At $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| CHARACTERISTIC | SYMBOL | TEST CONDITIONS |  | LIMTS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | CDP1824/3 |  | CDP1824C/3 |  |  |
|  |  | $V_{D R}$ <br> (V) | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | MIN | MAX | MIN | MAX |  |
| Data Retention Voltage | $V_{\text {DR }}$ | - | - | 2.5 | - | 2.5 | - | V |
| Data Retention Quiescent Current | $\mathrm{I}_{\mathrm{DD}}$ | 2.5 | - | - | 10 | - | 40 | $\mu \mathrm{A}$ |
| Chip Deselect ot Data Retention Time | $\mathrm{t}_{\text {CDR }}$ | 2.5 | 5 | 600 | - | 600 | - | ns |
|  |  | 2.5 | 10 | 300 | - | - | - | ns |
| Recovery to Normal Operation Time | $t_{\text {RC }}$ | 2.5 | 5 | 600 | $\bullet$ | 600 | - | ns |
|  |  | 2.5 | 10 | 300 | - | - | - | ns |



LOW $V_{\text {DD }}$ DATA RETENTION WAVEFORMS AND TIMING DIAGRAM

## Static Burn-in Circuit



| TYPE | VDD | TEMPERATURE | TIME |
| :--- | :---: | :---: | :---: |
| CDP1824 | 11 V | $+125^{\circ} \mathrm{C}$ | 160 Hrs., Min. |
| CDP1824C | 7 V | $+125^{\circ} \mathrm{C}$ | 160 Hrs., Min. |

All Resistors $47 \mathrm{k} \Omega( \pm 20 \%)$

CMOS 64-Word x 8-Bit<br>Static RAM

## Features

- Ideal for Small, Low-Power RAM Memory Requirements in Microprocessor and Microcomputer Applications
- Interfaces with CDP1800-Series Microprocessors Without Additional Address Decoding
- Daisy Chain Feature to Further Reduce External Decoding Needs
- Multiple Chip-Select Inputs for Versatility
- Single Voltage Supply
- No Clock or Precharge Required


## Ordering Information

| PACKAGE | TEMP. <br> RANGE | ORDER CODE |
| :--- | :--- | :--- |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to | CDP1826CE |
| $+85^{\circ} \mathrm{C}$ | Ceramic DIP |  |

## Description

The CDP1826C is a general purpose, fully static, 64 -word x 8 -bit random-access memory, for use in CDP1800-series or other microprocessor systems where minimum component count and/or price performance and simplicity in use are desirable.

The CDP1826C has 8 common data input and data-output terminals with 3-state capability for direct connection to a standard bidirectional data bus. Two chip-select inputs CS1 and CS2 - are provided to simplify memory-system expansion. An additional select pin, CS/A5, is provided to enable the CDP1826C to be selected directly from the CDP1800 multiplexed address bus without additional latching or decoding. In an 1800 system, the CS/A5 pin can be tied to any MA address line from the CDP1800 processor. A TPA input is provided to latch the high-order bit of this address line as a chip-select for the CDP1826C. If this CS/A5 input is latched high, and if CS = 1 and CS2 $=0$ at the appropriate time in the memory cycle, the CDP1826C will be enabled for writing or reading. In a non-1800 system, the TPA pin can be tied high, and the CS/A5 pin can be used as a normal address input.
The six input-address buffers are gated with the chip-select function to reduce standby current when the device is deselected, as well as to provide for a simplified power down mode by reducing address buffer sensitivity to long fall times from address drivers which are being powered down.
Two memory control signals, $\overline{M R D}$ and $\overline{M W R}$, are provided for reading from the writing to the CDP1826C. The logic is designed so that MWR overrides MRD, allowing the chip to be controlled from a single $R \bar{W}$.

A CHIP ENABLE OUTPUT is provided for daisy-chaining to additional memories or I/O devices. This output is high whenever the chip-select function selects the CDP1826C, which deselects any other chip which has its CS input connected to the CDP 1826C CEO output. The connected chip is selected when the CDP1826C is de-selected and the MRD input is low. Thus, the CEO is only active for a read cycle and can be set up so that a CEO of another device can feed the MRD of the CDP1826C, which in turn selects a third chip in the daisy chain.
The CDP1826C has a recommended operating voltage of 4.5 V to 5.5 V and is supplied in 22 lead hermetic dual-in-line sidebrazed ceramic packages ( D suffix), in 22 lead dual-inline plastic packages ( E suffix). The CDP 1826C is also available in chip form ( H suffix).


Fig. 1 - Typical CDP1802 microprocessor system

## Absolute Maximum Ratings

DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ):
(All Voltages Referenced to $\mathrm{V}_{\mathrm{SS}}$ Terminal) CDP1826C $\qquad$ Input Voltage Range, All Inputs
$\qquad$ . -0.5 V to +7 V
$\ldots . . . . . .-0.5 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$
DC Input Current, Any One Input. . . . . . . . . . . . . . . . . . . . . . . . . $\pm 10 \mathrm{~mA}$
Power Dissipation Per Package ( $P_{D}$ )
$T_{A}=-40^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (Package Type E) . . . . . . . . . . . . . . . 500 mW
$\mathrm{T}_{\mathrm{A}}=+60^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type E) $\ldots$. . . Derate Linearly at
$12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (Package Type D) . . . . . . . . . . . . 500 mW
$T_{A}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Package Type D) $\ldots$. . Derate Linearly at
$12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW

Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range
(All Package Types)
100 mW
Operating Temperature Range $\left(T_{A}\right)$ :
Package Type D. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Package Type E. . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stg }}$ ) $\ldots \ldots \ldots . . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \ln .(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10 s max.
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions at $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | SYMBOL | CDP1826C |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| DC Operating Voltage Range |  | 4 | 6.5 | V |
| Input Voltage Range |  | $\mathrm{V}_{\text {ss }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |
| Input Signal Rise or Fall Time, $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{4}$ | - | 10 | $\mu \mathrm{s}$ |

Static Electrical Characteristics At $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$, Except as Noted:

| CHARACTERISTIC |  | SYMBOL | CONDITIONS |  | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & V_{0} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | CDP1826C |  |  |  |
|  |  |  |  |  | MIN | (Note 1) TYP | MAX |  |
| Quiescent Device Current |  | $\mathrm{I}_{\mathrm{DD}}$ | - | $0, V_{D D}$ | - | 5 | 50 | $\mu \mathrm{A}$ |
| Output Low (Sink) Current | BUS | loL | 0.4 | $0, V_{D D}$ | 1.6 | 3.2 | - | mA |
|  | CEO |  | 0.4 | $0, V_{D D}$ | 0.8 | 1.6 | - | mA |
| Output High (Source) Current | BUS | $\mathrm{IOH}^{\text {a }}$ | $\mathrm{V}_{\text {DD }}-0.4$ | $0, V_{D D}$ | -1.0 | -1.5 | - | mA |
|  | CEO |  | $\mathrm{V}_{\mathrm{DD}}-0.4$ | $0, V_{D D}$ | -0.6 | -1.0 | - | mA |
| Output Voltage Low-Level |  | $\mathrm{V}_{\mathrm{OL}}$ | - | $0, V_{D D}$ | - | 0 | 0.1 | V |
| Output Voltage High-Level |  | $\mathrm{V}_{\mathrm{OH}}$ | - | $0, V_{D D}$ | $\mathrm{V}_{\mathrm{DD}}-0.1$ | $\mathrm{V}_{\mathrm{DD}}$ | - | V |
| Input Low Voltage |  | $\mathrm{V}_{\mathrm{IL}}$ |  | . | - | - | 1.5 | V |
| Input High Voltage |  | $\mathrm{V}_{\mathrm{IH}}$ |  | - | 3.5 | - | - | V |
| Input Leakage Current |  | IN | Any Input | $0, V_{D D}$ | - | $\pm 0.1$ | $\pm 1$ | $\mu \mathrm{A}$ |
| Operating Device Current (Note 2) |  | $\mathrm{l}_{\text {OPER }}$ | - | $0, V_{D D}$ | - | 5 | 10 | mA |
| 3-State Output Leakage Current |  | lout | $0, \mathrm{~V}_{\mathrm{DD}}$ | $0, V_{D D}$ | - | $\pm 0.1$ | $\pm 1$ | $\mu \mathrm{A}$ |
| Input Capacitance |  | $\mathrm{C}_{\text {IN }}$ | - | - | - | 5 | 7.5 | pF |
| Output Capacitance |  | $\mathrm{Cout}^{\text {O }}$ | - | $0, V_{D D}$ | - | 10 | 15 | pF |

NOTES:

1. Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$ -
2. Outputs open circuited; Cycle time $=1 \mu \mathrm{~s}$.

## Signal Descriptions

A0 - A4, CS/A5 (Address Inputs): These inputs must be stable prior to a write operation, but may change asynchronously during Read operations.
In an 1800 system, the multiplexed high-order address bit at pin CS/ A5 can be latched at the end of TPA. A high level will provide a valid chip select for the CDP1826C. The low-order address bit which appears after TPA is used for data word selection. In non-1800 systems, TPA can be tied high to disable the latch and allow the CS/A5 pin to function as a normal address input.
BUS 0-BUS 7: 8-bit 3-state common input/output data bus.
TPA: High-order address strobe input. The high-order address bit at input CS/A5 is latched on the high-to-low transition of the TPA input.

Tie TPA high to disable the CS/A5 latch feature.
CS1, $\overline{\mathrm{CS} 2}$ (Chip Selector): Either chip select (CS1 or $\overline{\mathrm{CS} 2}$ ), when not valid, powers down the chip, disables READ and WRITE functions, and gates off the address and output buffers.
$\overline{M R D}, \overline{M W R}$ : Read and Write control signals. $\overline{M W R}$ overrides $\overline{M R D}$, allowing the CDP1826C to be controlled from a single $\mathrm{R} \overline{\mathrm{W}}$ line.
CEO (Chip Enable Output): Allows daisy chaining to additional memories. CEO is high whenever the CDP1826C is selected. CEO is only active (low) for a Read cycle with the CDP1826C deselected and the $\overline{M R D}$ input low.
$\mathbf{V}_{\mathrm{DD}}, \mathbf{V}_{\mathbf{S s}}$ : Power supply connections.


Fig. 2 - Functional diagram


|  | OPERATING MODES |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FUNCTION | $\overline{\text { MRD }}$ | MWR | csl. $\overline{\mathrm{cs} 2}$ | TPA | CS/A5* | CEO |
|  | WRITE | x | 0 | 1 | $\checkmark$ | 1 | 1 |
|  | READ | 0 | 1 | 1 | $\sqrt{2}$ | 1 | 1 |
| $\frac{1}{\Sigma}$ | DESELECT | 1 | 1 | 1 | 厄 | 1 | 1 |
| - | DESELECT | 1 | x | 0 | $x$ | $x$ | 1 |
| ¢ | DESELECT | 0 | $x$ | 0 | x | x | 0 |
| $\frac{0}{0}$ | deselect | 1 | $x$ | $x$ | $\sqrt{2}$ | 0 | 1 |
|  | DESELECT | 0 | x | $\times$ | $\sqrt{2}$ | 0 | 0 |
|  | WRITE | x | 0 | 1 | 1 | X | 1 |
| $\frac{\infty}{0} w$ | READ | 0 | 1 | 1 | 1 | X | 1 |
| $0{ }^{0}$ | DESELECT | 1 | 1 | 1 | 1 | x | 1 |
| $z^{2}$ | DESELECT | 1 | $x$ | 0 | 1 | x | 1 |
| \% | DESELECT | 0 | x | 0 | 1 | x | 0 |

* FOR CDPI800 MODE, REFERS TO HIGH ORDER MEMORY ADDRESS BIT LEVEL AT TIME WHEN TPA Z TRANSITION
TAKES PLACE

Fig 3-Chıp Enable Output tıming waveforms for CDP1800-based systems.

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, V_{D D}=5 \mathrm{~V} \pm 5 \%$,
Input $t_{r}, t_{\mathrm{f}}=10 \mathrm{~ns} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ and 1 TTL Load

| CHARACTERISTIC | LIMITS |  |  |
| :--- | :--- | :--- | :--- |
|  | UNITS |  |  |
|  | MIN. $\dagger$ | TYP. $\bullet$ | MAX. |
|  |  |  |  |

Read - Cycle Times (Figs. 4 and 5)

| Address to TPA Setup |  | 100 | - | - | n |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{t}_{\text {ASH }}$ |  |  |  |  |
| Address to TPA Hold |  | 100 | - | - |  |
|  | $t_{\text {AH }}$ |  |  |  |  |
| Access from Address Change | $\mathrm{T}_{\text {AA }}$ | - | 500 | 1000 |  |
| TPA Pulse Width |  | 200 | - | - |  |
|  | $t_{\text {paw }}$ |  |  |  |  |
| Output Valıd from $\overline{\text { MRD }}$ | $t_{\text {AM }}$ | - | 500 | 1000 |  |
| Access from Chip Select | $t_{A C}$ | - | 500 | 1000 |  |
| CEO Delay from TPA 1 Edge | $t_{\text {CA }}$ | - | 150 | 300 |  |
| $\overline{\mathrm{MRD}}$ to CEO Delay | $\mathrm{t}_{\text {MC }}$ | 75 | - | - |  |
| Output High $Z$ from Invalid $\overline{M R D}$ | $\mathrm{t}_{\text {RHz }}$ | - | - | 125 |  |
| Output High Z from Chip Deselect | $t_{\text {SHZ }}$ | - | - | 225 |  |

$\dagger$ Time required by a limit device to allow for the indicated function
-Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$


Fig. 4 - Timing waveforms for Read-cycle 1


Fig 5 - Timing waveforms for Read-cycle 2 [TPA-High].

DYNAMIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}, V_{D D}=5 \mathrm{~V} \pm 5 \%$,
Input $t_{t}, t_{\mathrm{f}}=10 \mathrm{~ns} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ and 1 TTL Load

| CHARACTERISTIC | LIMITS |  |  |
| :--- | :--- | :--- | :--- |
|  | UNITS |  |  |
|  |  | CDP1826C |  |  |
|  |  |  |  |
|  | MIN. $\dagger$ | TYP. $\bullet$ | MAX. |
|  |  |  |  |

Write-Cycle Times (Figs. 6 and 7)

| Address to TPA Setup, High Byte | $t_{\text {ASH }}$ | 100 | - | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Address to TPA Hold | $\mathrm{t}_{\text {AH }}$ | 100 | - | - |  |
| Address Setup Low Byte | $\mathrm{t}_{\text {ASL }}$ | 500 | 250 | - |  |
| TPA Pulse Width | $t_{\text {Paw }}$ | 200 | - | - |  |
| Chip Select Setup | tcs | 700 | 350 | - |  |
| Write Pulse Width | tww | 300 | 200 | - |  |
| Write Recovery | $t_{\text {Wr }}$ | 100 | - | - |  |
| Data Setup | tos | 400 | 200 | - |  |
| Data Hold from End of $\overline{M W R}$ | $\mathrm{t}_{\text {DH1 }}$ | 100 | 50 | - |  |
| Data Hold from End of Chip Select | $\mathrm{t}_{\text {DH2 }}$ | 125 | 50 | - |  |

[^20]

Fig 6-Timing waveforms for Write-cycle 1.


Fig. 7-Timing waveforms for Write-cycle 2 [TPA $=$ High $]$.

DATA RETENTION CHARACTERISTICS at $T_{A}=-40$ to $+85^{\circ} \mathrm{C}$; see Fig. 8

| CHARACTERISTIC |  | TEST CONDITIONS |  | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | CDP1826C |  |  |  |
|  |  | $V_{\text {DR }}$ <br> (V) | $V_{D D}$ <br> (V) | MIN. | TYP.• | MAX. |  |
| Min. Data Retention Voltage | $V_{\text {DR }}$ | - | - | - | 2 | 2.5 | V |
| Data Retention Quiescent Current | $\mathrm{I}_{\text {DD }}$ | 25 | - | - | 5 | 25 | $\mu \mathrm{A}$ |
| Chip Deselect to Data Retention Time | $\mathrm{t}_{\text {CDR }}$ | - | 5 | 600 | - | - | ns |
| Recovery to Normal Operation Time | $t_{\text {RC }}$ | - | 5 | 600 | - | - |  |
| $V_{D D}$ to $V_{D R}$ Rise and Fall Time | $t_{\text {t }}, \mathrm{t}_{\text {t }}$ | 2.5 | 5 | 1 | - | - | $\mu \mathrm{s}$ |

- Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$


FIg 8-Low VDD data retention tıming waveforms

HARRIS
SEMICONDUCTOR

## Features

- Industry Standard Pinout
- Very Low Operating Current . . . . . . . . . . . . . . . . . . 8mA at $V_{D D}=5 \mathrm{~V}$ and Cycle Time $=1 \mu \mathrm{~s}$
- Two Chip Select Inputs Simple Memory Expansion
- Memory Retention for Standby. 2V (Min) Battery Voltage
- Output Disable for Common I/O Systems
- 3-State Data Output for Bus Oriented Systems
- Separate Data Inputs and Outputs
- TTL Compatible (MWS5101A)


## Pinout

> 22 LEAD DIP
> TOP VIEW


## Description

The MWS5101 and MWS5101A are 256 word by 4 bit static random access memories designed for use in memory systems where high speed, very low operating current, and simplicity in use are desirable. They have separate data inputs and outputs and utilize a single power supply of 4 to 6.5 volts. The MWS5101 and MWS5101A differ in input voltage characteristics (MWS5101A is TTL compatible).

Two Chip Select inputs are provided to simplify system expansion. An Output Disable control provides Wire-OR capability and is also useful in common Input/Output systems by forcing the output into a high impedance state during a write operation independent of the Chip Select input condition. The output assumes a high impedance state when the Output Disable is at high level or when the chip is deselected by $\overline{\mathrm{CS} 1}$ and/or CS2.
The high noise immunity of the CMOS technology is preserved in this design. For TTL interfacing at 5 V operation, excellent system noise margin is preserved by using an external pull-up resistor at each input.

For applications requiring wider temperature and operating voltage ranges, the mechanically and functionally equivalent static RAM, CDP1822 may be used.
The MWS5101 and MWS5101A types are supplied in 22 lead hermetic dual-in-line, sidebrazed ceramic packages ( $D$ suffix), in 22 lead dual-in-line plastic packages ( $E$ suffix), and in chip form (H suffix).

## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | MWS5101 |  | MWS5101A |  |
| :---: | :---: | :---: | :--- | :--- | :--- |
|  |  | 350ns | 250ns | 350ns |  |
| Plastic DIP <br> Burn-In | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | MWS5101EL2 <br> MWS5101EL2X | MWS5101EL3 <br> MWS5101EL3X | MWS5101AEL2 <br> MWS5101AEL2X | MWS5101AEL3 <br> MWS5101AEL3X |
| Ceramic DIP <br> Burn-In | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | - | MWS5101DL3 <br> MWS5101DL3X | - | MWS5101ADL3 <br> MWS5101ADL3X |

## OPERATIONAL MODES

| MODE | INPUTS |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { CHIP SELECT }}^{\mathrm{CS}_{1}}$ | $\begin{aligned} & \text { CHIP SELECT } 2 \\ & \text { CS }_{2} \end{aligned}$ | OUTPUT DISABLE OD | READ/ $\overline{\text { WRITE }}$ R $\bar{W}$ |  |
| Read | 0 | 1 | 0 | 1 | Read |
| Write | 0 | 1 | 0 | 0 | Data In |
| Write | 0 | 1 | 1 | 0 | High Impedance |
| Standby | 1 | X | X | X | High Impedance |
| Standby | X | 0 | X | X | High Impedance |
| Output Disable | X | X | 1 | X | High Impedance |

Logic $1=$ High, Logic $0=$ Low, $X=$ Don't Care

## Functional Block Diagram



| Absolute Maximum Ratings |  |
| :---: | :---: |
| DC Supply Voltage Range, ( $\mathrm{V}_{\mathrm{DD}}$ ): <br> (All Voltages Referenced to $\mathrm{V}_{\text {SS }}$ Terminal) | -0.5 V to +7 V |
| Input Voltage Range, All inputs | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| DC Input Current, Any One Input. | $\pm 10 \mathrm{~mA}$ |
| Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ ) |  |
| $T_{A}=-40^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (Package Type E) | 500 mW |
| $\mathrm{T}_{\mathrm{A}}=+60^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Package Type E) | . . . Derate Linearly at $12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ to 200 mW |
| $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (Package Type D) | 500 mW |
| $\mathrm{T}_{\mathrm{A}}=+100^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Package Type D) | Derate Linearly at |

Device Dissipation Per Output Transistor
$T_{A}=$ Full Package Temperature Range (All Package Types)

100 mW
Operating Temperature Range ( $T_{A}$ ):
Package Type D. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Package Type E. . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {stg }}$ ) $\ldots \ldots . . . . . .{ }^{-65^{\circ} \mathrm{C}}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering): At distance $1 / 16 \pm 1 / 32 \mathrm{ln}$. $(1.59 \pm 0.79 \mathrm{~mm})$ from case for 10 s max.
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions At $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC |  |  | UNITS |
| :---: | :---: | :---: | :---: |
|  | ALL TYPES |  |  |
|  | MiN | MAX |  |
| DC Operating Voltage Range | 4 | 6.5 | V |
| Input Voltage Range | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |

Static Electrical Characteristics At $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$

| CHARACTERISTIC |  | SYMBOL | CONDITIONS |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & v_{0} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{\mathbb{N}} \\ & (V) \end{aligned}$ | MWS5101 |  |  | MWS5101A |  |  |  |
|  |  | MIN |  | (Note 1) TYP | MAX | MIN | (Note 1) TYP | MAX |  |
| Quiescent Device Current | L2 Types |  | IDD | - | 0,5 | - | 25 | 50 | - | 25 | 50 | $\mu \mathrm{A}$ |
|  | L3 Types | $\cdot$ |  | 0, 10 | - | 100 | 200 | - | 100 | 200 | $\mu \mathrm{A}$ |
| Output Low (Sink) Current |  | $\mathrm{IOL}^{\text {a }}$ | 0.4 | 0,5 | 2 | 4 | - | 2 | 4 | - | mA |
| Output High (Source) Current |  | $\mathrm{IOH}^{\text {l }}$ | 4.6 | 0,5 | -1 | -2 | - | -1 | -2 | - | mA |
| Output Voltage Low-Level |  | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,5 | - | 0 | 0.1 | - | 0 | 0.1 | V |
| Output Voltage High-Level |  | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 4.9 | 5 | - | 4.9 | 5 | - | V |
| Input Low Voltage |  | $\mathrm{V}_{\text {IL }}$ | - | - | - | - | 1.5 | - | - | 0.65 | V |
| Input High Voltage |  | $\mathrm{V}_{\mathrm{IH}}$ | - | - | 3.5 | - | - | 2.2 | - | - | V |
| Input Leakage Current |  | $\mathrm{I}_{\text {IN }}$ | - | 0,5 | - | - | $\pm 5$ | $\bullet$ | - | $\pm 5$ | $\mu \mathrm{A}$ |
| Operating Current (Note 2) |  | $\mathrm{I}_{\text {D } 1}$ | - | 0,5 | - | 4 | 8 | $\bullet$ | 4 | 8 | mA |
| 3-State Output Leakage Current | $\underline{L 2 \text { Types }}$ | lout | 0,5 | 0,5 | $\cdot$ | $\cdot$ | $\pm 5$ | $\cdot$ | $\cdot$ | $\pm 5$ | $\mu \mathrm{A}$ |
|  | L3 Types |  | 0,5 | 0,5 | - | - | $\pm 5$ | - | - | $\pm 5$ | $\mu \mathrm{A}$ |
| Input Capacitance |  | $\mathrm{C}_{\text {IN }}$ | - | - | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance |  | $\mathrm{C}_{\text {OUT }}$ | - | - | - | 10 | 15 | - | 10 | 15 | pF |

[^21]2. Outputs open circuited; Cycle time $=1 \mu \mathrm{~s}$.

Specifications MWS5101, MWS5101A
Dynamic Electrical Characteristics at $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$

| CHARACTERISTIC | SYMBOL | LIMITS (NOTE 1) |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | L2 TYPES |  |  | L3 TYPES |  |  |  |
|  |  | (NOTE 2) MIN | (NOTE 3) TYP | MAX | (NOTE 2) MIN | (NOTE 3) TYP | MAX |  |
| READ CYCLE TIMES (FIGURE 1) |  |  |  |  |  |  |  |  |
| Read Cycle | $\mathrm{t}_{\mathrm{RC}}$ | 250 | - | - | 350 | - | - | ns |
| Access from Address | $t_{A A}$ | - | 150 | 250 | - | 200 | 350 | ns |
| Output Valid from Chip Select 1 | $\mathrm{t}_{\text {DOA }}$ | - | 150 | 250 | - | 200 | 350 | ns |
| Output Valid from Chip Select 2 | $\mathrm{t}_{\text {DOA } 2}$ | - | 150 | 250 | - | 200 | 350 | ns |
| Output Valid from Output Disable | $\mathrm{t}_{\text {DOA }}$ | - | - | 110 | - | - | 150 | ns |
| Output Hold from Chip Select 1 | $\mathrm{t}_{\text {DOHI }}$ | 20 | - | - | 20 | - | - | ns |
| Output Hold from Chip Select 2 | $\mathrm{t}_{\mathrm{DOH} 2}$ | 20 | - | - | 20 | - | - | ns |
| Output Hold from Output Disable | $\mathrm{t}_{\text {DOH3 }}$ | 20 | - | - | 20 | $\bullet$ | - | ns |
| WRITE CYCLE TIMES (FIGURE 2) |  |  |  |  |  |  |  |  |
| Write Cycle | $t_{\text {wc }}$ | 300 | - | - | 400 | $\bullet$ | - | ns |
| Address Setup | $t_{\text {AS }}$ | 110 | - | - | 150 | - | - | ns |
| Write Recovery | $t_{\text {Wh }}$ | 40 | - | - | 50 | - | - | ns |
| Write Width | ${ }^{\text {twRW }}$ | 150 | - | - | 200 | $\bullet$ | - | ns |
| Input Data Setup Time | $t_{\text {DS }}$ | 150 | - | - | 200 | - | - | ns |
| Data in Hold | $\mathrm{t}_{\mathrm{DH}}$ | 40 | - | - | 50 | - | - | ns |
| Chip Select 1 Setup | ${ }^{\text {CS }} 15$ | 110 | - | - | 150 | - | - | ns |
| Chip Select 2 Setup | $\mathrm{t}_{\mathrm{CS2S}}$ | 110 | - | - | 150 | - | - | ns |
| Chip Select 1 Hold | tesiH | 0 | - | - | 0 | - | - | ns |
| Chip Select 2 Hold | ${ }^{\text {CSS2H }}$ | 0 | - | - | 0 | - | - | ns |
| Output Disable Setup | tods | 110 | - | - | 150 | - | - | ns |

NOTES:

1. MWS5101: $t_{r} t_{1}=20 \mathrm{~ns}, V_{I H}=0.7 V_{D D}, V_{I L}=3 V_{D D} ; C_{L}=100 \mathrm{pF}$ and MWS5101A: tr, $4=20 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IH}}=2.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.65 \mathrm{~V} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ and 1 TTL Load.
2. Time required by a limit device to allow for the indicated function
3. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$


FIGURE 1. READ CYCLE TIMING WAVEFORMS


*toDs is required for common I/O operation only; for separate I/O operations, output disable is "don't care"

FIGURE 2. WRITE CYCLE TIMING WAVEFORMS

Data Retention Characteristics at $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; See Figure 3

| CHARACTERISTIC | SYMBOL | TEST CONDITIONS |  | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & V_{D R} \\ & (V) \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | ALL TYPES |  |  |  |
|  |  |  |  | MIN | (NOTE 1) TYP | MAX |  |
| Minimum Data Retention Voltage | $V_{\text {DR }}$ | - | - | - | 1.5 | 2 | V |
| Data Retention Quiescent Current | ID | 2 | - | - | 2 | 10 | $\mu \mathrm{A}$ |
|  |  | 2 | - | - | 5 | 50 | $\mu \mathrm{A}$ |
| Chip Deselect to Data Retention Time | $\mathrm{t}_{\text {CDR }}$ | - | 5 | 600 | - | - | ns |
| Recovery to Normal Operation Time | $\mathrm{t}_{\mathrm{RC}}$ | - | 5 | 600 | - | - | ns |
| $V_{D D}$ to $V_{D R}$ Rise and Fall Time | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | 2 | 5 | 1 | - | - | $\mu \mathrm{s}$ |

NOTE:

1. Typical Values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$


Figure 3. LOW $V_{\text {DD }}$ DATA RETENTION TIMING WAVEFORMS


FIGURE 4. MEMORY CELL CONFIGURATION


FIGURE 5. LOGIC DIAGRAM OF CONTROLS FOR MWS5101, MWS5101A

## Features

- Low Power Standby. $\qquad$ 50رW Max.
- Low Power Operation 20mW/MHz Max.
- Fast Access Time. 180ns Max.
- Data Retention .2.0V Min.
- TTL Compatible Input/Output
- High Output Drive - 2 TTL Loads
- On-Chip Address Register


## Ordering Information

| PACKAGE | TEMP. RANGE | 180ns | 250ns |
| :---: | :---: | :--- | :--- |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM3-6508B-9 | HM3-6508-9 |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM1-6508B-9 | HM1-6508-9 |
| $* / 883$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM1-6508B/883 | HM1-6508/883 |

*Respective /883 specifications are included at the end of this datasheet

## Description

The HM-6508 is a $1024 \times 1$ static CMOS RAM fabricated using 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 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

16 LEAD DIP TOP VIEW


| PIN | DESCRIPTION |
| :---: | :--- |
| A | Address Input |
| $\bar{E}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| D | Data Input |
| $\mathbf{Q}$ | Data Output |

## Functional Diagram



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

## Absolute Maximum Ratings

Supply Voltage $\qquad$ .................. +7.0 V
Input, Output or I/O Voltage . . . . . . . . . . . . . GND-0.3V to VCC+0.3V
Storage Temperature Range . . . . . . . . . . . . . . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s) . . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
Typical Derating Factor . . . . . . . . . . . 1.5 mAMMHz Increase in ICCOP
ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1
CAUTION: Stresses above those listed in "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.
Operating Conditions
Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . $+4.5 V$ to +5.5V Operating Temperature Range HM-6508B-9, HM-6508-9 . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

DC Electrical Specifications $\quad V C C=5 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6508B-9, HM-6508-9)

| SYMBOL | PARAMETER |  | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICCSB | Standby Supply Current |  | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \\ & \mathrm{VCC}=5.0 \mathrm{~V} \end{aligned}$ |
| ICCOP | Operating Supply Current (Note 1) |  | - | 4 | mA | $\begin{aligned} & \overline{\mathrm{E}}=1 \mathrm{MHz}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & G N D, V C C=5.5 \mathrm{~V} \end{aligned}$ |
| ICCDR | Data Retention Supply Current | HM-6508B-9 | - | 5 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & \mathrm{GND}, \overline{\mathrm{E}}=\mathrm{VCC} \end{aligned}$ |
|  |  | HM-6508-9 | - | 10 | $\mu \mathrm{A}$ |  |
| VCCDR | Data Retention Supply Voltage |  | 2.0 | - | V |  |
| 11 | Input Leakage Current |  | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| 1OZ | Output Leakage Current |  | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage |  | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage |  | vCc-2.0 | VCC +0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage |  | - | 0.4 | V | $1 \mathrm{O}=3.2 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH | Output High Voltage |  | 2.4 | - | v | $10=-0.4 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| Cl | Input Capacitance (Note 2) | 6 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| CO | Output Capacitance (Note 2) | 10 | pF |  |

## NOTES:

1. Typical derating $1.5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
2. Tested at initial design and after major design changes 1

Reliability Information


Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$
$\qquad$
Gate Count
1925 Gates

AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6508B-9, HM-6508-9)

| SYMBOL | PARAMETER | HM-6508B-9 |  | HM-6508-9 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) TELQV | Chip Enable Access Time | - | 180 | - | 250 | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access Time | - | 180 | - | 250 | ns | (Notes 1, 3, 4) |
| (3) TELQX | Chip Enable Output Enable Time | 5 | 120 | 5 | 160 | ns | (Notes 2, 3) |
| (4) TWLQZ | Write Enable Output Disable Time | - | 120 | - | 160 | ns | (Notes 2, 3) |
| (5) TEHQZ | Chip Enable Output Disable Time | - | 120 | - | 160 | ns | (Notes 2, 3) |
| (6) TELEH | Chip Enable Pulse Negative Width | 180 | - | 250 | - | ns | (Notes 1, 3) |
| (7) TEHEL | Chip Enable Pulse Positive Width | 100 | - | 100 | - | ns | (Notes 1, 3) |
| (8) TAVEL | Address Setup Time | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (9) TELAX | Address Hold Time | 40 | - | 50 | - | ns | (Notes 1, 3) |
| (10) TDVWH | Data Setup Time | 80 | - | 110 | - | ns | (Notes 1, 3) |
| (11) TWHDX | Data Hold Time | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (12) TWLEH | Chip Enable Write Pulse Setup Time | 100 | - | 130 | - | ns | (Notes 1, 3) |
| (13) TELWH | Chip Enable Write Pulse Hold Time | 100 | - | 130 | - | ns | (Notes 1, 3) |
| (14) TWLWH | Write Enable Pulse Width | 100 | - | 130 | - | ns | (Notes 1, 3) |
| (15) TELEL | Read or Write Cycle Time | 280 | - | 350 | - | ns | (Notes 1, 3) |

## NOTES:

1. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load:

1 TTL gate equivalent, $C L=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .
4. $T A V Q V=$ TELQV + TAVEL.

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\bar{W}$ | A | D | Q |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | 7 | H | $v$ | X | 2 | Cycle Begins, Addresses are Latched |
| 1 | L | H | x | x | X | Output Enabled |
| 2 | $L$ | H | X | X | V | Output Valid |
| 3 | ${ }^{-}$ | H | X | X | V | Read Accomplished |
| 4 | H | X | x | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | 7 | H | V | x | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

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 ( $\mathrm{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$ ).

## Timing Waveforms (Continued)



TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}}$ | $\overline{\text { w }}$ | A | D | Q |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | 1 | X | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | $\downarrow$ | X | X | Z | Write Period Begins |
| 2 | L | - | X | V | z | Data is Written |
| 3 | $\xrightarrow{\sim}$ | H | X | X | Z | Write Completed |
| 4 | H | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | 1 | X | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

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 $\overline{\mathrm{E}}$ or $\overline{\mathrm{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 $\vec{E}$. By posi-
tioning the $\bar{W}$ pulse at different times within the $\bar{E}$ low time (TELEH), various types of write cycles may be performed.

If the $\overline{\mathrm{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.

## Test Load Circuit



## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby $\qquad$
- Low Power Operation 20mW/MHz Max.
- Fast Access Time. 180ns Max.
- Data Retention $\qquad$
- TTL Compatible Input/Output
- High Output Drive - 2 TTL Loads
- On-Chip Address Register


## Description

The HM-6508/883 is a $1024 \times 1$ static CMOS RAM fabricated using 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 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/883 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

HM1-6508/883 (CERAMIC DIP) TOP VIEW


| PIN | DESCRIPTION |
| :---: | :--- |
| A | Address Input |
| $\bar{E}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| D | Data Input |
| Q | Data Output |

## Functional Diagram



ALL LINES POSITIVE LOGIC - ACTIVE HIGH THREE STATE BUFFERS: A HIGH $\rightarrow$ OUTPUT ACTIVE ADDRESS LATCHES AND GATED DECODERS: LATCH ON FALLUNG EDGE OF E
GATE ON FALLING EDGE OF $\bar{E}$


Reliability Information

| Thermal Resistance . . Ceramic DIP Packag | $\begin{gathered} \theta_{\mathrm{Ja}} \\ 75^{\circ} \mathrm{C} / \mathrm{w} \end{gathered}$ | $\begin{gathered} \theta_{\mathrm{c}} \\ 15^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ |
| :---: | :---: | :---: |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 0.67 W |
| Gate Count |  | 925 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions



TABLE 1. HM-6508/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & 10 \mathrm{~L}=3.2 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Output High Voltage | VOH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & \mathrm{IOH}=-0.4 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | v |
| Input Leakage Current | II | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Output Leakage Current | loz | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} \\ & \mathrm{VO}=\mathrm{GND} \text { or VCC } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Data Retention Supply Current HM-6508B/883 | ICCDR | $\begin{aligned} & V C C=2.0 \mathrm{~V}, \\ & \bar{E}=V C C, \\ & 10=O m A, \\ & V I=V C C \text { or } G N D \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 5 | $\mu \mathrm{A}$ |
| HM-6508/883 |  |  |  |  | - | 10 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V}, \\ & \text { (Note 2), } \\ & E=1 \mathrm{MHz}, \\ & 10=0 \mathrm{~mA}, \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 4 | mA |
| Standby Supply Current | ICCSB | $\begin{aligned} & \mathrm{VCC}=5.0 \mathrm{~V}, \\ & 10=0 \mathrm{~mA}, \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | $\mu \mathrm{A}$ |

NOTES:

1. All voltages referenced to device GND.
2. Typical derating $1.5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP

TABLE 2. HM-6508/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTES 1, 2) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | HM-6508B/883 |  | HM-6508/883 |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Chip Enable Access Time | (1) TELQV | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 180 | - | 250 | ns |
| Address Access Time | (2) TAVQV | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V}, \text { Note } 3 \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 180 | - | 250 | ns |
| Chip Enable Output Disable Time | (3) TELQX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | ns |
| Write Enable Output Disable Time | (4) TWLQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 120 | - | 160 | ns |
| Chip Enable Output Disable Time | (5) TEHQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 120 | - | 160 | ns |
| Chip Enable Pulse Negative Width | (6) TELEH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 180 | $\bullet$ | 250 | - | ns |
| Chip Enable Pulse Positive Width | (7) TEHEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 100 | - | ns |
| Address Setup Time | (8) TAVEL | $\begin{aligned} & V C C=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Address Hold Time | (9) TELAX | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 40 | $\bullet$ | 50 | - | ns |
| Data Setup Time | (10) TDVWH | $\begin{aligned} & V C C=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 80 | - | 110 | - | ns |
| Data Hold Time | (11) TWHDX | $\begin{aligned} & V C C=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Chip Enable Write Pulse Setup Time | (12) TWLEH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 130 | - | ns |
| Chip Enable Write Pulse Hold Time | (13) TELWH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 130 | - | ns |
| Write Enable Pulse Width | (14) TWLWH | $\begin{aligned} & V C C=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 130 | - | ns |
| Read or Write Cycle Time | (15) TELEL | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 280 | - | 350 | - | ns |

NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent, $C L=50 \mathrm{pF}(\mathrm{min})$ - for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
3. TAVQV = TELQV + TAVEL.

Specifications HM-6508/883
TABLE 3. HM-6508/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTE | TEMPERATURE | MIN | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | CI | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}, \mathrm{All}$ <br> Measurements Referenced <br> to Device Ground | 1 | $\mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 6 | pF |
| Output Capacitance | CO | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}$, All <br> Measurements Referenced <br> to Device Ground | 1 | $\mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |

NOTE:

1. The parameters listed in Table 3 are controlled via design or process parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 A, 8 B, 10,11$ |
| Group A | Samples $/ 5005$ | $1,2,3,7,8 A, 8 B, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\mathbf{w}}$ | A | D | 0 |  |
| -1 | H | X | X | X | z | Memory Disabled |
| 0 | 7 | H | $v$ | x | z | Cycle Begins, Addresses are Latched |
| 1 | L | H | X | X | X | Output Enabled |
| 2 | $L$ | H | X | X | V | Output Valid |
| 3 | - | H | X | X | V | Read Accomplished |
| 4 | H | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | H | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

In the HM-6508/883 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, $\vec{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 ( $T=4$ ).

## Timing Waveforms (Continued)

WRITE CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbf{E}}$ | $\overline{\mathbf{w}}$ | A | D | Q |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | 1 | X | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | 1 | X | X | Z | Write Period Begins |
| 2 | L | $\checkmark$ | X | V | Z | Data is Written |
| 3 | $\checkmark$ | H | X | X | Z | Write Completed |
| 4 | H | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | L | X | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

The write cycle is initiated by the falling edge of $\overline{\mathrm{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 $\overline{\mathrm{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 $\vec{E}$. By posi-
tioning the $\bar{W}$ pulse at different times within the $\bar{E}$ low time (TELEH), various types of write cycles may be performed.
If the $\overline{\mathrm{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.

## Test Load Circuit



## Burn-In Circuit

HM-6508/883 CERAMIC DIP


NOTES:
All resistors $47 \mathrm{~kW} \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 12=F 11+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ Min.

## Packaging

16 PIN CERAMIC DIP


LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T16
MATERIALS: Compliant to MIL-M-38510

## Metallization Topology

DIE DIMENSIONS:
$130 \times 150 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 2 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.342 \times 10^{5} \mathrm{~A} \mathrm{~cm}^{2}$
LEAD TEMPERATURE ( 10 seconds soldering): $\leq 300^{\circ} \mathrm{C}$

Metallization Mask Layout
HM-6508/883


SEMICONDUCTOR

## Features

- Low Power Standby $\qquad$
- Low Power Operation $\qquad$
- Fast Access Time. ,
- Data Retention $\qquad$ © 2.0V Min.
- TTL Compatible Input/Output
- High Output Drive - 2 TTL Loads
- High Noise Immunity
- On-Chip Address Register
- Two-Chip Selects for Easy Array Expansion
- Three-State Output


## Description

The HM-6518 is a $1024 \times 1$ static CMOS RAM fabricated using 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 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 overtemperature.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 180ns | 250ns |
| :--- | :--- | :--- | :--- |
| Plastıc DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM3-6518B-9 | HM3-6518-9 |
| Ceramic DIP <br> $*$$/ 883$ | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $\mathrm{HM} 1-6518 \mathrm{~B}-9$ | HM1-6518-9 |

* Respective $/ 883$ specifications are included at the end of this data sheet.


## Pinout

```
18 LEAD DIP TOP VIEW
```



| PIN | DESCRIPTION |
| :---: | :--- |
| A | Address Input |
| $\bar{E}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| S | Chip Select |
| D | Data Input |
| Q | Data Output |

Functional Diagram

aLl lines positive logic - active high THREE STATE BUFFERS: A HIGH $\longrightarrow$ OUTPUT ACTIVE
DATA LATCHES:
LHIGH $\longrightarrow \mathrm{Q}=\mathrm{D}$
a LATCHES ON RISING EDGE OF L
ADDRESS LATCHES AND GATED DECODERS:
LATCH ON FALLING EDGE OF E
GATE ON FALLUNG EDGE OFE $\bar{E}$

## Absolute Maximum Ratings

Supply Voltage
Input, Output or I/O Voltage . . . . . . . . . . . . . GND-0.3V to VCC+0.3V
Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
ESD Classification
Class 1

## Reliability Information

| Thermal Resistance | $\theta_{\text {رa }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $75^{\circ} \mathrm{C} / \mathrm{W}$ | $18^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe | $125^{\circ} \mathrm{C}$ |  |
| ate Count |  | 36 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V Operating Temperature Range
HM-6518B-9, HM-6518-9
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

DC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HM}-6518 \mathrm{~B}-9, \mathrm{HM}-6518-9)$

| PARAMETER |  | SYMBOL |  |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| Standby Supply Current |  |  | ICCSB | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| Operating Supply Current (Note 1) |  | ICCOP | - | 4 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & G N D, V C C=5.5 \mathrm{~V} \end{aligned}$ |
| Data Retention Supply Current | HM-6518B-9 | ICCDR | - | 5 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & \mathrm{GND}, \overline{\mathrm{E}}=\mathrm{VCC} \end{aligned}$ |
|  | HM-6518-9 |  | $\bullet$ | 10 | $\mu \mathrm{A}$ |  |
| Data Retention Supply Voltage |  | VCCDR | 2.0 | $\bullet$ | V |  |
| Input Leakage Current |  | 11 | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or $\mathrm{GND}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| Output Leakage Current |  | IOZ | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| Input Low Voltage |  | VIL | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| Input High Voltage |  | VIH | vcc-2.0 | VCC +0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| Output Low Voltage |  | VOL | - | 0.4 | V | $10=3.2 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| Output High Voltage |  | VOH | 2.4 | - | V | $1 \mathrm{O}=-0.4 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: |
| Input Capacitance (Note 2) | CI | 6 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| Output Capacitance (Note 2) | CO | 10 | pF |  |

NOTES:

1. Typical derating $1.5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
2. Tested at initial design and after major design changes.

AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6518B-9, HM-6518-9)

| PARAMETER | SYMBOL | LIMITS |  |  |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-6518B-9 |  | HM-6518-9 |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Chıp Enable Access Time | (1) TELQV | - | 180 | - | 250 | ns | (Notes 1, 3) |
| Address Access Time | (2) TAVQV | - | 180 | - | 250 | ns | (Notes 1, 3, 4) |
| Chip Select Output Enable Time | (3) TSLQX | 5 | 120 | 5 | 160 | ns | (Notes 2, 3) |
| Write Enable Output Disable Time | (4) TWLQZ | - | 120 | - | 160 | ns | (Notes 2, 3) |
| Chip Select Output Disable Time | (5) TSHQZ | - | 120 | - | 160 | ns | (Notes 2, 3) |
| Chip Enable Pulse Negative Width | (6) TELEH | 180 | - | 250 | - | ns | (Notes 1, 3) |
| Chip Enable Pulse Positive Width | (7) TEHEL | 100 | - | 100 | - | ns | (Notes 1, 3) |
| Address Setup Time | (8) TAVEL | 0 | - | 0 | - | ns | (Notes 1, 3) |
| Address Hold Time | (9) TELAX | 40 | - | 50 | - | ns | (Notes 1, 3) |
| Data Setup Time | (10) TDVWH | 80 | - | 110 | - | ns | (Notes 1, 3) |
| Data Hold Time | (11) TWHDX | 0 | - | 0 | - | ns | (Notes 1, 3) |
| Chip Select Write Pulse Setup Time | (12) TWLSH | 100 | - | 130 | - | ns | (Notes 1, 3) |
| Chip Enable Write Pulse Setup Time | (13) TWLEH | 100 | - | 130 | - | ns | (Notes 1, 3) |
| Chıp Select Write Pulse Hold Time | (14) TSLWH | 100 | - | 130 | - | ns | (Notes 1, 3) |
| Chip Enable Write Pulse Hold Tıme | (15) TELWH | 100 | - | 130 | - | ns | (Notes 1, 3) |
| Write Enable Pulse Width | (16) TWLWH | 100 | - | 130 | - | ns | (Notes 1, 3) |
| Read or Write Cycle Time | (17) TELEL | 280 | - | 350 | - | ns | (Notes 1, 3) |

NOTES:

1. Input pulse levels: 0.8 V to VCC -2.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})-$ for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .
4. $T A V Q V=T E L Q V+T A V E L$.

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{51}$ | $\overline{\mathbf{w}}$ | A | D | Q |  |
| -1 | H | H | X | X | X | Z | Memory Disabled |
| 0 | $\checkmark$ | X | H | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | L | H | X | X | X | Output Enabled |
| 2 | L | L | H | X | X | V | Output Valid |
| 3 | $\checkmark$ | L. | H | X | X | V | Output Latched |
| 4 | H | H | X | X | X | Z | Device Disabled, Prepare for Next Cycle (Same as -1) |
| 5 | 7 | X | H | v | x | z | Cycle Ends, Next Cycle Begins (Same as 0) |

NOTE: 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}$ ( $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{\mathbf{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 $\overline{\mathrm{E}}$ the data will be unlatched.

## Timing Waveforms (Continued)

 WRITE CYCLE

TRUTH TABLE

| TIME <br> REFERENCE | INPUTS |  |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
|  | $\overline{\mathbf{E}}$ | $\overline{\mathbf{S} 1}$ | $\overline{\mathbf{W}}$ | A | D |  |  |
| -1 | H | X | X | X | X | Z | Memory Disabled |
| 0 | L | X | X | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | L | L | X | V | Z | Write Mode has Begun |
| 2 | L | - | L | X | V | Z | Data is Written |
| 3 | $\nearrow$ | X | X | X | X | Z | Write Completed |
| 4 | H | X | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | L | X | X | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

NOTE: 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 is initiated by the falling edge of $\overline{\mathrm{E}}$ which latches the address information into the on chip registers. The write portion of the cycle is defined as $\overline{\mathrm{E}}, \overline{\mathrm{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 $\overline{\mathrm{E}}, \overline{\mathrm{W}}, \overline{\mathrm{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 risina edqe 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 (TWLQZ) after $\bar{W}$ goes low before applying input data to the bus. This will insure that the output buffers are not active.

## Test Load Circuit



## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby

50 $\mu \mathrm{W}$ Max.

- Low Power Operation 20mW/MHz Max.
- Fast Access Time

180ns Max.

- Data Retention © 2.0V Min.
- TTL Compatible Input/Output
- High Output Drive - 2 TTL Loads
- High Noise Immunity
- On-Chip Address Register
- Two-Chip Selects for Easy Array Expansion
- Three-State Output


## Description

The HM-6518/883 is a $1024 \times 1$ static CMOS RAM fabricated using 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 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/883 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.


```
Absolute Maximum Ratings
Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0V
Input, Output or I/O Voltage
    GND-0.3V to VCC}+0.3\textrm{V
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . +1750
    . }6\mp@subsup{5}{}{\circ}\textrm{C}\mathrm{ to +150}\mp@subsup{0}{}{\circ}\textrm{C
Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . +300
ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1
```

Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $75^{\circ} \mathrm{C} / \mathrm{N}$ | $18^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe | $125^{\circ} \mathrm{C}$ |  |
| Ceramic DIP Package |  | 0.67W |
| Gate Count . |  | 1936 Gate |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

| Operating Voltage Range | +4.5 V to +5.5 V | Input High Voltage. . . . . . . . . . . . . . . . . . . . . . VCC - 2.0V to VCC |
| :---: | :---: | :---: |
| Operating Temperature Range. | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Input Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . . 40ns Max |
| Input Low Voltage. | . . 0 V to +0.8 V |  |

TABLE 1. HM-6518/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (Note 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Output Low Voltage | VOL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & 10 \mathrm{~L}=3.2 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Output High Voltage | VOH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & 1 \mathrm{OH}=-0.4 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | v |
| Input Leakage Current | II | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Output Leakage Current | 102 | $\begin{aligned} & V C C=5.5 V \\ & V O=G N D \text { or } V C C \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Data Retention Supply Current HM-6518B/883 | ICCDR | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, \\ & \mathrm{E}=\mathrm{VCC}, \\ & 10=O \mathrm{~mA}, \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 5 | $\mu \mathrm{A}$ |
| HM-6518/883 |  |  |  |  | - | 10 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & (\mathrm{Note} 2), \\ & \mathrm{E}=1 \mathrm{MHz}, \\ & 10=0 \mathrm{~mA}, \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 4 | mA |
| Standby Supply Current | ICCSB | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & 10=0 \mathrm{~mA}, \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | $\mu \mathrm{A}$ |

NOTES:

1. All voltages referenced to device GND.
2. Typical derating $1.5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP

Specifications HM-6518/883
TABLE 2. HM-6518/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (Notes 1, 2) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | HM-6518B/883 |  | HM-6518/883 |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Chip Enable Access Time | (1) TELQV | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 180 | - | 250 | ns |
| Address Access Time | (2) TAVQV | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \text {, Note } 3 \end{aligned}$ | 9, 10, 11 | ${ }^{-55}{ }^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 180 | - | 250 | ns |
| Chip Select Output Enable Time | (3) TSLQX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | ns |
| Write Enable Output Disable Time | (4) TWLQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 120 | - | 160 | ns |
| Chip Select Output Disable Time | (5) TSHQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 120 | - | 160 | ns |
| Chip Enable Pulse Negative Width | (6) TELEH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 180 | - | 250 | - | ns |
| Chip Enable Pulse Positive Width | (7) TEHEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 100 | - | ns |
| Address Setup Time | (8) TAVEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Address Hold Time | (9) TELAX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 40 | - | 50 | - | ns |
| Data Setup Time | (10) TDVWH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 80 | - | 110 | - | ns |
| Data Hold Time | (11) TWHDX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Chip Select Write Pulse Setup Time | (12) TWLSH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | $\bullet$ | 130 | $\bullet$ | ns |
| Chip Enable Write Pulse Setup Time | (13) TWLEH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 130 | - | ns |
| Chip Select Write Pulse Hold Time | (14) TSLWH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 130 | - | ns |
| Chip Enable Write Pulse Hold Time | (15) TELWH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 130 | - | ns |
| Write Enable Pulse Width | (16) TWLWH | $\begin{aligned} & V C C=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 130 | - | ns |
| Read or Write Cycle Time | (17) TELEL | $\begin{aligned} & V C C=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 280 | - | 350 | - | ns |

NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: $-1 T \mathrm{TL}$ gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
3. TAVQV = TELQV + TAVEL.

Specifications HM-6518/883
TABLE 3. HM-6518/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTE | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | Cl | $\mathrm{VCC}=\mathrm{Open}, \mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 6 | pF |
| Output Capacitance | CO | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |

NOTE: 1. The parameters listed in Table 3 are controlled via design or process parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| time REFERENCE | INPUTS |  |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { S1 }}$ | $\overline{\mathbf{w}}$ | A | D | 0 |  |
| -1 | H | H | X | X | X | Z | Memory Disabled |
| 0 | $\checkmark$ | X | H | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | L | H | X | X | X | Output Enabled |
| 2 | L | L | H | X | X | V | Output Valid |
| 3 | $\Gamma$ | L | H | X | X | V | Output Latched |
| 4 | H | H | X | X | X | Z | Device Disabled, Prepare for Next Cycle (Same as -1) |
| 5 | 7 | X | H | v | X | z | Cycle Ends, Next Cycle Begins (Same as 0) |

NOTE: 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/883 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 $\overline{\mathrm{E}}$ the data will be unlatched.

## Timing Waveforms (Continued)



TRUTH TABLE

| TIME <br> REFERENCE | INPUTS |  |  |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
|  | $\overline{\mathbf{E}}$ | $\overline{\mathbf{S} 1}$ | $\overline{\mathbf{W}}$ | $\mathbf{A}$ | D | $\mathbf{Q}$ |  |
| -1 | H | X | X | X | X | Z | Memory Disabled |
| 0 | L | X | X | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | L | L | X | V | Z | Write Mode has Begun |
| 2 | L | - | L | X | V | Z | Data is Written |
| 3 | - | X | X | X | X | Z | Write Completed |
| 4 | H | X | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | L | X | X | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

NOTE: 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 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 $\overline{\mathrm{E}}, \overline{\mathrm{W}}, \overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ 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 $\overline{\mathrm{E}}, \overline{\mathrm{W}}, \overline{\mathrm{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 risina edae of $\overline{\mathrm{E}}$. BV
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 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 (TWLQZ) after $\bar{W}$ goes low before applying input data to the bus. This will insure that the output buffers are not active.

## Test Load Circuit

DUT


## Burn-In Circuit

HM-6518/883 CERAMIC DIP


NOTES:
All resistors $47 \mathrm{~kW} \pm 5 \%$
$\mathrm{F} 0=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1 \div 2, F 3=F 2 \div 2 \ldots F 12=F 11+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
VIH $=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ Min.
Packaging


* INCREASE MAX LIMIT BY . 003 INCHES MEASURED AT CENTER OF FLAT FOR
- SOLDER FINISH

LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T18
MATERIALS: Compliant to MIL-M-38510

## Metallization Topology

DIE DIMENSIONS:
$130 \times 150 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 2 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.342 \times 10^{5} \mathrm{Alcm}^{2}$

## Metallization Mask Layout

## HM-6518/883



HARRIS
SEMICONDUCTOR
HM-6551

$256 \times 4$ CMOS RAM

## Features

- Low Power Standby $\qquad$
- Low Power Operation $\qquad$
- Fast Access Time $\qquad$ 220ns Max.
- Data Retention © 2.0V Min.
- TTL Compatible Input/Output
- High Output Drive - 1 TTL Load
- Internal Latched Chip Select
- High Noise Immunity
- On-Chip Address Register
- Latched Outputs
- Three-State Output


## Description

The HM-6551 is a $256 \times 4$ static CMOS RAM fabricated using 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 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-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 overtemperature.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 220ns | 300 ns |
| :--- | :--- | :--- | :--- |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $\mathrm{HM} 3-6551 \mathrm{~B}-9$ | $\mathrm{HM} 3-6551-9$ |
| Ceramic DIP <br> $*$ 883 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $\mathrm{HM} 1-6551 \mathrm{~B}-9$ | $\mathrm{HM} 1-6551-9$ |

* Respective $/ 883$ specifications are included at the end of this data sheet.


## Pinout

22 LEAD DIP TOP VIEW

| A3 1 | 22 vcc |
| :---: | :---: |
| A2 2 | 21 A4 |
| A1 3 | 20 w |
| A0 4 | 19 S1 |
| A5 5 | 18 E |
| A6 6 | 17 s 2 |
| A7 7 | $16{ }^{16}$ |
| GND 8 | 15 D3 |
| Do 9 | 14.02 |
| 0010 | 13 D 2 |
| D1 11 | 12 Q 1 |


| PIN | DESCRIPTION |
| :---: | :--- |
| $\mathbf{A}$ | Address Input |
| $\overline{\mathrm{E}}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| $\overline{\mathrm{S}}$ | Chip Select |
| $\mathbf{D}$ | Data Input |
| $\mathbf{Q}$ | Data Output |

## Functional Diagram



SELECT LATCH:
LLOW - $Q=D$
Q LATCHES ON RISING EDGE OFL
ADDRESS LATCHES AND GATED DECODERS: LATCH ON FALLING EDGE OF $\bar{E}$ GATE ON FALLING EDGE OF E

ALL LINES POSITIVE LOGIC-ACTIVE HIGH THREE STATE BUFFERS:

A HIGH - OUTPUT ACTIVE
dATA LATCHES:
LHIGH $\rightarrow \quad Q=0$
Q LATCHES ON FALLING EDGE OF L

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | 7.0V |
| Input, Output or I/O Voltage | GND-0.3V to VCC +0.3 V |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{c}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $60^{\circ} \mathrm{C} / \mathrm{N}$ | $15^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 0.83W |
| Gate Count |  | 1930 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range. +4.5 V to +5.5 V Operating Temperature Range HM-6551B-9, HM-6551-9 . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

DC Electrical Specifications $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6551B-9, HM-6551-9)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSB | Standby Supply Current | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| ICCOP | Operating Supply Current (Note 1) | - | 4 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, 1 O=O \mathrm{~mA}, \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \overline{\mathrm{~W}}=\mathrm{GND}, \end{aligned}$ |
| ICCDR | Data Retention Supply Current | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & \mathrm{GND}, \overline{\mathrm{E}}=\mathrm{VCC} \end{aligned}$ |
| vCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| 1 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage | vCC-2.0 | VCC+0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $10=1.6 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH | Output High Voltage | 2.4 | - | V | $10=-0.4 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CI | Input Capacitance (Note 2) | 6 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| CO | Output Capacitance (Note 2) | 10 | pF |  |

## NOTES:

1. Typical derating $1.5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
2. Tested at initial design and after major design changes.

Specifications HM-6551
AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6551B-9, HM-6551-9)

| SYMBOL | PARAMETER | LIMITS |  |  |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-6551B-9 |  | HM-6551-9 |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) TELQV | Chip Enable Access Time | - | 220 | - | 300 | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access Time | - | 220 | - | 300 | ns | (Notes 1, 3, 4) |
| (3) TS1LQX | Chip Select 1 Output Enable Time | 5 | 130 | 5 | 150 | ns | (Notes 2, 3) |
| (4) TWLQZ | Write Enable Output Disable Time | - | 130 | - | 150 | ns | (Notes 2, 3) |
| (5) TS1HQZ | Chip Select 1 Output Disable Time | - | 130 | - | 150 | ns | (Notes 2, 3) |
| (6) TELEH | Chip Enable Pulse Negative Width | 220 | - | 300 | - | ns | (Notes 1, 3) |
| (7) TEHEL | Chip Enable Pulse Positive Width | 100 | - | 100 | - | ns | (Notes 1, 3) |
| (8) TAVEL | Address Setup Time | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (9) TS2LEL | Chip Select 2 Output Disable Tıme | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (10) TELAX | Address Hold Time | 40 | - | 50 | - | ns | (Notes 1, 3) |
| (11) TELS2X | Chip Select 2 Hold Time | 40 | - | 50 |  |  | (Notes 1, 3) |
| (12) TDVWH | Data Setup Time | 100 | - | 150 | - | ns | (Notes 1, 3) |
| (13) TWHDX | Data Hold Time | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (14) TWLSTH | Chip Select 1 Write Pulse Setup Time | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (15) TWLEH | Chip Enable Write Pulse Setup Tıme | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (16) TS1LWH | Chip Select 1 Write Pulse Hold Time | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (17) TELWH | Chip Enable Write Pulse Hold Time | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (18) TWLWH | Write Enable Pulse Width | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (19) TELEL | Read or Write Cycle Time | 320 | - | 400 | $\bullet$ | ns | (Notes 1, 3) |

NOTES:

1. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $V C C=4.5 \mathrm{~V}$ and 5.5 V .
4. $T A V Q V=$ TELQV + TAVEL.

## Timing Waveforms

## READ CYCLE



| time REFERENCE | INPUTS |  |  |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { S1 }}$ | $\overline{\text { S2 }}$ | $\bar{W}$ | A | D | Q |  |
| -1 | H | H | X | X | X | X | Z | Memory Disabled |
| 0 | $\downarrow$ | X | L | H | V | X | Z | Addresses and $\overline{\mathrm{S} 2}$ are Latched, Cycle Begins |
| 1 | L | L | x | H | x | X | X | Output Enabled but Undefined |
| 2 | L | L | X | H | X | X | V | Data Output Valid |
| 3 | $\sim$ | L | X | H | X | X | V | Outputs Latched, Valid Data, S2 Unlatches |
| 4 | H | H | X | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | X | L | H | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

The HM-6551 Read Cycle is initiated by the falling edge of $\overline{\mathrm{E}}$. This signal latches the input address word and $\overline{\mathrm{S} 2}$ into on chip registers providing the minimum setup and hold times are met. After the required hold time, these inputs may change state without affecting device operation. $\overline{\text { S} 2 ~ a c t s ~ a s ~ a ~}$ high order address and simplifies decoding. For the output to be read, $\overline{\mathrm{E}}, \overline{\mathrm{S} 1}$ must be low and $\overline{\mathrm{W}}$ must be high. $\overline{\mathrm{S} 2}$ 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 $\bar{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.

## Timing Waveforms (Continued)



TRUTH TABLE

| TIME REfERENCE | INPUTS |  |  |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}}$ | $\overline{\mathbf{S 1}}$ | $\overline{\text { S2 }}$ | $\overline{\text { w }}$ | A | D | 0 |  |
| -1 | H | H | X | X | X | X | Z | Memory Disabled |
| 0 | $\downarrow$ | X | L | X | V | X | Z | Cycle Begins, Addresses and $\overline{\text { S2 }}$ are Latched, |
| 1 | L | L | X | 7 | X | X | Z | Write Period Begins |
| 2 | L | L | X | $\checkmark$ | X | V | Z | Data In is Written |
| 3 | ${ }^{\prime}$ | X | X | H | X | X | Z | Write is Completed |
| 4 | H | H | X | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | X | L | X | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

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}, \bar{S} 1$ being low and $\overline{\mathrm{S} 2}$ being latched 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 $\bar{E}, \bar{W}$, or $\bar{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 $\overline{\mathrm{E}}$ and S1 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 (TWLQZ) must be allowed before applying input data to the bus.

Test Load Circuit


HARRIS
SEMICONDUCTOR

## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby $.50 \mu \mathrm{~W}$ Max.
- Low Power Operation $\qquad$
- Fast Access Time.

220ns Max.

- Data Retention © 2.0V Min.
- TTL Compatible Input/Output
- High Output Drive - 1 TTL Load
- Internal Latched Chip Select
- High Noise Immunity
- On-Chip Address Register
- Latched Outputs
- Three-State Output


## Description

The HM-6551/883 is a $256 \times 4$ static CMOS RAM fabricated using 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 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-6551/883 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

HM1-6551/883 (CERAMIC DIP) TOP VIEW


| PIN | DESCRIPTION |
| :--- | :--- |
| A | Address Input |
| $\overline{\mathrm{E}}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| $\bar{S}$ | Chip Select |
| D | Data Input |
| Q | Data Output |

Functional Diagram


SELECT LATCH:
L LOW $\rightarrow \mathbf{Q}=\mathbf{D}$
Q LATCHES ON RISING EDGE OF L
ADDRESS LATCHES AND GATED DECODERS:
LATCH ON FALLING EDGE OF $\bar{E}$
GATE ON FALLING EDGE OF $\bar{E}$

ALL LINES POSITIVE LOGIC-ACTIVE HIGH THREE STATE BUFFERS: A HIGH - OUTPUT ACTIVE DATA LATCHES:

LHIGH - $Q=D$
Q LATCHES ON FALLING EDGE OF L

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +7.0V |
| Input, Output or I/O Voltage | GND-0.3V to VCC +0.3 V |
| Storage Temperature Range | ..$^{65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}}$ |
| Junction Temperature . | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Reliability Information
Thermal Resistance
Ceramic DIP Package
....

$\theta_{j c}$
Maximum Package Power Dissipation at $125^{\circ}$
Ceramic DIP Package $15^{\circ} \mathrm{C} / \mathrm{W}$ Gate Count . . 0.83W 1930 Gates

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range. $\qquad$ +4.5 V to +5.5 V
Operating Temperature Range. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Input Low Voltage 0 V to +0.8 V

Input High Voltage. . . . . . . . . . . . . . . . . . . . . . . . . .VCC-2.0V to VCC Input Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . . . . 40ns Max.

TABLE 1. HM-6551/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Output Low Voltage | VOL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & 10 \mathrm{~L}=1.6 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Output High Voltage | VOH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & 1 \mathrm{OH}=-0.4 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Input Leakage Current | 11 | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Output Leakage Current | 102 | $\begin{aligned} & V C C=5.5 \mathrm{~V}, \\ & V O=G N D \text { or } V C C \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Data Retention Supply Current | ICCDR | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC} \\ & \mathrm{IO}=0 \mathrm{~mA}, \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V},(\text { Note } 2) \\ & \bar{E}=1 \mathrm{MHz}, 10=0 \mathrm{~mA} \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 4 | mA |
| Standby Supply Current | ICCSB | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & 10=0 \mathrm{~mA} \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | $\mu \mathrm{A}$ |

NOTES:

1. All voltages referenced to device GND.
2. Typical derating $1.5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.

Specifications HM-6551/883
TABLE 2. HM-6551/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL |  | (NOTES 1, 2) CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | HM-6551B/883 |  |  | HM-6551/883 |  |  |
|  |  |  | MIN |  |  | MAX | MIN | MAX |  |
| Chip Enable Access Time |  | TELQV |  | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 220 | - | 300 | ns |
| Address Access Time | (2) | TAVQV |  | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V}, \text { Note } 3 \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 220 | - | 300 | ns |
| Chip Select 1 Output Enable Time | (3) | TS1LQX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | ns |
| Write Enable Output Disable Time | (4) | TWLQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{and} \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 130 | - | 150 | ns |
| Chip Select 1 Output Disable Time | (5) | TS1HQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 130 | $\bullet$ | 150 | ns |
| Chip Enable Pulse Negative Width | (6) | TELEH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 220 | - | 300 | - | ns |
| Chip Enable Pulse Postive Width | (7) | TEHEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 100 | - | ns |
| Address Setup Time | (8) | TAVEL | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Chip Select 2 Setup Time | (9) | TS2LEL | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | $\bullet$ | ns |
| Address Hold Time | (10) | TELAX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 40 | - | 50 | $\bullet$ | ns |
| Chip Select 2 Hold Time | (11) | TELS2X | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{and} \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 40 | - | 50 | $\bullet$ | ns |
| Data Setup Time | (12) | TDVWH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | - | 150 | $\bullet$ | ns |
| Data Hold Time | (13) | TWHDX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | $\bullet$ | ns |
| Chip Select 1 Write Pulse Setup Time | (14) | TWLS1H | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{and} \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 180 | - | ns |
| Chip Enable Write Pulse Setup Time | (15) | TWLEH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 180 | - | ns |
| Chip Select 1 Write Pulse Hold Time | (16) | TS1LWH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{and} \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 180 | - | ns |
| Chip Enable Write Pulse Hold Time | (17) | TELWH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 180 | - | ns |
| Write Enable Pulse Width | (18) | TWLWH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{and} \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 180 | - | ns |
| Read or Write Cycle Time | (19) | TELEL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{and} \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 320 | - | 400 | - | ns |

NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: $\mathrm{IOL}=1.6 \mathrm{~mA}, \mathrm{IOH}=-0.4 \mathrm{~mA}, \mathrm{CL}=50 \mathrm{pF}(\mathrm{min})-$ for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
3. $T A V Q V=$ TELQV + TAVEL.

Specifications HM-6551/883
TABLE 3. HM-6551B/883 AND HM-6551/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTE | TEMPERATURE | MIN | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | Cl | VCC $=$ Open, $\mathrm{f}=1 \mathrm{MHz}$, All <br> Measurements Referenced <br> to Device Ground | 1 | $\mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| Output Capacitance | CO | VCC $=$ Open, $\mathrm{f}=1 \mathrm{MHz}$, All <br> Measurements Referenced <br> to Device Ground | 1 | $\mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | pF |

NOTE:

1. The parameters listed in Table 3 are controlled via design or process parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| time REFERENCE | INPUTS |  |  |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { S1 }}$ | $\overline{\text { S2 }}$ | $\overline{\mathbf{W}}$ | A | D | 0 |  |
| -1 | H | H | X | X | X | X | Z | Memory Disabled |
| 0 | $\downarrow$ | X | L | H | V | X | Z | Addresses and $\overline{\mathrm{S} 2}$ are Latched, Cycle Begins |
| 1 | L | L | x | H | X | X | X | Output Enabled but Undefined |
| 2 | L | L | X | H | x | X | V | Data Output Valid |
| 3 | $\sim$ | L | X | H | X | X | v | Outputs Latched, Valid Data, S2 Unlatches |
| 4 | H | H | X | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | X | L | H | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

The HM-6551/883 Read Cycle is initiated by the falling edge of $\overline{\mathrm{E}}$. This signal latches the input address word and $\overline{\mathrm{S} 2}$ into on chip registers providing the 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, $\bar{E}, \bar{S} 1$ must be low and $\bar{W}$ must be high. $\bar{S} 2$ 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/883 has output data latches that are controlled by $\bar{E}$. On the rising edge of $\bar{E}$ the present data is latched and remains in that state until $\overline{\mathrm{E}}$ falls. Also on the rising edge of $\overline{\mathrm{E}}, \overline{\mathrm{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.

## Timing Waveforms (Continued)

WRITE CYCLE


| time REFERENCE | INPUTS |  |  |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { S1 }}$ | $\overline{\text { S2 }}$ | $\overline{\text { w }}$ | A | D | 0 |  |
| -1 | H | H | X | X | X | X | Z | Memory Disabled |
| 0 | $\downarrow$ | X | L | X | V | X | Z | Cycle Begins, Addresses and $\overline{\text { S2 }}$ are Latched, |
| 1 | L | L | X | $\downarrow$ | X | X | Z | Write Period Begins |
| 2 | L | L | X | $\sim$ | X | V | Z | Data In is Written |
| 3 | - | X | X | H | X | X | Z | Write is Completed |
| 4 | H | H | X | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | X | L | X | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

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 $\overline{\mathrm{E}}, \overline{\mathrm{W}}, \overline{\mathrm{S} 1}$ being low and $\overline{\mathrm{S} 2}$ being latched 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 $\bar{E}$ or $\overline{S 1}$. By
positioning the write pulse at different times within the $\overline{\mathrm{E}}$ and S1 low time (TELEH), various types of write cycles may be performed. If the $\overline{\mathrm{S} 1}$ low time (TS1LS1H) is greater than the 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/883 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 (TWLQZ) must be allowed before applying input data to the bus.

## Test Load Circuit



## Burn-In Circuit

## HM-6551/883 CERAMIC DIP



NOTES:
All resistors $47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 12=F 11+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V $\mathrm{C} 1=0.01 \mu \mathrm{~F}$ Min.

Packaging
22 PIN CERAMIC DIP


* IncRease max limit by 003 inches MEASURED AT CENTER OF FLAT FOR SOLDER FINISH

LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T22

## Metallization Topology

DIE DIMENSIONS:
$132 \times 160 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si-Al
Thickness: $11 \mathrm{k} \AA \pm 2 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY: $1.337 \times 10^{5} \mathrm{Acm}^{2}$

LEAD TEMPERATURE (10 seconds soldering): $\leq 300^{\circ} \mathrm{C}$

## Metallization Mask Layout

HM-6551/883


NOTE: Pin Numbers Correspond to DIP Package Only.

## Features

- Low Power Standby $\qquad$
- Low Power Operation 20mW/MHz Max.
- Fast Access Time

200ns Max.

- Data Retention $\qquad$ © 2.0V Min.
- TTL Compatible Input/Output
- High Output Drive - 1 TTL Load
- On-Chip Address Registers
- Common Data In/Out
- Three-State Output
- Easy Microprocessor Interfacing


## Description

The HM-6561 is a $256 \times 4$ static CMOS RAM fabricated using 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 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.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 220ns | 300ns |
| :--- | :--- | :--- | :--- |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM3-6561B-9 | HM3-6561-9 |
| Ceramic DIP <br> $*$$/ 883$ |  |  |  |

* Respective $/ 883$ specifications are included at the end of this data sheet.


## Pinout

|  | 18 LEAD DIP TOP VIEW |  |
| :---: | :---: | :---: |
| A3 1 | $\square$ | 18 vcc |
| A2 2 |  | 1774 |
| A1 3 |  | 16 W |
| A0 4 |  | 15 s1 |
| A5 5 |  | 14 DQ3 |
| A6 6 |  | $13 \mathrm{DQ2}$ |
| A7 7 |  | $12 \mathrm{DQ1}$ |
| GND 8 |  | 11 DQo |
| E 9 |  | 10 S2 |


| PIN | DESCRIPTION |
| :---: | :--- |
| $A$ | Address Input |
| $\bar{E}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| $\bar{S}$ | Chip Select |
| DQ | Data In/Out |

Functional Diagram


ADDRESS LATCHES AND GATED DECODERS:
LATCH ON FALLING EDGE OF $\bar{E}$
GATE ON FALLING EDGE OF $\bar{E}$

ALL LINES POSITIVE LOGIC-ACTIVE HIGH THREE-STATE BUFFERS:

A HIGH - - OUTPUT ACTIVE
DATA LATCHES:
L HIGH $-\mathbf{Q}=\mathbf{D}$
Q LATCHES ON FALLING EDGE OF $L$

## Absolute Maximum Ratings



## Reliability Information

| Thermal Resistance | $\theta_{\text {Ja }}$ | $\theta_{\text {ck }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $74^{\circ} \mathrm{C} / \mathrm{W}$ | $18^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package . |  | . .0.68W |
| Gate Count |  | 1944 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range
Operating Temperature Range
HM-6561B-9, HM6561-9
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
DC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HM}-6561 \mathrm{~B}-9, \mathrm{HM}-6561-9)$

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSB | Standby Supply Current | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| ICCOP | Operating Supply Current (Note 1) | - | 4 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, \mathrm{IO}=0 \mathrm{~mA}, \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \overline{\mathrm{~W}}=\mathrm{GND}, \end{aligned}$ |
| ICCDR | Data Retention Supply Current | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & \mathrm{GND}, \mathrm{E}=\mathrm{VCC} \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or $\mathrm{GND}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| IIOZ | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | V | $V C C=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage | vcc-2.0 | VCC +0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $10=1.6 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH | Output High Voltage | 2.4 | - | V | $10=-0.4 \mathrm{~mA}, \mathrm{VCC}=5.5 \mathrm{~V}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CI | Input Capacitance (Note 2) | 6 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| CIO | Input/Output Capacitance (Note 2) | 10 | pF |  |

## NOTES:

1. Typical derating 1.5 mAMHz increase in ICCOP.
2. Tested at initial design and after major design changes.

Specifications HM-6561
AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HM}-6561 \mathrm{~B}-9, \mathrm{HM}-6561-9)$

| SYMBOL | PARAMETER | LIMTS |  |  |  | UNTTS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-6561B-9 |  | HM-6561-9 |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) TELQV | Chip Enable Access Time | - | 220 | - | 300 | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access Time | - | 220 | - | 300 | ns | (Notes 1, 3, 4) |
| (3) TSLQX | Chip Select Output Enable Time | 5 | 120 | 5 | 150 | ns | (Notes 2, 3) |
| (4) TSHQZ | Chip Select Output Disable Time | - | 120 | - | 150 | ns | (Notes 2, 3) |
| (5) TELEH | Chip Enable Pulse Negative Width | 220 | - | 300 | - | ns | (Notes 1, 3) |
| (6) TEHEL | Chip Enable Pulse Positive Width | 100 | - | 100 | - | ns | (Notes 1, 3) |
| (7) TAVEL | Address Setup Time | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (8) TELAX | Address Hold Time | 40 | - | 50 | - | ns | (Notes 1, 3) |
| (9) TDVWH | Data Setup Time | 100 | - | 150 | - | ns | (Notes 1, 3) |
| (10) TWHDX | Data Hold Time | 0 | - | 0 | - | ns | (Notes 1,3) |
| (11) TWLDV | Write Data Delay Time | 20 | - | 30 | - | ns | (Notes 1, 3) |
| (12) TWLSH | Chip Select Write Pulse Setup Time | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (13) TWLEH | Chip Enable Write Pulse Setup Time | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (14) TSLWH | Chip Select Write Pulse Hold Time | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (15) TELWH | Chip Enable Write Pulse Hold Time | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (16) TWLWH | Write Enable Pulse Width | 120 | - | 180 | - | ns | (Notes 1, 3) |
| (17) TELEL | Read or Write Cycle Time | 320 | - | 400 | - | ns | (Notes 1, 3) |

## NOTES:

1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load:

1 TTL gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .
4. $T A V Q V=T E L Q V+T A V E L$.

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | E | $\overline{51}$ | $\overline{\mathbf{W}}$ | A | DQ |  |
| -1 | H | H | X | X | Z | Memory Disabled |
| 0 | 7 | X | H | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | L | H | X | X | Output Enabled |
| 2 | L | L | H | X | V | Output Valid |
| 3 | $\sim$ | L | H | X | V | Output Latched |
| 4 | H | H | X | X | Z | Device Disabled, Prepare for Next Cycle (Same as -1) |
| 5 | 7 | X | H | V | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

NOTE: 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 $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 $E, \overline{S 1}$ and $\overline{S 2}$ must be low and $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 $E$. On the rising edge of $E$ the present data is latched and remains latched until $\bar{E}$ falls. Either or both $\overline{S 1}$ or $\bar{S} 2$ may be used to force the output buffers into a high impedance state.

## Timing Waveforms (Continued)

WRITE CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { S1 }}$ | $\overline{\text { w }}$ | A | DQ |  |
| -1 | H | H | X | X | X | Memory Disabled |
| 0 | $\downarrow$ | X | X | V | X | Cycle Begins, Addresses are Latched |
| 1 | L | L | L | X | X | Write Period Begins |
| 2 | L | L | $\sim$ | X | V | Data In is Written |
| 3 | $\sim$ | X | H | X | X | Write is Completed |
| 4 | H | H | X | X | X | Prepare for Next Cycle (Same as -1) |
| 5 | 7 | X | X | V | X | Cycle Ends, Next Cycle Begins (Same as 0) |

NOTE: 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 $\vec{E}, \overline{\mathrm{~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 $\overline{\mathrm{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 + TSHWH are meaningless and can be ignored.
Case 2: $\overline{\mathrm{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 data just written. They will not disable until either select goes high (TSHQZ).

|  | IF | OBSERVE | IGNORE |
| :--- | :--- | :--- | :--- |
| CASE 1 | Both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}=$ Low <br> Before $\overline{\mathrm{W}}=$ Low | TWLQZ <br> TWLDV <br> TDVWH | TWLWH |
| CASE 2 | $\bar{W}=$ Low Before Both <br> $\overline{S 1}$ and $\overline{\text { S2 }}=$ Low | TWLWH <br> TDVWH | TWLQZ <br> 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.

HARRIS НМ-6561/883

## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby $\qquad$ $50 \mu \mathrm{~W}$ Max.
- Low Power Operation 20mW/MHz Max.
- Fast Access Time 200ns Max.
- Data Retention © 2.0V Min.
- TTL Compatible Input/Output
- High Output Drive - 1 TTL Load
- On-Chip Address Registers
- Common Data In/Out
- Three-State Output
- Easy Microprocessor Interfacing


## Description

The HM-6561/883 is a $256 \times 4$ static CMOS RAM fabricated using 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 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/883 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

HM1-6561/883 (CERAMIC DIP) TOP VIEW


| PIN | DESCRIPTION |
| :---: | :--- |
| A | Address Input |
| $\bar{E}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| $\bar{S}$ | Chip Select |
| DQ | Data In/Out |

## Functional Diagram



## Absolute Maximum Ratings



## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {g }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $74^{\circ} \mathrm{CN}$ | $18^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 0.68W |
| Gate Count |  | 1944 Gate |

CAUTION: Stresses above those listed in "Absolute Maxımum Ratıngs" may cause permanent damage to the device. This is a stress only ratıng and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

| Operating Voltage Range | +4.5 V to +5.5 V | Input High Voltage. . . . . . . . . . . . . . . . . . . . . . VCC - 2.0V to VCC |
| :---: | :---: | :---: |
| Operating Temperature Range | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Input Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . 40ns Max |
| Input Low Voltage | . . 0 V to +0.8 V |  |

TABLE 1. HM-6561/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Output Low Voltage | VOL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & 1 \mathrm{OL}=1.6 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| Output High Voltage | VOH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & 1 \mathrm{OH}=-0.4 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Input Leakage Current | II | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Input/Output Leakage Current | IIOZ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VIO}=\mathrm{GND} \text { or } \\ & \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Data Retention Supply Current | ICCDR | $\begin{aligned} & v C C=2.0 \mathrm{~V}, \\ & E=v C C, \\ & 10=0 \mathrm{~mA}, \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V}, \\ & \text { (Note 2), } \\ & E=1 \mathrm{MHz}, \\ & \mathrm{~W}=\mathrm{GND}, \\ & \mathrm{VI}=\text { VCC or GND } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 4 | mA |
| Standby Supply Current | ICCSB | $\begin{aligned} & V C C=5.5 \mathrm{~V}, \\ & 10=0 \mathrm{~mA}, \\ & \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | $\mu \mathrm{A}$ |

NOTES:

1. All voltages referenced to device GND.
2. Typical derating 1.5 mAMMz increase in ICCOP.

TABLE 2. HM-6561/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTES 1, 2) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | HM-6561B/883 |  | HM-6561/883 |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Chip Enable Access Time | (1) TELQV | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 220 | - | 300 | ns |
| Address Access Time | (2) TAVQV | $\begin{aligned} & \text { VCC = } 4.5 \text { and } \\ & 5.5 \mathrm{~V} \text {, (Note 3) } \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 220 | - | 300 | ns |
| Chip Select Output Enable Time | (3) TSLQX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | ns |
| Chip Select Output Disable Time | (4) TSHQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 120 | - | 150 | ns |
| Chip Enable Pulse Negative Width | (5) TELEH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 220 | $\bullet$ | 300 | - | ns |
| Chip Enable Pulse Positive Width | (6) TEHEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | $\bullet$ | 100 | - | ns |
| Address Setup Time | (7) TAVEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | $\bullet$ | 0 | - | ns |
| Address Hold Time | (8) TELAX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 40 | - | 50 | - | ns |
| Data Setup Time | (9) TDVWH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 100 | $\bullet$ | 150 | - | ns |
| Data Hold Time | (10) TWHDX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Write Data Delay Time | (11) TWLDV | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 30 | - |  |
| Chip Select Write Pulse Setup Time | (12) TWLSH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | $\bullet$ | 180 | - | ns |
| Chip Enable Write Pulse Setup Time | (13) TWLEH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 180 | - | ns |
| Chip Select Write Pulse Hold Time | (14) TSLWH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | $\bullet$ | 180 | - | ns |
| Chip Enable Write Pulse Hold Time | (15) TELWH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 180 | - | ns |
| Write Enable Pulse Width | (16) TWLWH | $\begin{aligned} & \operatorname{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 180 | - | ns |
| Read or Write Cycle Time | (17) TELEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 320 | - | 400 | - | ns |

## NOTES

1. All voltages referenced to device GND.
2. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: $1 O L=1.6 \mathrm{~mA}, \mathrm{IOH}=-0.4 \mathrm{~mA}, \mathrm{CL}=50 \mathrm{pF}(\mathrm{min})-$ for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
3. $T A V Q V=T E L Q V+T A V E L$.

Specifications HM-6561/883
TABLE 3. HM-6561/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| SYMBOL | PARAMETER | CONDITIONS | NOTE | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Cl | Input Capacitance | $\mathrm{VCC}=\text { Open, } \mathrm{f}=1 \mathrm{MHz}$ <br> All Measurements Referenced to Device Ground | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 8 | pF |
| CO | Output Capacitance | $\mathrm{VCC}=\mathrm{Open}, \mathrm{f}=1 \mathrm{MHz},$ <br> All Measurements Referenced to Device Ground | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |

NOTE:

1. The parameters listed in Table 3 are controlled via design or process parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

Test Load Circuit

TEST HEAD CAPACITANCE,


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

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| TIME <br> REFERENCE | INPUTS |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
|  | E | ST | W | A | DQ |  |
| -1 | H | H | X | X | Z | Memory Disabled |
| $\mathbf{0}$ | L | X | H | V | Z | Cycle Begins, Addresses are Latched |
| $\mathbf{1}$ | L | L | H | X | X | Output Enabled |
| 2 | L | L | H | X | V | Output Valid |
| 3 | N | L | H | X | V | Output Latched |
| 4 | H | H | X | X | Z | Device Disabled, Prepare for Next Cycle (Same as -1) |
| 5 | L | X | H | V | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

NOTE: 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/883 Read Cycle is initiated on the falling edge of $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 E, ST and S2 must be low and $\mathbf{W}$ must be high. The output data will be valid at access time (TELQV).

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

## Timing Waveforms (Continued)

WRITE CYCLE


TRUTH TABLE

| time REFERENCE | INPUTS |  |  |  |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { S1 }}$ | $\overline{\text { w }}$ | A | DQ |  |
| -1 | H | H | X | X | X | Memory Disabled |
| 0 | 7 | X | X | $v$ | X | Cycle Begins, Addresses are Latched |
| 1 | L | L | L | X | x | Write Period Begins |
| 2 | L | L | $\sim$ | x | V | Data In is Written |
| 3 | $\stackrel{\sim}{\sim}$ | X | H | X | X | Write is Completed |
| 4 | H | H | X | X | X | Prepare for Next Cycle (Same as -1) |
| 5 | 7 | x | X | V | X | Cycle Ends, Next Cycle Begins (Same as 0) |

NOTE: 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 $\overline{\mathrm{E}}, \overline{\mathrm{S}}$, $\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, $\mathrm{E}, \mathrm{S} 1, \overline{\mathrm{~S}}$ 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}}$ 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 $\overline{\mathrm{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 $\overline{\mathrm{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 + TSHWH are meaningless and can be ignored.
Case 2: $\overline{\mathrm{W}}$ Falls Before Both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}$ Fall.

If one or both selects are high until $\overline{\mathrm{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 data just written. They will not disable until either select goes high (TSHQZ).

|  | IF | OBSERVE | IGNORE |
| :--- | :--- | :--- | :--- |
| CASE 1 | Both $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 2}=$ Low <br> Before $\overline{\mathrm{W}}=$ Low | TWLQZ <br> TWLDV <br> TDVWH | TWLWH |
| CASE 2 | $\overline{\bar{W}}=$ Low Before Both | TWLWH <br> $\overline{S 1}$ and $\overline{S 2}=$ Low | TDVWH |

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.

## Burn-In Circuit

## HM-6561/883 CERAMIC DIP



NOTES:
All resistors $47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{F} 0=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 12=F 11+2$
$V C C=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
C1 $=0.01 \mu \mathrm{~F}$ Min.

## Packaging

18 PIN CERAMIC DIP


* INCREASE MAX LIMIT BY . 003 INCHES MEASURED AT CENTER OF FLAT FOR
- SOLDER FINISH

LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T18
MATERIALS: Compliant to MIL-M-38510

## Metallization Topology

## DIE DIMENSIONS:

$132 \times 160 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al
Thickness: $11 k \AA \pm 2 k \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$

## DIE ATTACH:

Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.337 \times 10^{5} \mathrm{~A} \mathrm{~cm}^{2}$
LEAD TEMPERATURE (10 seconds soldering):
$\leq 300^{\circ} \mathrm{C}$
Metallization Mask Layout
HM-6561/883


HM-6504

## Features

- Low Power Standby
$125 \mu \mathrm{~W}$ Max.
- Low Power Operation 35mW/MHz Max.
- Data Retention @2.0V Min.
- TTL Compatible Input/Output
- Three-State Output
- Standard JEDEC Pinout
- Fast Access Time. . . . . . . . . . . . . . . . . . 120/200ns Max.
- 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 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 state for use in expanded memory arrays.

Gated inputs allow lower operating current and also eliminate 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.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 120ns | 200ns | 300 ns |
| :---: | :---: | :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM3-6504S-9 | HM3-6504B-9 | HM3-6504-9 |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM1-6504S-9 | HM1-6504B-9 | HM1-6504-9 |
| */883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM1-6504S/883 | HM1-6504B/883 | HM1-6504/883 |
| JAN \# |  | 24501BVA | - | - |
| SMD \# |  | 810240IVA | 8102403VA | 8102405VA |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | - | HM4-6504B-9 | HM4-6504-9 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | - | HM4-6504B-8 | HM4-6504-8 |

*Respective / 883 specifications are included at the end of this data sheet.

## Pinouts

## 18 LEAD DIP

TOP VIEW


| PIN | DESCRIPTION |
| :---: | :--- |
| A | Address Input |
| $\bar{E}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| D | Data Input |
| Q | Data Output |



## Functional Diagram



## Absolute Maximum Ratings



## Reliability Information

| Thermal Resistance . . Ceramic DIP Package | $\begin{gathered} \theta_{\mathrm{ja}} \\ 66^{\circ} \mathrm{C} / \mathrm{w} \end{gathered}$ | $\begin{gathered} \theta_{c}, \\ 12^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ |
| :---: | :---: | :---: |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 0.75W |
|  |  |  |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range
+4.5 V to +5.5 V Operating Temperature Range
HM-6504S-9, HM-6504B-9, HM-6504-9 . . . . . . . . $40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ HM-6504B-8, HM-6504-8 . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HM}-6504 \mathrm{~B}-9, \mathrm{HM}-6504-9)$
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-6504B-8, HM-6504-8)

| SYMBOL | PARAMETER |  | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICCSB | Standby Supply Current | HM-6504-9 | - | 25 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
|  |  | HM-6504-8 | - | 50 | $\mu \mathrm{A}$ |  |
| ICCOP | Operating Supply Current (Note 1) |  | - | 7 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, 1 \mathrm{O}=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{GND}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| ICCDR | Data Retention Supply Current | HM-6504-9 | - | 15 | $\mu \mathrm{A}$ | $10=0 \mathrm{~mA}, \mathrm{VCC}=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}$ |
|  |  | HM-6504-8 | - | 25 | $\mu \mathrm{A}$ |  |
| VCCDR | Data Retention Supply Voltage |  | 2.0 | - | V |  |
| 11 | Input Leakage Current |  | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| IOZ | Output Leakage Current |  | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage |  | -0.3 | 0.8 | V | $V C C=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage |  | vcc-2.0 | VCC+0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage |  | - | 0.4 | V | $1 \mathrm{O}=2.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH1 | Output High Voltage |  | 2.4 | - | V | $1 \mathrm{O}=-1.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 2) |  | VCC -0.4 | - | V | $10=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CI | Input Capacitance (Note 2) | 8 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| CO | Output Capacitance (Note 2) | 10 | pF |  |

NOTES:

1. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
2. Tested at initial design and after major design changes.

Specifications HM-6504
AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6504S-9, HM-6504B-9, HM-6504-9)
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-6504B-8, HM-6504-8)

| SYMBOL |  | PARAMETER | HM-6504S |  | HM-6504B |  | HM-6504 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| (1) | TELQV |  | Chip Enable Access Tıme | - | 120 | - | 200 | - | 300 | ns | (Notes 1, 3) |
| (2) | TAVQV | Address Access Time | - | 120 | - | 220 | - | 320 | ns | (Notes 1, 3, 4) |
| (3) | TELQX | Chip Enable Output Enable Time | 5 | - | 5 | - | 5 | - | ns | (Notes 2, 3) |
| (4) | TEHQZ | Chip Enable Output Disable Time | - | 50 | - | 80 | - | 100 | ns | (Notes 2, 3) |
| (5) | TELEH | Chip Enable Pulse Negative Width | 120 | - | 200 | - | 300 | - | ns | (Notes 1, 3) |
| (6) | TEHEL | Chip Enable Pulse Positive Width | 50 | - | 90 | - | 120 | - | ns | (Notes 1, 3) |
| (7) | TAVEL | Address Setup Time | 0 | - | 20 | - | 20 | - | ns | (Notes 1, 3) |
| (8) | TELAX | Address Hold Time | 40 | - | 50 | - | 50 | - | ns | (Notes 1, 3) |
| (9) | TWLWH | Write Enable Pulse Width | 20 | - | 60 | - | 80 | - | ns | (Notes 1, 3) |
| (10) | TWLEH | Write Enable Pulse Setup Time | 70 | - | 150 | - | 200 | - | ns | (Notes 1, 3) |
| (11) | TWLEL | Early Write Pulse Setup Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (12) | TWHEL | Write EnableRead Mode Setup Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (13) | TELWH | Early Write Pulse Hold Time | 40 | - | 60 | - | 80 | - | ns | (Notes 1, 3) |
| (14) | TDVWL | Data Setup Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (15) | TDVEL | Early Write Data Setup Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (16) | TWLDX | Data Hold Time | 25 | - | 60 | - | 80 | - | ns | (Notes 1, 3) |
| (17) | TELDX | Early Write Data Hold Time | 25 | - | 60 | - | 80 | - | ns | (Notes 1, 3) |
| (18) | TELEL | Read or Write Cycle Time | 170 | - | 290 | - | 420 | - | ns | (Notes 1, 3) |

## NOTES:

1. Input pulse levels: 0.8 V to VCC -2.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load:

1 THL gate equivalent, $C L=50 \mathrm{pF}(\mathrm{min})$ - for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $V C C=4.5 \mathrm{~V}$ and 5.5 V .
4. $T A V Q V=$ TELQV + TAVEL.

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  | OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { w }}$ | A | 0 |  |
| -1 | H | X | X | Z | Memory Disabled |
| 0 | $\downarrow$ | H | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | H | X | X | 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 | 7 | H | V | 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 ( $\mathrm{T}=1$ ) the output becomes
enabled but 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 output buffer and all input and ready the RAM for the next memory cycle ( $T=4$ ).

EARLY WRITE CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
|  | $\bar{E}$ | $\overline{\mathbf{W}}$ | $\mathbf{A}$ | D | $\mathbf{Q}$ |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | Z | L | V | V | Z | Cycle Begins, Addresses are Latched |
| $\mathbf{1}$ | L | X | X | X | Z | Write in Progress Internally |
| 2 | - | X | X | X | Z | Write Completed |
| 3 | H | X | X | X | Z | Prepare for Next Cycle (Same as - 1) |
| 4 | L | 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 $\bar{E}$ ( $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 $\overline{\mathrm{E}}$ returns high ( $\mathrm{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.

## Timing Waveforms (Continued)

LATE WRITE CYCLE


TRUTH TABLE

| time REFERENCE | INPUTS |  |  |  | OUTPUTS | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\mathbf{w}}$ | A | D | Q |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | 1 | H | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | $\ldots$ | X | V | X | Write Begins, Data is Latched |
| 2 | L | H | X | X | X | Write In Progress Internally |
| 3 | $\checkmark$ | H | X | X | X | Write Completed |
| 4 | H | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | 2 | H | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

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.

## Test Load Circuit



HM-6504/883

## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby

125 $\mu$ W Max.

- Low Power Operation . . . . . . . . . . . . . 35mW/MHz Max.
- Data Retention
@2.0V Min.
- TTL Compatible Input/Output
- Three-State Output
- Standard JEDEC Pinout
- Fast Access Time. . . . . . . . . . . . . . . . . . 120/200ns Max.
- 18 Pin Package for High Density
- On-Chip Address Register
- Gated Inputs - No Pull Up or Pull Down Resistors Required


## Description

The HM-6504/883 is a $4096 \times 1$ 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 addresses, data input and data output allowing efficient interfacing with microprocessor systems. The data output can be forced to a high impedance state for use in expanded memory arrays.

Gated inputs allow lower operating current and also eliminate the need for pull up or pull down resistors. The HM-6504/883 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

HM1-6504/883 (CERAMIC DIP) TOP VIEW


| PIN | DESCRIPTION |
| :---: | :--- |
| A | Address Input |
| $\bar{E}$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| D | Data Input |
| $\mathbf{Q}$ | Data Output |

## Functional Diagram



## Absolute Maximum Ratings

| Supply Voltage | 7.0V |
| :---: | :---: |
| Input, Output or l/O Voltage . | GND-0.3V to VCC +0.3 V |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | . . $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

## Reliability Information

Thermal Resistance .................. ${ }^{\theta_{j a}} \quad{ }_{10^{\circ}}{ }^{\prime}$ Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ Ceramic DIP Package 0.75 W

CAUTION: Stresses above those listed in "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

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Input Low Voltage .-0.3 V to +0.8 V Input High Voltage

VCC -2.0 V to $\mathrm{VCC}+0.3 \mathrm{~V}$

TABLE 1. HM-6504/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Output Low Voltage | VOL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & 10 \mathrm{~L}=2 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Output High Voltage | VOH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & 1 O H=-1.0 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Input Leakage Current | 11 | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Output Leakage Current | 102 | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VO}=\mathrm{GND} \text { or VCC } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Data Retention Supply Current | ICCDR | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, \\ & \mathrm{E}=\mathrm{VCC}, \\ & 10=0 \mathrm{~mA}, \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \text { (Note 2), } \\ & \mathrm{E}=1 \mathrm{MHz}, \\ & 10=0 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | mA |
| Standby Supply Current | ICCSB | $\begin{aligned} & \mathrm{VCC}=5.0 \mathrm{~V}, \\ & \mathrm{E}=\mathrm{VCC}-0.3 \mathrm{~V}, \\ & 10=0 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | $\mu \mathrm{A}$ |

NOTES:

1. All voltage referenced to device GND.
2. Typical derating 1.5 mAMMz increase in ICCOP

## Specifications HM-6504/883

TABLE 2. HM-6504/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTES 1, 2) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | Limits |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | HM-6504S/883 |  | HM-6504B/883 |  | HM-6504/883 |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Chip Enable Access Time | (1) TELQV | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | - | 120 | - | 200 | - | 300 | ns |
| Address Access Time | (2) TAVQV | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 55 \mathrm{~V} \text {, Note } 3 \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | - | 120 | - | 220 | - | 320 | ns |
| Chip Enable <br> Pulse Negative <br> Width | (5) TELEH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 120 | - | 200 | - | 300 | - | ns |
| Chip Enable <br> Pulse Positive Width | (6) TEHEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 50 | - | 90 | - | 120 | - | ns |
| Address Setup Time | (7) TAVEL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{and} \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 0 | - | 20 | - | 20 | - | ns |
| Address Hold Time | (8) TELAX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{and} \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 40 | - | 50 | - | 50 | - | ns |
| Write Enable Pulse Width | (9) TWLWH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 20 | - | 60 | - | 80 | - | ns |
| Write Enable Pulse Setup Time | (10) TWLEH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 70 | - | 150 | - | 200 | - | ns |
| Early Write Pulse Setup Time | (11) TWLEL | $\begin{aligned} & V C C=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 0 | - | 0 | - | 0 | - | ns |
| Early Write Pulse Hold Time | (13) TELWH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 40 | - | 60 | $\bullet$ | 80 | - | ns |
| Data Setup Time | (14) TDVWL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 0 | - | 0 | $\bullet$ | 0 | $\cdot$ | ns |
| Early Write Data Setup Time | (15) TDVEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 0 | - | 0 | $\bullet$ | 0 | - | ns |
| Data Hold Time | (16) TWLDX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 25 | - | 60 | - | 80 | - | ns |
| Early Write Data Hold Time | (17) TELDX | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq T_{A} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 25 | - | 60 | - | 80 | - | ns |
| Read or Write Cycle Time | (18) TELEL | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq T_{A} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 170 | - | 290 | - | 420 | - | ns |

NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels: 08 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load1 TTL gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})-$ for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
3. $T A V Q V=T E L Q V+T A V E L$.

TABLE 3. HM-6504/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL |  | CONDITIONS | NOTE | TEMPERATURE | $\frac{\text { HM-6504S/883 }}{\text { LIMITS }}$ |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
|  |  |  | MIN |  |  | MAX |  |
| Input Capacitance | Cl |  |  | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | $\bullet$ | 8 | pF |
| Output Capacitance | CO |  | $\mathrm{VCC}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| Chip Enable Output Disable Tıme | (3) | TELQX | $\mathrm{VCC}=4.5$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | $\bullet$ |  |
| Chip Enable Output Disable Time | (4) | TEHQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } 5.5 \mathrm{~V} \\ & H M-6504 \mathrm{~S} / 883 \end{aligned}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |
|  |  |  | $V C C=4.5 \text { and } 5.5 \mathrm{~V}$ <br> HM-6504B/883 | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 80 | ns |
|  |  |  | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } 5.5 \mathrm{~V} \\ & H M-6504 / 883 \end{aligned}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 100 | ns |
| Write Enable Read Mode Setup Time | (12) | TWHEL | $\mathrm{VCC}=4.5$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | $\bullet$ | ns |
| High Level Output Voltage |  | VOHL | $\mathrm{VCC}=4.5 \mathrm{~V}, 1 \mathrm{O}=-100 \mu \mathrm{~A}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | VCC -0.4 | - | V |

NOTE:

1. The parameters listed in Table 3 are controlled via design or process parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interım Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  | OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | E | $\overline{\text { w }}$ | A | 0 |  |
| -1 | H | X | X | Z | Memory Disabled |
| 0 | 1 | H | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | H | X | X | Output Enabled |
| 2 | L | H | X | V | Output Valid |
| 3 | - | 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 0) |

The address information is latched in the on chip registers on the falling edge of $\overline{\mathrm{E}}(\mathrm{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 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 output buffer and all input and ready the RAM for the next memory cycle ( $T=4$ ).

## EARLY WRITE CYCLE



TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { w }}$ | A | D | 0 |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | 7 | L | V | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | X | X | X | Z | Write in Progress Internally |
| 2 | ${ }^{-}$ | X | X | X | Z | Write Completed |
| 3 | H | X | X | X | Z | Prepare for Next Cycle (Same as - 1) |
| 4 | $\downarrow$ | 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 $\bar{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 $\overline{\mathrm{E}}$ returns high ( $\mathrm{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.

## Timing Waveforms (Continued)

## LATE WRITE CYCLE



TRUTH TABLE

| TIME <br> REFERENCE | INPUTS |  |  |  |  | OUTPUTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
|  | $\overline{\mathbf{E}}$ | $\overline{\mathbf{W}}$ | $\mathbf{A}$ | $\mathbf{D}$ | $\mathbf{Q}$ |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | L | H | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | L | X | V | X | Write Begins, Data is Latched |
| 2 | L | H | X | X | X | Write In Progress Internally |
| 3 | $\boldsymbol{r}$ | H | X | X | X | Write Completed |
| 4 | H | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| $\mathbf{5}$ | L | H | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

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.

## Test Load Circuit



## Burn-In Circuit

## HM-6504/883 CERAMIC DIP



NOTES:
All resistors $47 \mathrm{~kW} \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 12=F 11+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ Min.

## Packaging

18 PIN CERAMIC DIP


* INCREASE MAX LIMIT BY . 003 INCHES MEASURED AT CENTER OF FLAT FOR SOLDER FINISH

LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T18
MATERIALS: Compliant to MIL-M-38510

## Metallization Topology

DIE DIMENSIONS:
$136 \times 169 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - AI
Thickness: $11 \mathrm{k} \AA \pm 2 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.79 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
LEAD TEMPERATURE (10 seconds soldering): $\leq 300^{\circ} \mathrm{C}$

## Metallization Mask Layout



NOTE: Pin Numbers Correspond to DIP Package Only.

CAM $\triangle \rightarrow \rightarrow$
HM-6514

## Features

- Low Power Standby $\qquad$ $125 \mu$ W Max.
- Low Power Operation $\qquad$ . $35 \mathrm{~mW} / \mathrm{MHz}$ Max.
- Data Retention $\qquad$ @2.0V Min.
- TTL Compatible Input/Output
- Common Data Input/Output
- Three-State Output
- Standard JEDEC Pinout
- Fast Access Time.

120/200ns Max.

- 18 Pin Package for High Density
- On-Chip Address Register
- Gated Inputs - No Pull Up or Pull Down Resistors Required


## Description

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 addresses allowing efficient interfacing with microprocessor systems. The data output can be forced to a high impedance state for use in expanded memory arrays.
Gated inputs allow lower operating current and also eliminate the need for pull up or pull down 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.

Ordering Information

| PACKAGE | TEMPERATURE RANGE | 120ns | 200ns | 300ns |
| :---: | :---: | :---: | :---: | :---: |
| Plastic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM3-6514S-9 | HM3-6514B-9 | HM3-6514-9 |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM1-6514S-9 | HM1-6514B-9 | HM1-6514-9 |
| */883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM1-6514S/883 | HM1-6514B/883 | HM1-6514/883 |
| JAN\# |  | 24502BVA | - | - |
| SMD\# |  | 8102402VA | 8102404VA | 8102406VA |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | - | HM4-6514B-9 | HM4-6514-9 |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | - | HM4-6514B-8 | HM4-6514-8 |

* Respective $/ 883$ specifications are included at the end of this data sheet.


## Pinouts



Functional Diagram


## Absolute Maximum Ratings



Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {c }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $66^{\circ} \mathrm{C} / \mathrm{N}$ | $12^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe | $125^{\circ} \mathrm{C}$ |  |
| Ceramic DIP Package |  | .0.75W |
|  |  |  |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . +4.5 V to +5.5 V Operating Temperature Ranges: HM-6514S-9, HM-6514B-9, HM-6514-9 . . . . . . . . $40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ HM-6514B-8, HM-6514-8 . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $V C C=5 V \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6514S-9, HM-6514B-9, HM-6514-9) $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-6514B-8, HM-6514-8)

| SYMBOL |  |  |  |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PARAMETER |  | MIN | MAX |  |  |
| ICCSB | Standby Supply Current | HM-6514-9 | - | 25 | $\mu \mathrm{A}$ | $10=0 \mathrm{~mA}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
|  |  | HM-6514-8 | - | 50 | $\mu \mathrm{A}$ |  |
| ICCOP | Operating Supply Current (Note 1) |  | - | 7 | mA | $\begin{aligned} & \overline{\mathrm{E}}=1 \mathrm{MHz}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{GND}, \\ & \mathrm{VCC}=5.5 \mathrm{~V}, \end{aligned}$ |
| ICCDR | Data Retention Supply Current | HM-6514-9 | - | 15 | $\mu \mathrm{A}$ | $1 \mathrm{O}=0 \mathrm{~mA}, \mathrm{VCC}=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}$ |
|  |  | HM-6514-8 | - | 25 | $\mu \mathrm{A}$ |  |
| VCCDR | Data Retention Supply Voltage |  | 2.0 | $\bullet$ | V |  |
| 11 | Input Leakage Current |  | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or $\mathrm{GND}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| IIOZ | Input/Output Leakage Current |  | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage |  | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage |  | VCC-2.0 | VCC +0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage |  | $\bullet$ | 0.4 | V | $1 \mathrm{O}=2.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH1 | Output High Voltage |  | 2.4 | - | V | $10=-1.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 2) |  | VCC-0.4 | - | V | $1 \mathrm{O}=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| Cl | Input Capacitance (Note 2) | 8 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| ClO | Input/Output Capacitance (Note 2) | 10 | pF |  |

NOTES:

1. Typical derating 5 mAMHz increase in ICCOP.
2. Tested at initial design and after major design changes.

AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(H M-6514 \mathrm{~S}-9, \mathrm{HM}-6514 \mathrm{~B}-9, \mathrm{HM}-6514-9)$
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-6514B-8, HM-6514-8)

| SYMBOL | PARAMETER | LIMITS |  |  |  |  |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-6514S-9 |  | HM-6514B-9 |  | HM-6514-9 |  |  |  |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| (1) TELQV | Chip Enable Access Time | - | 120 | - | 220 | - | 300 | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access Time | - | 120 | - | 220 | - | 320 | ns | (Notes 1, 3, 4) |
| (3) TELQX | Chip Enable Output Enable Time | 5 | - | 5 | - | 5 | - | ns | (Notes 2, 3) |
| (4) TEHQZ | Chip Enable Output Disable Time | - | 50 | - | 80 | - | 100 | ns | (Notes 2, 3) |
| (5) TELEH | Chip Enable Pulse Negative Width | 120 | - | 200 | - | 300 | - | ns | (Notes 1, 3) |
| (6) TEHEL | Chip Enable Pulse Positive Width | 50 | - | 90 | - | 120 | - | ns | (Notes 1, 3) |
| (7) TAVEL | Address Setup Time | 0 | - | 20 | - | 20 | - | ns | (Notes 1, 3) |
| (8) TELAX | Address Hold Time | 40 | - | 50 | - | 50 | - | ns | (Notes 1, 3) |
| (9) TWLWH | Write Enable Pulse Width | 120 | - | 200 | - | 300 | - | ns | (Notes 1, 3) |
| (10) TWLEH | Chip Enable Write Pulse Setup Time | 120 | - | 200 | - | 300 | $\bullet$ | ns | (Notes 1, 3) |
| (11) TELWH | Chip Enable Write Pulse Hold Time | 120 | - | 200 | - | 300 | - | ns | (Notes 1, 3) |
| (12) TDVWH | Data Setup Time | 50 | - | 120 | - | 200 | - | ns | (Notes 1, 3) |
| (13) TWHDX | Data Hold Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (14) TWLDV | Write Data Delay Time | 70 | - | 80 | - | 100 | - | ns | (Notes 1, 3) |
| (15) TWLEL | Early Output High-Z Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (16) TEHWH | Late Output High-Z Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (17) TELEL | Read or Write Cycle Time | 170 | - | 290 | - | 420 | - |  | (Notes 1, 3) |

NOTES:

1. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: $1 \mathrm{~T} L$ gate equivalent, $C L=50 \mathrm{pF}(\mathrm{min})$ - for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .
4. TAVQV = TELQV + TAVEL.

HM-6514

## Timing Waveforms

read cycle


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  | DATA VO DQ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { w }}$ | A |  |  |
| -1 | H | X | X | Z | Memory Disabled |
| 0 | $\downarrow$ | H | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | H | X | X | Output Enabled |
| 2 | L | H | X | V | Output Valid |
| 3 | - | H | X | V | Read Accomplished |
| 4 | H | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | 1 | H | V | 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 throughout the read cycle. After the output data has been read, $\overline{\mathrm{E}}$ may return high $(\mathrm{T}=3)$. This will disable the output buffer and all inputs and ready the RAM for the next memory cycle ( $T=4$ ).

WRITE CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  | DQ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\mathrm{w}}$ | A |  |  |
| -1 | H | X | X | Z | Memory Disabled |
| 0 | L | X | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | L | X | Z | Write Period Begins |
| 2 | L | - | X | V | Data In is Written |
| 3 | ${ }^{\prime}$ | H | X | Z | Write Completed |
| 4 | H | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | X | V | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

## Timing Waveforms (Continued)

## WRITE CYCLE (Continued)

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.

## Case 1: $\overline{\mathrm{E}}$ falls before $\overline{\mathrm{W}}$ 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 three-state after $\overline{\mathrm{E}}$ rises (TEHQZ). 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 $\bar{E}$ and $\bar{W}$ control timing will guarantee that the data outputs will stay disabled throughout the cycle, thus simplifying 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 | $\overline{\bar{E}}$ falls before $\bar{W}$ | TWLDV | TWLEL |
| Case 2 | $\overline{\bar{E}}$ falls after $\bar{W}$ and | 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).

## Test Load Circuit



## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby $\qquad$ $.125 \mu$ W Max.
- Low Power Operation . . . . . . . . . . . . . 35mW/MHz Max.
- Data Retention $\qquad$ @2.0V Min.
- TTL Compatible Input/Output
- Common Data Input/Output
- Three-State Output
- Standard JEDEC Pinout
- Fast Access Time

120/200ns Max.

- 18 Pin Package for High Density
- On-Chip Address Register
- Gated Inputs - No Pull Up or Pull Down Resistors Required


## Pinout

HM1-6514/883 (CERAMIC DIP) TOP VIEW


| PIN | DESCRIPTION |
| :---: | :--- |
| $\mathbf{A}$ | Address Input |
| $\overline{\mathbf{E}}$ | Chip Enable |
| $\overline{\mathbf{W}}$ | Write Enable |
| $\mathbf{D}$ | Data Input |
| $\mathbf{Q}$ | Data Output |

## Functional Diagram




Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 V
Input, Output or I/O Voltage . . . . . . . . . . . . . GND-0.3V to VCC +0.3 V
Storage Temperature Range . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1

Reliability Information

| Thermal Resistance | $\theta_{j a}$ | $\theta_{\text {c }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $66^{\circ} \mathrm{C} / \mathrm{N}$ | $12^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe | $125^{\circ} \mathrm{C}$ |  |
| Ceramic DIP Package |  | 75W |
| Gate Count |  | 910 Gates |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . . . . $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Input Low Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . OV to +0.8 V

Input High Voltage
VCC-2.0V to VCC
Input Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 ns Max.

TABLE 1. HM-6514/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Output Low Voltage | VOL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & 10 \mathrm{~L}=3.2 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Output High Voltage | VOH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & 1 \mathrm{OH}=-1.0 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Input Leakage Current | 11 | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Input/Output Leakage Current | IIOZ | $\begin{aligned} & V C C=5.5 \mathrm{~V} \\ & V I O=G N D \text { or } V C C \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
| Data Retention Supply Current | ICCDR | $\begin{aligned} & V C C=2.0 \mathrm{~V}, \\ & \bar{E}=V C C-0.3 \mathrm{~V}, \\ & 10=0 \mathrm{~mA}, \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\begin{aligned} & V C C=5.5 \mathrm{~V},(\text { Note } 2) \\ & E=1 \mathrm{MHz} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 7 | mA |
| Standby Supply Current | ICCSB | $\begin{aligned} & V C C=5.5 \mathrm{~V}, \\ & \mathrm{E}=\mathrm{VCC-0.3V,} \\ & 10=0 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | $\mu \mathrm{A}$ |

NOTES:

1. All voltages referenced to device GND.
2. Typical derating 1.5 mAMHz increase in ICCOP.

Specifications HM-6514/883

TABLE 2. HM-6514/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTES 1, 2) CONDITIONS | GROUP GROUPS | TEMPERATURE | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | HM-6514S/883 |  | HM-6514B/883 |  | HM-6514/883 |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Chip Enable Access Time | (1) TELQV | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | - | 120 | - | 200 | - | 300 | ns |
| Address Access Time | (2) TAVQV | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \text {, Note } 3 \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | - | 120 | - | 220 | - | 320 | ns |
| Chip Enable <br> Pulse Negative <br> Width | (5) TELEH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 120 | - | 200 | $\bullet$ | 300 | - | ns |
| Chip Enable <br> Pulse Positive Width | (6) TEHEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq T_{A} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 50 | - | 90 | $\bullet$ | 120 | - | ns |
| Address Setup Time | (7) TAVEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 0 | - | 20 | - | 20 | - | ns |
| Address Hold Time | (8) TELAX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 40 | - | 50 | - | 50 | - | ns |
| Write Enable Pulse Width | (9) TWLWH | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 120 | - | 200 | - | 300 | - | ns |
| Write Enable <br> Pulse Setup Time | (10) TWLEH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 120 | - | 200 | - | 300 | - | ns |
| Write Enable Pulse Hold Time | (11) TELWH | $\begin{aligned} & \text { VCC }=45 \text { and } \\ & 55 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 120 | - | 200 | - | 300 | - | ns |
| Data Setup Time | (12) TDVWH | $\begin{aligned} & V C C=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 50 | $\cdot$ | 120 | $\bullet$ | 200 | - | ns |
| Data Hold Time | (13) TWHDX | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 0 | - | 0 | - | 0 | - | ns |
| Write Data Delay Time | (14) TWLDV | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 70 | - | 80 | - | 100 | - | ns |
| Early Output High-Z Time | (15) TWLEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 0 | - | 0 | - | 0 | - | ns |
| Late Output High-Z Time | (16) TEHWH | $\begin{aligned} & \text { VCC }=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 0 | - | 0 | - | 0 | - | ns |
| Read or Write Cycle Time | (17) TELEL | $\begin{aligned} & \mathrm{VCC}=4.5 \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{aligned} & -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \\ & \leq+125^{\circ} \mathrm{C} \end{aligned}$ | 170 | - | 290 | - | 420 | - | ns |

NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time is derated by 0.15 ns per pF
3. $T A V Q V=T E L Q V+T A V E L$.

TABLE 3. HM-6514/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTE | TEMPERATURE | $\frac{\text { HM-6514/883 }}{\text { LIMITS }}$ |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | Cl | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 8 | pF |
| Input/Output Capacitance | ClO | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| Chip Enable Output Disable Time | TELQX | $\mathrm{VCC}=4.5$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - |  |
| Chip Enable Output Disable Time | TEHQZ | $V C C=4.5 \text { and } 5.5 \mathrm{~V}$ <br> HM-6514S/883 | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |
|  |  | $V C C=4.5 \text { and } 5.5 \mathrm{~V}$ \| HM-6514B/883 | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 80 | ns |
|  |  | $\mathrm{VCC}=4.5 \text { and } 5.5 \mathrm{~V}$ HM-6514/883 | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 100 | ns |
| High Level Output Voltage | VOH2 | $\mathrm{VCC}=4.5 \mathrm{~V}, 10=-100 \mu \mathrm{~A}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | VCC -0.4 | - | V |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Timing Waveforms

READ CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  | DATA VO DQ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}}$ | $\overline{\text { W }}$ | A |  |  |
| -1 | H | X | X | Z | Memory Disabled |
| 0 | L | H | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | H | X | X | Output Enabled |
| 2 | L | H | X | V | Output Valid |
| 3 | - | H | X | V | Read Accomplished |
| 4 | H | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | H | V | 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 throughout the read cycle. After the output data has been read, $\overline{\mathrm{E}}$ may return high $(\mathrm{T}=3)$. This will disable the output buffer and all inputs and ready the RAM for the next memory cycle ( $T=4$ ).

WRITE CYCLE


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  | DQ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}}$ | $\overline{\text { w }}$ | A |  |  |
| -1 | H | X | X | Z | Memory Disabled |
| 0 | L | X | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | L | X | Z | Write Period Begins |
| 2 | L | $\checkmark$ | X | V | Data In is Written |
| 3 | $\sim$ | H | X | Z | Write Completed |
| 4 | H | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | \% | X | V | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

## Timing Waveforms (Continued)

## WRITE CYCLE (Contınued)

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.

## Case 1: $\overline{\mathrm{E}}$ falls before $\bar{W}$ 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 three-state after $\overline{\mathrm{E}}$ rises (TEHQZ). 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 simplifying 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 | $\overline{\mathrm{E}}$ falls before $\bar{W}$ | TWLDV | TWLEL |
| Case 2 | $\overline{\bar{E}}$ falls after $\bar{W}$ and | 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).

## Test Load Circuit



## Burn-In Circuit

## HM6514/883 CERAMIC DIP



NOTES:
All resistors $47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 12=F 11+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
VIH $=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ Min.

## Packaging

18 PIN CERAMIC DIP


* INCREASE MAX LIMIT BY . 003 INCHES MEASURED AT CENTER OF FLAT FOR - SOLDER FINISH

LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T18
MATERIALS: Compliant to MIL-M-38510

## Metallization Topology

DIE DIMENSIONS:
$136 \times 167 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si-Al
Thickness: $11 k \AA \pm 2 k \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 k \AA \pm 1 \mathrm{k} \AA$

## DIE ATTACH:

Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.79 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
LEAD TEMPERATURE (10 seconds soldering): $300^{\circ} \mathrm{C}$

Metallization Mask Layout


Pin Numbers Correspond to DIP Package Only.

MWS5114

February 1992

## Features

- Fully Static Operation
- Industry Standard $1024 \times 4$ Pinout (Same as Pinouts for 6514, 2114, 9114, and 4045 Types)
- Common Data Input and Output
- Memory Retention for Standby Battery Voltage as Low as 2 V Min
- All Inputs and Outputs Directly TTL Compatible
- 3 State Outputs
- Low Standby and Operating Power


## Description

The MWS5114 is a 1024 word by 4 bit static random access memory that uses the ion-implanted silicon gate complementary MOS (CMOS) technology. It is designed for use in memory systems where low power and simplicity in use are desirable. This type has common data input and data output and utilizes a single power supply of 4.5 V to 6.5 V .

The MWS5114 is supplied in 18 lead, hermetic, dual-in-line sidebrazed ceramic packages ( $D$ suffix) and in 18 lead dual-in-line plastic packages ( $E$ suffix).

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 200ns | 250ns | 300ns |
| :--- | :---: | :--- | :--- | :--- |
| Plastic DIP <br> Burn-In | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | MWS5114E3 <br> MWS5114E3X | MWS5114E2 <br> MWS5114E2X | MWS5114E1 <br> MWS5114E1X |
| Ceramic DIP <br> Burn-In | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | MWS5114D3 <br> MWS5114D3X | MWS5114D2 <br> MWS5114D2X | MWS5114D1 <br> MWS5114D1X |



Functional Block Diagram


| Operational Modes |  |  |  |
| :--- | :---: | :---: | :--- |
| FUNCTION | $\overline{\mathbf{C S}}$ | $\overline{\mathrm{WE}}$ | DATA PINS |
| Read | 0 | 1 | Output: Dependent on <br> data |
| Write | 0 | 0 | Input |
| Not Selected | 1 | x | High Impedance |

## Absolute Maximum Ratings

DC Supply Voltage Range, ( $V_{D D}$ ):
(All Voltages Referenced to $\mathrm{V}_{\text {SS }}$ Terminal) $\ldots \ldots \ldots-0.5 \mathrm{~V}$ to +7 V
Input Voltage Range, All Inputs ............... -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$
DC Input Current, Any One Input.
.$\pm 10 \mathrm{~mA}$
Power Dissipation Per Package ( $\mathrm{P}_{\mathrm{D}}$ )

$$
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+60^{\circ} \mathrm{C} \text { (Package Type E) } \\
& 500 \mathrm{~mW} \\
& \mathrm{~T}_{\mathrm{A}}=+60^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \text { (Package Type E) . . . . . . . Derate Linearly at } \\
& 12 \mathrm{~mW} /{ }^{\circ} \mathrm{C} \text { to } 200 \mathrm{~mW} \\
& \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to }+100^{\circ} \mathrm{C} \text { (Package Type D) . . . . . . . . . . . . . 500 mW } \\
& T_{A}=+100^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \text { (Package Type D) . . . . Derate Linearly at } \\
& 12 \mathrm{~mW} /{ }^{\circ} \mathrm{C} \text { to } 200 \mathrm{~mW}
\end{aligned}
$$

Device Dissipation Per Output Transistor
$\mathrm{T}_{\mathrm{A}}=$ Full Package Temperature Range (All Package Types)

100 mW
Operating Temperature Range $\left(T_{A}\right)$ :
Package Type D.
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Package Type E $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range ( $\mathrm{T}_{\text {sto }}$ ) . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (During Soldering):
At distance $1 / 16 \pm 1 / 32 \mathrm{ln}$. $(1.59 \pm 0.79 \mathrm{~mm})$
from case for 10 s max
$+265^{\circ} \mathrm{C}$

Recommended Operating Conditions at $T_{A}=$ Full Package Temperature Range.For maximum reliability, operating conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: |
|  | ALL TYPES |  |  |
|  | MIN | MAX |  |
| DC Operating Voltage Range | 4.5 | 6.5 | V |
| Input Voltage Range | VSS | VDD | V |

Static Electrical Characteristics At $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{VDD}= \pm 5 \%$, Except as Noted

| CHARACTERISTIC | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { vo } \\ & \text { (V) } \end{aligned}$ | VIN <br> (V) | VDD <br> (V) | MWS5114-3 |  |  | MWS5114-2 |  |  | MWS5114-1 |  |  |  |
|  |  |  |  |  | MIN | $\begin{array}{\|c} \hline \text { (Note 1) } \\ \text { TYP } \end{array}$ | MAX | MIN | (Note 1) TYP | MAX | MIN | (Note 1) TYP | MAX |  |
| Quiescent Device Current | IDD | - | 0,5 | 5 | - | 75 | 100 | $\bullet$ | 75 | 100 | - | 75 | 250 | $\mu \mathrm{A}$ |
| Output Low (Sink) Current | IOL | 0.4 | 0,5 | 5 | 2 | 4 | - | 2 | 4 | - | 2 | 4 | - | mA |
| Output High (Source) Current | IOH | 4.6 | 0,5 | 5 | -0.4 | -1 | - | -0.4 | -1 | $\bullet$ | -0.4 | -1 | - | mA |
| Output Voltage Low-Level | VOL | - | 0,5 | 5 | - | 0 | 0.1 | $\bullet$ | 0 | 0.1 | - | 0 | 0.1 | V |
| Output Voltage High-Level | VOH | - | 0,5 | 5 | 4.9 | 5 | - | 4.9 | 5 | - | 4.9 | 5 | - | V |
| Input Low Voltage | VIL | $\begin{aligned} & 0.5, \\ & 4.5 \end{aligned}$ | - | 5 | - | 1.2 | 0.8 | $\cdot$ | 1.2 | 0.8 | - | 1.2 | 0.8 | V |
| Input High Voltage | VIH | $\begin{aligned} & 0.5, \\ & 4.5 \end{aligned}$ | - | 5 | 2.4 | - | - | 2.4 | - | - | 2.4 | $\bullet$ | - | V |
| Input Leakage Current (Note 2) | IIN | - | 0,5 | 5 | - | $\pm 0.1$ | $\pm 5$ | - | $\pm 0.1$ | $\pm 5$ | - | $\pm 0.1$ | $\pm 5$ | $\mu \mathrm{A}$ |
| Operating Current (Note 3) | IDD1 | - | 0,5 | 5 | - | 4 | 8 | - | 4 | 8 | - | 4 | 8 | mA |
| 3-State Output Leakage Current (Note 4) | IOUT | 0,5 | 0,5 | 5 | - | $\pm 0.5$ | $\pm 5$ | - | $\pm 0.5$ | $\pm 5$ | - | $\pm 0.5$ | $\pm 5$ | $\mu \mathrm{A}$ |
| Input Capacitance | CIN | - | $\cdot$ | - | $\cdot$ | 5 | 7.5 | - | 5 | 7.5 | - | 5 | 7.5 | pF |
| Output Capacitance | COUT | - | $\cdot$ |  | - | 10 | 15 | - | 10 | 15 | - | 10 | 15 | pF |

NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal VDD.
2. All inputs in parallel
3. Outputs open circuited; cycle time $=1 \mu \mathrm{~s}$.
4. All outputs in parallel

Dynamic Electrical Characteristics at $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$, input tr, $\mathrm{t}=10 \mathrm{~ns} ; \mathrm{CL}=50 \mathrm{pF}$ and 1 TrL Load

| CHARACTERISTIC | SYMBOL | LIMITS |  |  |  |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MWS5114-3 |  |  | MWS5114-2 |  |  | MWS5114-1 |  |  |  |
|  |  | (Note 1) MIN | $\begin{aligned} & \text { (Note 2) } \\ & \text { TYP } \end{aligned}$ | MAX | $\begin{aligned} & \text { (Note 1) } \\ & \text { MIN } \end{aligned}$ | (Note 2) TYP | MAX | $\begin{gathered} \text { (Note 1) } \\ \text { MIN } \end{gathered}$ | $\begin{gathered} \text { (Note 2) } \\ \text { TYP } \end{gathered}$ | MAX |  |
| READ CYCLE TIMES (FIGURE 1) |  |  |  |  |  |  |  |  |  |  |  |
| Read Cycle | tRC | 200 | 160 | - | 250 | 200 | $\bullet$ | 300 | 250 | - | ns |
| Access from Address | tAA | - | 160 | 200 | - | 200 | 250 | - | 250 | 300 | ns |
| Chip Selection to Output Valid | tco | - | 110 | 150 | - | 150 | 200 | - | 200 | 250 | ns |
| Chip Selection to Output Active | tcx | 20 | 100 | - | 20 | 100 | - | 20 | 100 | - | ns |
| Output 3 State from Deselection | totd | - | 75 | 125 | - | 75 | 125 | - | 75 | 125 | ns |
| Output Hold from Address Change | toha | 50 | 100 | - | 50 | 100 | - | 50 | 100 | - | ns |
| WRITE CYCLE TIMES (FIGURE 2) |  |  |  |  |  |  |  |  |  |  |  |
| Write Cycle | twC | 200 | 160 | $\bullet$ | 250 | 200 | $\cdot$ | 300 | 220 | - | ns |
| Write | tw | 125 | 100 | - | 150 | 120 | $\cdot$ | 200 | 140 | - | ns |
| Write Release | tWR | 50 | 40 | - | 50 | 40 | - | 50 | 40 | $\cdot$ | ns |
| Address to Chip Select Setup Time | tACS | 0 | 0 | - | 0 | 0 | - | 0 | 0 | - | ns |
| Address to Write Setup Time | t $\overline{A W}$ | 25 | 20 | - | 50 | 40 | - | 50 | 40 | $\bullet$ | ns |
| Data to Write Setup Time | tDSU | 75 | 50 | - | 75 | 50 | - | 75 | 50 | - | ns |
| Data Hold from Write | tDH | 30 | 10 | - | 30 | 10 | - | 30 | 10 | - | ns |

NOTES:

1. Time required by a limit device to allow for the indicated function.
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal VDD.


NOTE: $\overline{\mathrm{WE}}$ is high during the Read Cycle. Timing Measurement Ref. Level is 1.5 V

Figure 1. READ CYCLE TIMING WAVEFORMS


NOTE: $\overline{\mathrm{WE}}$ is low during the Write Cycle. Timing Measurement Ref. Level is 1.5 V

FIGURE 2. WRITE CYCLE TIMING WAVEFORMS

Data Retention Characteristics at $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; See Figure 3

| CHARACTERISTIC |  | SYMBOL | TEST CONDITIONS |  | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | VDR <br> (V) | VDD (V) | ALL TYPES |  |  |  |
|  |  | MIN |  | $\begin{aligned} & \text { (Note 1) } \\ & \text { TYP } \end{aligned}$ | MAX |  |
| Minımum Data Retention |  |  | VDR | - | - | 2 | - | - | V |
| Data Retention Quiescent | MWS5114-3 | IDD | 2 | - | - | 25 | 50 | $\mu \mathrm{A}$ |
|  | MWS5114-2 |  | 2 | - | - | 25 | 50 | $\mu \mathrm{A}$ |
|  | MWS5114-1 |  | 2 | - | - | 60 | 125 | $\mu \mathrm{A}$ |
| Chip Deselect to Data Retention Time |  | tCDR | - | 5 | 300 | - | - | ns |
| Recovery to Normal Operation Time |  | tRC | - | 5 | 300 | - | - | ns |
| VDD to VDR Rise and Fall Time |  | tr, tf | 2 | 5 | 1 | - | - | $\mu \mathrm{s}$ |

NOTE: 1. Typical Values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$


FIGURE 3. LOW VDD DATA RETENTION TIMING WAVEFORMS

HM-6516

## Features

- Low Power Standby . . . . . . . . . . . . $275 \mu$ W Max.
- Low Power Operation . . . . . . 55mW/MHz Max.
- Fast Access Time. . . . . . . . . . . 120/200ns Max.
- Industry Standard Pinout
- Single Supply
.5.0V VCC
- TTL Compatible
- Static Memory Cells
- High Output Drive
- On-Chip Address Latches
- Easy Microprocessor Interfacing


## 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, which also gives 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 accommodate 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.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 120ns | 200ns |
| :---: | :---: | :---: | :---: |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM1-6516B-9 | HM1-6516-9 |
| 1883* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM1-6516B/883 | HM1-6516/883 |
| JAN\# |  | $\cdot$ | 29102BJA |
| SMD\# |  | 8403607JA | 8403601JA |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | - | HM4-6516-9 |
| 1883* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM4-6516B/883 | HM4-6516/883 |
| JAN\# |  | - | 29102BXA |
| SMD\# |  | 8403607JA | 8403601ZA |

* Respective $/ 883$ specifications are included at the end of this data sheet.


## Pinouts

```
        24 LEAD DIP
        TOP VIEW
```


TOP VIEW

| PIN | DESCRIPTION |
| :---: | :--- |
| NC | No Connect |
| A0 - A10 | Address Inputs |
| $\bar{E}$ | Chip Enable/Power Down |
| VSS/GND | Ground |
| DQ0 - DQ7 | Data In/Data Out |
| VCC | Power (+5V) |
| $\bar{W}$ | Write Enable |
| $\overline{\mathrm{G}}$ | Output Enable |

Functional Diagram


## Absolute Maximum Ratings

Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 . 7.0 V
Input or Output Voltage Applied for all Grades . . . . . . . GND-0.3V to
$\mathrm{VCC}+0.3 \mathrm{~V}$

## Storage Temperature Range $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

Junction Temperature
$+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
ESD Classification
. . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1 of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range +4.5 V to +5.5 V Operating Temperature Ranges:

HM-6516B-9, HM-6516-9
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
DC Electrical Specifications VCC $=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6516B-9, HM-6516-9)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSB | Standby Supply Current | - | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \\ & \mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{HM}-6516 \mathrm{~B}-9 \end{aligned}$ |
|  |  | - | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \\ & H M-6516-9 \end{aligned}$ |
| ICCOP | Operating Supply Current (Note 1) | - | 10 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, 10=0 \mathrm{~mA}, \overline{\mathrm{G}}=\mathrm{VCC}, \mathrm{VCC}= \\ & 5.5 \mathrm{~V}, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| ICCDR | Data Retention Supply Current | - | 25 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & \mathrm{GND}, \overline{\mathrm{E}}=\mathrm{VCC}, \mathrm{HM}-6516 \mathrm{~B}-9 \end{aligned}$ |
|  |  | - | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & \mathrm{GND}, \overline{\mathrm{E}}=\mathrm{VCC}, \mathrm{HM}-6516-9 \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or $\mathrm{GND}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| IIOZ | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIO}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage | 2.4 | VCC+0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $10=3.2 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH1 | Output High Voltage | 2.4 | - | V | $1 \mathrm{O}=-1.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 2) | VCC-0.4 | - | v | $10=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CI | Input Capacitance (Note 2) | 8 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| CIO | Input/Output Capacitance (Note 2) | 10 | pF |  |

## NOTES:

1. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
2. Tested at initial design and after major design changes.

Specifications HM-6516
AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HM}-6516 \mathrm{~B}-9, \mathrm{HM}-6516-9)$

| SYMBOL | PARAMETER | LIMTTS |  |  |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-6516B-9 |  | HM-6516-9 |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) TELQV | Chip Enable Access Time | - | 120 | $\bullet$ | 200 | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access Time | - | 120 | - | 200 | ns | (Notes 1, 3, 4) |
| (3) TELQX | Chip Enable Output Enable Time | 10 | - | 10 | - | ns | (Notes 2, 3) |
| (4) TWLQZ | Write Enable Output Disable Time | - | 50 | - | 80 | ns | (Notes 2, 3) |
| (5) TEHQZ | Chip Enable Output Disable Time | - | 50 | - | 80 | ns | (Notes 2, 3) |
| (6) TGLQV | Output Enable Output Valid Time | - | 80 | - | 80 | ns | ( Notes 1, 3 |
| (7) TGLQX | Output Enable Output Enable Time | 10 | - | 10 | - | ns | (Notes 2, 3) |
| (8) TGHQZ | Output Enable Output DisableTime | - | 50 | - | 80 | ns | (Notes 2, 3) |
| (9) TELEH | Chip Enable Pulse Negative Width | 120 | - | 200 | - | ns | ( Notes 1, 3 |
| (10) TEHEL | Chip Enable Pulse Positive Width | 50 | - | 80 | - | ns | (Notes 1, 3 |
| (11) TAVEL | Address Setup Time | 0 | - | 0 | - | ns | ( $N$ otes 1, 3 |
| (12) TELAX | Address Hold Time | 30 | - | 50 | - | ns | ( Notes 1, 3 |
| (13) TWLWH | Write Enable Pulse Width | 120 | - | 200 | - | ns | ( Notes 1, 3 |
| (14) TWLEH | Write Enable Pulse Setup Time | 120 | - | 200 | - | ns | (Notes 1, 3 |
| (15) TELWH | Write Enable Pulse Hold Time | 120 | - | 200 | - | ns | ( Notes 1, 3 |
| (16) TDVWH | Data Setup Time | 50 | - | 80 | - | ns | ( Notes 1, 3 |
| (17) TWHDX | Data Hold Time | 10 | $\cdot$ | 10 | - | ns | ( Notes 1, 3 |
| (18) TELEL | Read or Write Cycle Time | 170 | - | 280 | - | ns | (Notes 1, 3 |

NOTES:

1. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .
4. $T A V Q V=$ TELQV + TAVEL.

## Timing Waveforms

## 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 ( $\mathrm{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 $(\mathrm{T}=3)$. This will force the output buffers into a high impedance mode at time ( $\mathrm{T}=4$ ). $\overline{\mathrm{G}}$ is used to disable the output buffers when in a logical " 1 " state ( $\mathrm{T}=-1,0,3,4,5$ ). After ( $\mathrm{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 $\bar{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 of $\overline{\mathrm{E}}$.

Performance Curve
TYPICAL ICCDR vs $\mathrm{T}_{\mathrm{A}}$


HM-6516/883

2K x 8 CMOS RAM

## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby . . . . . . . . . . . . $275 \mu \mathrm{~W}$ Max.
- Low Power Operation $\qquad$ 55mW/MHz Max.
- Fast Access Time. . . . . . . . . . . .120/200ns Max.
- Industry Standard Pinout
- Single Supply $\qquad$ 5.0V VCC
- TTL Compatible
- Static Memory Cells
- High Output Drive
- On-Chip Address Latches
- Easy Microprocessor Interfacing


## Description

The HM-6516/883 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, which also gives fast access times. The pinout of the HM-6516/883 is the popular 24 pin, 8 bit wide JEDEC standard which allows easy memory board layouts, flexible enough to accommodate a variety of PROMs, RAMS, EPROMs, and ROMs.

The HM-6516/883 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

HM1-6516/883 (CERAMIC DIP) TOP VIEW


HM4-6516/883 (CERAMIC LCC) TOP VIEW


| PIN | DESCRIPTION |
| :---: | :--- |
| NC | No Connect |
| AO - A10 | Address Inputs |
| $\bar{E}$ | Chip Enable/Power Down |
| VSS/GND | Ground |
| DQ0 - DQ7 | Data In/Data Out |
| VCC | Power (+5V) |
| $\bar{W}$ | Write Enable |
| $\bar{G}$ | Output Enable |

Functional Diagram



CAUTION: Stresses above those listed in "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.

## Operating Conditions

| Operating Voltag | +4.5 V to +5.5 V | Input High Voltage. . . . . . . . . . . . . . . . . . . . . . . . . . + +2.4V to VCC |
| :---: | :---: | :---: |
| Operating Temperature Range | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Data Retention Supply Voltage . . . . . . . . . . . . . . . . . . . 2.0 l . 4 to to 4.5 V |
| Input Low Voltage | . 0 V to +0.8 V | Input Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . 40 4n |

TABLE 1. HM-6516/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| High Level Output Voltage | VOH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & 10=-1.0 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Low Level Output Voltage | VOL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & 10=3.2 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| High Impedance Output Leakage Current | IIOZ | $\begin{aligned} & \mathrm{VCC}=\overline{\mathrm{G}}=5.5 \mathrm{~V}, \\ & \mathrm{VIO}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Input Leakage Current | 11 | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\begin{aligned} & V C C=\bar{G}=5.5 V,(\text { Note } 2) \\ & f=1 \mathrm{MHz}, V I=G N D \text { or } V C C \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | mA |
| Standby Supply Current | ICCSB1 | $\begin{aligned} & V C C=5.5 \mathrm{~V}, \mathrm{HM}-6516 / 883 \\ & \bar{E}=\mathrm{VCC}-0.3 \mathrm{~V}, \\ & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 100 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{HM}-6516 \mathrm{~B} / 883 \\ & \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}, \\ & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | $\mu \mathrm{A}$ |
| Data Retention Supply Current | ICCDR | $\begin{aligned} & V C C=2.0 \mathrm{~V}, \mathrm{HM}-6516 / 883 \\ & \bar{E}=\mathrm{VCC}-0.3 \mathrm{~V}, \\ & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 50 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & V C C=2.0 \mathrm{~V}, \mathrm{HM}-6516 \mathrm{~B} / 883 \\ & \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}, \\ & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | $\mu \mathrm{A}$ |
| Functional Test | FT | $\mathrm{VCC}=4.5 \mathrm{~V}$ (Note 3) | 7, 8A, 8B | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. All voltages referenced to device GND.
2. Typical derating $1.5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
3. Tested as follows: $f=2 \mathrm{MHz}, \mathrm{VIH}=2.4 \mathrm{~V}, \mathrm{VIL}=0.4 \mathrm{~V}, \mathrm{IOH}=-4.0 \mathrm{~mA}, \mathrm{IOL}=4.0 \mathrm{~mA}, \mathrm{VOH} \quad 1.5 \mathrm{~V}$, and $\mathrm{VOL} \leq 1.5 \mathrm{~V}$.

Specifications HM-6516/883
TABLE 2. HM-6514/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTES 1, 2) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | HM-6516B/883 |  | HM-6516/883 |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Chip Enable Access Time | (1) TELQV | $\mathrm{VCC}=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 120 | - | 200 | ns |
| Address Access Time | (2) TAVQV | $V C C=4.5$ and 5.5 V , (Note 3) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 120 | - | 200 | ns |
| Chip Enable Pulse Negative Width | (9) TELEH | $\mathrm{VCC}=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 200 | - | ns |
| Chip Enable Pulse Positive Width | (10) TEHEL | $\mathrm{VCC}=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | $\bullet$ | 80 | - | ns |
| Address Set-up Time | (11) TAVEL | $\mathrm{VCC}=4.5$ and 5.5 V | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Address Hold Time | (12) TELAX | $\mathrm{VCC}=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 30 | $\bullet$ | 50 | $\bullet$ | ns |
| Write Enable Pulse Width | (13) TWLWH | $V C C=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 200 | - | ns |
| Write Enable Pulse Set-up Time | (14) TWLEH | $\mathrm{VCC}=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 200 | - | ns |
| Chip Selection to End of Write | (15) TELWH | $V C C=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | $\bullet$ | 200 | - | ns |
| Data Set-up Time | (16) TDVWH | $\mathrm{VCC}=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 50 | $\bullet$ | 80 | - | ns |
| Data Hold Time | (17) TWHDX | $\mathrm{VCC}=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 10 | $\bullet$ | 10 | - | ns |
| Read or Write Cycle Time | (18) TELEL | $\mathrm{VCC}=4.5$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 170 | - | 280 | - | ns |

NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times. 5 ns (max), Input and output timing reference level: 15 V ; Output load 1 TTL gate equivalent, $C L=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access tıme is derated by 015 ns per pF .
3. $T A V Q V=T E L Q V+T A V E L$.

Specifications HM-6516/883

## TABLE 3. HM-6516/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | Cl | VCC = Open, $f=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1, 2 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 8 | pF |
|  |  | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1,3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | pF |
| Input/Output Capacitance | ClO | VCC = Open, $f=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1, 2 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
|  |  | VCC = Open, $f=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1, 3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 14 | pF |
| Chip Enable to Output Valid Time | (3) TELQX | $\mathrm{VCC}=4.5$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | ns |
| Write Enable Output Disable Time | (4) TWLQZ | $V C C=4.5 \text { and } 5.5 \mathrm{~V}$ <br> HM-6516/883 | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 80 | ns |
|  |  | VCC $=4.5$ and 5.5 V HM-6516B/883 | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\cdot$ | 50 | ns |
| Chip Enable Output Disable Time | (5) TEHQZ | $\mathrm{VCC}=4.5$ and 5.5 V HM-6516/883 | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 80 | ns |
|  |  | $\begin{aligned} & \text { VCC }=4.5 \text { and } 5.5 \mathrm{~V} \\ & H M-6516 B / 883 \end{aligned}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |
| Output Enable Access Time | (6) TGLQV | $\mathrm{VCC}=4.5$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 80 | ns |
| Output Enable to Output Valid Time | (7) TGLQX | $\mathrm{VCC}=4.5$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | ns |
| Output Disable Time | (8) TGHQZ | $\begin{aligned} & \text { VCC }=4.5 \text { and } 5.5 \mathrm{~V} \\ & \text { HM-6516/883 } \end{aligned}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 80 | ns |
|  |  | $\mathrm{VCC}=4.5$ and 5.5 V HM-6516B/883 | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |

## NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design release and upon design changes which would affect these characteristics.
2. Applies to LCC device types only.
3. Applies to DIP device types only.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples $/ 5005$ | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

## Timing Waveforms

READ CYCLE: HM-6516/883 and HM-6516B/883


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 ( $\mathrm{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: HM-6516/883 and HM-6516B/883I



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 $\bar{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 of $\overline{\mathrm{E}}$.

Test Circuit


## Burn-In Circuits

HM-6516/883 CERAMIC DIP


NOTES:
All resistors $47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
VIH $=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$\mathrm{C} 1=0.01 \mu \mathrm{~F}$ Min.

## Metallization Topology

DIE DIMENSIONS:
$186.6 \times 199.6 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si-Al
Thickness: $9 \mathrm{k} \AA-13 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $7 \mathrm{k} \AA \pm 9 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold/Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max) Cerarnic LCC - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$0.5 \times 10^{5} \mathrm{~A}^{\mathrm{cm}}{ }^{2}$

Metallization Mask Layout
HM-6516/883


## Packaging



LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M38510

COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T24
INCREASE MAX LIMIT BY . 003 INCHES MEASURED AT CENTER OF FLAT FOR SOLDER FINISH

32 PAD CERAMIC LCC


LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, CQCC1-N32

## 2K x 8 Asynchronous CMOS Static RAM

## Features

- Fast Access Time
.70/90ns Max
- Low Standby Current. . 50 5 A Max
- Low Operating Current . 70 mA Max
- Data Retention at 2.0 Volts . $20 \mu \mathrm{~A}$ Max
- TTL Compatible Inputs and Outputs
- JEDEC Approved Pinout (2716, 6116 Type)
- No Clocks or Strobes Required
- Equal Cycle and Access Time
- Single 5 Volt Supply
- Gated Inputs
- No Pull-Up or Pull-Down Resistors Required


## Description

The HM-65162 is a CMOS $2048 \times 8$ Static Random Access Memory manufactured using the Harris Advanced SAlI V process. The device utilizes asynchronous circuit design for fast cycle time and ease of use. The pinout is the JEDEC 24 pin DIP, and 32 pad 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.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 55ns/40 $/ \mathrm{A}^{*}$ | 70ns/20 ${ }^{\text {A }}$ * | $90 \mathrm{~ns} / 40 \mu \mathrm{~A}^{*}$ | $90 \mathrm{~ns} / 300 \mu \mathrm{~A}^{*}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM1-65162S-9 | HM1-65162B-9 | HM1-65162-9 | HM1-65162C-9 |
| 1883** | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | - | HM1-65162B/883 | HM1-65162/883 | HM1-65162C/883 |
| JAN\# |  | - | 29110BJA | 29104BJA | - |
| SMD\# |  | - | 8403606JA | 8403602JA | 8403603JA |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | - | HM4-65162B-9 | HM4-65162-9 | HM4-65162C-9 |
| 1883** | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | - | HM4-65162B/883 | HM4-65162/883 | HM4-65162C/883 |
| JAN\# |  | - | 29110BXA | 29104BXA | - |
| SMD\# |  | - | 8403606ZA | 8403602ZA | 8403603ZA |

* Access Time/Data Retention Supply Current.
** Respective $/ 883$ specifications are included at the end of this data sheet.


## Pinouts <br> 24 LEAD DIP TOP VIEW

| A7 1 | 24 vcc |
| :---: | :---: |
| A6 2 | 23 AB |
| A5 3 | $2{ }^{2} 10$ |
| A4 4 | 21 $\overline{\text { w }}$ |
| A3 5 | 20 G |
| A2 6 | 10 A10 |
| A1 7 | 18 E |
| A0 8 | 17 Da7 |
| D00 9 | 16 D 96 |
| DQ1 10 | 15 DO5 |
| DQ2 11 | 14 DO4 |
| GND 12 | 13 Da3 |

## Functional Diagram



## Absolute Maximum Ratings

Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 V
Input, Output or I/O Voltage . . . . . . . . . . . . . GND-0.3V to VCC +0.3 V
Storage Temperature Range . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
Typical Derating Factor . . . . . . . . . . . 5mAMMz Increase in ICCOP
ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1

Reliability Information

| Thermal Resistance | ${ }^{\theta_{\text {ja }}}$ | $8^{\circ} \mathrm{CNW}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $48^{\circ} \mathrm{C}, \mathrm{W}$ | $8^{\circ} \mathrm{C}$ W |
| Ceramic LCC Package | $85^{\circ} \mathrm{C} / \mathrm{N}$ | $40^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe | $125^{\circ} \mathrm{C}$ |  |
| Ceramic DIP Package |  |  |
| Ceramic LCC Package |  | 0.58 |
|  |  |  |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V Operating Temperature Range HM-65162S-9, HM-65162B-9, HM-65162-9, HM65162C-9
$40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
DC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-65162S-9, HM-65162B-9, HM-65162-9, HM-65162C-9)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSB1 | Standby Supply Current | - | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{HM}-65162 \mathrm{~B}-9,10=0 \mathrm{~mA}, \\ & \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
|  |  | - | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { HM-65162S-9, HM65162-9, } \\ & 1 O=0 \mathrm{~mA}, \bar{E}=\mathrm{VCC}-0.3 \mathrm{~V}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
|  |  | - | 900 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{HM}-65162 \mathrm{C}-9,1 \mathrm{O}=0 \mathrm{~mA}, \\ & \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| ICCSB | Standby Supply Current | - | 8 | mA | $\overline{\mathrm{E}}=2.2 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCEN | Enabled Supply Current | - | 70 | mA | $\overline{\mathrm{E}}=0.8 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCOP | Operating Supply Current (Note 1) | - | 70 | mA | $\begin{aligned} & \overline{\mathrm{E}}=0.8 \mathrm{~V}, \mathrm{IO}=0 \mathrm{~mA}, \mathrm{f}=1 \mathrm{MHz}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| ICCDR | Data Retention Supply Current | - | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{HM}-65162 \mathrm{~B}-9,10=0 \mathrm{~mA}, \\ & \mathrm{VCC}=2.0 \mathrm{~V}, \mathrm{E}=\mathrm{VCC}-0.3 \mathrm{~V} \end{aligned}$ |
|  |  | - | 40 | $\mu \mathrm{A}$ | $\begin{aligned} & H M-65162 \mathrm{~S}-9, \mathrm{HM}-65162-9, \\ & 10=0 \mathrm{~mA}, \mathrm{VCC}=2.0 \mathrm{~V}, \\ & \bar{E}=\text { VCC }-0.3 \mathrm{~V} \end{aligned}$ |
|  |  | - | 300 | $\mu \mathrm{A}$ | $\begin{aligned} & H M-65162 \mathrm{C}-9,1 \mathrm{O}=0 \mathrm{~mA}, \\ & \mathrm{VCC}=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V} \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| IIOZ | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage | 2.2 | VCC +0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $1 \mathrm{O}=4.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH1 | Output High Voltage | 2.4 | - | V | $10=-1.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 2) | vcc-0.4 | - | V | $10=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| Cl | Input Capacitance (Note 2) | 10 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurem snts are <br> referenced to device <br> ClO $\mathrm{Input/Output} \mathrm{Capacitance} \mathrm{(Note} \mathrm{2)}$ |

NOTES: 1. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
2. Tested at initial design and after major design changes.

Specifications HM-65162
AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \%, T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-65162S-9, HM-65162B-9, HM65162-9, HM-65162C-9)

| SYMBOL | PARAMETER | LIMITS |  |  |  |  |  |  |  | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-65162S-9 |  | HM-65162B-9 |  | HM-65162-9 |  | HM-65162C-9 |  |  |  |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |  |

READ CYCLE

| (1) TAVAX | Read Cycle Tıme | 55 | - | 70 | - | 90 | - | 90 | - | ns | (Notes 1, 3) |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (2) TAVQV | Address Access Tıme | - | 55 | - | 70 | - | 90 | - | 90 | ns | (Notes 1, 3, 4) |
| (3) TELQV | Chip Enable Access <br> Time | - | 55 | - | 70 | - | 90 | - | 90 | ns | (Notes 1,3) |
| (4) TELQX | Chip Enable Output <br> Enable Tıme | 5 | - | 5 | - | 5 | - | 5 | - | ns | (Notes 2, 3) |
| (5) TGLQV | Output Enable Access <br> Time | - | 35 | - | 50 | - | 65 | - | 65 | ns | (Notes 1,3) |
| (6) TGLQX | Output Enable Output <br> Enable Tıme | 5 | - | 5 | - | 5 | - | 5 | - | ns | (Notes 2,3) |
| (7) TEHQZ | Chip Enable Output <br> Disable Time | - | 35 | - | 35 | - | 50 | - | 50 | ns | (Notes 2,3) |
| (8) TGHQZ | Output Enable Output <br> Disable Time | - | 30 | - | 35 | - | 40 | - | 40 | ns | (Notes 2,3) |
| (9) TAVQX | Output Hold From <br> Address Change | 5 | - | 5 | - | 5 | - | 5 | - | ns | (Notes 1, 3) |

## WRITE CYCLE

| (10) TAVAX | Write Cycle Time | 55 | - | 70 | - | 90 | - | 90 | - | ns | (Notes 1, 3) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (11) TELWH | Chip Selection to End of Write | 45 | - | 45 | - | 55 | - | 55 | - | ns | (Notes 1, 3) |
| (12) TAVWL | Address Setup Time | 5 | - | 10 | - | 10 | - | 10 | - | ns | (Notes 1, 3) |
| (13) TWLWH | Write Enable Pulse Width | 40 | - | 40 | - | 55 | - | 55 | - | ns | (Notes 1, 3) |
| (14) TWHAX | Write Enable Read Setup Time | 10 | - | 10 | - | 10 | - | 10 | - | ns | (Notes 1, 3) |
| (15) TGHQZ | Output Enable Output Disable Time | - | 30 | - | 35 | - | 40 | - | 40 | ns | (Notes 2, 3) |
| (16) TWLQZ | Write Enable Output Disable Time | - | 30 | - | 40 | - | 50 | - | 50 | ns | (Notes 2, 3) |
| (17) TDVWH | Data Setup Time | 25 | - | 30 | - | 30 | - | 30 | - | ns | (Notes 1, 3) |
| (18) TWHDX | Data Hold Time | 10 | - | 10 | - | 15 | - | 15 | - | ns | (Notes 1, 3) |
| (19) TWHQX | Write Enable Output Enable Time | 0 | - | 0 | - | 0 | $\cdot$ | 0 | - | ns | (Notes 1, 3) |
| (20) TWLEH | Write Enable Pulse Setup Time | 45 | - | 40 | - | 55 | - | 55 | - | ns | (Notes 1, 3) |
| (21) TDVEH | Chip Enable Data Setup Time | 25 | - | 30 | - | 30 | - | 30 | - | ns | (Notes 1, 3) |
| (22) TAVWH | Address Valid to End of Write | 45 | - | 50 | - | 65 | - | 65 | - | ns | (Notes 1, 3) |

## NOTES:

1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent and $C L=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=45$ and 5.5 V .
4. $\operatorname{TAVQV}=T E L Q V+T A V E L$.

## Timing Waveforms

## READ CYCLE



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

## WRITE CYCLE I



NOTE: $\overline{\mathrm{G}}$ is Low throughout Write Cycle

To write, addresses must be stable, $\overline{\mathrm{E}}$ low and $\overline{\mathrm{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 $\overline{\mathrm{E}}$ transitions low simultaneously with the $\bar{W}$ line transitioning low or after the $\bar{W}$ transition, the output will remain in a high impedance state. $\overline{\mathrm{G}}$ is held continuously low.

## Timing Waveforms (Continued)

WRITE CYCLE II


In this write cycle $\overline{\mathrm{G}}$ has control of the output atter 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 $\overline{\mathrm{W}}$ transitions high, the data in can change after TWHDX to complete the write cycle.

## 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 - 0.3 V to VCC +0.3 V .
2. On RAMs which have selects or output enables (e.g., $\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 dissıpation.
3. 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 down transitions.
4. The RAM can begin operation $>55 \mathrm{~ns}$ after VCC reaches the minimum operating voltage ( 4.5 volts).

DATA RETENTION TIMING


## Performance Curve

TYPICAL ICCDR vs TA


## Description

The HM-65162/883 is a CMOS $2048 \times 8$ Static Random Access Memory manufactured using the Harris Advanced SAll V process. The device utilizes asynchronous circuit design for fast cycle time and ease of use. The pinout is the JEDEC 24 pin DIP, and 32 pad 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/883 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 pullup or pull-down resistors.

Pinouts
HM1-65162/883 (CERAMIC DIP) TOP VIEW

| A7 1 | 24 | VCC |
| :---: | :---: | :---: |
| A6 2 | 23 | A8 |
| A5 3 | 22 | A9 |
| A4 4 | 21 | $\bar{W}$ |
| A3 5 | 20 | $\overline{\mathbf{G}}$ |
| A2 6 | 19 | A10 |
| A1 7 | 18 | $\bar{E}$ |
| AO 8 | 17 | DQ7 |
| DOO 9 | 16 | D66 |
| Da1 10 | 15 | DQ5 |
| DQ2 11 | 14 | DQ4 |
| GND 12 | 13 | DQ3 |

HM4-65162/883 CERAMIC LCC) TOP VIEW


PIN NAMES

| PIN | DESCRIPTION |
| :---: | :--- |
| NC | No Connect |
| A0 - A10 | Address Input |
| $\overline{\mathrm{E}}$ | Chip Enable/Power Down |
| VSS/GND | Ground |
| DQ0 - DQ7 | Data in/Data Out |
| VCC | Power (+5V) |
| $\bar{W}$ | Write Enable |
| $\bar{G}$ | Output Enable |

Functional Diagram


| Absolute Maximum Ratings | Reliability Information |
| :---: | :---: |
| Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 l V | Thermal Resistance |
| Input, Output or I/O Voltage . . . . . . . . . . . . . GND-0.3V to VCC+0.3V |  |
| Storage Temperature Range . . . . . . . . . . . . . . . . . $665^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Ceramic LCC Package . . . . . . . . . . . $85^{\circ} \mathrm{CNW} \quad 40^{\circ} \mathrm{C} W$ |
| Junction Temperature. . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ | Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$ | Ceramic DIP Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1W |
| Typical Derating Factor . . . . . . . . . $1.5 \mathrm{~mA} / \mathrm{MHz}^{\text {Increase in }}$ ICCOP | Ceramic LCC Package . . . . . . . . . . . . . . . . . . . . . . . . . . . 0.58 F W |
| ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1 | Gate Count . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26000 Gates |
| CAUTION: Stresses above those listed in "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. |  |
| Operating Conditions |  |
| Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . +4.5 V to + +5.5 V | Input High Voltage. . . . . . . . . . . . . . . . . . . . . . . . . . -2.2V to VCC |
| Operating Temperature Range . . . . . . . . . . . . . . . . $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Data Retention Supply Voltage . . . . . . . . . . . . . . . . . . . 2.0 V to to 4.5 V |
| Input Low Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0 . $\mathrm{V}^{\text {to }}+0.0 .8 \mathrm{~V}$ | Input Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . 40ns Max. |
| Chip Enable High/Low Time . . . . . . . . . . . . . . . . . . . . . 40ns (Min) |  |

TABLE 1. 65162/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| High Level Output Voltage | VOH1 | $\mathrm{VCC}=4.5 \mathrm{~V}, 1 \mathrm{O}=-1.0 \mathrm{~mA}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Low Level Output Voltage | VOL | $\mathrm{VCC}=4.5 \mathrm{~V}, 1 \mathrm{O}=4.0 \mathrm{~mA}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| High Impedance Output Leakage Current | IIOZ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{G}}=2.2 \mathrm{~V}, \text { or } \\ & \overline{\mathrm{E}}=2.2 \mathrm{~V}, \mathrm{VI/O}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Input Leakage Current | II | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \mathrm{VI}=\mathrm{GND} \text { or } \mathrm{VCC} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB1 | $\begin{aligned} & H M-65162 \mathrm{~B} / 883,1 \mathrm{O}=0 \mathrm{~mA}, \\ & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | $\mu \mathrm{A}$ |
|  |  | HM-65162/883, $10=0 \mathrm{~mA}$, $\mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 100 | $\mu \mathrm{A}$ |
|  |  | HM-65162C/883, $10=0 \mathrm{~mA}$, $\mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 900 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, 10=0 \mathrm{~mA}, \\ & \mathrm{E}=2.2 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | mA |
| Operating Supply Current | ICCOP | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{G}}=5.5 \mathrm{~V} \\ & \text { (Note } 2 \text { ), } \mathrm{f}=1 \mathrm{MHz}, \overline{\mathrm{E}}=0.8 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 70 | mA |
| Enable Supply Current | ICCEN | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, 10=0 \mathrm{~mA}, \\ & \mathrm{E}=0.8 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 70 | mA |
| Data Retention Supply Current | ICCDR | $\mathrm{HM}-65162 \mathrm{~B} / 883,1 \mathrm{O}=0 \mathrm{~mA}$, $\mathrm{VCC}=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | $\mu \mathrm{A}$ |
|  |  | HM-65162/883, $10=0 \mathrm{~mA}$, $V C C=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 40 | $\mu \mathrm{A}$ |
|  |  | HM-65162C/883, $10=0 \mathrm{~mA}$, $V C C=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 300 | $\mu \mathrm{A}$ |
| Functional Test | FT | $\mathrm{VCC}=4.5 \mathrm{~V}$ (Note 3) | 7, 8A, 8B | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

## NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels: 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load:
$T \mathrm{TL}$ gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time by 0.15 ns per pF .
3. $T A V Q V=$ TELQV + TAVEL.

Specifications HM-65162/883
TABLE 2. HM-65162/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested.

| PARAMETER | SYMBOL | (NOTES 1, 2 ) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{gathered} \text { HM-65162B } \\ / 883 \end{gathered}$ |  | $\begin{gathered} \text { HM-65162 } \\ / 883 \end{gathered}$ |  | $\begin{gathered} \text { HM-65162C } \\ / 883 \end{gathered}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Read/Write/ Cycle Time | (1) TAVAX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq T_{A} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 70 | - | 90 | - | 90 | - | ns |
| Address <br> Access Time | (2) TAVQV | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{array}{r} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{array}$ | - | 70 | - | 90 | - | 90 | ns |
| Chip Enable Access Time | (3) TELQV | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq T_{A} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | - | 70 | - | 90 | - | 90 | ns |
| Output Enable Access Time | (5) TGLQV | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{array}{r} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{array}$ | - | 50 | - | 65 | - | 65 | ns |
| Chip Selection to End of Write | (11) TELWH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 45 | - | 55 | - | 55 | - | ns |
| Address Setup Time | (12) TAVWL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5V | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 10 | - | 10 | - | 10 | - | ns |
| Write Enable Pulse Write | (13) TWLWH | $\begin{aligned} & \mathrm{vcc}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{array}{r} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{array}$ | 40 | - | 55 | - | 55 | - | ns |
| Write Enable <br> Read Setup <br> Time | (14) TWHAX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 10 | - | 10 | - | 10 | - | ns |
| Data Setup Time | (17) TDVWH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 30 | - | 30 | - | 30 | - | ns |
| Data Hold Time | (18) TWHDX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 10 | - | 15 | - | 15 | - | ns |
| Write Enable Pulse Setup Time | (20) TWLEH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 40 | - | 55 | - | 55 | - | ns |
| Chip Enable <br> Data Setup <br> Time | (21) TDVEH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 30 | - | 30 | - | 30 | $\bullet$ | ns |
| Address Valid to End of Write | (22) TAVWH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \\ & \text { and } 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 50 | - | 65 | $\bullet$ | 65 | - | ns |

NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels' 0.8 V to $\mathrm{VCC}-2.0 \mathrm{~V}$; Input rise and fall times: $5 \mathrm{~ns}(\max )$; Input and output timing reference level: 1.5 V ; Output load. 1 TTL gate equivalent, $C L=50 \mathrm{pF}(\mathrm{min})$ - for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
3. $T A V Q V=T E L Q V+T A V E L$.

Specifications HM-65162/883
TABLE 3. HM-65162/883 ELECTRICAL PERFORMANCE CHARACTERISTICS, A.C. AND D.C.

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{aligned} & \text { HM-65162B/ } \\ & 883 \end{aligned}$ |  | $\begin{gathered} \text { HM-65162/ } \\ 883 \end{gathered}$ |  | $\begin{gathered} \text { HM-65162C/ } \\ 883 \end{gathered}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Input Capacitance | CIN | $\begin{aligned} & \text { VCC }=\text { Open, } \\ & F=1 \mathrm{MHz}, \text { All } \end{aligned}$ <br> Measurements <br> Referenced To Device Ground | 1,2 | $+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
|  |  |  | 1,3 | $+25^{\circ} \mathrm{C}$ | - | 8 | - | 8 | - | 8 | pF |
| I/O Capacitance | $\mathrm{Cl} / \mathrm{O}$ | VCC = Open, $\mathrm{F}=1 \mathrm{MHz}$, All Measurements Referenced To Device Ground | 1,2 | $+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | - | 12 | pF |
|  |  |  | 1, 3 | $+25^{\circ} \mathrm{C}$ | $\bullet$ | 10 | - | 10 | - | 10 | pF |
| Chip Enable to Output ON | (4) TELQX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 5 | - | 0 | - | 5 | - | ns |
| Output Enable to Output ON | $\begin{gathered} \text { (6) } \\ \text { TGLQX } \end{gathered}$ | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 5 | - | 5 | - | 5 | - | ns |
| Chip Enable High to Output In High Z | $\begin{gathered} \text { (7) } \\ \text { TEHQZ } \end{gathered}$ | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | - | 35 | - | 50 | - | 50 | ns |
| Output Disable to Output in High Z | (8) TGHQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | - | 35 | - | 40 | - | 40 | ns |
| Output Hold from Address Change | (9) TAVQX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 5 | - | 5 | - | 5 | - | ns |
| Write Enable to Output in High Z | (16) TWLQZ | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | - | 40 | $\bullet$ | 50 | - | 50 | ns |
| Write Enable High to Output ON | (19) TWHQX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | 0 | - | 0 | - | 0 | $\bullet$ | ns |
| Output High Voltage | VOH2 | $\begin{aligned} & \text { VCC }=4.5 \mathrm{~V}, \\ & 10=-100 \mu \mathrm{~A} \end{aligned}$ | 1 | $\begin{gathered} -55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq \\ +125^{\circ} \mathrm{C} \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { VCC } \\ 0.4 \mathrm{~V} \end{array}$ | - | $\begin{array}{\|c} \mathrm{VCC} \\ 0.4 \mathrm{~V} \end{array}$ | $\bullet$ | $\begin{gathered} \text { VCC - } \\ 0.4 \mathrm{~V} \end{gathered}$ | - | V |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon inital design release and upon design changes which would affect these characteristics.
2. Applies to DIP device types only.
3. Applies to LCC device types only.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Timing Waveforms

## 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 $\leq$ VIL and $\bar{W} \geq$ VIH. The output buffers can be controlled independently by $\bar{G}$ while $\bar{E}$ is low. To execute consecutive read cycles, $\bar{E}$ may be tied
low continuously until all desired locations are accessed. When $\bar{E}$ is low, addresses must be driven by stable logic levels and must not be in the high impedance state.

## WRITE CYCLE I



NOTE: $\overline{\mathbf{G}}$ is Low throughout Write Cycle

To write, addresses must be stable, $\overline{\mathrm{E}}$ low and $\overline{\mathrm{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 $\overline{\mathrm{E}}$ transitions 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.

## Timing Waveforms (Continued)

## WRITE CYCLE II



In this write cycle $\overline{\mathrm{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.

## 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}}$ ) must be held high during data retention; within VCC - 0.3 V to $\mathrm{VCC}+0.3 \mathrm{~V}$.
2. On RAMs which have selects or output enables (e.g., $\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. Inputs which are to be held high (e.g., $\overline{\mathrm{E}}$ ) must be kept between VCC +0.3 V and $70 \%$ of VCC during the power up and down transitions.
4. The RAM can begin operation $>55 \mathrm{~ns}$ after VCC reaches the minimum operating voltage ( 4.5 volts).

DATA RETENTION TIMING


## Test Circuit



## Burn-In Circuits

HM-65162/883 CERAMIC DIP


NOTES:
All resistors $47 \mathrm{~kW} \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 13=F 12+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
VIH $=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$\mathrm{C}=0.01 \mu \mathrm{~F}$ Min.

HM-65162/883 CERAMIC LCC


NOTES:
All resistors $47 \mathrm{~kW} \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 13=F 12+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$C=0.01 \mu \mathrm{~F}$ Min.

## Metallization Topology

DIE DIMENSIONS:
$186.2 \times 200.1 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 2 k \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$

## DIE ATTACH:

Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)

$$
\text { Ceramic LCC - } 420^{\circ} \mathrm{C} \text { (Max) }
$$

WORST CASE CURRENT DENSITY:
$1.7 \times 10^{5} \mathrm{~A}^{2} \mathrm{~cm}^{2}$

Metallization Mask Layout


## Packaging

24 PIN CERAMIC DIP


LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T24
MATERIALS: Compliant to MIL-M38510
32 PAD CERAMIC LCC


LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, CQCC1-N32
MATERIALS: Compliant to MIL-M38510

SEMICONDUCTOR

## Features

- Fast Access Time

70/85ns Max

- Low Standby Current . . 50 $\mu$ A Max
- Low Operating Current 50mA Max
- Data Retention at 2.0 Volts $20 \mu A$ Max
- TTL Compatible Inputs and Outputs
- JEDEC Approved Pinout
- No Clocks or Strobes Required
- 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 Required


## Description

The HM-65262 is a CMOS $16384 \times 1$ bit Static Random Access Memory manufactured using the Harris Advanced SANI $V$ process. The device utilizes asynchronous circuit design for fast cycle times and ease of use. The HM-65262 is available in both JEDEC standard 20 pın, 0.300 inch wide DIP and 20 pad LCC packages, providing high board-level packing density. Gated inputs lower standby current, and also elminate the need for pull-up or pull-down resistors.
The HM-65262, a full CMOS RAM, utilizes an array of six transistor (6T) memory cells for the most stable and lowest possible standby supply current over the full military temperature range. In addition to this, the high stability of the 6T RAM cell provides excellent protection against soft errors due to noise and alpha particles. This stability also improves the radiation tolerance of the RAM over that of four transistor (4T) devices.

## Functional Diagram



## Ordering Information

| PACKAGE | TEMP. RANGE | $70 \mathrm{~ns} / 20 \mu \mathrm{~A}^{*}$ | *85ns/20 $/$ A* | *85ns/400 1 A* |
| :---: | :---: | :---: | :---: | :---: |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM1-65262B-9 | HM1-65262-9 | HM1-65262C-9 |
| /883** | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM1-65262B/883 | HM1-65262/883 | - |
| JAN \# |  | 29109BRA | 29103BRA | - |
| SMD\# |  | 8413203RA | 8413201RA | - |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM4-65262B-9 | HM4-65262-9 | HM4-65262C-9 |
| /883** | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM4-65262B/883 | HM4-65262/883 | - |
| JAN \# |  | 29109BYA | 29103BYA | - |
| SMD\# |  | 8413203YA | 8413201YA | - |

[^22]

| A0 - A13 | Address Input |
| :---: | :--- |
| $\overline{\mathrm{E}}$ | Chip Enable/ <br> Power Down |
| Q | Data Out |
| D | Data In |
| VSS/ <br> GND | Ground |
| VCC | Power (+5) |
| $\bar{W}$ | Write Enable |

## Absolute Maximum Ratings

Supply Votage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 V
Input or Output Voltage Applied for all grades ........0.3V to VCC +0.3 V

Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s) . . . . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
Typical Derating Factor . . . . . . . . . . . . . . . .5mAMMz Increase in ICCOP ESD Classification

## Reliability Information

| rmal Resistance. | ${ }^{\text {ja }}$ |  |
| :---: | :---: | :---: |
| Ceramic DIP Package | $66^{\circ} \mathrm{C} / \mathrm{W}$ | $13^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $85^{\circ} \mathrm{C} / \mathrm{W}$ | $40^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | .75 |
| ate Count |  | 56 |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V Operating Temperature Range
HM-65262B-9, HM-65262-9, HM-65262C-9 . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
DC Electrical Specifications $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-65262B-9, HM-65262-9, HM-65262C-9)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSB1 | Standby Supply Current | - | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & H M-65262 B-9, H M-65262-9,10=0 \mathrm{~mA}, \\ & \bar{E}=\mathrm{VCC}-0.3 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
|  |  | - | 900 | $\mu \mathrm{A}$ | $\begin{aligned} & H M-65262 \mathrm{C}-9,10=0 \mathrm{~mA}, \\ & \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| ICCSB | Standby Supply Current | $\bullet$ | 5 | mA | $\overline{\mathrm{E}}=2.2 \mathrm{~V}, 1 \mathrm{O}=0 \mathrm{~mA}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCEN | Enabled Supply Current | - | 50 | mA | $\overline{\mathrm{E}}=0.8 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCOP | Operating Supply Current (Note 1) | $\bullet$ | 50 | mA | $\begin{aligned} & \overline{\mathrm{E}}=0.8 \mathrm{~V}, \mathrm{IO}=0 \mathrm{~mA}, \mathrm{f}=1 \mathrm{MHz} \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| ICCDR | Data Retention Supply Current | $\bullet$ | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { HM-65262B-9, HM-65262-9, } \\ & \text { VCC }=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC} \end{aligned}$ |
|  |  | - | 400 | $\mu \mathrm{A}$ | HM-65262C-9, VCC $=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}$ |
| ICCDR1 | Data Retention Supply Current | - | 30 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { HM-65262B-9, HM-65262-9, } \\ & \text { VCC }=3.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC} \end{aligned}$ |
|  |  | - | 550 | $\mu \mathrm{A}$ | HM-65262C-9, VCC $=3.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage | 2.2 | VCC +0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $1 \mathrm{O}=8.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH 1 | Output High Voltage | 2.4 | - | V | $10=-4.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 2) | VCC-0.4 | - | V | $10=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| Cl | Input Capacitance (Note 2) | 10 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| CIO | Input/Output Capacitance (Note 2) | 12 | pF |  |

NOTES: 1. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
2. Tested at initial design and after major design changes.

Specifications HM-65262
AC Electrical Specifications $V C C=5 \mathrm{~V} \quad 10 \%, T A=-400 \mathrm{C}$ to +850 C (HM-65262B-9, HM-65262-9, HM-65262C-9)

| SYMBOL | PARAMETER | LIMITS |  |  |  |  |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-65262B-9 |  | HM-65262-9 |  | HM-65262C-9 |  |  |  |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |
| (1) TAVAX | Read/Cycle Time | 70 | - | 85 | - | 85 | - | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access Tıme | - | 70 | - | 85 | - | 85 | ns | (Notes 1, 3) |
| (3) TELQV | Chip Enable Access Time | - | 70 | - | 85 | - | 85 | ns | (Notes 1, 3) |
| (4) TELQX | Chip Enable Output Enable Time | 5 | - | 5 | $\bullet$ | 5 | - | ns | (Notes 2, 3) |
| (5) TEHQX | Chip Disable Output Hold Time | 5 | - | 5 | - | 5 | - | ns | (Notes 2, 3) |
| (6) TAXQX | Address Invalid Output Hold Time | 5 | - | 5 | - | 5 | $\bullet$ | ns | (Notes 2, 3) |
| (7) TEHQZ | Chip Enable Output Disable Time | - | 30 | - | 30 | - | 30 | ns | (Notes 2, 3) |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |
| (8) TAVAX | Write Cycle Time | 70 | - | 85 | - | 85 | - | ns | (Notes 1, 3) |
| (9) TELWH | Chip Selection to End of Write | 55 | - | 65 | - | 65 | - | ns | (Notes 1, 3) |
| (10) TWLWH | Write Enable Pulse Width | 40 | - | 45 | - | 45 | - | ns | (Notes 1, 3) |
| (11) TAVWL | Address Setup Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (12) TWHAX | Address Hold Time | 0 | - | 0 | $\bullet$ | 0 | - | ns | (Notes 1, 3) |
| (13) TDVWH | Data Setup Time | 30 | - | 35 | - | 35 | - | ns | (Notes 1, 3) |
| (14) TWHDX | Data Hold Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (15) TWLOZ | Write Enable Output Disable Time | - | 30 | - | 30 | - | 30 | ns | (Notes 2, 3) |
| (16) TWHQX | Write Disable Output Enable Time | 0 | - | 0 | - | 0 | - | ns | (Notes 2, 3) |
| (17) TAVWH | Address Valid to End of Write | 55 | - | 65 | - | 65 | $\bullet$ | ns | (Notes 1, 3) |
| (18) TAVEL | Address Setup Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (19) TEHAX | Address Hold Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |
| (20) TAVEH | Address Valid to End of Write | 55 | - | 65 | $\bullet$ | 65 | - | ns | (Notes 1, 3) |
| (21) TELEH | Enable Pulse Width | 55 | - | 65 | - | 65 | - | ns | (Notes 1, 3) |
| (22) TWLEH | Write Enable Pulse Setup Time | 40 | - | 45 | - | 45 | - | ns | (Notes 1, 3) |
| (23) TDVEH | Chip Setup Time | 30 | * | 35 | - | 35 | 0 | ns | (Notes 1, 3) |
| (24) TEHDX | Data Hold Time | 0 | - | 0 | - | 0 | - | ns | (Notes 1, 3) |

## NOTES:

1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent and $\mathrm{CL}=50 \mathrm{pF}$ (min) - for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
2 Tested at intial design and after major design changes
2. $\mathrm{VCC}=45$ and 55 V .

## Timing Waveforms

READ CYCLE 1: CONTROLLED BY E


NOTE: $\bar{W}$ is high for entre cycle and $D$ is ignored. Address is stable by the time $\bar{E}$ goes low and remains valid until $\bar{E}$ goes high.

READ CYCLE 2: CONTROLLED BY ADDRESS


NOTE: $\bar{W}$ is high for the entire cycle and $D$ is ignored. $\bar{E}$ is stable prior to $A$ becoming valid and after $A$ becomes invalid.

WRITE CYCLE 1: CONTROLLED BY $\overline{\mathbf{W}}$ (LATE WRITE)

A


NOTE: In this mode, $\overline{\mathrm{E}}$ rises after $\overline{\mathrm{W}}$. The address must remain stable when- ever both $\overline{\mathrm{E}}$ and $\overline{\mathrm{W}}$ are low.

## Timing Waveforms (Continued)

WRITE CYCLE 2: Controlled by E(EARLY WRITE)


NOTE: In this mode, $\bar{W}$ rises after $\overline{\mathrm{E}}$. If $\mathbf{W}$ falls before $\overline{\mathrm{E}}$ by a time exceeding TWLQZ (Max) TELQX (Min), and rises after $\bar{E}$ by a time exceeding TEHQZ (Max)-TWHQZ (Min), then $Q$ will remain in the high impedance state throughout the cycle.

## 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}})$ 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., S , $\bar{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. Inputs which are to be held high (e.g., $\overline{\mathrm{E}}$ ) must be kept between VCC +0.3 V and $70 \%$ of VCC during the power up and down transitions.
4. The RAM can begin operation $>55 \mathrm{~ns}$ after VCC reaches the minimum operating voltage ( 4.5 volts).

DATA RETENTION TIMING


## Performance Curve

TYPICAL ICCDR vs TA


## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Fast Access Time. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $70 / 85 n s$ Max
- Low Standby Current. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50رA Max
- Low Operating Current . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50mA Max
- Data Retention at 2.0 Volts . . . . . . . . . . . . . . . . . . . . . . . . 20رA Max
- TTL Compatible Inputs and Outputs
- JEDEC Approved Pinout
- No Clocks or Strobes Required
- Temperature Range $\qquad$ $+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 Required


## Description

The HM-65262/883 is a CMOS $16384 \times 1$ bit Static Random Access Memory manufactured using the Harris Advanced SAJI V process. The device utilizes asynchronous circuit design for fast cycle times and ease of use. The HM-65262/883 is available in both JEDEC standard 20 pin, 0.300 inch wide DIP and 20 pad LCC packages, providing high boardlevel packing density. Gated inputs lower standby current, and also elminate the need for pull-up or pull-down resistors.

The HM-65262/883, a full CMOS RAM, utilizes an array of six transistor (6T) memory cells for the most stable and lowest possible standby supply current over the full military temperature range. In addition to this, the high stability of the 6T RAM cell provides excellent protection against soft errors due to noise and alpha particles. This stability also improves the radiation tolerance of the RAM over that of four transistor (4T) devices.

## Functional Diagram



## Pinouts

HM1-65262/883 (CERAMIC DIP) TOP VIEW

| A0 1 | 20 vcc |
| :---: | :---: |
| A1 2 | $19 \mathrm{Al3}$ |
| A2 3 | 18 A12 |
| A3 4 | 17 A11 |
| A4 5 | 16 A10 |
| A5 6 | 15 A9 |
| A6 7 | 14.48 |
| 08 |  |
| W 9 | 12 D |
| GND 10 | 11 E |



| A0 - A13 | Address Input |
| :---: | :--- |
| $\overline{\mathrm{E}}$ | Chip Enable/ <br> Power Down |
| Q | Data Out |
| D | Data In |
| VSS/GND | Ground |
| VCC | Power (+5) |
| $\overline{\mathrm{W}}$ | Write Enable |

## Absolute Maximum Ratings

Supply Vottage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 V Input or Output VoltageApplied for all grades . . . . . . . -0.3 V to VCC +0.3 V Storage Temperature Range ......................... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Junction Temperature $\qquad$ $+175^{\circ} \mathrm{C}$ Lead Temperature (Soldering 10s) . . . . . . . . . . . . . . . . . . . . . . . . $300^{\circ} \mathrm{C}$ Typical Derating Factor . . . . . . . . . . . . . . . $5 \mathrm{~mA} / \mathrm{MHz}$ Increase in ICCOP ESD Classification
$\qquad$
$\qquad$ CAUTION: Stresses above those listed in "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.

## Operating Conditions

| Operating Voltage | V to +5.5 V | Input High Voltage (VIH) . . . . . . . . . . . . . . . . . . . . - +2.2 e to VCC |
| :---: | :---: | :---: |
| Operating Temperature Range | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Data Retention Supply Voltage . . . . . . . . . . . . . . . . . . . 2.0V to 4.5V |
| Input Low Voltage | 0 V to +0.8 V | Input Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . 40 ns Max |

Reliability Information

| Thermal Resistance. . . . Ceramic DIP Package | $\begin{gathered} \theta_{\text {确 }} \\ 66^{\circ} \mathrm{C} \end{gathered}$ | $\begin{gathered} \theta_{\text {cc }} \\ 13^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ |
| :---: | :---: | :---: |
| Ceramic LCC Package | $85^{\circ} \mathrm{C} / \mathrm{W}$ | $40^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe Ceramic DIP Package |  |  |

## TABLE 1. HM-65262/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

Device Guaranteed and $100 \%$ Tested

| D.C. PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUB-GROUPS | TEMPERATURE | MIN | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| High Level Output Voltage | VOH1 | $\mathrm{VCC}=4.5 \mathrm{~V}, 10=-4.0 \mathrm{~mA}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Low Level Output Voltage | VOL | $\mathrm{VCC}=4.5 \mathrm{~V}, 10=8.0 \mathrm{~mA}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| High Impedance Output Leakage Current | 102 | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{E}}=5.5 \mathrm{~V}, \mathrm{VO}=\mathrm{GND} \\ & \text { or VCC } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Input Leakage Current | II | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VI}=\mathrm{GND}$ or VCC | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB1 | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, 10=0 \mathrm{~mA}, \overline{\mathrm{E}}=\mathrm{VCC} . \\ & 0.3 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 50 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB | $\mathrm{VCC}=5.5 \mathrm{~V}, 1 \mathrm{O}=0 \mathrm{~mA}, \overline{\mathrm{E}}=2.2 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 5 | mA |
| Operating Supply Current | ICCOP | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V},(\text { Note } 2), \mathrm{f}=1 \mathrm{MHz}, \overline{\mathrm{E}} \\ & =08 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 50 | mA |
| Data Retention Supply Current | ICCDR | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, 10=0 \mathrm{~mA}, \overline{\mathrm{E}}=\mathrm{VCC} . \\ & 0.3 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | $\mu \mathrm{A}$ |
| Enable Supply Current | ICCEN | $\mathrm{VCC}=5.5 \mathrm{~V}, 1 \mathrm{O}=0 \mathrm{~mA}, \overline{\mathrm{E}}=0.8 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | mA |
| Functional Test | FT | $\mathrm{VCC}=4.5 \mathrm{~V}$ (Note 3) | 7, 8A, 8B | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES:

1. All voltages referenced to device GND.
2. Typical derating $1.5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP
3. Tested as follows: $\mathfrak{f}=2 \mathrm{MHz}, \mathrm{VIH}=2.4 \mathrm{~V}, \mathrm{VIL}=0.4 \mathrm{~V}, \mathrm{IOH}=-4 \mathrm{OmA}, \mathrm{IOL}=4.0 \mathrm{~mA}, \mathrm{VOH} \geq 1.5 \mathrm{~V}$, and $\mathrm{VOL} \leq 1.5 \mathrm{~V}$.

TABLE 2. HM-65262/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| A.C. PARAMETERS | SYMBOL | (NOTES 1,2) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | HM-65262B/883 LIMITS |  | HM-65262/883 LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Read/Write/Cycle Time | (1) TAVAX | $\mathrm{VCC}=45 \mathrm{~V}$ and 55 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 70 | - | 85 | - | ns |
| Address Access Time | (2) TAVQV | $\mathrm{VCC}=45 \mathrm{~V}$ and 55 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\cdot$ | 70 | - | 85 | ns |
| Chip Enable to End of Write | (3) TELWH | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 55 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 55 | - | 65 | $\bullet$ | ns |
| Chip Enable Access Time | (4) TELQV | $\mathrm{VCC}=45 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\cdot$ | 70 | $\bullet$ | 85 | ns |
| Address Hold Time | (5) TWHAX | $\mathrm{VCC}=45 \mathrm{~V}$ and 55 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | $\cdot$ | ns |
| Address Setup Time | (6) TAVWL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Address Valid to End of Write | (7) TAVWH | $\mathrm{VCC}=45 \mathrm{~V}$ and 55 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 55 | - | 65 | - | ns |
| Address Setup Time | (8) TAVEL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 55 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Address Hold Time | (9) TEHAX | $\mathrm{VCC}=45 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Address Valid to End of Writes | (10) TAVEH | $V C C=45 \mathrm{~V}$ and 55 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 55 | - | 65 | - | ns |

TABLE 2. HM-65262/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS (Continued)
Device Guaranteed and $100 \%$ Tested

| A.C. PARAMETERS | SYMBOL |  | (NOTES 1,2) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | HM-65262B/883 LIMITS |  | HM-65262/883 LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN |  |  | MAX | MIN | MAX |  |
| Write Enable Pulse Write | (11) | TWLWH |  | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 40 | $\bullet$ | 45 | - | ns |
| Data Setup Time | (12) | TDVWH | $\mathrm{VCC}=45 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 35 | - | ns |
| Data Hold Time | (13) | TWHDX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Enable Pulse Width | (14) | TELEH | $\mathrm{VCC}=45 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 55 | - | 65 | $\bullet$ | ns |
| Write to End of Write | (15) | TWLEH | $V C C=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 40 | - | 45 | - | ns |
| Data Setup Time | (16) | TDVEH | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 35 | - | ns |
| Data Hold Time | (17) | TEHDX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 55 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns | NOTES:

1. All voltages referenced to device GND.
2. Input pulse levels 0.8 V to VCC-2.0V; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
3. $T A V Q V=T E L Q V+T A V E L$.

TABLE 3. HM-65262/883 ELECTRICAL PERFORMANCE CHARACTERISTICS, A.C. AND D.C.

| PARAMETERS | SYMBOL |  | (NOTE 1) CONDITIONS | NOTES | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN |  |  | MAX |  |
| Input Capacitance | CIN |  |  | VCC = Open, $f=1 \mathrm{MHz}$, All Measurements Referenced To Device Grounds | 1,2 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
|  |  |  | VCC $=$ Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced To Device Grounds | 1, 3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 6 | pF |
| Output Capacitance | CO |  | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced To Device Grounds | 1, 2 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | pF |
|  |  |  | VCC $=$ Open, $f=1 \mathrm{MHz}$, All Measurements Referenced To Device Grounds | 1, 3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 8 | pF |
| Write Enable to Output in High Z | (18) | TWLQZ | $V C C=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 40 | ns |
| Write Enable High to Output ON | (19) | TWHQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | ns |
| Chip Enable to Output ON | (20) | TELQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 5 | - | ns |
| Output Enable High to Output in High Z | (21) | TEHQZ | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 40 | ns |
| Chip Disable to Output Hold Time | (22) | TEHQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 5 | - | ns |
| Address Invalid Output Hold Time | (23) | TAXQX | $V C C=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 5 | - | ns |
| High Level Output Voltage |  | VOH2 | $\mathrm{VCC}=45 \mathrm{~V}, 10=-100 \mathrm{~mA}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}-$ | $\begin{aligned} & \mathrm{VCC} \\ & -0.4 \mathrm{~V} \end{aligned}$ | - | V |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design release and upon design changes which would affect these characteristics.
2. Applies to DIP device types only.
3. Applies to LCC device types only.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE <br> GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

[^23]
## Timing Waveforms

READ CYCLE 1: CONTROLLED BY $\bar{E}$


NOTE: $\bar{W}$ is high for entire cycle and D is ignored. Address is stable by the time $\overline{\mathrm{E}}$ goes low and remains valid until $\overline{\mathrm{E}}$ goes high.

READ CYCLE 2: CONTROLLED BY ADDRESS


NOTE: $\bar{W}$ is high for the entire cycle and $D$ is ignored. $\overline{\mathrm{E}}$ is stable prior to A becoming valid and after A becomes invalid.

WRITE CYCLE 1: CONTROLLED BY $\bar{W}$ (LATE WRITE)


## Timing Waveforms (Continued)

WRITE CYCLE 2: CONTROLLED BY $\bar{E}$ (EARLY WRITE)


NOTE: In this mode, $\bar{W}$ rises after $\bar{E}$. If $W$ falls before $\bar{E}$ by a time exceeding TWLQZ (Max) TELQX (Min), and rises after $\bar{E}$ by a time exceeding TEHQZ (Max)-TWHQZ (Min), then Q will remain in the high impedance state throughout the cycle.

## 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}}$ ) must be held high during data retention; within VCC to VCC + 0.3V.
2. On RAMs which have selects or output enables (e.g., 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. Inputs which are to be held high (e.g., $\overline{\mathrm{E}}$ ) must be kept between VCC +0.3 V and $70 \%$ of VCC during the power up and down transitions.
4. The RAM can begin operation $>55 \mathrm{~ns}$ after VCC reaches the minimum operating voltage ( 4.5 volts).

DATA RETENTION TIMING


## Test Circuit



## Burn-In Circuits

## HM-65262/883 CERAMIC DIP

HM-65262/883 CERAMIC LCC


NOTES:
All resistors $47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 13=F 12+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$\mathrm{C}=0.01 \mu \mathrm{~F}$ Min.

NOTES:
All resistors $47 \mathrm{k} \Omega \pm 5 \%$
F0 $=100 \mathrm{kHz} \pm 10 \%$
$F 1=F 0+2, F 2=F 1+2, F 3=F 2+2 \ldots F 13=F 12+2$
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V
$\mathrm{C}=0.01 \mu \mathrm{~F}$ Min.

## Metallization Topology

DIE DIOENSIONS:
$186.2 \times 200.1 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 2 \mathrm{k} \AA$

## GLASSIVATION:

Type: $\mathrm{SiO}_{2}$
Thickness: $8 k \AA \pm 1 \mathrm{k} \AA$

## DIE ATTACH:

Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max) Ceramic LCC $-420^{\circ} \mathrm{C}$ (Max)

WORST CASE CURRENT DENSITY:
$1.2 \times 10^{5} \mathrm{~A} \mathrm{~cm}^{2}$

Metallization Mask Layout


## Packaging



LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T20
MATERIALS: Compliant to MIL-M38510
20 PAD CERAMIC LCC


LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, CQCC1-N20
MATERIALS: Compliant to MIL-M38510
$\underset{\text { semiconductor }}{\text { HARPIS }}$
HM-65642

## 8K x 8 Asynchronous CMOS Static RAM

## Features

- Full CMOS Design
- Six Transistor Memory Cell
- Low Standby Supply Current $100 \mu \mathrm{~A}$
- Low Operating Supply Current 20 mA
- Fast Address Access Time


## 150ns

- Low Data Retention Supply Voltage .2.0V
- СмоS/TTL Compatible Inputs/Outputs
- JEDEC Approved Pinout
- Equal Cycle and Access Times
- No Clocks or Strobes Required
- Gated Inputs
- No Pull-Up or Pull-Down Resistors Required
- Easy Microprocessor Interfacing
- Dual Chip Enable Control


## Description

The HM-65642 is a CMOS $8192 \times 8$-bit Static Random Access Memory. The pinout is the JEDEC 28 pin, 8 -bit wide standard, which allows easy memory board layouts which accommodate a variety of industry standard ROM, PROM, EPROM, EEPROM and RAMs. The HM-65642 is ideally suited for use in microprocessor based systems. In particular, interfacing with the Harris 80 C 86 and 80 C 88 microprocessors is simplified by the convenient output enable ( $\overline{\mathrm{G}}$ ) input.
The HM-65642 is a full CMOS RAM which utilizes an array of six transistor (6T) memory cells for the most stable and lowest possible standby supply current over the full military temperature range. In addition to this, the high stability of the 6T RAM cell provides excellent protection against soft errors due to noise and alpha particles. This stability also improves the radiation tolerance of the RAM over that of four transistor or MIX-MOS (4T) devices.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | *150ns/75 $\mu \mathrm{A}$ | *150ns/150 $/ \mathrm{A}$ | *200ns/250 $/$ A |
| :---: | :---: | :---: | :---: | :---: |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | - | HM1-65642-9 | - |
| **/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM1-65642B/883 | HM1-65642/883 | HM1-65642C/883 |
| JAN\# |  | 29205BXA | $\cdot$ | - |
| SMD\# |  | - | 8552514XA | - |
| LCC, $1883^{* *}$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM4-65642B/883 | HM4-65642/883 | HM4-65642C/883 |
| JAN\# |  | 29205BYA | - | - |
| SMD\# |  | - | 8552514YA | - |

* Access Time/Data Retention Supply Current
** Respective $/ 883$ specifications are included at the end of this data sheet.


## Pinout

|  |  |
| :---: | :---: |
| 1 | 28 vcc |
| A12 2 | 27 w |
| A7 3 | 26 E 2 |
| A6 4 | 25 A8 |
| A5 5 | 24 A 9 |
| A4 6 | $23 \mathrm{Al1}$ |
| $\mathrm{A}_{3} 7$ | $2]^{\mathbf{G}}$ |
| A2 8 | 21 A10 |
| A1 9 | 20 E1 |
| A0 10 | $19 \mathrm{DQ7}$ |
| DQO 11 | 18 DQ6 |
| DQ1 12 | 17 DC5 |
| DQ2 13 | 16 DO4 |
| GND 14 | 15 DQ3 |


| PIN | DESCRIPTION |
| :---: | :--- |
| A | Address Input |
| DQ | Data Input/Output |
| $\overline{E 1}$ | Chip Enable |
| $E 2$ | Chip Enable |
| $\bar{W}$ | Write Enable |
| $\bar{G}$ | Output Enable |
| NC | No Connections |
| GND | Ground |
| VCC | Power |

Functional Diagram


TRUTH TABLE

| MODE | $\overline{E 1}$ | E2 | $\overline{\mathrm{W}}$ | $\overline{\mathbf{G}}$ |
| :--- | :---: | :---: | :---: | :---: |
| Standby (CMOS) | X | GND | X | X |
| Standby (TTL) | VIH | X | X | X |
|  | X | VIL | X | X |
|  | VIL | VIH | VIH | VIH |
| Write | VIL | VIH | VIL | X |
| Read | VIL | VIH | VIH | VIL |

## Absolute Maximum Ratings

Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 V
Input or Output Voltage Applied for all grades . . . . . . . GND-0.3V to $\mathrm{VCC}+0.3 \mathrm{~V}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$
Typical Derating Factor . . . . . . . . . . . . 5mAMMHz Increase in ICCOP
ESD Classification
Class 1

## Reliability Information

| Thermal Resistance . . . Ceramic DIP Package | $\begin{gathered} \theta_{, \mathrm{a}} \\ 45^{\circ} \mathrm{C} \\ \hline \end{gathered}$ | $\begin{gathered} \theta_{\mathrm{c}} \\ 8^{\circ} \mathrm{C} / \mathbf{W} \end{gathered}$ |
| :---: | :---: | :---: |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ Ceramic DIP Package |  |  |
|  |  |  |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

| Operating Voltage Range | +4.5 V to +5.5V | Input Low Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . .0.3V to +0.8 V |
| :---: | :---: | :---: |
| Operating Temperature Range |  | Input High Voltage. . . . . . . . . . . . . . . . . . . . . . +2.2 V to VCC +0.3 V |
| HM-65642-9 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |  |

DC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}(\mathrm{HM}-65642-9)$

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSB1 | Standby Supply Current (CMOS) | - | 250 | $\mu \mathrm{A}$ | $\mathrm{E} 2=\mathrm{GND}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCSB2 | Standby Supply Current (TTL) | - | 5 | mA | $\mathrm{E} 2=0.8 \mathrm{~V}$ or $\overline{\mathrm{E} 1}=2.2 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCDR | Data Retention Supply Current | - | 150 | $\mu \mathrm{A}$ | $\mathrm{E} 2=\mathrm{GND}, \mathrm{VCC}=2.0 \mathrm{~V}$ |
| ICCEN | Enabled Supply Current | - | 5 | mA | $\begin{aligned} & \mathrm{E} 2=2.2 \mathrm{~V}, \overline{\mathrm{E} 1}=0.8 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V}, \\ & \\| \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ |
| ICCOP | Operating Supply Current (Note 1) | $\bullet$ | 20 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, \overline{\mathrm{El}}=0.8 \mathrm{~V}, \mathrm{E2}=2.2 \mathrm{~V}, \\ & \mathrm{VCC}=5.5 \mathrm{~V}, 110=0 \mathrm{~mA} \end{aligned}$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| IIOZ | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { E2 = GND, VIO = VCC or GND, } \\ & \text { VCC }=5.5 \mathrm{~V} \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | $\bullet$ | V |  |
| VOH1 | Output High Voltage | 2.4 | - | V | $1 \mathrm{OH}=-1.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 2) | VCC-0.4 | $\bullet$ | V | $1 \mathrm{OH}=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | v | $1 \mathrm{OL}=4.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CI | Input Capacitance (Note 2) | 12 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| CIO | Input/Output Capacitance (Note 2) | 14 | pF |  |

NOTES:

1. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
2. Tested at initial design and after major design changes.

Specifications HM-65642-9
AC Electrical Specifications $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ( $\mathrm{HM}-65642-9$ )

| SYMBOL | PARAMETER |  |  | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | MAX |  |  |
| READ CYCLE |  |  |  |  |  |  |  |
| (1) TAVAX | Read Cycle Time |  |  | 150 | - | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access Time |  |  | - | 150 | ns | (Notes 1, 3) |
| (3) TE1LQV | Chip Enable Access T |  | E1 | - | 150 | ns | (Notes 2, 3) |
| (4) TE2HQV | Chip Enable Access T |  | E2 | - | 150 | ns | (Notes 1, 3) |
| (5) TGLQV | Output Enable Access Time |  |  | - | 70 | ns | (Notes 1, 3) |
| (6) TE1LQX | Chip Enable Valid to |  | $\overline{E 1}$ | 10 | - | ns | (Notes 2, 3) |
| (7) TE2HQX | Chip Enable Valid to |  | E2 | 10 | - | ns | (Notes 2, 3) |
| (8) TGLQX | Output Enable Valid to Output On |  |  | 5 | - | ns | (Notes 2, 3) |
| (9) TE1HQZ | Chip Enable Not Valid to Output Off |  | $\overline{E 1}$ | - | 50 | ns | (Notes 2, 3) |
| (10) TE2LQZ | Chip Enable Not Valid to Output Off |  | E2 | - | 60 | ns | (Notes 2, 3) |
| (11) TGHQZ | Output Enable Not Valid to Output Off |  |  | - | 50 | ns | (Notes 2, 3) |
| (12) TAXQX | Output Hold From Address Change |  |  | 10 | - | ns | (Notes 2, 3) |
| WRITE CYCLE |  |  |  |  |  |  |  |
| (13) TAVAX | Write Cycle Time |  |  | 150 | - | ns | (Notes 1, 3) |
| (14) TWLWH | Write Pulse Width |  |  | 90 | - | ns | (Notes 1, 3) |
| (15) TE1LE1H | Chip Enable to End of Write |  | $\overline{\text { E1 }}$ | 90 | - | ns | (Notes 1, 3) |
| (16) TE2HE2L | Chip Enable to End of Write |  | E2 | 90 | - | ns | (Notes 1, 3) |
| (17) TAVWL | Address Setup Time | Late Write |  | 0 | - | ns | (Notes 1, 3) |
| (18) TAVE1L | Address Setup Time | Early Write | $\overline{\mathrm{E} 1}$ | 0 | - | ns | (Notes 1, 3) |
| (19) TAVE2H | Address Setup Time | Early Write | E2 | 0 | - | ns | (Notes 1, 3) |
| (20) TWHAX | Write Recovery Time | Late Write |  | 10 | - | ns | (Notes 1, 3) |
| (21) TE1HAX | Write Recovery Time | Early Write | $\overline{\mathrm{E} 1}$ | 10 | - | ns | (Notes 1, 3) |
| (22) TE2LAX | Write Recovery Time | Early Write | E2 | 10 | - | ns | (Notes 1, 3) |
| (23) TDVWH | Data Setup Time | Late Write |  | 60 | - | ns | (Notes 1, 3) |
| (24) TDVE1H | Data Setup Time | Early Write | $\overline{E 1}$ | 60 | - |  | (Notes 1, 3) |
| (25) TDVE2L | Data Setup Time | Early Write | E2 | 60 | - | ns | (Notes 1, 3) |
| (26) TWHDX | Data Hold Time | Late Write |  | 5 | - | ns | (Notes 1, 3) |
| (27) TE1HDX | Data Hold Time | Early Write | $\overline{\mathrm{E} 1}$ | 10 | - | ns | (Notes 1, 3) |
| (28) TE2LDX | Data Hold Time | Early Write | E2 | 10 | - | ns | (Notes 1, 3) |
| (29) TWLQZ | Write Enable Low to Output Off |  |  | - | 50 | ns | (Notes 2, 3) |
| (30) TWHQX | Write Enable High to Output On |  |  | 5 | - | ns | (Notes 2, 3) |

## NOTES:

1. Input pulse levels: OV to 3.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent, $\mathrm{CL}=50 \mathrm{pF}(\min )$ - for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .

## Low Voltage Data Retention

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

1. The RAM must be kept disabled during data retention. This is accomplished by holding the E2 pin between -0.3 V and GND.
2. During power-up and power-down transitions, E2 must be held between -0.3 V and $10 \%$ of VCC.
3. The RAM can begin operating one TAVAX after VCC reaches the minımum operating voltage of 4.5 V .


## Read Cycles

READ CYCLE I: $\overline{\mathbf{W}}, \mathrm{E} 2 \mathrm{HIGH} ; \overline{\mathrm{G}}, \overline{\mathrm{E} 1}$ LOW


READ CYCLE II: $\overline{\mathbf{W}}$ high


## Write Cycles

WRITE CYCLE I: LATE WRITE


WRITE CYCLE II: EARLY WRITE - CONTROLLED BY E1


WRITE CYCLE III: EARLY WRITE - CONTROLLED BY E2


## Performance Curve

TYPICAL ICCDR vs $\mathrm{T}_{\mathrm{A}}$


HM-65642/883

## 8K x 8 Asynchronous CMOS Static RAM

## Features

- This Circuit Is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Full CMOS Design
- Six Transistor Memory Cell
- Low Standby Supply Current . . . . . . . . . . . . . . . . $100 \mu \mathrm{~A}$
- Low Operating Supply Current . . . . . . . . . . . . . . . 20mA
- Fast Address Access Time
.150ns
- Low Data Retention Supply Voltage . . . . . . . . . . . . 2.0V
- CMOS/TTL Compatible Inputs/Outputs
- JEDEC Approved Pinout
- Equal Cycle and Access Times
- No Clocks or Strobes Required
- Gated Inputs
- No Pull-Up or Pull-Down Resistors Required
- Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- Easy Microprocessor Interfacing
- Dual Chip Enable Control


## Description

The HM-65642/883 is a CMOS $8192 \times 8$-bit Static Random Access Memory. The pinout is the JEDEC 28 pin, 8 -bit wide standard, which allows easy memory board layouts which accommodate a variety of industry standard ROM, PROM, EPROM, EEPROM and RAMs. The HM-65642/883 is ideally suited for use in microprocessor based systems. In particular, interfacing with the Harris 80C86 and 80C88 microprocessors is simplified by the convenient output enable ( $\overline{\mathrm{G}}$ ) input.

The HM-65642/883 is a full CMOS RAM which utilizes an array of six transistor (6T) memory cells for the most stable and lowest possible standby supply current over the full military temperature range. In addition to this, the high stability of the 6T RAM cell provides excellent protection against soft errors due to noise and alpha particles. This stability also improves the radiation tolerance of the RAM over that of four transistor or MIX-MOS (4T) devices.

## Pinouts



Absolute Maximum Ratings


## Reliability Information

| Thermal Resis | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package . | $45^{\circ} \mathrm{C} / \mathrm{N}$ | $8^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic LCC Package | $55^{\circ} \mathrm{CN}$ | $45^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power | $125^{\circ} \mathrm{C}$ |  |
| Ceramic DIP Package . |  | 1.1 W |
| Ceramic LCC Package |  | 0.90 W |
| Gate Count . |  | 000 Gate |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Input Low Voltage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0.3 V to +0.8 V

Input High Voltage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.2 V 2. V
Data Retention Supply Voltage
Input Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . . 40 ns Max.

TABLE 1. HM-65642/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| High Level Output Voltage | VOH 1 | $\mathrm{VCC}=4.5 \mathrm{~V}, 10=-1.0 \mathrm{~mA}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Low Level Output Voltage | VOL | $\mathrm{VCC}=4.5 \mathrm{~V}, 10=4.0 \mathrm{~mA}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| High Impedance Output Leakage Current | IIOZ | HM-65642B/883, HM-65642/883 $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{G}}=2.2 \mathrm{~V}, \\ & \mathrm{VIIO}=\mathrm{GND} \text { or VCC } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & \mathrm{HM}-65642 \mathrm{C} / 883 \\ & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{G}}=2.2 \mathrm{~V}, \\ & \mathrm{VI} / \mathrm{O}=\mathrm{GND} \text { or VCC } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -2.0 | +2.0 | $\mu \mathrm{A}$ |
| Input Leakage Current | 11 | HM-65642B/883, HM-65642/883 $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VI}=\mathrm{GND}$ or VCC | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & \mathrm{HM}-65642 \mathrm{C} / 883 \\ & \mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VI}=\mathrm{GND} \text { or VCC } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -2.0 | +2.0 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB1 | $\begin{aligned} & H M-65642 B / 883 \\ & V C C=5.5 \mathrm{~V}, E 1=\mathrm{VCC}-0.3 \mathrm{~V} \text { or } \\ & E 2=G N D+0.3 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 100 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & H M-65642 / 883 \\ & \text { VCC }=5.5 \mathrm{~V}, \overline{\mathrm{E} 1}=\mathrm{VCC}-0.3 \mathrm{~V} \text { or } \\ & \mathrm{E} 2=\mathrm{GND}+0.3 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 250 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & \mathrm{HM}-65642 \mathrm{C} / 883 \\ & \mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{E} 1=\mathrm{VCC}-0.3 \mathrm{~V} \text { or } \\ & \mathrm{E} 2=\mathrm{GND}+0.3 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 400 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, 1 \mathrm{O}=0 \mathrm{~mA}, \overline{\mathrm{El}}=2.2 \mathrm{~V} \text { or } \\ & \mathrm{E} 2=0.8 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 5 | mA |
| Enable Supply Current | ICCEN | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, 1 \mathrm{O}=0 \mathrm{~mA}, \overline{\mathrm{E} 1}=0.8 \mathrm{~V}, \\ & \mathrm{E} 2=2.2 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 5 | mA |
| Operating Supply Current | ICCOP | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{G}}=5.5 \mathrm{~V},(\text { Note } 2), \\ & \mathrm{f}=1 \mathrm{MHz}, \overline{\mathrm{E} 1}=0.8 \mathrm{~V}, \mathrm{E} 2=2.2 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | mA |

## NOTES:

1. All voltages referenced to device GND.
2. Typical derating 5 mAMHz increase in ICCOP.
3. Tested as follows: $\mathrm{f}=2 \mathrm{MHz}, \mathrm{VIH}=2.4 \mathrm{~V}, \mathrm{VIL}=0.4 \mathrm{~V}, \mathrm{IOH}=-4.0 \mathrm{~mA}, 1 \mathrm{OL}=4.0 \mathrm{~mA}, \mathrm{VOH} \geq 1.5 \mathrm{~V}$, and $\mathrm{VOL} \leq 1.5 \mathrm{~V}$.

TABLE 1. HM-65642/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS (Continued)
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Data Retention Supply Current | ICCDR | $\begin{aligned} & H M-65642 B / 883 \\ & V C C=2.0 \mathrm{~V}, \overline{\mathrm{E} 1}=\mathrm{VCC}-0.3 \mathrm{~V} \text { or } \\ & E 2=G N D+0.3 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 75 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & H M-65642 / 883 \\ & \mathrm{VCC}=2.0 \mathrm{~V}, \overline{\mathrm{E} 1}=\mathrm{VCC}-0.3 \mathrm{~V} \text { or } \\ & \mathrm{E} 2=\mathrm{GND}+0.3 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 150 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & \mathrm{HM}-65642 \mathrm{C} / 883 \\ & \mathrm{VCC}=2.0 \mathrm{~V}, \overline{\mathrm{E} 1}=\mathrm{VCC}-0.3 \mathrm{~V} \text { or } \\ & \mathrm{E} 2=\mathrm{GND}+0.3 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 250 | $\mu \mathrm{A}$ |
| Functional Test | FT | $\mathrm{VCC}=4.5 \mathrm{~V}$ (Note 3) | 7, 8A, 8B | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES:

1. All voltages referenced to device GND.
2. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
3. Tested as follows: $\mathfrak{f}=2 \mathrm{MHz}, \mathrm{VIH}=2.4 \mathrm{~V}, \mathrm{VIL}=0.4 \mathrm{~V}, 1 \mathrm{OH}=-4.0 \mathrm{~mA}, 1 \mathrm{OL}=4.0 \mathrm{~mA}, \mathrm{VOH} \geq 1.5 \mathrm{~V}$, and $\mathrm{VOL} \leq 1.5 \mathrm{~V}$.

TABLE 2. HM-65642/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | (NOTES 1, 2) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{gathered} \text { HM-65642B/ } \\ 883 \end{gathered}$ |  | $\begin{gathered} \text { HM-65642/ } \\ 883 \end{gathered}$ |  | $\begin{gathered} \text { HM-65642C/ } \\ 883 \end{gathered}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Read/Write/ Cycle Time | TAVAX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 150 | - | 150 | - | 200 | - | ns |
| Address Access Time | TAVQV | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 150 | - | 150 |  | 200 |  |
| Output Enable Access Time | TGLQV | $\begin{aligned} & V C C=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 70 | - | 70 | - | 70 | ns |
| Chip Enable Access Time | TE1LQV TE2HQV | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 150 | - | 150 | - | 200 | ns |
| Write Recovery Time | TWHAX <br> TE1HAX TE2LAX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | 10 | - | 10 | $\bullet$ | ns |
| Chip Enable to End-of-Write | TE1LE1H TE2HE2L | $\begin{aligned} & V C C=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 90 | $\bullet$ | 90 | $\bullet$ | 120 | $\bullet$ | ns |
| Address Setup Time | TAVWL TAVE1L TAVE2H | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | $\bullet$ | 0 | - | ns |
| Write Enable Pulse Width | TWLWH | $\begin{aligned} & V C C=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 90 | - | 90 | $\bullet$ | 120 | $\bullet$ | ns |
| Data Setup Time | TDVWH TDVE1H TDVE2L | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 60 | $\bullet$ | 60 | $\bullet$ | 80 | - | ns |
| Data Hold Time | TWHDX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \\ & \hline \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | 5 | - | ns |
|  | TE1HDX | $\begin{aligned} & V C C=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | $\bullet$ | 10 | - | 10 | $\bullet$ | ns |
|  | TE2LDX | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } \\ & 5.5 \mathrm{~V} \end{aligned}$ | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | 10 | - | 10 | - | ns |

NOTES:

1. All voltages referenced to device GND.
2. $A C$ measurements assume transition time $\leq 5 \mathrm{~ns}$; input levels $=0.0 \mathrm{~V}$ to 3.0 V ; timing reference levels $=1.5 \mathrm{~V}$; output load $=1 \mathrm{TTL}$ equivalent load and CL $\geq 50 \mathrm{pF}$, for $\mathrm{CL}>50 \mathrm{pF}$, access times are derated $0.15 \mathrm{~ns} / \mathrm{pF}$.

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

Specifications HM-65642/883
TABLE 3. HM-65642/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Output High Voltage | VOH2 | $\mathrm{VCC}=4.5 \mathrm{~V}, 10=-100 \mu \mathrm{~A}$ | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\begin{gathered} \text { VCC- } \\ 0.4 \end{gathered}$ | - | V |
| Input Capacitance | CIN | VCC = Open, $f=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1,2 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | pF |
|  |  | VCC = Open, $f=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1,3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| VO Capacitance | CI/O | VCC = Open, $\mathrm{f}=1 \mathrm{MHz}$, All Measurements Referenced to Device Ground | 1,2 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 14 | pF |
|  |  | $\mathrm{VCC}=4.5 \mathrm{~V}, \mathrm{~V} / / \mathrm{O}=\mathrm{GND} \text { or }$ VCC, All Measurements Referenced to Device Ground | 1,3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | pF |
| Write Enable to Output in High Z | TWLQZ | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |
| Write Enable High to Output ON | TWHQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | ns |
| Chip Enable to Output ON | $\begin{aligned} & \text { TE1LQX } \\ & \text { TE2HQX } \end{aligned}$ | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | ns |
| Output Enable to Output ON | TGLQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | ns |
| Chip Enable to Output in High Z | TE1HQZ | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |
|  | TE2LQZ | - | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 60 | ns |
| Output Disable to Output in High Z | TGHQZ | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | ns |
| Output Hold from Address Change | TAXQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | ns |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design release and upon design changes which would affect these characteristics.
2. Applies to DIP device types only. For design purposes $\mathrm{CIN}=6 \mathrm{pF}$ typical and $\mathrm{CI} / \mathrm{O}=7 \mathrm{pF}$ typical.
3. Applies to LCC device types only. For design purposes $\mathrm{CIN}=4 \mathrm{pF}$ typical and $\mathrm{CI} / \mathrm{O}=5 \mathrm{pF}$ typical.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | GROUPS METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Interim Test 1 | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test 1 | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C and D | Samples/5005 | $1,7,9$ |

## Low Voltage Data Retention

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

1. The RAM must be kept disabled during data retention. This is accomplished by holding the E2 pin between -0.3 V and GND.
2. During power-up and power-down transitions, E2 must be held between -0.3 V and $10 \%$ of VCC.
3. The RAM can begin operating one TAVAX after VCC reaches the minimum operating voltage of 4.5 V .


## Read Cycles

read cycle l: $\overline{\mathbf{W}}, \mathrm{E} 2 \mathrm{high} ; \overline{\mathrm{G}}, \overline{\mathrm{E} 1}$ Low


READ CYCLE II: $\overline{\mathbf{W}}$ HIGH


## Write Cycles

WRITE CYCLE I: LATE WRITE


WRITE CYCLE II: EARLY WRITE - CONTROLLED BY E1


WRITE CYCLE III: EARLY WRITE - CONTROLLED BY E2


## Test Circuit



## Burn-In Circuits

HM-65642/883 CERAMIC DIP


NOTES:
FO $=100 \mathrm{kHz} \pm 10 \%$
All resistors $47 \mathrm{k} \Omega \pm 5 \%$
$\mathrm{C}=0.01 \mu \mathrm{~F}$ Min.
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V

HM-65642/883 CERAMIC LCC


NOTES:
$F O=100 \mathrm{kHz} \pm 10 \%$
$\mathrm{C}=0.01 \mu \mathrm{~F}$ Min.
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIH}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{VIL}=-0.2 \mathrm{~V}$ to +0.4 V

## Metallization Topology

## DIE DIMENSIONS:

$276.8 \times 305.5 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 2 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)

$$
\text { Ceramic LCC }-460^{\circ} \mathrm{C} \text { (Max) }
$$

WORST CASE CURRENT DENSITY:
$0.9 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout


## Packaging



LEAD FINISH: Type A
COMPLIANT OUTLINE: MIL-STD-1835, GDIP1-T28
MATERIALS: Compliant to MIL-M38510
32 PAD CERAMIC LCC


LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M38510


COMPLIANT OUTLINE: MIL-STD-1835, CQCC1-N32

HM-6564

## Features

- Low Power Standby $\qquad$ 4mW Max.
- Low Power Operation $\qquad$ 280mW/MHz Max.
- Data Retention 2.0V Min.
- TTL Compatible In/Out
- Three State Outputs
- Fast Access Time. 350ns Max.
- Operating Temperature Range . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- On Chip Address Registers
- Organizable $8 \mathrm{~K} \times 8$ or $16 \mathrm{~K} \times 4$
- 40 Pin DIP Pinout - 2.000" x 0.900"


## Ordering Information

| PACKAGE | TEMP. RANGE | 350ns |
| :---: | :---: | :---: |
| Module | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM5-6564-8 |

## Description

The HM-6564 is a 64K bit CMOS RAM. It consists of 16 HM-6504 4K x 1 CMOS RAMs, in leadless carriers, mounted on a ceramic substrate. The HM-6564 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 8K 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 8 K by 8 or a 16 K by 4 array.
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 non-volatile 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.

Pinout

|  | 40 LEAD MODULE TOP VIEW |  |
| :---: | :---: | :---: |
| -GND 1 | $\checkmark$ | 40 vcc |
| 042 |  | 3900 |
| D4 3 |  | 38 DO |
| 054 |  | 37 O |
| D5 5 |  | 36 D 1 |
| A0 6 |  | 35 A11 |
| A1 7 |  | 34 A10 |
| A2 8 |  | 33 A9 |
| E3 9 |  | $32 \mathrm{E1}$ |
| *W2 10 |  | $3{ }^{\text {W1 }}$ * |
| W2 11 |  | $3{ }^{\text {W1 }}$ |
| E4 12 |  | 2 E E2 |
| A6 13 |  | 28 A5 |
| A7 14 |  | 27 A4 |
| A8 15 |  | 2 A A |
| D6 16 |  | 25 D 2 |
| 0617 |  | 2402 |
| D7 18 |  | 23 D3 |
| Q7 19 |  | 22 Q3 |
| *VCc 20 | $N$ | 21 GND* |

NOTES:

* Pins 20 and 40 (VCC) are internally connected. Similarly pins 1 and 21 (Ground) are connected. The user is advised to connect all four VCC pins and Ground pins to his board busses. This will improve power distribution across the array and will enhance decoupling.
Pin 10 is internally connected to pin 11, and pin 30 is connected to pin 31.

Functional Diagram


## Absolute Maximum Ratings



## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . 4.4 .5 V to +5.5 V Rise and Fall Time . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40ns Max.
Operating Temperature Range.
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

DC Electrical Specifications $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-6564-8)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCSB | Standby Supply Current | - | 800 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| ICCOP1 | Operating Supply Current (8K $\times 8$ ) (Note 1) | - | 56 | mA | $\overline{\mathrm{E}}=1 \mathrm{MHz}, \mathrm{IO}=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or }$ GND, VCC = 5.5V |
| ICCOP2 | Operating Supply Current (16K $\times 4$ ( (Notes 1, 2) | - | 28 | mA | $\begin{aligned} & \bar{E}=1 \mathrm{MHz}, 1 \mathrm{IO}=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & G N D, V C C=5.5 \mathrm{~V} \end{aligned}$ |
| ICCDR | Data Retention Supply Current | - | 400 | $\mu \mathrm{A}$ | $\begin{aligned} & 10=0 \mathrm{~mA}, \mathrm{VCC}=2.0 \mathrm{~V}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & \text { GND } \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| IIA | Address Input Leakage | -20 | +20 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| IID1 | Data Input Leakage ( $8 \mathrm{~K} \times 8$ ) | -3 | +3 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| IID2 | Data Input Leakage (16K $\times 4$ ) (Note 2) | -5 | +5 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| IIE1 | Enable Input Leakage (8K $\times 8$ ) | -10 | +10 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| IIE2 | Enable Input Leakage (16K $\times 4$ ) (Note 2) | -5 | +5 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| IIW | Write Enable Input Leakage (Each) | -10 | +10 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| IOZ1 | Output Leakage (8K $\times 8$ ) | -5 | +5 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| 1OZ2 | Output Leakage (16K $\times 4$ ) (Note 2) | -10 | +10 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage | 0 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage | VCC-2.0 | VCC | V | VCC $=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $1 \mathrm{O}=2.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH1 | Output High Voltage | 2.4 | - | V | $10=-1.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 2) | VCC-0.4 | - | V | $1 \mathrm{O}=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| CIA | Address Input Capacitance (Note 2) | - | 200 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are |
| CID1 | Data Input Capacitance (8K $\times 8$ ) (Note 2) | - | 50 | pF | referenced to device GND |
| CID2 | Data Input Capacitance (16K $\times 4$ ) (Note 2) | - | 100 | pF |  |
| CIE1 | Enable Input Capacitance (8K $\times 8$ ) (Note 2) | - | 160 | pF |  |
| CIE2 | Enable Input Capacitance (16K $\times 4$ ) (Note 2) | - | 80 | pF |  |
| CIW | Write Enable Input Capacitance (Each) (Note 2) | - | 100 | pF |  |
| CO1 | Output Capacitance (8K $\times 8$ ) (Note 2) | - | 50 | pF |  |
| CO 2 | Output Capacitance (16K x 4) (Note 2) | $\bullet$ | 100 | pF |  |

NOTES:

1. ICCOP is proportional to operating frequency.
2. Tested at initial design and after major design changes.

AC Electrical Specifications $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ( $\mathrm{HM}-6564-8$ )

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| (1) TELQV | Chip Enable Access | - | 350 | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access (TAVQV = TELQV + TAVEL) | - | 400 | ns | (Notes 1, 3) |
| (3) TELQX | Output Enable | 5 | - | ns | (Notes 2, 3) |
| (4) TEHQZ | Output Disable | - | 120 | ns | (Notes 2, 3) |
| (5) TELEL | Read or Write Cycle | 480 | - | ns | (Notes 1, 3) |
| (6) TELEH | Chip Enable Low | 350 | - | ns | (Notes 1, 3) |
| (7) TEHEL | Chip Enable High | 130 | - | ns | (Notes 1, 3) |
| (8) TAVEL | Address Setup | 50 | - | ns | (Notes 1, 3) |
| (9) TELAX | Address Hold | 50 | - | ns | (Notes 1,3) |
| (10) TWLWH | Write Enable Low | 150 | - | ns | (Notes 1,3) |
| (11) TWLEH | Write Enable Setup | 250 | - | ns | (Notes 1,3) |
| (12) TWLEL | Early Write Setup (Write Mode) | 10 | - | ns | (Notes 1, 3) |
| (13) TELWH | Early Write Hold (Write Mode) | 100 | - | ns | (Notes 1, 3) |
| (14) TDVWL | Data Setup | 10 | - | ns | (Notes 1,3) |
| (15) TDVEL | Early Write Data Setup | 10 | - | ns | (Notes 1,3) |
| (16) TWLDX | Data Hold | 100 | - | ns | (Notes 1, 3) |
| (17) TELDX | Early Write Data Hold | 100 | - | ns | (Notes 1, 3) |

## NOTES:

1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 5 ns max; Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent and $C L=50 \mathrm{pF}$ (Min) for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V

## 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 +0.3 V to VCC.
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 held high (e.g. $\overline{\mathrm{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 after VCC reaches the minimum operating voltage ( 4.5 volts).

## DATA RETENTION TIMING



Read Cycle


TRUTH TABLE

| TIME <br> REFERENCE | OUTPUT |  |  | FUNCTION |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
|  | $\overline{\mathrm{E}}$ | $\overline{\mathrm{W}}$ | $\mathbf{A}$ |  |  |
| -1 | H | X | X | Z | Memory Disabled |
| 0 | L | H | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | H | X | X | Output Enabled |
| 2 | L | H | X | V | Output Valid |
| 3 | $\nearrow$ | H | X | V | Read Accomplished |
| 4 | H | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | L | H | V | 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 ( $\mathrm{T}=1$ ) the output becomes
enabled but data is not valid until during time $(T=2) . \bar{W}$ must remain high until after time ( $\mathrm{T}=2$ ). After the output data has been read, $\overline{\mathrm{E}}$ may return high $(\mathrm{T}=3)$. This will disable the output buffer and ready the RAM for the next memory cycle ( $\mathrm{T}=4$ ).


TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | $\begin{gathered} \text { OUTPUT } \\ \mathbf{Q} \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}}$ | $\overline{\text { w }}$ | A | D |  |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | , | L | V | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | X | X | X | Z | Write in Progress Internally |
| 2 | r | X | X | X | Z | Write Complete |
| 3 | H | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 4 | $\downarrow$ | 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 $\bar{E}$ (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 the 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 ( $\mathrm{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 disables and all signals are unlatched. The device is now ready for the next cycle.

## Late Write

 Cycle

TRUTH TABLE

| time REFERENCE | INPUTS |  |  |  | $\begin{gathered} \text { OUTPUT } \\ \mathbf{a} \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\text { w }}$ | A | D |  |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | 1 | H | V | X | Z | Cycle Begins, Addresses are Latched |
| 1 | L | + | X | V | X | Write Begins, Data is Latched |
| 2 | L | H | X | X | X | Write in Progress Internally |
| 3 | $\stackrel{\sim}{\sim}$ | H | X | X | X | Write Completed |
| 4 | H | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | H | V | X | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

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

NOTE: In the above descriptions the numbers in parenthesis $(T=n$ ) refers 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)



## Organization Guide

## To Organize 8K x 8:

Connect: $\overline{E 1}$ with $\overline{E 3}$
E2 with E4
$\overline{\mathrm{W}} 1$ with $\overline{\mathrm{W}} 2$
(Pins $9+32$ )
(Pins $12+29$ )
(Pins $11+31$ )

## To Organize 16K x 4:

Connect: Q0 with Q4
D0 with D4
(Pins $2+39$ )
Q1 with Q5
D1 with D5
D2 with D6
Q2 with Q6
D3 with D7
Q3 with Q7
Optional $\overline{\mathrm{W} 1}$ may be common with $\overline{\mathrm{W} 2}$
(Pins $3+38$ )
(Pins $4+37$ )
(Pins $5+36$ )
(Pins $16+25$ )
(Pins $17+24$ )
(Pins $18+23$ )
(Pins $19+22$ )
(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 E2. 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 avoid.

## 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.

## Board Size Tradeoffs

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<nd>6564 RAM array. Both fine line, close tolerance layout and standard "easy" layout board sizes are shown in the comparison.
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 of 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.

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

| PACKAGE | CIRCUIT SUBSTRATE | SIZE |
| :--- | :--- | :--- |
| 18 Pin DIP | Standard Two Sided PCB | 12 to 15 square inches |
| 18 Pin DIP | Fine Line or Multilayer PCB | 9 to 11 square inches |
| 18 Pin Leadless Carrier | Multilayer Alumina Substrate | 3 to 5 square inches |
| HM-6564 | Two Sided Mounting Multilayer <br> Alumina Substrate | 2 square inches |

# 8K x 8 Asynchronous CMOS Static RAM Module 

## Features

- Full CMOS Design
- 6 Transistor Memory Cell
- Low Standby Current. . . . . . . . . . . . . . . . . . . . 250/900 $\mu \mathrm{A}$
- Low Operating Current

70 mA

- Fast Address Access Time . . . . . . . . . . . 100/120/150ns
- CMOS/TTL Compatible Inputs/Outputs
- JEDEC Approved Pinout
- Equal Cycle and Access Time
- No Clocks or Strobes Required
- Single 5 Volt Supply
- Gated Inputs - No Pull-Up or Pull-Down Resistors Required
- Temperature Range . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- Easy Microprocessor Interfacing
- Dual Chip Enable Control (HM-8808A)


## Description

The HM-8808 and HM-8808A are 8K x 8 Asynchronous CMOS Static RAM Modules, based on multi-layered, co-fired, dual-in-line substrates. Mounted on each substrate are four HM-65162 $2 \mathrm{~K} \times 8$ CMOS SRAMs, a high speed CMOS decoder, and a ceramic decoupling capacitor, all packaged in leadless chip carriers. The capacitor is added to reduce noise and the need for external decoupling. The HM-65162 RAMs used in these modules are full CMOS devices, utilizing arrays of six transistor (6T) memory cells for the most stable and lowest possible standby supply current over the full military temperature range. In addition to this, the high stability of the 6 T cell provides excellent protection against soft errors due to noise and alpha particles. This stability also improves the radiation tolerance of the RAM over that of four transistor devices. The HM-8808 and HM8808A have gated inputs to simplify system design for optimum standby supply current. The pinouts of these modules conform to the JEDEC 28 pin 8 bit wide standard, which is compatible with a variety of industry standard memories. The HM-8808A is pin-compatible with many standard 8K $\times 8$ RAMs, adding the advantage of high performance over the full military temperature range. Also, because of the second chip enable (E2), the HM-8808A simplifies the design of low-power battery back-up memory systems.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 100ns | 120ns | 150ns |
| :--- | :---: | :--- | :--- | :--- |
| MODULE | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM5-8808S-8 | HM5-8808B-8 | HM5-8808-8 |
| MODULE | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM5-8808AS-8 | HM5-8808AB-8 | HM5-8808A-8 |

## Pinouts



| PIN | DESCRIPTION |
| :---: | :--- |
| $A$ | InputAddress Input |
| DQ | Data Input/Output |
| $\overline{\bar{E}}$ | Chip Enable (HM-8808) |
| $\overline{E 1}$ | Chip Enable (HM-8808A) |
| $\overline{E 2}$ | Chip Enable (HM-8808A) |
| $\bar{W}$ | Write Enable |
| $\bar{G}$ | Output Enable |

Functional Diagram


## Absolute Maximum Ratings



CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent darnage 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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V Input Rise ànd Fall Time . . . . . . . . . . . . . . . . . . . . . . . . . . . 40ns Max.
Operating Temperature Range . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

## DC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{HM}-8808 \mathrm{X}-8)$

| SYMBOL | PARAMETER | MIN | MAX | UNTTS | TEST CONDITIONS (NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCSB1 | Standby Supply Current (CMOS) | - | 250 | $\mu \mathrm{A}$ | HM-8808S/AS-8, HM-8808B/AB-8 $10=0$, $E=$ VCC-0.3V (Note 4), E2 $=0.3 \mathrm{~V}$ (Note 5) |
|  |  | - | 900 | $\mu \mathrm{A}$ | HM-8808_/A-8 $10=0, E=V C C-0.3 V$ (Note 4), E2 = 0.3V (Note 5) |
| ICCSB | Standby Supply Current (TTL) | - | 35 | mA | $10=0, \mathrm{E}=\mathrm{VIH}$ (Note 4), E2 = VIL (Note 5) |
| ICCEN | Enabled Supply Current | - | 60 | mA | $\begin{aligned} & \text { HM-8808S/AS-8, HM-8808B/AB-8, } 1 \mathrm{O}=0 \text {, } \\ & \mathrm{E}=\text { VIL (Note 4), } \mathrm{E} 2=\text { VIH (Note 5) } \end{aligned}$ |
|  |  | - | 70 | mA | $\begin{aligned} & \text { HM-8808 } / A-8,1 \mathrm{O}=0, \mathrm{E}=\mathrm{VIL}(\text { (Note 4), } \\ & E 2=\text { VIH (Note 5) } \end{aligned}$ |
| ICCOP | Operating Supply Current | - | 70 | mA | $\begin{aligned} & \mathrm{IO}=0, \mathrm{f}=1 \mathrm{MHz}, \mathrm{E}=\text { VIL (Note 4), E2 }=\mathrm{VIH} \\ & \text { (Notes } 2,5 \text { ) } \end{aligned}$ |
| ICCDR | Data Retention Supply Current | $\bullet$ | 125 | $\mu \mathrm{A}$ | HM-8808S/AS-8, HM-8808B/AB-8, $\mathrm{VCC}=2.0 \mathrm{~V}, \mathrm{E}=\mathrm{VCC}-0.3 \mathrm{~V}$ (Note 4), $\mathrm{E} 2=0.3 \mathrm{~V}$ (Note 5) |
|  |  | - | 400 | $\mu \mathrm{A}$ | HM-8808/A-8, <br> $\mathrm{VCC}=2.0 \mathrm{~V}, \mathrm{E}=\mathrm{VCC}-0.3 \mathrm{~V}$ (Note 4), <br> $\mathrm{E} 2=0.3 \mathrm{~V}$ (Note 5) |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=$ GND or VCC |
| IIOZ | Input/Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIO}=\mathrm{GND}$ or VCC |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, \mathrm{E}=\mathrm{VCC}(\text { Note 4), E2 = GND } \\ & \text { (Note 5) } \end{aligned}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $10=4.0 \mathrm{~mA}$ |
| VOH1 | Output High Voltage | 2.4 | - | V | $10=-1.0 \mathrm{~mA}$ |
| VOH2 | Output High Voltage | VCC-0.4 | - | V | $10=-100 \mathrm{~mA}$ (Note 3) |
| VIL | Input Low Voltage | 0 | 0.8 | V |  |
| VIH | Input High Voltage | 2.4 | VCC | V |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ (Note 3)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| CE | Enable Input Capacitance | - | 15 | pF | VE $=$ VCC or GND, $\mathrm{f}=1 \mathrm{MHz}$ (Note 3) |
| CW | Write Enable Capacitance | - | 48 | pF | $\mathrm{VW}=\mathrm{VCC}$ or $\mathrm{GND}, \mathrm{f}=1 \mathrm{MHz}$ (Note 3) |
| CI | Input Capacitance: $\overline{\mathrm{G}, \mathrm{A}}$ | - | 35 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ (Note 3) |
| ClO | Input/Output Capacitance | - | 43 | pF | VIO $=\mathrm{VCC}$ or GND, $\mathrm{f}=\mathbf{1 \mathrm { MHz } \text { (Note 3) }}$ |

## NOTES:

1. All devices tested at worst case temperature and supply voltage limits.
2. Typical derating $=5 \mathrm{mAMHz}$ increase in $I C C O P, \mathrm{VI}=\mathrm{VCC}$ or GND.
3. Guaranteed but not tested.
4. Relevant to the HM-8808-8 only.
5. Relevant to the HM-8808A-8 only.

Specifications HM-8808, HM-8808A
AC Electrical Specifications $V C C=5 \mathrm{~V} \quad 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | HM-8808S/AS-8 |  | HM-8808B/AB-8 |  | HM-8808_/A-8 |  | UNITS | (NOTES 1, 2) <br> TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |
| (1) TAVAX | Read Cycle Time | 100 | - | 120 | - | 150 | - | ns |  |
| (2) TAVQV | Address Access Time | - | 100 | - | 120 | - | 150 | ns |  |
| (3) TELQV | Chip Enable Access Time | - | 100 | - | 120 | - | 150 | ns | (Note 4) |
| (4) TGLQV | Output Enable Access Time | - | 50 | - | 65 | - | 65 | ns |  |
| (5) TELQX | Chip Enable Output Enable Time | 20 | - | 20 | - | 25 | - | ns | (Notes 3, 4) |
| (6) TGLQX | Output Enable Output Enable Time | 5 | - | 5 | - | 5 | - | ns | (Note 3) |
| (7) TAXQX | Address Output Hold Time | 5 | - | 5 | $\bullet$ | 5 | - | ns |  |
| (8) TEHQZ | Chip Disable Output Disable Time | 0 | 60 | 0 | 70 | 0 | 80 | ns | (Notes 3, 5) |
| (9) TGHQZ | Output Disable Time | 0 | 40 | 0 | 40 | 0 | 50 | ns | (Note 3) |

## WRITE CYCLE

| (10) TAVAX | Write Cycle Time | 100 | - | 120 | - | 150 | - | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (11) TELWH | Chip Enable to End of Write | 70 | - | 80 | - | 90 | - | ns | (Note 4) |
| (12) TWLWH | Write Enable Pulse Width | 40 | - | 55 | - | 65 | - | ns |  |
| (13) TELEH | Enable Pulse Width (Early Write) | 40 | - | 60 | - | 65 | - | ns | (Notes 3, 4, 5) |
| (14) TAWWL | Address Setup Time (Late Write) | 15 | - | 15 | - | 20 | - | ns |  |
| (15) TAVEL | Address Setup Time (Early Write) | 0 | - | 0 | - | 5 | - | ns | (Notes 3, 4) |
| (16) TWHAX | Address Hold Time (Late Write) | 10 | - | 10 | - | 20 | - | ns |  |
| (17) TEHAX | Address Hold Time (Early Write) | 30 | - | 30 | - | 45 | - | ns | (Note 3) |
| (18) TDVWH | Data Setup Time (Late Write) | 30 | - | 30 | - | 35 | - | ns |  |
| (19) TDVEH | Data Setup Time (Early Write) | 30 | - | 30 | - | 35 | - | ns | (Note 5) |
| (20) TWHDX | Data Hold Time (Late Write) | 10 | - | 15 | - | 20 | - | ns |  |
| (21) TEHDX | Data Hold Time (Early Write) | 30 | - | 30 | - | 45 | - | ns | (Notes 3, 5) |
| (22) TWLEH | Write Enable Pulse Setup Time | 40 | - | 55 | - | 65 | - | ns | (Note 5) |
| (23) TWLQZ | Write Enable Output Disable Time | - | 40 | - | 40 | - | 50 | ns | (Note 3) |
| (24) TWHQX | Write Disable Output Enable Time | 0 | - | 0 | - | 0 | - | ns | (Note 3) |

## NOTES:

1. All devices tested at worst case temperature and supply voltage limits.
2. Input pulse levels: VIL $=0.0 \mathrm{~V}, \mathrm{VIH}=3.0 \mathrm{~V}$ Input rise and fall times: 5 ns (max.) $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V . Input and output timing reference levels: 1.5 V Output load: 1 TTL gate equivalent and 50 pF ( min , including scope and jig).
3. Guaranteed but not tested.
4. "EL" (enable input valid) equivalent to: EL on the HM-8808-8. EIL and E2H on the HM-8808A-8
5. "EH" (enable input invalid) equivalent to: EH on the HM-8808-8. EIH or E2L on the HM-8808A-8.

HM-8808, HM-8808A

## Truth Table

| MODE | HM-8808 | HM-8808A |  | HM-8808/8808A |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | E | E1 | E2 | $\overline{\mathbf{W}}$ | $\overline{\mathbf{G}}$ |
| Standby (CMOS) | VCC | X | GND | X | X |
| Standby (TTL) | VIH | VIH | VIL | X | X |
| Enabled (High Z) | VIL | VIL | VIH | VIH | VIH |
| Write | VIL | VIL | VIH | VIL | X |
| Read | VIL | VIL | VIH | VIH | VIL |

## HM-8808 Timing Diagrams

READ CYCLE 1 (Notes 1, 2)


READ CYCLE 2 (Note 1)


NOTES:

1. In a read cycle, $W$ is held high.
2. In read cycle 1 , the module is kept continuously enabled. $\bar{G}$, and $\bar{E}$ are held at VIL.

HM-8808 Timing Diagrams (Continued)
WRTE CYCLE 1 (Notes 1, 3, 4)


WRITE CYCLE 2 (Notes 2, 4)


NOTES:

1. In Write Cycle 1, the module is first enabled and then data is strobed into the RAM with a pulse on Write Enable ( $W$ ). Because $W$ becomes valid after the part is enabled, this is sometimes referred to as a "Late Write" cycle.
2. In Write Cycle 2, Address (A) and Write Enable ( $W$ ) are first set up, and then data is strobed into the RAM with a pulse on E. Because $W$ is valid before the module is enabled, this is sometimes referred to as an "Early Write" cycle.
3. Output Enable $(\bar{G})$ is normally held stable throughout the entire cycle. If $G$ is held high, then the outputs ( $Q$ ) remain in the high impedance state. If $\bar{G}$ is held low, then it may be necessary to lengthen the cycle to prevent bus contention. This would occur if TWLQZ and TDVWH overlapped.
4. Data Inputs (D) and Data Outputs (Q) are connected internally at the DQ pins.

## HM-8808A Timing Diagrams

READ CYCLE 1 (Note 1, 2)


READ CYCLE 2 (Note 1)


NOTES:

1. In a read cycle, $W$ is held high.
2. In read cycle 2, the module is kept continuously enabled: $\bar{G}$ and $E T$ are held at VIL. E2 is held at VIH.
3. The AC timing of E2 is the same as that of ET. Only the polarity is reversed. While E1 is active low, E2 is active high. Therefore AC parameters that refer to the falling edge of enable, such as TELQV, can be applied to the rising edge of E2, and parameters that refer to the rising edge of enable, such as TEHQZ, can be applied to the falling edge of E2.

## HM-8808, HM-8808A

## HM-8808A Timing Diagrams (Continued)

WRITE CYCLE 1: Controlled by W (Notes 1, 3, 4)


WRITE CYCLE 2: Controlled by E1 (Notes 2, 4)


WRITE CYCLE 3: Controlled by E2 (Notes 2, 4)


NOTES:

1. In Write Cycle 1, the module is first enabled and then data is strobed into the RAM with a pulse on Write Enable ( $\overline{\mathbf{W}})$. Because $\bar{W}$ becomes valid after the part is enabled, this is sometimes referred to as a "Late Write" cycle.
2. In Write Cycle 2 and 3, Address (A) and Write Enable ( $W$ ) are first set up, and then data is strobed into the RAM with a pulse on ET or E2. Because W is valid before the module is enabled, this is sometimes referred to as an "Early Write" cycle.
3. Output Enable $(\bar{G})$ is normally held stable throughout the entire cycle. If $\bar{G}$ is held high, then the outputs $(Q)$ remain in the high impedance state. If $\bar{G}$ is held low, then it may be necessary to lengthen the cycle to prevent bus contention. This would occur if TWL.QZ and TDVWH overlapped.
4. Data Inputs (D) and Data Outputs (Q) are connected internally at the $D Q$ pins.
5. The AC timing of E2 is the same as that of E1. Only the polarity is reversed. While E1 is active low, E2 is active high. Therefore AC parameters that refer to the falling edge of enable, such as TELQV, can be applied to the rising edge of E2, and parameters that refer to the rising edge of enable, such as TEHQZ, can be applied to the falling edge of E 2 .

## 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. The module must be kept disabled during data retention. The Chip Enable ( $E$ ) on the HM-8808 must be held between VCC-0.3V and VCC+0.3V. Chip Enable 2 (E2) on the HM-8808A must be held between -0.3V and GND +0.3 V .
2. During power-up and power-down transitions, $E$ (HM8808) must be held between $90 \%$ of VCC and VCC +0.3 V ; E2 (HM-8808A) must be held above -0.3V and below $10 \%$ of VCC.
3. The RAM module can begin operation one TAVAX after VCC reaches the minimum operating voltage (4.5V).

HM-8808 Data Retention Timing
DATA RETENTION MODE


HM-8808A Data Retention Timing
DATA RETENTION MODE


# 16K x 8 High Speed Asynchronous CMOS Static RAM Module 

## Description

The HM-8816H is a high speed, asynchronous CMOS static RAM module, based on a multilayer, co-fired, dual-in-line ceramic substrate and eight HM-65262 $16 \mathrm{~K} \times 1$ asynchronous CMOS static RAMs packaged in leadless chip carriers. The HM-8816H uses on-substrate decoupling capacitors packaged in leadless chip carriers to reduce electrical noise and improve reliability. The pinout of the $\mathrm{HM}-8816 \mathrm{H}$ conforms to the JEDEC 8 bit wide, 28 pin RAM standard, which allows the system designer to design sockets that will accommodate a variety of industry standard RAMs and EPROMs. The HM-8816H also has gated inputs to simplify system design for optimum standby supply current.

The HM-65262 RAMs used in this module are full CMOS devices, utilizing arrays of six transistor (6T) memory cells for the most stable and lowest possible standby supply current over the full military temperature range. In addition to this, the high stability of the 6 T cell provides excellent protection against soft errors due to electrical noise and alpha particles. This stability also improves the radiation tolerance of the RAMs over that of four transistor devices.

## Pinout

| 28 LEAD MODULE TOP VIEW |  |
| :---: | :---: |
| NC 1 | 28 vcc |
| A12 2 | 27 w |
| A7 3 | 26 A13 |
| A6 4 | 25 AB |
| A5 5 | 24) A 9 |
| A4 6 | 23 A11 |
| A3 7 | 22 NC |
| A2 8 | 21 A10 |
| A1 9 | 20 E |
| A0 10 | $19 \mathrm{DQ7}$ |
| DQ0 11 | 18 DQ6 |
| DQ1 12 | 17 DQ5 |
| DQ2 13 | 16 DQ4 |
| GND 14 | 15 DQ3 |

## Ordering Information

| PACKAGE | TEMPERATURE <br> RANGE | 70ns | 80ns |
| :--- | :---: | :---: | :---: |
| MODULE | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $\mathrm{HM} 5-8816 \mathrm{HB}-8$ | $\mathrm{HM} 5-8816 \mathrm{H}-8$ |

Functional Diagram


TRUTH TABLE

| MODE | $\overline{\mathbf{E}}$ | $\overline{\mathbf{W}}$ |
| :--- | :---: | :---: |
| Standby (CMOS) | VCC | X |
| Standby (TTL) | VIH | X |
| Read | VIL | VIH |
| Write | VIL | VIL |

PIN DESCRIPTIONS

| PIN | FUNCTION |
| :--- | :--- |
| AO-A13 | Address Inputs |
| DQ0-DQ7 | Data Input/Outputs |
| $\bar{E}$ | Chip Enable |
| W | Write Enable |
| VCC | Power ( +5 V ) |
| GND | GND |

## Absolute Maximum Ratings


CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permenent 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.

## Operating Conditions


DC Electrical Specifications $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{HM}-8816 \mathrm{HB}-8, \mathrm{HM}-8816 \mathrm{H}-8)$

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSBI | Standby Supply Current (CMOS) | - | 800 | $\mu \mathrm{A}$ | $10=0, \bar{E}=V C C-0.3 V$ |
| ICCSB | Standby Supply Current (TTL) | - | 40 | mA | $10=0, \bar{E}=\mathrm{VIH}$ |
| ICCEN | Enabled Supply Current | - | 400 | mA | $10=0, \bar{E}+$ VIL, VIN $=$ VIH or VIL |
| ICCOP | Operating Supply Current (Note 1) | - | 400 | mA | $\begin{aligned} & 10=0, f=1 M H z, E=V I L, V I N=V C C \\ & \text { or } G N D \end{aligned}$ |
| ICCDR | Data Retention Supply Current | - | 320 | $\mu \mathrm{A}$ | $\mathrm{VCCC}=2.0 \mathrm{~V}, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}, 10=0$ |
| 11 | Input Leakage Current | -1 | +1 | $\mu \mathrm{A}$ | VIN = VCC or GND |
| IIOZ | I/O Leakage Current | -1 | +1 | $\mu \mathrm{A}$ | VIO $=$ VCC or GND |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V | $\overline{\mathrm{E}}=\mathrm{VCC}$ |
| VOL | Output Voltage Low | - | 0.4 | v | $10 \mathrm{~L}=0.8 \mathrm{~mA}$ |
| VOH1 | Output Voltage High | 2.4 | - | V | $10 \mathrm{H}=-4.0 \mathrm{~mA}$ |
| VOH2 | Output Voltage High (Note 2) | VCC - 0.4 | - | V | $10 \mathrm{H}=100 \mathrm{~mA}$ |
| VIL | Input Voltage Low | 0 | 0.8 | V |  |
| VIH | Input Voltage High | 2.4 | vcc | V |  |

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

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| Cl | Input Capacitance | 70 | pF | $\mathrm{f}=1 \mathrm{MHz}$, VIN $=$ VCC or GND |
| CIO | Input/Output Capacitance | 25 | pF | $\mathrm{f}=1 \mathrm{MHz}$, VIO $=$ VCC or GND |

NOTES:

1. Typical derating: 40 mAMHz increase in ICCOP.
2. Tested at initial design and after major design changes.

AC Electrical Specifications $\quad \mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-8816HB-8, HM-8816H-8)

| SYMBOL | PARAMETER | LImits |  |  |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-8816HB |  | HM-8816H |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |

READ CYCLE

| (1) TAVAX | Read Cycle Time | 70 | - | 85 | - | ns | 1,3 |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| (2) TAVQV | Address Access Time | - | 70 | - | 85 | ns | 1,3 |
| (3) TELQV | Chip Enable Access Time | - | 70 | - | 85 | ns | 1,3 |
| (4) TELQX | Chip Enable Output Enable Time | 5 | - | 5 | - | ns | 2,3 |
| (5) TEHQX | Chip Enable Output Hold Time | 5 | - | 5 | - | ns | 2,3 |
| (6) TAXQX | Address Output Hold Time | 5 | - | 5 | - | ns | 2,3 |
| (7) TEHQZ | Chip Disable Output Disable Time | 0 | 40 | 0 | 40 | ns | 2,3 |

WRITE CYCLE

| (8) TAVAX | Write Cycle Time |  | 70 | - | 85 | $\bullet$ | ns | 1,3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (9) TELWH | Chip Enable to End of Write | W Controlled | 65 | - | 75 | - | ns | 1,3 |
| (10) TELEH | Chip Enable to End of Write | $\bar{E}$ Controlled | 65 | - | 75 | - | ns | 2, 3 |
| (11) TWLWH | Write Pulse Width |  | 55 | $\bullet$ | 60 | - | ns | 1,3 |
| (12) TAVWL | Address Setup Time | $\bar{W}$ Controlled | 0 | $\bullet$ | 0 | - | ns | 1,3 |
| (13) TAVEL | Address Setup Time | $\bar{E}$ Controlled | 0 | - | 0 | $\bullet$ | ns | 2, 3 |
| (14) TWHAX | Write Recovery Time | W Controlled | 10 | - | 10 | - | ns | 1,3 |
| (15) TEHAX | Write Recovery Time | E Controlled | 10 | - | 10 | - | ns | 2, 3 |
| (16) TDVWH | Data Setup Time | $\bar{W}$ Controlled | 30 | $\bullet$ | 35 | - | ns | 1,3 |
| (17) TDVEH | Data Setup Time | $\bar{E}$ Controlled | 30 | - | 35 | - | ns | 2, 3 |
| (18) TWHDX | Data Hold Time | $\bar{W}$ Controlled | 5 | $\bullet$ | 5 | - | ns | 1,3 |
| (19) TEHDX | Data Hold Time | $\bar{E}$ Controlled | 10 | $\bullet$ | 10 | - | ns | 1,3 |
| (20) TWLQZ | Write Enable Low to Output Off |  | - | 40 | - | 40 | ns | 2, 3 |
| (21) TWHQX | Write Enable High to Output On |  | 0 | - | 0 | - | ns | 2, 3 |

## NOTES:

1. Input puise levels: 0 to 3.0 V ; Input rise and fall times: 5 ns max.; Input and output timing reference level; 1.5 V ; Output Load: 1 TTL gate equivalent and $C L=50 \mathrm{pF}(\mathrm{min})$ - for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .

## Timing Diagram

READ CYCLE 1: CONTROLLED BYE


NOTE: $\bar{W}$ is held high for entire cycle and $D$ is ignored. Address is stable by the time $\bar{E}$ goes low and remains valid until $\bar{E}$ goes high.

READ CYCLE 2: CONTROLLED BY ADDRESS
(1)


NOTE: $\bar{W}$ is high for entire cycle and $D$ is ignored. $\bar{E}$ is stable prior to $A$ becoming valid and after $A$ becomes invalid.
WRITE CYCLE 1: CONTROLLED BY $\overline{\mathbf{W}}$ (LATE WRITE)


NOTE: In this mode, $\overline{\mathrm{E}}$ rises after $\overline{\mathrm{W}}$. The address must remain stable whenever both $\overline{\mathrm{E}}$ and $\overline{\mathrm{W}}$ are low.

## Timing Diagrams (Continued)

WRITE CYCLE 2: CONTROLLED BY E (EARLY WRITE)


NOTE: In this mode, $\bar{W}$ rises after $\overline{\bar{E}}$. If $\bar{W}$ falls before $\overline{\mathrm{E}}$ by a time exceeding TWLQZ (Max) - TELQX (Min), and rises after $\overline{\mathrm{E}}$ by a time exceeding TEHQZ (Max - TWHQZ (Min), then Q will remain in the high impedance state throughout the cycle. The address must remain stable whenever $\overline{\mathrm{E}}$ and $\overline{\mathrm{W}}$ are both low.

## 32K x 8 Asynchronous CMOS Static RAM Module

## Description

The HM-8832 is a $32 \mathrm{~K} \times 8$ Bit Asynchronous CMOS Static RAM Module based on a multilayered, co-fired, dual-in-line ceramic substrate, four HM-65642 CMOS Asynchronous Static RAMs, and an HCT-138 high-speed CMOS decoder, all mounted in ceramic leadless chip carriers. In addition to this, each module is equipped with a ceramic capacitor to minimize power supply noise and reduce the need for external decoupling. Furthermore, this capacitor is sealed in a ceramic leadless carrier for maximum reliability, even in extreme environments. All inputs on the HM-8832 are gated by the $\bar{E}$ input to simplify system design requirements to obtain the minimum standby and data retention supply current. The pinout of the HM-8832 conforms with the JEDEC standard for eight-bit wide, 28 pin RAMs, which allows the module to be pin compatible with future generations of high density RAMs and EPROMs.
The HM-65642 RAMs used on the HM-8832 module are full CMOS devices, utilizing arrays of six-transistor (6T) memory cells for the most stable and lowest possible standby and data retention supply current over the full military operating temperature range. In addition to this, the high stability of the 6 T cell provides excellent protection against soft errors due to power supply noise and alpha particles. This stability also improves the radiation tolerance of the module over that of RAMs utilizing four transistor (4T) Mix-MOS memory cells.

* Access Time/Data Retention Supply Current


## Features

- Full CMOS Six Transistor Memory Cell
- Low Standby Supply Current . . . . . . . . . . . . . . . . $250 \mu \mathrm{~A}$
- Low Operating Supply Current. . . . . . . . . . . . . . . . 15mA
- Fast Address Access Time . . . . . . . . . . . . . . . . . . 180ns
- Low Data Retention Supply Voltage. . . . . . . . . . . . . 2.0V
- CMOS/TTL Compatible Inputs/Outputs
- JEDEC Approved Pinout
- Equal Cycle and Access Times
- No Clocks or Strobes Required
- Single 5V Power Supply
- Easy Microprocessor Interfacing
- Operating Temperature Range . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- Standard DIP Size - 0.6" $\times 1.4^{\prime \prime}$

Ordering Information

| PKG | TEMP. RANGE | 180ns $/ 200 \mu \mathrm{~A}^{*}$ | 180ns $/ 750 \mu \mathrm{~A}^{*}$ |
| :---: | :---: | :---: | :--- |
| MODULE | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM5-8832B-8 | HM5-8832-8 |

## Functional Diagram



TRUTH TABLE

| MODE | $\overline{\mathbf{E}}$ | $\overline{\mathbf{W}}$ | $\overline{\mathbf{G}}$ |
| :--- | :---: | :---: | :---: |
| Standby (CMOS) | VCC | X | X |
| Standby (TTL) | VIH | X | X |
| Enabled (High Z) | VIL | VIH | VIH |
| Read | VIL | VIH | VIL |
| Write | VIL | VIL | X |


| PIN | FUNCTION |
| :--- | :--- |
| A0-A14 | Address Inputs |
| DQ0-DQ7 | Data Input/Output |
| $\bar{E}$ | Chip Enable |
| $\bar{G}$ | Output Enable |
| $\bar{W}$ | Write Enable |
| VCC | Power (+5V) |
| GND | Ground |

## Absolute Maximum Ratings

Supply Voltage .
. 7.0 V
Input, Output or I/O Voltage . . . . . . . . . . . . . GND-0.3V to VCC +0.3 V
Storage Temperature Range
GND-0.3V to VCC +0.3 V
. . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature
$+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s)
$+300^{\circ} \mathrm{C}$
Gate Count
405,230 Gates
CAUTION: Stresses above those listed in "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.

## Operating Conditions


DC Electrical Specifications $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{HM}-8832 \mathrm{~B}-8, \mathrm{HM}-8832-8$ )

| SYMBOL | PARAMETER | LIMITS |  | UNITS | (NOTE 1) <br> TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSBI | Standby Supply Current (CMOS) | - | 250 | $\mu \mathrm{A}$ | HM-8832B, $\mathrm{IO}=0, \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V}$ |
|  |  | - | 900 | $\mu \mathrm{A}$ | HM-8832, $10=0, \bar{E}=\mathrm{VCC}-0.3 \mathrm{~V}$ |
| ICCSB | Standby Supply Current (TTL) | - | 2 | mA | HM-8832B, $10=0, \bar{E}=\mathrm{VIH}$ |
|  |  | - | 10 | mA | HM-8832, $10=0, \bar{E}=$ VIH |
| ICCEN | Enabled Supply Current | - | 10 | mA | $10=0, \bar{E}=\mathrm{VIL}$ |
| ICCOP | Operating Supply Current (Note 3) | - | 15 | mA | $\begin{aligned} & 10=0, f=1 \mathrm{MHz}, \bar{E}=\text { VIL, VIN }=V C C \\ & \text { or } G N D \end{aligned}$ |
| ICCDR | Data Retention Supply Current | - | 200 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{HM}-8832 \mathrm{~B}, \mathrm{VCC}=2.0 \mathrm{~V}, \\ & \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V} \end{aligned}$ |
|  |  | - | 750 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{HM}-8832, \mathrm{VCC}=2.0 \mathrm{~V}, \\ & \overline{\mathrm{E}}=\mathrm{VCC}-0.3 \mathrm{~V} \end{aligned}$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | VIN = VCC or GND |
| 1102 | I/O Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIO}=\mathrm{VCC}$ or GND |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V | $\overline{\mathrm{E}}=\mathrm{VCC}$ |
| VOL | Output Voltage Low | - | 0.4 | V | $1 \mathrm{OL}=4.0 \mathrm{~mA}$ |
| VOH1 | Output Voltage High | 2.4 | - | V | $1 \mathrm{OH}=-1.0 \mathrm{~mA}$ |
| VOH2 | Output Voltage High (Note 2) | vcc - 0.4 | - | v | $1 \mathrm{OH}=100 \mu \mathrm{~A}$ |
| VIL | Input Voltage Low | 0 | 0.8 | V |  |
| VIH | Input Voltage High | 2.4 | VCC | V |  |

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

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :--- |
| CA | Address Input Capacitance | 40 | pF | $\mathrm{VA}=\mathrm{VCC}$ or $G N D, f=1 \mathrm{MHz}$ |
| CDQ, CG | Data, Output Enable Capacitance | 45 | pF | VDQ, VG $=\mathrm{VCC}$ or $\mathrm{GND}, \mathrm{f}=1 \mathrm{MHz}$ |
| CEN | Chip Enable Capacitance | 15 | pF | VEN $=\mathrm{VCC}$ or $G N D, f=1 \mathrm{MHz}$ |
| CW | Write Enable Capacitance | 60 | pF | $\mathrm{VW}=\mathrm{VCC}$ or $G N D, f=1 \mathrm{MHz}$ |

NOTES:

1. All devices tested at worst case temperature and supply voltage limits.
2. Guaranteed but not tested.
3. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.

## AC Electrical Specifications $\quad V C C=5 \mathrm{~V} \pm 10 \%, T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}(\mathrm{HM}-8832 \mathrm{~B}-8, \mathrm{HM}-8832-8)$

| SYMBOL | PARAMETER | LIMITS |  |  |  | UNITS | (NOTES 1, 3) TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-8832B-8 |  | HM-8832-8 |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |
| READ CYCLE |  |  |  |  |  |  |  |
| (1) TAVAX | Read Cycle Time | 180 | - | 180 | - | ns |  |
| (2) TAVQV | Address Access Time | - | 180 | - | 180 | ns |  |
| (3) TELQV | Chip Enable Access Time | - | 180 | - | 180 | ns |  |
| (4) TGLQV | Output Enable Access Time | - | 75 | - | 75 | ns |  |
| (5) TELQX | Chip Enable Output Enable Time | 10 | - | 10 | - | ns | (Note 2) |
| (6) TGLQX | Output Enable Time | 5 | - | 5 | - |  | (Note 2) |
| (7) TAXQX | Address Output Hold Time | 10 | - | 10 | - | ns | (Note 2) |
| (8) TEHQZ | Chip Disable Output Disable Time | 0 | 80 | 0 | 80 | ns | (Note 2) |
| (9) TGHQZ | Output Disable Time | 0 | 55 | 0 | 55 | ns | (Note 2) |

WRITE CYCLE

| (10) TAVAX | Write Cycle Time |  | 180 | - | 180 | - | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (11) TWLWH | Write Pulse Width |  | 95 | - | 95 | - | ns |  |
| (12) TELWH | Chip Enable to End of Write | $\overline{\text { W }}$ Controlled | 95 | $\bullet$ | 95 | - | ns |  |
| (13) TELEH | Chip Enable to End of Write | $\overline{\text { E Controlled }}$ | 90 | - | 90 | - | ns | (Note 2) |
| (14) TAVWL | Address Setup Time | W Controlled | 30 | - | 30 | - | ns |  |
| (15) TAVEL | Address Setup Time | $\overline{\text { E Controlled }}$ | 30 | - | 30 | - | ns | (Note 2) |
| (16) TWHAX | Write Recovery Time | $\overline{\text { W }}$ Controlled | 10 | - | 10 | - | ns |  |
| (17) TEHAX | Write Recovery Time | $\bar{E}$ Controlled | 40 | - | 40 | - | ns | (Note 2) |
| (18) TDVWH | Data Setup Time | W Controlled | 65 | - | 65 | - | ns |  |
| (19) TDVEH | Data Setup Time | $\overline{\text { E Controlled }}$ | 65 | - | 65 | - | ns | (Note 2) |
| (20) TWHDX | Data Hold Time | W Controlled | 10 | - | 10 | - | ns |  |
| (21) TEHDX | Data Hold Time | $\overline{\text { E Controlled }}$ | 40 | - | 40 | - | ns | (Note 2) |
| (22) TWLQZ | Write Enable Output Disable Time |  | - | 15 | - | 55 | ns | (Note 2) |
| (23) TWHQX | Write Disable Output Enable Time |  | 5 | - | 5 | - | ns | (Note 2) |

NOTES:

1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent $C L=100 \mathrm{pF}(\mathrm{min})$ including scope and jig - for CL greater than 100 pF , access time is derated by 0.15 ns per pF .
2. Guaranteed but not tested.
3. All devices tested at worst case temperature and supply voltage limits.

## Timing Diagram

READ CYCLE 1: ADDRESS CONTROLLED (Notes 1, 2)


READ CYCLE 2: $\overline{\mathrm{E}} \mathbf{O R} \overline{\mathrm{G}}$ CONTROLLED (Note 1)


READ CYCLE NOTES: 1. In a read cycle, $\bar{W}$ is held high.
2. In read cycle 1, the module is kept continuously enabled: $\overline{\mathrm{E}}$ and $\overline{\mathrm{G}}$ are held low.

WRITE CYCLE 1: $\overline{\mathbf{W}}$ CONTROLLED (Note 1)


WRITE CYCLE 1: E CONTROLLED (Note 2)


WRITE CYCLE NOTES: 1. In Write Cycle 1, the module is first enabled, and then data is strobed into the RAM with a pulse on $\bar{W}$. If $\bar{G}$ is held high for the entire cycle, the outputs will remain in the high impedance state. If $\overline{\mathrm{G}}$ is held low, it may be necessary to lengthen the cycle to prevent bus contention. This would occur if TWLQZ and TDVWH overlapped. 2. In Write Cycle 2, Address (A) and Write Enable $(\bar{W})$ are first setup and then data is strobed into the RAM with a pulse on $\overline{\mathrm{E}}$.

## 256K Synchronous CMOS RAM Module

## Description

The HM-92560 is a high density 256K bit CMOS RAM module. Sixteen synchronous HM-6516 2K x 8 CMOS RAMs in Leadless Chip Carriers are mounted on a multilayer ceramic substrate. The HM92560 RAM module is organized as two $16 \mathrm{~K} \times 8$ CMOS RAM arrays sharing a common address bus. Separate data input/output buses and chip enables allow the user to format the 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 package technique combines the high packing density of CMOS and Leadless Chip Carriers with the ease of use of DIP packaging.

| PACKAGE | TEMP. RANGE | 150ns |
| :---: | :---: | :---: |
| Module | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM5-92560-8 |

## Features

- Low Standby Current.
$500 \mu \mathrm{~A}$
- Fast Address Access Time . . . . . . . . . . . .170ns
- Data Retention . . . . . . . . . . . . . . 2.0V Min VCC
- Three-State Outputs
- Organizable as 32K x 8 or 16K x 16 Array
- On Chip Address Registers
- 48 Pin DIP Pinout . . . . . $2.66^{\prime \prime} \times 1.30^{\prime \prime} \times 0.29 "$
- Synchronous Operation . . . . . . . . 30mAMHz Yields Low Operating Power
- Operating Temperature Range . . . . . . $-55^{\circ} \mathrm{C}$ to
$+125^{\circ} \mathrm{C}$


## Ordering Information

## Pinout

## 48 LEAD MODULE <br> TOP VIEW

## Functional Diagram



## Organizational Guide

FOR 32K $\times 8$ CONFIGURATION
CONNECT: PIN 16 (DQ0) 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 16K $\times 16$ CONFIGURATION
CONNECT: PIN $6(\overline{\mathrm{E} 1})$ to PIN 15 ( $\overline{\mathrm{E9}})$
PIN $7(\overline{E 2})$ to PIN 24 ( $\overline{\mathrm{E} 10}$ )
PIN 8 (E3) to PIN 25 (E11) PIN 9 (E4) to PIN 34 ( $\overline{\mathrm{E} 12}$ ) PIN 10 (E5) to PIN 35 ( $\overline{\mathrm{E} 13}$ ) PIN 11 ( $\overline{\mathrm{E} 6}$ ) to PIN 38 ( $\overline{\mathrm{E} 14}$ ) PIN 12 ( $\overline{\mathrm{E}}$ ) to PIN 39 ( $\overline{\mathrm{E15}}$ ) PIN 14 ( $\overline{\mathrm{E} 8}$ ) to PIN 40 ( $\overline{\mathrm{E} 16}$ ) PIN $13(\overline{\mathrm{GA}})$ to PIN $36(\overline{\mathrm{~GB}})$

## 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 eight, $\overline{E 1}$ thru $\overline{E 8}$. 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 synchronous 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 HM-92560 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
.+7.0V
Input, Output or I/O Voltage $\qquad$
Storage Temperature Range
GND-0.3V to VCC +0.3 V
Junction Temperature
$+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s)
$+300^{\circ} \mathrm{C}$

CAUTION. Stresses above those listed in "Absolute Maximum Pating" 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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V Operating Temperature Range $\ldots \ldots \ldots \ldots \ldots . . . . . . .5^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
DC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ( $\mathrm{HM}-92560-8$ )

| SYMBOL | PARAMETER | MIN | MAX | UNITS | (NOTE 1) TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| ICCSB | Standby Supply Current | - | 500 | $\mu \mathrm{~A}$ | $10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC}$ or GND |
| ICCOP | Operating Supply Current (16K $\times 16$ ) (Note 2) | - | 30 | mA | $\overline{\mathrm{E}}=1 \mathrm{MHz}, \mathrm{IO}=\mathrm{OmA}, \mathrm{VI}=\mathrm{VCC}$ or <br> $\mathrm{GND}, \overline{\mathrm{G}}=\mathrm{VCC}$ |
| ICCOP | Operating Supply Current (32K $\times 8$ ) (Note 2) | - | 15 | mA | $\overline{\mathrm{E}}=1 \mathrm{MHz}, \mathrm{IO}=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC}$ or <br> $\mathrm{GND}, \overline{\mathrm{G}}=\mathrm{VCCC}$ |
| ICCDR | Data Retention Supply Current | - | 350 | $\mu \mathrm{~A}$ | $\mathrm{VCC}=2.0 \mathrm{~V}, \mathrm{IO}=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC}$ or <br> $\mathrm{GND}, \overline{\mathrm{E}}=\mathrm{VCC}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| II | Input Leakage Current | -5.0 | +5.0 | $\mu \mathrm{~A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND |
| IIOZ | Input/Output Leakage Current | -5.0 | +5.0 | $\mu \mathrm{~A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND |
| VIL | Input Low Voltage | 0 | 0.8 | V |  |
| VIH | Input High Voltage | $\mathrm{VCC}-2.0$ | VCC | V |  |
| VOL | Output Low Voltage | - | 0.4 | V | $10=3.2 \mathrm{~mA}$ |
| VOH1 | Output High Voltage | 2.4 | - | V | $10=-1.0 \mathrm{~mA}$ |
| VOH2 | Output High Voltage (Note 3) | $\mathrm{VCC}-0.4$ | - | V | $10=-100 \mu \mathrm{~A}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :---: |
| CIA | Address Input Capacitance (Note 3) | - | 200 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All measurements are <br> referenced to device GND |
| CIE1 | Enable Input Capacitance (16K x 16) (Note 3) | - | 100 | pF |  |
| CIE2 | Enable Input Capacitance (32K $\times$ 8) (Note 3) | - | 50 | pF |  |
| CIG1 | Output Enable Input Capacitance (16K $\times 16)$ <br> (Note 3) | - | 150 | pF |  |
| CIG2 | Output Enable Input Capacitance (32K x 8) <br> (Note 3) | - | 100 | pF |  |
| CIO1 | Input/Output Capacitance (16K $\times 16)($ Note 3) | - | 150 | pF |  |
| CIO2 | Input/Output Capacitance (32K $\times 8$ ) (Note 3) | - | 250 | pF |  |
| CIW | Write Input Capacitance (Note 3) | - | 200 | pF |  |
| CCVCC | Decoupling Capacitance | 0.5 | - | $\mu \mathrm{F}$ |  |

NOTES:

1. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V
2. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
3. Tested at initial design and after major design changes.

Specifications HM-92560
AC Electrical Specifications $\quad \mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-92560-8)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (1) TELQV | Chip Enable Access Time | - | 150 | ns | (Notes 1, 3) |
| (2) TAVQV | Address Access Time | - | 170 | ns | (Notes 1, 3) |
| (3) TELQX | Chip Enable Output Enable Time | 10 | - | ns | (Notes 2, 3) |
| (4) TEHQZ | Chip Enable Output Disable Time | - | 70 | ns | (Notes 2, 3) |
| (5) TGLQX | Output Enable Output Enable Time | 10 | - | ns | (Notes 2, 3) |
| (6) TGLQV | Output Enable Output Valid Time | - | 70 | ns | (Notes 1, 3) |
| (7) TGHQZ | Output Enable Output Disable Time | - | 70 | ns | (Notes 2, 3) |
| (8) TELEH | Chip Enable Pulse Negative Width | 150 | - | ns | (Notes 1, 3) |
| (9) TEHEL | Chip Enable Pulse Positive Width | 80 | - | ns | (Notes 1, 3) |
| (10) TAVEL | Address Setup Time | 20 | - | ns | (Notes 1, 3) |
| (11) TELAX | Address Hold Tıme | 50 | - | ns | (Notes 1, 3) |
| (12) TWLWH | Write Enable Puise Width | 150 | - | ns | (Notes 1, 3) |
| (13) TWLEH | Write Enable Pulse Setup Time | 150 | - | ns | (Notes 1, 3) |
| (14) TELWH | Write Enable Pulse Hold Time | 150 | - | ns | (Notes 1, 3) |
| (15) TDVWH | Data Setup Time | 80 | - | ns | (Notes 1, 3) |
| (16) TWHDX | Data Hold Time | 20 | - | ns | (Notes 1, 3) |
| (17) TWLDV | Write Data Delay Time | 70 | - | ns | (Notes 1, 3) |
| (18) TELEL | Read or Write Cycle Time | 230 | - | ns | (Notes 1, 3) |

NOTES:

1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 10 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent $C L=50 \mathrm{pF}(\mathrm{min})$ - for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .

## Read Cycle

TRUTH TABLE

| time REFERENCE | INPUTS |  |  |  |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}}$ | $\overline{\text { w }}$ | $\overline{\mathbf{G}}$ | A | DQ |  |
| -1 | H | X | X | X | Z | Memory Disabled |
| 0 | L | H | X | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | H | L | X | X | Output Enabled |
| 2 | L | H | L | X | V | Output Valid |
| 3 | ${ }^{\sim}$ | H | X | X | V | Read Accomplished |
| 4 | H | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\underline{L}$ | H | X | V | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

## Read Cycle (Continued)

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 ( $\mathrm{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 ( $\mathrm{T}=4$ ).

## Write Cycle



TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}}$ | $\overline{\mathbf{w}}$ | $\overline{\mathbf{G}}$ | A | DQ |  |
| -1 | H | X | H | X | X | Memory Disabled |
| 0 | 7 | X | H | V | X | Cycle Begins, Addresses are Latched |
| 1 | L | L | H | X | X | Write Perıod Begins |
| 2 | L | $\checkmark$ | H | X | V | Data In is Written |
| 3 | $\checkmark$ | H | H | X | X | Write Completed |
| 4 | H | X | H | X | X | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | X | H | V | X | Cycle Ends, Next Cycle Begins (Same as 0) |

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, $\bar{G}$ can be held high (inactive). TWHDX and TDVWH 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}$.

## 256K Buffered Synchronous CMOS RAM Module

## Features

- Low Standby Current. . . . . . . . . . $600 \mu \mathrm{~A} / 3.5 \mathrm{~mA}$
- Fast Access Time. .250ns
- Data Retention 2.0 V
- Three-State Outputs
- Organizable As 32K x 8 or 16K x 16 Array
- Buffered Address And Control Lines
- On Chip Address Registers
- 48 Pin DIP Pinout - 2.66" $\times 1.30^{\prime \prime} \times 0.29 "$
- Operating Temperature Range . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Ordering Information

| PACKAGE | TEMP. RANGE | 250ns |
| :---: | :---: | :---: |
| Module | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $\mathrm{HM} 5-92570-8$ |

## Description

The HM-92570 is a fully buffered 256K bit CMOS RAM Module consisting of sixteen HM-6516 $2 \mathrm{~K} \times 8$ CMOS RAMs, two 82 C 82 CMOS octal latching bus drivers, and two HCT-138 CMOS 3:8 decoders in leadless chip carriers mounted on a multilayer ceramic substrate. The HM-92570 RAM Module is organized as two $16 \mathrm{~K} \times 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 buffers and decoders reduce external package count requirements. Write enable, output enable and chip enable control signals are buffered along with address inputs. Ceramic capacitors sealed in leadless carriers are included on the substrate to reduce power supply noise and to reduce the need for 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 microprocessors.
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 package technique combines the high packing density of CMOS and leadless chip carriers with the ease of use of DIP packaging.

## Pinout

48 LEAD MODULE TOP VIEW


PIN NAMES

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

## Functional Diagram



## Organizational Guide

## FOR 32K X 8 CONFIGURATION

Connect: Pin 16 (DQ0) 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 16K X 16 CONFIGURATION

Connect: Pin $9(\overline{\mathrm{E} 1 \mathrm{~A}})$ to $\operatorname{Pin} 40(\overline{\mathrm{E} 1 \mathrm{~B}})$
Pin 10 (E2A) to Pin 39 (E2B)
Pin 11 (E3A) to Pin 38 (E3B)
Pin 13 (GA) to Pin 36 (GB)

## 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. As the HM-92570 is a synchronous 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.

## Printed Circuit Board Mounting:

The leadless chip carrier packages used in the HM-92570 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 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0V | Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Input, Output or I/O Voltage . . . . . . . . . . . . GND-0.3V to VCC+0.3V | Lead Temperature (Soldering 10s) . . . . . . . . . . . . . . . . . . . . +300 ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range . . . . . . . . . . . . . . . . -65 ${ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Gate Count . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 417200 Gates |
| CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may of the device at these or any other conditions above those indicated in the ope | e permanent damage to the device. This is a stress only rating and operation nal sections of this specification is not implied. |

## Operating Conditions

Operating Voltage Range
+4.5 V to +5.5 V Operating Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
DC Electrical Specifications $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ( $\mathrm{HM}-92570-8$ )

| SYMBOL | PARAMETER | MIN | MAX | UNITS | (NOTE 1) TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCSB | Standby Supply Current | - | 600 | $\mu \mathrm{A}$ | $1 \mathrm{O}=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC}$ or GND |
| ICCOP | Operating Supply Current (16K x 16) (Note 3) | - | 30 | mA | $\begin{aligned} & \bar{E}=1 M H z, I O=O m A, V I=V C C \text { or } \\ & G N D, \bar{G}=V C C \end{aligned}$ |
| ICCOP | Operating Supply Current (32K x 8) (Note 3) | - | 15 | mA | $\begin{aligned} & \bar{E}=1 M H z, 1 O=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & G N D, \bar{G}=V C C \end{aligned}$ |
| ICCDR | Data Retention Supply Current | - | 450 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC}=2.0 \mathrm{~V}, 10=0 \mathrm{~mA}, \mathrm{VI}=\mathrm{VCC} \text { or } \\ & \mathrm{GND}, \overline{\mathrm{E}}=\mathrm{VCC} \end{aligned}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND |
| IIOZ | Input/Output Leakage Current | -5.0 | +5.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND |
| VIL | Input Low Voltage | 0 | 0.8 | V |  |
| VIH | Input High Voltage | 3.5 | VCC | V |  |
| VOL | Output Low Voltage | - | 0.4 | V | $10=3.2 \mathrm{~mA}$ |
| VOH1 | Output High Voltage | 2.4 | - | V | $10=-0.4 \mathrm{~mA}$ |
| VOH2 | Output High Voltage (Note 2) | VCC-0.4 | - | V | $10=-100 \mu \mathrm{~A}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| CIA | Address Input Capacitance (Note 2) | - | 50 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ |
| CIE1 | Decoder Enable Input Capacitance (16K $\times 16$ ) <br> (Note 2) | - | 50 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ |
| CIE2 | Decoder Enable Input Capacitance (32K $\times 8$ ) <br> (Note 2) | - | 25 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ |
| CIG1 | Output Enable Input Capacitance (16K $\times 16)$ <br> (Note 2) | - | 50 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ |
| CIG2 | Output Enable Input Capacitance (32K $\times 8$ ) <br> (Note 2) | - | 25 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ |
| CIO1 | Input/Output Capacitance (16K $\times 16$ ) (Note 2) | - | 150 | pF | $\mathrm{VI/O}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ |
| CIO2 | Input/Output Capacitance (32K $\times 8$ ) (Note 2) | - | 250 | pF | $\mathrm{VI/O}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ |
| CIW | Write Input Capacitance (Note 2) | - | 25 | pF | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{f}=1 \mathrm{MHz}$ |
| CCVCC | Decoupling Capacitance (Note 2) | 0.5 | - | $\mu \mathrm{F}$ | $\mathrm{f}=1 \mathrm{MHz}$ |

## NOTES:

1. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .
2. Tested at initial design and after major design changes.
3. ICCOP is proportional to operating frequency.

Specifications HM-92570
AC Electrical Specifications VCC $=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-92570-8)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (1) TELQV | Chip Enable Access Time | - | 250 | ns | (Notes 1, 4) |
| (2) TAVQV | Address Access Time | - | 270 | ns | (Notes 1, 4) |
| (3) TELQX | Chip Enable Output Enable Time | 5 | - | ns | (Notes 2, 4) |
| (4) TEHQZ | Chip Enable Output Disable Time | - | 150 | ns | (Notes 2, 4) |
| (5) TGLQX | Output Enable Output Enable Time | 10 | - | ns | (Notes 2, 4) |
| (6) TGLQV | Output Enable Output Valid Time | - | 120 | ns | (Notes 1, 4) |
| (7) TGHQZ | Output Enable Output Disable Time | - | 150 | ns | (Notes 2, 4) |
| (8) TELEH | Chip Enable Pulse Negative Width | 250 | - | ns | (Notes 1, 4) |
| (9) TEHEL | Chip Enable Pulse Positive Width | 100 | - | ns | (Notes 1, 4) |
| (10) TAVEL | Address Setup Time | 20 | - | ns | (Notes 1, 3, 4) |
| (11) TELAX | Address Hold Time | 120 | - | ns | (Notes 1, 4) |
| (12) TWLWH | Write Enable Pulse Width | 140 | - | ns | (Notes 1, 4) |
| (13) TWLEH | Write Enable Pulse Setup Time | 140 | - | ns | (Notes 1, 4) |
| (14) TELWH | Write Enable Pulse Hold Time | 250 | - | ns | (Notes 1, 4) |
| (15) TDVWH | Data Setup Time | 20 | - | ns | (Notes 1, 4) |
| (16) TWHDX | Data Hold Time | 70 | - | ns | (Notes 1, 4) |
| (17) TWLDV | Write Data Delay Time | 120 | - | ns | (Notes 1, 4) |
| (18) TELEL | Read or Write Cycle Time | 350 | - | ns | (Notes 1, 4) |
| (19) TAVAV | Enable Decoder Address Valid Time | 270 | - | ns | (Applies Only to A11, A12, A13) |

## NOTES:

1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 10 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. Includes A11, A12, A13.
4. $V C C=4.5 \mathrm{~V}$ and 5.5 V .

## Read Cycle



TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | $\begin{gathered} \text { A11,A12, } \\ \text { A13 } \\ \hline \end{gathered}$ | $\begin{gathered} \text { DATA VO } \\ \text { DQ } \\ \hline \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\mathrm{w}}$ | $\overline{\mathbf{G}}$ | A |  |  |  |
| -1 | H | X | X | X | X | Z | Memory Disabled |
| 0 | $\downarrow$ | H | X | V | V | Z | Cycle Begins, Addresses are Latched |
| 1 | L | H | L | X | V | X | Output Enabled |
| 2 | L | H | L | X | V | V | Output Valid |
| 3 | ${ }^{\prime}$ | H | X | X | V | V | Read Accomplished |
| 4 | H | X | X | X | X | Z | Prepare for Next Cycle (Same as -1) |
| 5 | $\downarrow$ | H | X | V | V | Z | Cycle Ends, Next Cycle Begins (Same as 0) |

## Read Cycle (Continued)

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$ ). $\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



TRUTH TABLE

| TIME REFERENCE | INPUTS |  |  |  | A11, A12, A13 | DATA VO DQ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}$ | $\overline{\mathbf{w}}$ | $\overline{\mathbf{G}}$ | A |  |  |  |
| -1 | H | X | H | X | X | X | Memory Disabled |
| 0 | 7 | X | H | V | V | X | Cycle Begins, Addresses are Latched |
| 1 | L | L | H | X | V | X | Write Period Begins |
| 2 | L | $\checkmark$ | H | X | V | V | Data In Is Written |
| 3 | - | H | H | X | V | X | Write Completed |
| 4 | H | X | H | X | X | X | Prepare For Next Cycle (Same As -1) |
| 5 | 7 | X | H | V | V | X | Cycle Ends, Next Cycle Begins (Same As O) |

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, $\bar{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 $\overline{\mathrm{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 $\overline{\mathrm{E}}$.

## Features

- Low Standby Current. . . . . . . . . . . . . . . . . . . . . . . $900 \mu \mathrm{~A}$
- Low Operating Supply Current . . . . . . . . . . . . . .10/20mA
- Fast Address Access Time . . . . . . . . . . . . . . . . . . 180ns
- Low Data Retention Supply Voltage. . . . . . . . . . . . 2.0V
- CMOS/TTL Compatible Inputs/Outputs
- Buffered Address and Control Lines
- 48 Pin DIP Pinout . . . . . . . . . . . . . . . . . . $2.66 \times 1.3 \times 0.3$ "
- Operating Temperature Range . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## Description

The HM-91M2 is a fully buffered $1,048,572$ bit CMOS RAM module consisting of sixteen HM-65642 $8 \mathrm{~K} \times 8$ CMOS RAMs, two 82C82 CMOS octal buffers, and two HCT-138 CMOS 3:8 decoders in leadless chip carriers mounted on a multi-layer, co-fired, ceramic substrate. The HM-91M2 CMOS RAM module is organized as two $64 \mathrm{~K} \times 8$ RAM arrays sharing a common address bus and write enable input. Separate data input/output buses allow the user to format the HM-91M2 as either a 64K $\times 16$ or 128K $\times 8$ bit array.

The on-substrate CMOS buffers and decoders on the HM91M2 reduce the system package count and minimize the capacitive load on the system address and control buses. In addition to this, the HM-91M2 has on-substrate decoupling capacitors mounted in leadless chip carriers to reduce power supply noise and minimize the need for external decoupling while ensuring high reliability, even in harsh environments.

The HM-91M2 is physically constructed as an extra wide 48 pin dual-in-line package with standard 0.1 " centers between pins to combine the high density of CMOS and leadless chip carriers with the ease of use of DIP packaging.

The HM-65642 RAMs used on the HM-91M2 module are full CMOS devices, utilizing arrays of six-transistor (6T) memory cells for the most stable and lowest possible standby and data retention supply current over full military operating temperature range. In addition to this, the high stability of the 6T cell provides excellent protection against soft errors due to power supply noise and alpha particles. This stability also improves the radiation tolerance of the module over that of RAMs utilizing four transistor (4T) Mix-MOS memory cells.

## Ordering Information

| PKG | TEMP. RANGE | 180ns | 200ns |
| :---: | :---: | :---: | :---: |
| Module | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $\mathrm{HM} 5-91 \mathrm{M} 2 \mathrm{~B}-8$ | $\mathrm{HM} 5-91 \mathrm{M} 2-8$ |

## Pinout



PIN NAMES

| PIN | DESCRIPTION |
| :---: | :--- |
| A | Address Input |
| DQ | Data Input/Output |
| $\overline{G X}$ | Output Enable |
| EXX | Chip Enable |
| $\bar{W}$ | Write Enable |
| NC | No Connection |
| S | Module Select |

## Functional Diagram



## Organizational Guide

## FOR 128K X 8 CONFIGURATION

Connect: Pin 16 (DQ0) 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 64K X 16 CONFIGURATION

Connect: Pin $9(\overline{\mathrm{E} 1 \mathrm{~A})}$ to Pin $40(\overline{\mathrm{E} 1 \mathrm{~B}})$
Pin 10 ( $\overline{\mathrm{E} 2 \mathrm{~A}})$ to $\operatorname{Pin} 39$ (E2B)
Pin 11 (E3A) to Pin 38 (E3B)
Pin $13(\overline{\mathrm{GA}})$ to Pin $36(\overline{\mathrm{~GB}})$

## 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 $64 \mathrm{~K} \times 16$ mode use the chip enables as if there were only three, E1 thru E3. In the $128 \mathrm{~K} \times 8$ mode all chip enables must be treated separately. Transitions between chip enables must be treated with the same constraints that apply to any one chip enable. More than one (internal) chip enable low simultaneously, for devices whose outputs are tied together 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-91M2 have conductive lids. These lids are electrically connected to GND. The system designer should be aware 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.

## 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. The module must be kept disabled during data retention. The Chip Enable (E3A and E3B) and module select (S) must be between -0.3 V and +0.3 V .
2. During power-up and power-down transitions. S must be held between -0.3 V and $10 \%$ of VCC.
3. The RAM module can begin operation one TAVAX after VCC reaches the minimum operating voltage ( 4.5 V ).


## Absolute Maximum Ratings



## Operating Conditions

Operating Voltage Range
+4.5 V to +5.5 V Operating Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
DC Electrical Specifications VCC $=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ( $\mathrm{HM}-91 \mathrm{M} 2 \mathrm{~B}-8, \mathrm{HM} 91 \mathrm{M} 2-8$ )

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS (NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCSB1 | Standby Supply Current (CMOS) | - | 900 | $\mu \mathrm{A}$ | $1 \mathrm{O}=0, \mathrm{E} 3=\mathrm{S}=0.3 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCSB | Standby Supply Current (TTL) | - | 2.0 | mA | $\begin{aligned} & 10=0, \overline{E 1}=\overline{E 2}=\mathrm{VIH}, E 3=S=\text { VIL, VCC } \\ & =5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| ICCEN | Enabled Supply Current $\quad \begin{aligned} & 128 \mathrm{~K} \times 8 \\ & \\ & \\ & 64 \mathrm{~K} \times 16\end{aligned}$ | - | $\begin{gathered} 5.0 \\ 10 \end{gathered}$ | $\begin{gathered} \mathrm{mA} \\ \mathrm{~mA} \end{gathered}$ | $\begin{aligned} & 10=0, \overline{E 1}=\overline{E 2}=V I L, E 3=V I H, S=V C C \\ & -0.3 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{VCC} \text { or } \mathrm{GND} \end{aligned}$ |
| ICCOP |   <br> Operating Supply Current $128 \mathrm{~K} \times 8$ <br> (Note 2) $64 \mathrm{~K} \times 16$ | - | $\begin{aligned} & 10 \\ & 20 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & 10=0, f=1 \mathrm{MHz}, \overline{E 1}=\overline{E 2}=V I L, S=V C C \\ & E 3=V I H, V C C=5.5 V, V I N=V C C \text { or } G N D \end{aligned}$ |
| ICCDR | Data Retention Supply Current | $\bullet$ | 750 | $\mu \mathrm{A}$ | $\mathrm{E} 3=\mathrm{S}=0.3 \mathrm{~V}, \mathrm{VCC}=2.0 \mathrm{~V}$ |
| II | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VI}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| IIS | Module Select Input Current | -5.0 | 5.0 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| IIOZ | Input/Output Leakage Current | -5.0 | +5.0 | $\mu \mathrm{A}$ | $\mathrm{VIO}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| VCCDR | Data Retention Supply Voltage | 2.0 | - | V |  |
| VOL | Output Low Voitage | - | 0.4 | V | $10 \mathrm{~L}=4.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH1 | Output High Voltage | 2.4 | - | V | $1 \mathrm{OH}=-1.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 3) | VCC-0.4 | $\bullet$ | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIL | Input Voltage Low | -0.3 | 0.8 | V |  |
| VIH | Input Voltage High | 2.4 | VCC +0.3 | V |  |

## Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ (Note 3)

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CI | Input Capacitance (Except S) | 25 | pF | $\mathrm{f}=1 \mathrm{MHz}$, VA $=$ VCC or GND |
| CDQ | Data I/O Capacitance | 150 | pF | $\mathrm{f}=1 \mathrm{MHz}$, VDQ and VG $=$ VCC or GND |
| CIS | Module Select Input Capacitance | 150 | pF | $\mathrm{f}=1 \mathrm{MHz}$, VEN $=$ VCC or GND |

NOTES:

1. All devices tested at worst case temperature and supply voltage limits.
2. Typical derating: $128 \mathrm{~K} \times 8: 5 \mathrm{mAMHz}$ increase in ICCOP; $64 \mathrm{~K} \times 16: 10 \mathrm{mAMHz}$.
3. Guaranteed but not tested.

AC Electrical Specifications $V C C=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (HM-91M2B-8, HM91M2-8)

| SYMBOL | PARAMETER |  | HM-91M2B-8 <br> LIMITS |  | $\begin{gathered} \text { HM91M2-8 } \\ \text { LIMITS } \end{gathered}$ |  | UNITS | TEST CONDITIONS (NOTES 1, 2) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
|  |  |  | MAX | MIN | MAX | MIN |  |  |
| READ CYCLE |  |  |  |  |  |  |  |  |
| (1) TAVAX | Read Cycle Time |  | 180 | - | 200 | - | ns |  |
| (2) TAVQV | Address Access Time |  | - | 180 | - | 200 | ns |  |
| (3) TEVQV | Chip Enable Access Time |  | - | 180 | - | 200 | ns | (Note 4) |
| (4) TSHQV | Module Select Access Time |  | - | 160 | - | 180 | ns |  |
| (5) TGLQV | Output Enable Access Time |  | - | 120 | - | 120 | ns |  |
| (6) TEVQX | Chip Enable Output Enable Time |  | 25 | - | 30 | - | ns | (Notes 3, 4) |
| (7) TSHQX | Module Select Output Enable Time |  | 5 | - | 5 | - | ns | (Note 3) |
| (8) TGLQX | Output Enable Time |  | 5 | - | 5 | - | ns | (Note 3) |
| (9) TAXQX | Address Output Hold Time |  | 30 | - | 30 | - | ns | (Note 3) |
| (10) TEXQZ | Chip Disable Output Disable Time |  | 0 | 75 | 0 | 85 | ns | (Notes 3, 4) |
| (11) TSLQZ | Module Select Output Disable Time |  | 0 | 50 | 0 | 60 | ns | (Note 3) |
| (12) TGHQZ | Output Disable Time |  | 0 | 60 | 0 | 70 | ns | (Note 3) |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| (13) TAVAX | Write Cycle Time |  | 180 | - | 200 | - | ns |  |
| (14) TWLWH | Write Pulse Width |  | 100 | - | 100 | - | ns |  |
| (15) TEVWH | Chip Enable to End of Write | $\overline{\text { W }}$ Controlied | 140 | - | 145 | - | ns | (Note 4) |
| (16) TEVEX | Chip Enable to End of Write | E Controlled | 120 | - | 120 | - | ns | (Notes 3, 4) |
| (17) TSHSL | Chip Enable to End of Write | S Controlled | 120 | - | 120 | - | ns | (Note 3) |
| (18) TAVWL | Andress Setup Time | $\bar{W}$ Controlled | 40 | - | 50 | - | ns |  |
| (19) TAVEV | Address Setup Time | E Controiled | 0 | - | 20 | - | ns | (Notes 3, 4) |
| (20) TAVSH | Address Setup Time | S Controlled | 40 | - | 40 | - | ns | (Note 3) |
| (21) TWHAX | Write Recovery Time | $\bar{W}$ Controlled | 10 | - | 10 | - | ns |  |
| (22) TEXAX | Write Recovery Time | E Controlled | 10 | - | 10 | - | ns | (Notes 3, 4) |
| (23) TSLAX | Write Recovery Time | S Controlled | 10 | - | 10 | - | ns | (Note 3) |
| (24) TDVWH | Data Setup Time | $\overline{\text { W }}$ Controlled | 60 | - | 60 | - | ns |  |
| (25) TDVEX | Data Setup Time | E Controlled | 55 | - | 55 | - | ns | (Note 3, 4) |
| (26) TDVSL | Data Setup Time | S Controlled | 55 | - | 55 | - | ns | (Note 3) |
| (27) TWHDX | Data Hold Time | $\bar{W}$ Controlled | 35 | - | 35 | - | ns |  |
| (28) TEXDX | Data Hold Time | E Controlled | 35 | - | 35 | - | ns | (Notes 3, 4) |
| (29) TSLDX | Data Hold Time | S Controiled | 35 | - | 35 | - | ns | (Note 3) |
| (30) TWLQZ | Write Enable Output Disable Time |  | - | 95 | - | 95 | ns | (Note 3) |
| (31) TWHQX | Write Disable Output Enable Tıme |  | 10 | - | 10 | - | ns | (Note 3) |

NOTES:

1. All devices tested at worst case temperature and supply voltage limits.
2. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 10 ns max; Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent and $C L=100 \mathrm{pF}$ min including scope and jig - for $C L$ greater than 100 pF , access time is derated by $0.15 \mathrm{~ns} / \mathrm{pF}$.
3. Guaranteed but not tested.
4. Enable valid (EV) in a parameter is determined by the last transition that results in the combination of $\overline{E 1}$ low, $\overline{E 2}$ low and $E 3$ high. Enable invalid (EX) in a parameter is determined by the first transition that results in any other combination than $\overline{\mathrm{E} 1}$ low, $\overline{\mathrm{E} 2}$ low and E3 high.

## Timing Diagrams

## READ CYCLE 1: ADDRESS CONTROLLED (NOTES 1,2)



READ CYCLE 2: E, S, or $\overline{\mathbf{G}}$ CONTROLLED (NOTE 1)


NOTES:

1. In a read cycle, $\bar{W}$ is held high.
2. In read cycle 1, the module is kept continuously enabled: $\overline{\mathrm{E} 1}, \overline{\mathrm{E} 2}$ and $\overline{\mathrm{G}}$ are held low; E3 and S are held high.

Timing Diagrams (Continued)
WRITE CYCLE 1: $\overline{\mathbf{W}}$ CONTROLLED (NOTE 1)


WRITE CYCLE 2: $\overline{E 1}, \overline{E 2}$, or E3 CONTROLLED (NOTE 2)


## Timing Diagrams (Continued)

WRITE CYCLE 1: S CONTROLLED (NOTE 3)


NOTES:

1. In Write Cycle 1, the module is first enabled, and then data is strobed into the RAM with a pulse on ( $\bar{W}$ ). If $\bar{G}$ is held high for the entire cycle, the out[puts will remain in the high impedance state. If $\bar{G}$ is held low, it may be necessary to lengthen the cycle to prevent bus contention. This would occur if TWLQZ and TDVWH overlapped.
2. In Write Cycle 2, Address (A) and Write Enable ( $\bar{W}$ ) are first set up, and then data is strobed into the RAM with a pulse on $\overline{\mathrm{E}}$.
3. In Write Cycle 3, Addresses (A), Write Enable ( $\bar{W}$ ) and the Chip Enable inputs ( $\overline{E 1}, \overline{E 2}$ and E3) are first set up and data is then strobed into the RAM with the Module Select (S) input.

TRUTH TABLE

| INPUTS |  |  |  |  |  |  |  |  |  | MODE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S | E1A | E2A | E3A | E1B | E2B | E3B | $\overline{\mathbf{G A}}$ | $\overline{\mathbf{G B}}$ | $\overline{\mathbf{W}}$ |  |
| GND | X | X | GND | X | X | GND | X | X | X | Standby (CMOS) Sides A and B |
| VIL | X | X | X | X | X | X | X | X | X | Standby (TTL) Sides A and B |
| x | VIH | X | X | X | X | X | X | X | X | Standby (TTL) Side A |
| $x$ | X | VIH | x | x | x | x | $x$ | x | x | Standby (TT:L) Side A |
| X | $x$ | $x$ | VIL | X | X | X | X | X | X | Standby (TTL) Side A |
| X | X | X | X | VIH | X | $x$ | X | X | X | Standby (TTL) Side B |
| x | $x$ | X | x | X | VIH | x | X | X | X | Standby (TTL) Side B |
| X | X | X | X | X | X | VIL | X | X | X | Standby (TTL) Side B |
| VIH | VIL | VIL | VIH | X | X | X | VIH | X | VIH | Side A Enabled, Outputs High Impedance |
| VIH | X | X | X | VIL | VIL | VIH | X | VIH | VIH | Side B Enabled, Outputs High Impedance |
| VIH | VIL | VIL | VIH | X | X | X | VIL | X | VIH | Read Side A |
| VIH | X | X | X | VIL | VIL | VIH | X | VIL | VIH | Read Side B |
| VIH | VIL | VIL | VIH | X | X | X | X | X | VIL | Write Side A |
| VIH | X | X | X | VIL | VIL | VIH | X | X | VIL | Write Side B |

NOTE:

1. Side $A$ refers to the half of the module that connects to DQ0 through DQ7 and side $B$ refers to the half of the module that conncets to DQ8 through DQ15. When the module is configured as a $64 \mathrm{~K} \times 16$ array, side $A$ and side $B$ may be enabled either simulaneously or separately. When the array is configured as a $128 \mathrm{~K} \times 8$ array, side A and B should not be enabled simultaneously, as bus contention could result.

HM-6642

## Features

- Low Power Standby and Operating Power
- ICCSB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $100 \mu \mathrm{~A}$
- ICCOP . . . . . . . . . . . . . . . . . . . . . . . . . . 20 mA at 1 MHz
- Fast Access Time. . . . . . . . . . . . . . . . . . . . . . . 120/200ns
- Industry Standard Pinout
- Single 5.0 Volt Supply
- CMOSTTTL Compatible Inputs
- Field Programmable
- Synchronous Operation
- On-Chip Address Latches
- Separate Output Enable


## Description

The HM-6642 is a $512 \times 8$ CMOS NiCr 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 addresss/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 independent of the chip enable control. The data output latches allow the use of the HM-6642 in high speed pipelined architecture systems, and also in synchronous logic replacement functions.

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

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

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 120ns | 200ns |
| :---: | :---: | :---: | :---: |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM1-6642B-9 | HM1-6642-9 |
| 1883* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM1-6642B/883 | HM1-6642/883 |
| SMD\# |  | 5962-8869002JA | 5962-8869001JA |
| SLIM | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM6-6642B-9 | HM6-6642-9 |
| /883* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM6-6642B/883 | HM6-6642/883 |
| SMD\# |  | 5962-8869002LA | 5962-8869001LA |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM4-6642B-9 | HM4-6642-9 |
| 1883* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM4-6642B/883 | HM4-6642/883 |
| SMD* |  | 5962-88690023A | 5962-88690013A |

[^24]
## Pinouts

24 LEAD DIP
TOP VIEW


28 LEAD LCC TOP VIEW


PIN DESCRIPTION

| PIN | DESCRIPTION |
| :--- | :--- |
| NC | No Connect |
| A0-A8 | Address Inputs |
| $\bar{E}$ | Chip Enable |
| Q | Data Output |
| VCC | Power (+5V) |
| $\overline{\text { G1 }, \overline{G 2}, ~ G 3 ~}$ | Output Enable |
| P* | Program Enable |

* P should be hardwired to GND except during programming.


## Functional Diagram



## Programming

## Introduction

The HM-6642 is a 512 word by 8 -bit field Programmable Read Only Memory utilizing nicrome 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.0V) and low VCC (4.0V) 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 ( $\overline{\mathrm{E}}$ ) and output enable $(\overline{\mathrm{G}}$ ) are used during the programming procedure. On PROMs which have more than one output enable control G3 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 ( $\overline{\mathrm{E}}$ ) falling edge. The output is disabled by taking the output enable $\overline{\mathrm{G}}$ Low: The programming pin is enabled by taking ( P ) high.
2. VCC is raised to the programming voltage level, 12.5 V .
3. All data output pins are pulled up to VCC program. Then the data output pin corresponding to the bit to be programmed is pulled low for 100 ms . Only one bit should be programmed at a time.
4. The data output pin is returned to VCC, and the VCC pin is returned to 6.0 V .
5. The address of the bit is again presented, and latched by a second chip enable falling edge.
6. The data outputs are enabled, and read, to verify that the bit was successfully programmed.
a). If verified, the next bit to be programmed is addressed and programmed.
b). If not verified, the programs verify sequence is repeated up to 8 times total.
7. After all bits to be programmed have been verified at 6.0 V , the VCC is lowered to 4.0 V 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 three voltages: $4.0 \mathrm{~V}, 6.0 \mathrm{~V}, 12.5 \mathrm{~V}$. This supply must be able to supply 500 mA average, and 1 A dynamic, currents to the PROM during programming. The power supply rise fall times when switching between voltages must be no quicker than 1 ms .
2. The address drivers must be able to supply a VIH of 4.0 V and 6.0 V and VIL when the system is at programming voltages.*
3. The control input buffers must be able to maintain input voltage levels of $\geq 70 \%$ and $\leq 20 \%$ VCC for VIH and VIL levels, respectively. Notice that chip enable ( $\overline{\mathrm{E}}$ ) and $\overline{\mathbf{G}}$ does not require a pull up to programming voltage levels. The program control ( $P$ ) must switch from ground to VIH and from VIH to the VCC PGM level.*
4. The data input buffers must be able to sink up to 3mA from the PROM's output pins without rising more than 0.7 V 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.*

* Never allow any input or output pin to rise more than 0.3 V above VCC , or fall more than 0.3 V below ground.

HM-6642

## Background Information HM-6642 Programming

PROGRAMMING SPECIFICATIONS

| SYMBOL | PARAMETER |  | LIMITS |  |  |
| :---: | :--- | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX |
| UNITS |  |  |  |  |  |
| VCC PROG | Programming VCC | 12.0 | 12.0 | 12.5 | V |
| VCCN | Operating VCC | 4.5 | 5.5 | 5.5 | V |
| VCC LV | Special Verify VCC | 4.0 | - | 6.0 | V |
| ICC | System ICC Capability | 500 | - | - | mA |
| ICC Peak | Transient ICC Capability | 1.0 | - | - | A |

PROM INPUT PINS

| VOL | Output Low Voltage (TO PROM) | -0.3 | GND | $20 \% \mathrm{VCC}$ | V |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VOH | Output High Voltage (To PROM) | $70 \%$ VCC | VCC | VCC +0.3 | V |
| IOL | Output Sink Current (At VOL) | 0.01 | - | - | mA |
| IOH | Output Source Current (At VOH) | 0.01 | - | - | mA |

PROM DATA OUTPUT PINS

| VOL | Output Low Voltage (To PROM) | -0.3 | GND | 0.7 | V |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VOH | Output High Voltage (To PROM) | $70 \%$ VCC | VCC | VCC +0.3 | V |
| IOL | Output Sink Current (At VOL) | 3.0 | - | - | mA |
| IOH | Output Source Current (At VOH) | 0.5 | 1.0 | 2.0 | mA |
| td | Delay Time | 1.0 | 1.0 | - | $\mu \mathrm{s}$ |
| tr | Rise Time | 1.0 | 10.0 | 10.0 | $\mu \mathrm{~s}$ |
| tf | Fall Time | 1.0 | 10.0 | 10.0 | $\mu \mathrm{~s}$ |
| TEHEL | Chip Enable Pulse Width | 500 | - | - | ns |
| TAVEL | Address Valid to Chip Enable Low Time | 500 | - | - | ns |
| TELQV | Chip Enable Low to Output Valid Time | - | - | 500 | ns |
| tpw | Programming Pulse Width | 90 | 100 | 110 | $\mu \mathrm{~s}$ |
| tIP | Input Leakage at VCC = VCC PROG | -10 | +1.0 | 10 | $\mu \mathrm{~A}$ |
| TA | Ambient Temperature | - | 25 | - | ${ }^{\circ} \mathrm{C}$ |

HM-6642 PROGRAMMING CYCLE


HM-6642 POST PROGRAMMING VERIFY CYCLE


| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +7.0V |
| Input, Output or I/O Voltage | GND-0.3V to VCC +0.3 V |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | . . $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| Typical Derating Factor. | mAMHz Increase in ICCOP |
| ESD Classification | . . Class 1 |

Input, Output or I/O Voltage . . . . . . . . . . . . . GND-0.3V to VCC +0.3 V
Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
on Temperature
Typical Derating Factor . . . . . . . . . . . . 5mAMMHz Increase in ICCOP

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V Operating Temperature Range HM-6642B-9, HM-6642-9
$40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

DC Electrical Specifications $\quad V C C=5 V \pm 1-\% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (HM-6642B-9, HM-6642-9)

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| ICCSB | Standby Supply Current | - | 100 | $\mu \mathrm{A}$ | $1 \mathrm{O}=0, \mathrm{VI}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| ICCOP | Operating Supply Current (Note 3) | $\bullet$ | 20 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, 10=0, \mathrm{VI}=\mathrm{VCC} \text { or } \mathrm{GND}, \\ & \mathrm{VCC}=5.5 \mathrm{~V} \end{aligned}$ |
| 11 | Input Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VI} \leq \mathrm{VCC}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| IOZ | Output Leakage Current | -1.0 | +1.0 | $\mu \mathrm{A}$ | GND $\leq \mathrm{VO} \leq \mathrm{VCC}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| VIL | Input Low Voltage | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VIH | Input High Voltage | 2.4 | VCC + 0.3 | V | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $1 \mathrm{LL}=3.2 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH1 | Output High Voltage | 2.4 | - | V | $1 \mathrm{OH}=-1.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH2 | Output High Voltage (Note 2) | VCC - 1.0 | - | V | $1 \mathrm{OH}=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |

## AC Electrical Specifications

| SYMBOL | PARAMETER | LIMITS |  |  |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HM-6642B-9 |  | HM-6642-9 |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) TELQV | Chip Enable Access Time | - | 120 | - | 200 | ns | Notes 1, 4 |
| (2) TAVQV | Address Access Time (TAVQV = TELQV + TAVEL) | - | 140 | - | 220 | ns | Notes 1, 4 |
| (3) TGVQV | Output Enable Access Time | - | 50 | - | 150 | ns | Notes 1, 4 |
| (4) TGVQX | Output Enable Time | 5 | 50 | 5 | 150 | ns | Notes 2, 4 |
| (5) TGXQZ | Output Disable Time | - | 50 | - | 150 | ns | Notes 2, 4 |
| (6) TELEH | Chip Enable Pulse Negative Width | 120 | - | 200 | - | ns | Notes 1, 4 |
| (7) TELEL | Read Cycle Time | 160 | $\cdot$ | 350 | - | ns | Notes 1, 4 |
| (8) TEHEL | Chip Enable Pulse Positive Width | 40 | - | 150 | - | ns | Notes 1, 4 |
| (9) TAVEL | Address Setup Time | 20 | $\cdot$ | 20 | $\cdot$ | ns | Notes 1, 4 |
| (10) TELAX | Address Hold Time | 25 | - | 60 | - | ns | Notes 1, 4 |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| Cl | Input Capacitance (Note 2) | $\bullet$ | 10.0 | pF | $f=1 \mathrm{MHz}$, All Measurements Reference Device |
| CO | Output Capacitance (Note 2) | - | 12.0 | pF | Ground |

NOTES: 1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load:
1 TTL gate equivalent $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})$ - for CL greater than 50 pF , access time time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. Typical derating $5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
4. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V

## Switching Waveform

## READ CYCLE



* G has the same timing as $\overline{\mathrm{G}}$ except signal is inverted.

Test Load Circuit


$512 \times 8$ CMOS PROM

## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby and Operating Power
- ICCSB $.100 \mu \mathrm{~A}$
- ICCOP . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 mA at 1 MHz
- Fast Access Time. 120/200ns
- Wide Operating $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Temperature Range
- Industry Standard Pinout
- Single 5.0 Volt Supply
- CMOS/TTL Compatible Inputs
- Field Programmable
- Synchronous Operation
- On-Chip Address Latches
- Separate Output Enable


## Description

The HM-6642/883 is a $512 \times 8$ CMOS NiCr 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 addresss/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 independent of the chip enable control. The data output latches allow the use of the HM-6642/883 in high speed pipelined architecture systems, and also in synchronous logic replacement functions.

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

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

## Pinouts

HM1-6642/883 (CERAMIC DIP) TOP VIEW


HM4-6642/883 CERAMIC LCC) TOP VIEW


PIN DESCRIPTION

| PIN | DESCRIPTION |
| :--- | :--- |
| NC | No Connect |
| AO-A8 | Address Inputs |
| $\bar{E}$ | Chip Enable |
| Q | Data Output |
| VCC | Power (+5V) |
| $\overline{\text { G1, }} \overline{\text { G2, G3 }}$ | Output Enable |
| P $^{*}$ | Program Enable |

[^25]
## Functional Diagram


 of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range .
..$\pm 4.5 \mathrm{~V}$
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

Reliability Information


Input Low Voltage
. -0.3 V to +0.8 V
Input High Voltage
2.4 to VCC +0.3 V

TABLE 1. HM-6642/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETERS | SYMBOL | (NOTES 1, 4) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| High Level Output Voltage | VOH | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & 10=-1.0 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.4 | - | V |
| Low Level Output Voltage | VOL | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V}, \\ & 1 \mathrm{O}=+3.2 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| High Impedance Output Leakage Current | IIOZ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{G}}=5.5 \mathrm{~V}, \\ & \mathrm{VI} / \mathrm{O}=\mathrm{GND} \text { or VCC } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Input Leakage Current | II | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VI}=\mathrm{GND} \text { or }$ VCC, P Not Tested | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB | $\begin{aligned} & \mathrm{VI}=\mathrm{VCC} \text { or GND, } \\ & \mathrm{VCC}=5.5 \mathrm{~V}, 10=0 \mathrm{~mA} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 100 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\begin{aligned} & V C C=5.5 V, \bar{G}=G N D, \\ & G=V C C,(\text { Note } 3), \\ & f=1 M H z, I O=0 \mathrm{~mA}, \\ & V I=V C C \text { or } G N D \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | mA |
| Functional Test | FT | $\mathrm{VCC}=4.5 \mathrm{~V}$ (Note 5) | 7, 8A, 8B | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

TABLE 2. HM-6642/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETERS | SYMBOL | (NOTES 1, 2, 4) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{gathered} \hline \text { HM-6642B/ } \\ 883 \\ \hline \end{gathered}$ |  | $\begin{gathered} \hline \text { HM-6642/ } \\ 883 \end{gathered}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Address Access Time | TAVQV | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 140 | - | 220 | ns |
| Output Enable Access Time | TGVQV | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | - | 150 | ns |
| Chip Enable Access Time | TELQV | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 120 | - | 200 | ns |
| Address Setup Time | TAVEL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 20 | - | ns |
| Address Hold Time | TELAX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 25 | - | 60 | - | ns |
| Chip Enable Low Width | TELEH | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 120 | - | 200 | - | ns |
| Chip Enable High Width | TEHEL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 40 | - | 150 | - | ns |
| Read Cycle Time | TELEL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 160 | - | 350 | - | ns |

## NOTES:

1. All voltages referenced to VSS.
2. A.C. measurements assume transition time $<5 \mathrm{~ns}$; input levels $=0.0 \mathrm{~V}$ to 3.0 V ; timing reference levels $=1.5 \mathrm{~V}$; output load $=1 \mathrm{TTL}$ equivalent load and $\mathrm{CL} \cong 50 \mathrm{pF}$.
3. Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP .
4. All tests performed with $P$ hardwired to GND.
5. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{VIH}=2.4 \mathrm{~V}, \mathrm{VIL}=0.8 \mathrm{~V}, \mathrm{IOH}=-1 \mathrm{~mA}, \mathrm{IOL}=+1 \mathrm{~mA}, \mathrm{VOH} \geq 1.5 \mathrm{~V}, \mathrm{VOL} \leq 1.5 \mathrm{~V}$.

TABLE 3. HM-6642/883 A.C. and D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | (NOTES 1, 2) CONDITIONS | NOTES | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{gathered} \text { HM-6642B } \\ / 883 \end{gathered}$ |  | $\begin{gathered} \text { HM-6642 } \\ / 883 \end{gathered}$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | CIN | $\mathrm{VCC}=\text { Open, } \mathrm{f}=1 \mathrm{MHz},$ <br> All Measurements Reference Device Ground | 2, 3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
|  |  | $\mathrm{VCC}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$, | 2, 4 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
|  |  | Reference Device Ground | 2,5 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | $\bullet$ | 5 | $\bullet$ | 5 | pF |
| I/O Capacitance | CI/O | $\mathrm{VCC}=\text { Open, } \mathrm{f}=1 \mathrm{MHz},$ <br> All Measurements Reference Device Ground | 2, 3 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | $\bullet$ | 12 | - | 12 | pF |
|  |  | $\mathrm{VCC}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$, | 2, 4 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 14 | - | 14 | pF |
|  |  | Reference Device Ground | 2, 5 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 8 | - | 8 | pF |
| Output Enable Time | TGVQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | 50 | 5 | 150 | ns |
| Output Disable Time | TGXQZ | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | - | 150 | ns |

## NOTES:

1. All tests performed with $P$ hardwired to GND
2. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design changes which would affect these characteristics.
3. Applies to 0.600 inch Ceramic Dual-In-Line (DIP) device types only.
4. Applies to 0.300 inch Ceramic Dual-In-Line (DIP) device types only.
5. Applies to Ceramic Leadless Chip Carrier (LCC) device types only.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Switching Waveform

READ CYCLE


* G has the same timing as $\overline{\mathrm{G}}$ except signal is inverted.

Test Load Circuit

- TEST HEAD

CAPACITANCE,
includes stray AND JIG CAPACITANCE


## Burn-In Circuits

HM-6642/883 (0.300 INCH) CERAMIC DIP
HM-6642/883 ( 0.600 INCH) CERAMIC DIP


HM-6642/883 CERAMIC LCC

NOTES:
F0 $=100 \mathrm{kHz} \pm 10 \%$
All Resistors $=47 \mathrm{k} \Omega$, Unless Otherwise Noted $\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$
$\mathrm{VIL}=4.5 \mathrm{~V} \pm 10 \%$
$\mathrm{C}=0.01 \mu \mathrm{~F}$ Min.


## Metallization Topology

## DIE DIMENSIONS:

$136 \times 168 \times 19 \pm 1$ mils

## METALLIZATION:

Type: Si - AI
Thickness: $11 \mathrm{k} \AA \pm 15 \mathrm{k} \AA$

## GLASSIVATION:

Type: $\mathrm{SiO}_{2}$
Thickness: $8 \mathrm{k} \AA \pm 1 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold-Silicon Eutectic Alloy
Temperature: Ceramic DIP - $460^{\circ} \mathrm{C}$ (Max)
Ceramic LCC - $420^{\circ} \mathrm{C}$ (Max)
WORST CASE CURRENT DENSITY:
$1.7 \times 10^{5} \mathrm{~A} \mathrm{~cm}^{2}$

Metallization Mask Layout


## Packaging

## 24 PIN (0.300) CERAMIC DIP



24 PIN (.600) CERAMIC DIP


28 PAD CERAMIC LCC


LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M-38510 COMPLIANT OUTLINE:

MIL-STD-1835, GDIP3-T24

LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M-38510 COMPLIANT OUTLINE:
MIL-STD-1835, GDIP1-T24

MATERIALS: Compliant to MIL-M-38510 COMPLIANT OUTLINE:
MIL-STD-1835, CQCC1-N28

## Features

- Low Power Standby and Operating Power
- ICCSB $\qquad$
- ICCOP $\qquad$
- Fast Access Time. 90/120ns
- Industry Standard Pinout
- Single 5.0 Volt Supply
- CMOS/TTL Compatible Inputs
- High Output Drive $\qquad$ 12 LSTTL Loads
- Synchronous Operation
- On-Chip Address Latches
- Separate Output Enable


## Description

The HM-6617 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 Ceramic DIP, the 0.300 inch wide slimline Ceramic DIP, and the JEDEC standard 32 pad Ceramic LCC.
The HM-6617 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 NiCr fuse link technology is utilized on this and other Harris CMOS PROMs. This gives the user a PROM with permanent, stable storage characteristics over the full industrial and military temperature voltage ranges. NiCr 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.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 90ns | 120ns |
| :---: | :---: | :---: | :---: |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM1-6617B-9 | HM1-6617-9 |
| 1883* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM1-6617B/883 | HM1-6617/883 |
| SMD\# |  | 5962-8954002JA | 5962-8954001JA |
| SLIM | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM6-6617B-9 | HM6-6617-9 |
| 1883* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM6-6617B/883 | HM6-6617/883 |
| SMD* |  | 5962-8954002LA | 5962-8954001LA |
| LCC | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | HM4-6617B-9 | HM4-6617-9 |
| 1883* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | HM4-6617B/883 | HM4-6617/883 |
| SMD\# |  | 5962-8954002XA | 5962-8954001XA |

* Respective $/ 883$ specifications are included at the end of this data sheet.


## Pinouts

$$
\begin{aligned}
& 24 \text { LEAD DIP } \\
& \text { TOP VIEW }
\end{aligned}
$$

| A7 1 | 24. vcc |
| :---: | :---: |
| A6 2 | $3{ }^{48}$ |
| A5 [3] | 22 ${ }^{\text {a }}$ |
| A 4 [4] | 주 $\bar{\square}$ |
| A3 5 | $20 \overline{\mathbf{G}}$ |
| A2 6 | 19 A10 |
| A1 7 | 18 E |
| A0 8 | 1707 |
| 009 | 1606 |
| 0118 | 1505 |
| Q2 11 | 1404 |
| GND 12 | 13 Q3 |


| PIN | DESCRIPTION |
| :---: | :--- |
| NC | No Connect |
| A0 - A10 | Address Inputs |
| $\overline{\mathbf{E}}$ | Chip Enable |
| $\mathbf{Q}$ | Data Output |
| VCC | Power (+5V) |
| $\overline{\mathbf{G}}$ | Output Enable |
| $\overline{\mathbf{P}}^{*}$ | Output Enable |

[^26]
## Functional Diagram

ALL LINES POSITIVE LOGIC: ACTIVE HIGH THREE-STATE BUFFERS:

$$
\text { A HIGH } \longrightarrow \text { OUTPUT ACTIVE }
$$ ADDRESS LATCHES AND GATED DECODERS:

## LATCH ON FALLING EDGE OF E

GATE ON FALLUNG EDGE OF $\overline{\mathbf{G}}$

## Background Information Programming Algorithm

The HM-6617 CMOS PROM is manufactured with all bits containing a logical zero (output low). Any bit can be programmed selectively to a logical one (output high) state by following the procedure shown below. To accomplish this, a programmer can be built that meets the specifications shown, or any of the approved commercial programmers can be used.

## PROGRAMMING SEQUENCE OF EVENTS

1. Apply a voltage of VCC1 to VCC of the PROM.
2. Read all fuse locations to verify that the PROM is blank (output low).
3. Place the PROM in the initial state for programming: $\bar{E}=$ VIH, $\overline{\mathrm{P}}=\mathrm{VIH}, \overline{\mathrm{G}}=$ VIL.
4. Apply the correct binary address for the word to be programmed. No inputs should be left open circuit.
5. After a delay of td, apply voltage of VIL to $\bar{E}$ (pin 18) to access the addressed word.
6. The address may be held through the cycle, but must be held valid at least for a time equal to td after the falling edge of $\overline{\mathrm{E}}$. None of the inputs should be allowed to float to an invalid logic level.
7. After a delay of td, disable the outputs by applying a voltage of VIH to $\overline{\mathrm{G}}$ (pin 20).
8. After a delay of td, apply voltage of VIL to $\overline{\mathrm{P}}$ (pin 21).
9. After delay of td, raise VCC (pin 24) to VCCPROG with a rise time of tr. All outputs at VIH should track VCC with VCC-2.0V to VCC +0.3 V . This could be accomplished by pulling outputs at VIH to VCC through pull-up resistors of value Rn.
10. After a delay of td, pull the output which corresponds to the bit to be programmed to VIL. Only one bit should be programmed at a time.
11. After a delay of tpw, allow the output to be pulled to VIH through pull-up resistor Rn.
12. After a delay of td, reduce VCC (pin 24) to VCC1 with a fall time of tt. All outputs at VIH should track VCC with VCC-2.0V to VCC +0.3 V . This could be accomplished by pulling outputs at VIH to VCC through pull-up resistors of value Rn.
13. Apply a voltage of VIH to $\overline{\mathrm{P}}$ (pin 21).
14. After a delay of td, apply a voltage of VIL to $\overline{\mathrm{G}}$ (pin 20).
15. After a delay of td, examine the outputs for correct data. If any location verifies incorrectly, repeat steps 4 through 14 (attempting to program only those bits in the word which verified incorrectly) up to a maximum of eight attempts for a given word. If a word does not program within eight attempts, it should be considered a programming reject.
16. Repeat steps 3 through 15 for all other bits to be programmed in the PROM.

## POST-PROGRAMMING VERIFICATION

17. Place the $P R O M$ in the post-programming verification mode: $\overline{\mathrm{E}}=\mathrm{VIH}, \overline{\mathrm{G}}=$ VIL, $\overline{\mathrm{P}}=$ VIH, VCC $($ pin 24$)=$ VCC1.
18. Apply the correct binary address of the word to be verified to the PROM.
19. After a delay of td, apply a voltage of VIL to $\overline{\mathrm{E}}$ (pin 18).
20. After a delay of td, examine the outputs for correct data. If any location fails to verify correctly, the PROM should be considered a programming reject.
21. Repeat steps 17 through 20 for all possible programming locations

## POST-PROGRAMMING READ

22. Apply a voltage of $\mathrm{VCC} 2=4.0 \mathrm{~V}$ to VCC (pin 24).
23. After a delay of td, apply a voltage of VIH to $\bar{E}$ (pin 18).
24. Apply the correct binary address of the word to be read.
25. After a delay of TAVEL, apply a voltage of VIL to $\overline{\mathrm{E}}$ (pin 18).
26. After a delay of TELQV, examine the outputs for correct data. If any location fails to verify correctly, the PROM should be considered a programming reject.
27. Repeat steps 23 through 26 for all address locations.
28. Apply a voltage of $\mathrm{VCC2}=6.0 \mathrm{~V}$ to VCC (pin 24).
29. Repeat steps 23 through 26 for all address locations.

## Programming Cycle

HM-6617 PROGRAMMING CYCLE


HM-6617 POST PROGRAMMING VERIFY CYCLE


## Background Information HM-6617 Programming

Programming Specifications

| SYMBOL | PARAMETER | MIN | TYP | MAX | UNITS |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VIL | Input "0" | 0.0 | 0.2 | 0.8 | V |
| VIH | Voltage "1" (Note 6) | VCC-2 | VCC | VCC +0.3 | V |
| VCCPROG | Programming VCC (Note 2) | 12.0 | 12.0 | 12.5 | V |
| VCC1 | Operating VCC | 4.5 | 5.5 | 5.5 | V |
| VCC2 | Special Verify VCC (Note 3) | 4.0 | - | 6.0 | V |
| td | Delay Time | 1.0 | 1.0 | - | $\mu \mathrm{s}$ |
| tr | Rise Time | 1.0 | 10.0 | 10.0 | $\mu \mathrm{~s}$ |
| tf | Fall Time | 1.0 | 10.0 | 10.0 | $\mu \mathrm{~s}$ |
| 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 |
| tpw | Programming Pulse Width (Note 4) | 90 | 100 | 110 | $\mu \mathrm{~s}$ |
| tIP | Input Leakage at VCC = VCCPROG | -10 | +1.0 | 10 | $\mu \mathrm{~A}$ |
| IOP | Data Output Current at VCC = VCCPROG | - | -5.0 | -10 | mA |
| Rn | Output Pull-Up Resistor (Note 5) | 5 | 10 | 15 | ks |
| 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 22 through 29 of the Programming Algorithm.
4. See Step 11 of the Programming Algorithm.
5. All outputs should be pulled up to VCC through a resistor of value Rn.
6. Except during programming (See Programming Cycle Waveforms).

## Absolute Maximum Ratings

Supply Voltage (All Voltages Reference to Device GND) . . . . . +7.0 V Input or Output VoltageApplied for All Grades GND-0.3V to VCC +0.3 V
Storage Temperature Range $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Junction Temperature $+175^{\circ} \mathrm{C}$ Lead Temperature (Soldering 10s) . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$ Typical Derating Factor . . . . . . . . . . . . 5mA/MHz Increase in ICCOP ESD Classification $\qquad$ Class 1

Reliability Information

| Thermal Resistance | ${ }^{\theta_{\text {ja }}}$ | ${ }^{\circ}$ |
| :---: | :---: | :---: |
| Ceramic DIP Package | $48^{\circ} \mathrm{C} / \mathrm{W}$ | $9^{\circ} \mathrm{CM}$ |
| Ceramic LCC Package | $58^{\circ} \mathrm{C} / \mathrm{N}$ | $19^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic DIP Package |  | 1.0 W |
| Ceramic LCC Package |  | 0.86 W |
| Gate Count |  | 73 Gate |

CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V Operating Temperature Range: $\mathrm{HM}-6617-9, \mathrm{~B}-9 \ldots-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
DC Electrical Specifications $\quad \mathrm{VCC}=5 \mathrm{~V} \pm 10 \%$; (HM-6617B-9, HM-6617-9)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | Logical One Input Voltage | 2.4 | VCC+0.3 | V | $V C C=5.5 \mathrm{~V}$ |
| VIL | Logical Zero Input Voltage | -0.3 | 0.8 | V | $\mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH1 | Logical One Output Voltage | 2.4 | - | V | $1 \mathrm{OH}=-2.0 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOH 2 | Logıcal One Output Voltage (Note 2) | VCC-1.0 | - | V | $1 \mathrm{OH}=-100 \mu \mathrm{~A}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| VOL | Logıcal Zero Output Voltage | - | 0.4 | V | $1 \mathrm{OL}=+4.8 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ |
| II | Input Leakage | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{VCC}$ or GND, VCC $=5.5 \mathrm{~V}$ |
| IOZ | Output Leakage | -1.0 | +1.0 | $\mu \mathrm{A}$ | $\mathrm{VO}=\mathrm{VCC}$ or GND, $\overline{\mathrm{G}}=\mathrm{VCC}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| ICCSB | Standby Power Supply Current | - | 100 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{VCC}$ or GND, $\mathrm{VCC}=5.5 \mathrm{~V}, 1 \mathrm{O}=0$ |
| ICCOP | Operating Power Supply Current (Note 3) | - | 20 | mA | $\begin{aligned} & f=1 \mathrm{MHz}, \mathrm{VCC}=5.5 \mathrm{~V}, 1 \mathrm{O}=0, \mathrm{VIN}=\mathrm{VCC} \text { or } \\ & \text { GND } \end{aligned}$ |

## AC Electrical Specifications

| SYMBOL | PARAMETER | HM-6617B-9 |  | HM-6617-9 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| (1) TAVQV | Address Access Time | - | 105 | - | 140 | ns | ( Notes 1, 4) |
| (2) TELQV | Chip Enable Access Time | - | 90 | - | 120 | ns | (Notes 1, 4) |
| (3) TELQX | Chip Enable Time | 5 | $\cdot$ | 5 | - | ns | (Notes 2, 4) |
| (4) TAVEL | Address Setup Time | 15 | - | 20 | - | ns | (Notes 1, 4) |
| (5) TELAX | Address Hold Time | 20 | - | 25 | $\cdot$ | ns | (Notes 1, 4) |
| (6) TELEH | Chip Enable Low Width | 95 | $\bullet$ | 120 | - | ns | (Notes 1, 4) |
| (7) TEHEL | Chip Enable High Width | 40 | - | 40 | - | ns | (Notes 1, 4) |
| (8) TELEL | Cycle Tıme | 136 | - | 160 | - | ns | (Notes 1, 4) |
| (9) TGLQV | Output Access Time | - | 40 | - | 50 | ns | (Notes 1, 4) |
| (10) TGLQX | Output Enable Time | 5 | - | 5 | - | ns | (Notes 2, 4) |
| (11) TGHQZ | Output Disable Time | - | 40 | - | 50 | ns | (Notes 2, 4) |
| (12) TEHQZ | Chip Enable Disable Tıme | - | 45 | - | 50 | ns | (Notes 2, 4) |

## Capacitance $T_{A}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance (Note 2) | 10 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All Measurement are Referenced to Device GND |
| COUT | Output Capacitance (Note2) | 12 | pF | $\mathrm{f}=1 \mathrm{MHz}$, All Measurement are Referenced to Device GND |

NOTES:

1. Input pulse levels: 0 to 3.0 V ; Input rise and fall times: 5 ns (max); Input and output timing reference level: 1.5 V ; Output load: 1 TTL gate equivalent $\mathrm{CL}=50 \mathrm{pF}(\mathrm{min})-$ for $C L$ greater than 50 pF , access time is derated by 0.15 ns per pF .
2. Tested at initial design and after major design changes.
3. Typical derating 5 mAMHz increase in ICCOP.
4. $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V .

## Switching Waveforms

READ CYCLE


## Test Circuit

* TEST HEAD CAPACITANCE


HARRIS НМ-6617/883

# 2K x 8 CMOS PROM 

## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Low Power Standby and Operating Power
- ICCSB 100 mA
- ICCOP 20 mA at 1 MHz
- Fast Access Time 90/120ns
- Industry Standard Pinout
- Single 5.0 Volt Supply
- CMOS/TTL Compatible Inputs
- High Output Drive

12 LSTTL Loads

- Synchronous Operation
- On-Chip Address Latches
- Separate Output Enable
- Operating Temperature Range $\qquad$


## Description

The HM-6617/883 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 Ceramic DIP, the 0.300 inch wide slimline Ceramic DIP, and the JEDEC standard 32 pad Ceramic LCC.
The HM-6617/883 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 NiCr fuse link technology is utilized on this and other Harris CMOS PROMs. This gives the user a PROM with permanent, stable storage characteristics over the full industrial and military temperature voltage ranges. NiCr 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.

Functional Diagram


## Pinouts

HM1-6617/883 (CERAMIC DIP) TOP VIEW


HM4-6617/883 (CERAMIC LCC) TOP VIEW


| PIN | DESCRIPTION |
| :---: | :--- |
| NC | No Connect |
| $A 0-A 10$ | Address Inputs |
| $\overline{\mathrm{E}}$ | Chip Enable |
| Q | Data Input |
| VCC | Power ( +5 V ) |
| $\overline{\mathrm{G}}$ | Output Enable |
| $\mathrm{P}^{*}$ | Program Enable |

- $\overline{\mathrm{P}}$ should be hardwired to VCC except during programming


## Absolute Maximum Ratings



## Reliability Information



CAUTION: 1 Gas Cos
CAUTION: Stresses above those listed in "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.

## Operating Conditions

Operating Voltage Range . . . Operating Temperature Range
+4.5 V to +5.5 V
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

Input Low Voltage $\qquad$ .
Input High Voltage.
.-0.3 V to +0.8 V
Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$
Ceramic DIP Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.0 W
Ceramic LCC Package . . . . . . . . . . . . . . . . . . . . . . . . . . . 0.86 W
Gate Count
5473 Gates
——n
+2.4 V to $\mathrm{VCC}+0.3 \mathrm{~V}$

TABLE 1. HM-6617/883 DC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETERS | SYMBOL | (NOTES 1, 4) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| High Level Output Voltage | VOH1 | $\mathrm{VCC}=4.5 \mathrm{~V}, 1 \mathrm{O}=-2.0 \mathrm{~mA}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T A \leq+125^{\circ} \mathrm{C}$ | 2.4 | $\bullet$ | V |
| Low Level Output Voltage | VOL | $\mathrm{VCC}=4.5 \mathrm{~V}, 1 \mathrm{O}=+4.8 \mathrm{~mA}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| High Impedance Output Leakage Current | IIOZ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{G}}=5.5 \mathrm{~V}, \\ & \mathrm{~V} / / \mathrm{O}=\mathrm{GND} \text { or VCC } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Input Leakage Current | 11 | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VI}=\mathrm{GND} \text { or }$ VCC, $\overline{\mathrm{P}}$ Not Tested | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Standby Supply Current | ICCSB | $\begin{aligned} & \mathrm{VI}=\mathrm{VCC} \text { or GND, } \\ & \mathrm{VCC}=5.5 \mathrm{~V}, 1 \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | - | 100 | $\mu \mathrm{A}$ |
| Operating Supply Current | ICCOP | $\mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{G}}=\mathrm{GND}$, (Note 3), $\mathrm{f}=1 \mathrm{MHz}, \mathrm{IO}=$ $\mathrm{OmA}, \mathrm{VI}=\mathrm{VCC}$ or GND | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 20 | mA |
| Functional Test | FT | $\mathrm{VCC}=4.5 \mathrm{~V}$ (Note 6) | 7, 8A, 8B | $-55^{\circ} \mathrm{C} \leq T A \leq+125^{\circ} \mathrm{C}$ | - | - |  |

TABLE 2. HM-6617/883 AC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETERS | SYMBOL | (NOTES 1, 2, 4) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS HM-6617B/883 |  | LIMITS HM-6617/883 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Address Access Time | TAVQV | $\begin{aligned} & \mathrm{VCC}=4.5 \mathrm{~V} \text { and } 5.5 \mathrm{~V} \\ & \text { (Note 5) } \end{aligned}$ | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 105 | $\bullet$ | 140 | ns |
| Output Enable Access Time | TGLQV | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 40 | $\bullet$ | 50 | ns |
| Chip Enable Access Time | TELQV | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | - | 90 | - | 120 | ns |
| Address Setup Time | TAVEL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq$ TA $\leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Address Hold Time | TELAX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq$ TA $\leq+125^{\circ} \mathrm{C}$ | 20 | - | 25 | - | ns |
| Chip Enable Low Width | TELEH | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq$ TA $\leq+125^{\circ} \mathrm{C}$ | 95 | - | 120 | - | ns |
| Chip Enable High Width | TEHEL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq$ TA $\leq+125^{\circ} \mathrm{C}$ | 40 | - | 40 | - | ns |
| Read Cycle Time | TELEL | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq T A \leq+125^{\circ} \mathrm{C}$ | 136 | - | 160 | - | ns |

NOTES:

1. All voltages referenced to Device GND.
2. AC measurements assume transition time $\leq 5 \mathrm{~ns}$; input levels $=0.0 \mathrm{~V}$ to 3.0 V ; timing reference levels $=1.5 \mathrm{~V}$; output load $=1$ TTL equivalent load and $C L \cong 50 \mathrm{pF}$.
3. Typical derating $=5 \mathrm{~mA} / \mathrm{MHz}$ increase in ICCOP.
4. All tests performed with $\overline{\mathrm{P}}$ hardwired to VCC.
5. $T A V Q V=T E L Q V+T A V E L$
6. Tested as follows: $\mathrm{f}=1 \mathrm{MHz}, \mathrm{VIH}=2.4 \mathrm{~V}, \mathrm{VIL}=0.8 \mathrm{~V}, 1 \mathrm{OH}=-1 \mathrm{~mA}, 1 \mathrm{OL}=+1 \mathrm{~mA}, \mathrm{VOH} \geq 1.5 \mathrm{~V}$, $\mathrm{VOL} \leq 1.5 \mathrm{~V}$.

TABLE 3. HM-6617/883 AC AND DC ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | (NOTES 1, 2) CONDITIONS | NOTES | TEMPERATURE | LIMITSHM-6617B/883 |  | $\begin{gathered} \text { LIMITS } \\ \text { HM-6617/883 } \end{gathered}$ |  | UNTTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | CIN | VCC = Open, $f=1 \mathrm{MHz}$, All Measurements Referenced to Device GND | 2, 3 | $+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
|  |  | $\text { VCC }=\text { Open, } \mathrm{f}=1 \mathrm{MHz} \text {, All }$ <br> Measurements Referenced to Device GND | 2, 4 | $+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
|  |  |  | 2,5 | $+25^{\circ} \mathrm{C}$ | $\bullet$ | 10 | - | 10 | pF |
| VO Capacitance | CVO | VCC = Open, $f=1 \mathrm{MHz}$, All Measurements Referenced to Device GND | 2, 3 | $+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
|  |  | $\text { VCC = Open, } \mathrm{f}=1 \mathrm{MHz} \text {, All }$ <br> Measurements Referenced to Device GND | 2, 4 | $+25^{\circ} \mathrm{C}$ | - | 14 | - | 14 | pF |
|  |  |  | 2,5 | $+25^{\circ} \mathrm{C}$ | $\bullet$ | 12 | $\bullet$ | 12 | pF |
| Chip Enable Time | TELQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 2 | $-55^{\circ} \mathrm{C} \leq$ TA $\leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | ns |
| Output Enable Time | TGLQX | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 2 | $-55^{\circ} \mathrm{C} \leq$ TA $\leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | ns |
| Chip Disable Time | TEHQZ | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 2 | $-55^{\circ} \mathrm{C} \leq T A \leq+125^{\circ} \mathrm{C}$ | - | 45 | - | 50 | ns |
| Output Disable Time | TGHQZ | $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V | 2 | $-55^{\circ} \mathrm{C} \leq$ TA $\leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 40 | - | 50 | ns |
| Output High Voltage | VOH2 | $V C C=4.5 \mathrm{~V}, 1 \mathrm{O}=100 \mu \mathrm{~A}$ | 2 | $-55^{\circ} \mathrm{C} \leq \mathrm{TA} \leq+125^{\circ} \mathrm{C}$ | VCC- <br> 1V | - | VCC1V | - | V |

NOTES:

1. All tests performed with $\overline{\mathrm{P}}$ hardwired to VCC.
2. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design changes which would affect these characteristics.
3. Applies to .600 inch Ceramic Dual-In-Line (DIP) device types only.
4. Applies to .300 inch Ceramic Dual-In-Line (DIP) device types only.
5. Applies to Ceramic Leadless Chip Carrier (LCC) device types only.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | $1,7,9$ |
| PDA | $100 \% / 5004$ | 1 |
| Final Test | $100 \% / 5004$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | Samples/5005 | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Switching Waveforms

READ CYCLE


## Test Circuit



## Burn-In Circuits

HM-6617/883 (.300 INCH) CERAMIC DIP
HM-6617/883 (. 600 INCH) CERAMIC DIP


HM-6617/883 CERAMIC LCC


NOTES:
$\mathrm{fO}=100 \mathrm{KHz} \pm 10 \%$
All resistors $=47 \mathrm{k} \Omega$ Unless Otherwise Noted
$\mathrm{VCC}=5.5 \mathrm{~V} \pm 0.05 \mathrm{~V}$
$\mathrm{C}=0.01 \mu \mathrm{~F} \mathrm{~min}$.

## Metallization Topology

## DIE DIMENSIONS:

$140 \times 232 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: Si - Al
Thickness: $11 \mathrm{k} \AA \pm 15 \mathrm{k} \AA$
GLASSIVATION:
Type: $\mathrm{SiO}_{2}$
Thickness: $7 \mathrm{k} \AA \pm 9 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy
Temperature: Ceramic DIP $-460^{\circ} \mathrm{C}$ (Max) Ceramic LCC - $420^{\circ} \mathrm{C}$ (Max)

## WORST CASE CURRENT DENSITY:

$1.7 \times 10^{5} \mathrm{~A}^{\mathrm{cm}}{ }^{2}$

Metallization Mask Layout
HM-6617/883


## Packaging

24 PIN (0.300) CERAMIC DIP
LEAD FINISH: Type A
 MEASURED AT
SOLDER FNISH

## 24 PIN (.600) CERAMIC DIP



LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M-38510 COMPLIANT OUTLINE:

MIL-STD-1835, GDIP1-T24

32 PAD CERAMIC LCC
LEAD FINISH: Type A
MATERIALS: Compliant to MIL-M-38510


## COMPLIANT OUTLINE:

MIL-STD-1835, CQCC1-N32

## 4096 Bit CMOS UV EPROM

## Features

- Organization $\qquad$ $512 \times 8$
- Low Power $\qquad$
- High Speed
- Access Time for IM6654-AI

300ns 10V

- Access Time for IM6654-1I 450ns 5V
- Single Supply Operation $\qquad$
- UV Erasable
- Synchronous Operation for Low Power Dissipation
- Three-State Outputs and Chip Select for Easy System Expansion


## Description

The Harris IM6654 is a fully decoded 4096 bit CMOS electrically programmable ROM (EPROM) fabricated with Harris' advanced CMOS processing technology. In all static states this device exhibits the microwatt power dissipation typical of CMOS. Inputs and three-state outputs are TTL compatible and allow for direct interface with common system bus structures. On-chip address registers and chip select functions simplify system interfacing requirements.

The IM6654 is specifically designed for program development applications where rapid turn-around for program changes is required. The device may be erased by exposing its transparent lid to ultra-violet light, and then reprogrammed.

## Ordering Information

| PACKAGE | TEMPERATURE RANGE | 5V | 10V |
| :--- | :---: | :--- | :---: |
| Ceramic DIP | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | IM6654IJG | IM6654AIJG |
|  |  | IM6654-1IJG | - |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | IM6654MJG | IM6654AMJG |



## Block Diagram



## Program Mode Operation

Initially, all 4096 bits of the EPROM are in the logic one (output high) state. Selective programming of proper bit locations to " 0 " $s$ is performed electrically.

In the PROGRAM mode for all EPROMs, VCC and VDD are tied together to a +5 V operating supply. High logic levels at all of the appropriate chip inputs and outputs must be set at VDD -2V minimum. Low logic levels must be set at VSS +0.8 V maximum. Addressing of the desired location in PROGRAM mode is done as in the READ mode. Address and data lines are set at the desired logic levels, and PROGRAM and chip select $(\bar{S})$ pins are set high. The address is latched by the downward edge on the strobe line ( $\bar{E} 1)$ ). During valid DATA IN time, the PROGRAM pin is pulsed from VDD to 40 V . This pulse initiates the programming of the device to the levels set on the data outputs. Duty cycle limitations are specified from chip heat dissipation considerations. PULSE RISE AND FALL TIMES MUST NOT BE FASTER THAN $5 \mu \mathrm{~s}$.

Intelligent programmer equipment with successive READ/ PROGRAM/NERIFY sequences is recommended.

## Programming System Characteristics

1. During programming the power supply should be capable of limiting peak instantaneous current to 100 mA .
2. The programming pin is driven from VDD to -40 volts $( \pm 2 \mathrm{~V})$ by pulses of 20 milliseconds duration. These pulses should be applied in the sequence shown in the flow chart. Pulse rise and fall times of 10 microseconds are recommended. Note that any individual location may be programmed at any time.
3. Addresses and data should be presented to the device within the recommended setup/hold time and high/low logic level margins. Both "A" (10V) and non " $A$ " EPROMs are programmed at VCC, VDD of $5 \mathrm{~V} \pm 5 \%$.
4. Programming is to be done at room temperature.

## Erasing Procedure

The IM6654 is erased by exposure to high intensity shortwave ultraviolet light at a wavelength of $2537 \AA$. The recommended integrated dose (i.e., UV intensity $x$ exposure time) is 10 W sec/ $\mathrm{cm}^{2}$. The lamps should be used without shortwave filters, and the IM6654 to be erased should be placed about one inch away from the lamp tubes. For best results it is recommended that the device remain inactive for 5 min utes after erasure, before reprogramming.
The erasing effect of UV light is cumulative. Care should be taken to protect EPROMs from exposure to direct sunlight or fluorescent lamps radiating UV light in the $2000 \AA$ to $4000 \AA$ range.

## Programming Flow Chart



Specifications IM6654
DC Characteristics for Programming Operation $\mathrm{VCC}=\mathrm{VDD}=5 \mathrm{~V} \pm 5 \% \mathrm{VSS}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNITS |
| :---: | :--- | :--- | :---: | :---: | :---: | :---: |
| IPROG | Program Pin Load Current |  | - | 80 | 100 | mA |
| VPROG | Programming Pulse Amplitude |  | -38 | -40 | -42 | V |
| ICC | VCC Current |  | - | 0.1 | 5 | mA |
| IDD | VDD Current |  | - | 40 | 100 | mA |
| VIHA | Address Input High Voltage |  | VDD-2.0 | - | - | V |
| VILA | Address Input Low Voltage |  | - | - | 0.8 | V |
| VIH | Data Input High Voltage |  | VDD-2.0 | - | - | V |
| VIL | Data Input Low Voitage |  | - | - | 0.8 | V |

AC Characteristics for Programming Operation $\quad \mathrm{VCC}=\mathrm{VDD}=5 \mathrm{~V} \pm 5 \% \mathrm{VSS}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TPLPH | Program Pulse Width | trise $=$ tfall $=5 \mu \mathrm{~s}$ | 18 | 20 | 22 | ms |
|  | Program Pulse Duty Cycie |  | - | - | 75\% |  |
| TDVPL | Data Setup Time |  | 9 | - | - | $\mu s$ |
| TPHDX | Data Hold Time |  | 9 | - | - | $\mu s$ |
| TE1HE1L | Strobe Pulse Width |  | 150 | - | - | ns |
| TAVE1L | Address Setup Time |  | 0 | - | - | ns |
| TE1LE1X | Address Hold Time |  | 100 | - | - | ns |
| TEILQV | Access Time |  | - | - | 1000 | ns |

## Pin Description

| PIN | SYMBOL | ACTIVE LEVEL | DESCRIPTION |
| :---: | :---: | :---: | :--- |
| $1-8,23$ | A0-A7, A8 | - | Address LInes |
| $9-11,13-17$ | Q0-Q7 | - | Data Out Lines |
| 12 | VSS | - | Negative Supply |
| 18 | Program | - | Programming Pulse Input |
| 19 | VDD | - | Chip Positive Supply, Normally Tied to VCC |
| 20 | $\bar{E} 1$ | L | Strobe Line, Latches Both Address Lines and Chip Enable E2 |
| 21 | $\bar{S}$ | L | Chip Select Line, Must be Low for Valid Data Out |
| 22 | $\bar{E} 2$ | L | Chip Enable Line, Latched by Chip Enable $\bar{E} 1$ |
| 24 | VCC | - | Output Buffer Positive Supply |

Read and Program Cycle Timing


## Read Mode Operation

In a typical READ operation address lines and chip enable $\overline{\mathrm{E}} 2$ are latched by the falling edge of chip enable $\mathrm{E}_{1}(\mathrm{~T}=0)$. Valid data appears at the outputs one access time (TELQV) later, provided level-sensitive chip select line $\overline{\mathrm{S}}$ is low ( $\mathrm{T}=3$ ). Data remains valid until either $\overline{\mathrm{E}} 1$ or $\overline{\mathrm{S}}$ returns to a high level ( $\mathrm{T}=4$ ). Outputs are then forced to a high -Z state.
Address lines and E2 must be valid one setup time before (TAVEL), and one hold time after (TELAX), the falling edge of $\bar{E} 1$ starting the read cycle. Before becoming valid, Q output lines become active ( $\mathrm{T}=2$ ). The Q output lines return to a high-Z state one output disable time (TE1HQZ) after any rising edge on $\overline{\mathrm{E}} 1$ or $\overline{\mathrm{S}}$.

The program line remains high throughout the READ cycle.
Chip enable line $\bar{E} 1$ must remain high one minimum positive pulse width (TEHEL) before the next cycle can begin.

Read Cycle Timing


FUNCTION TABLE

| TIME REFERENCE | INPUTS |  |  |  | OUTPUTS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\bar{E}_{1}$ | E2 | $\overline{\mathbf{S}}$ | A | 0 |  |
| -1 | H | X | X | X | Z | Device Inactive |
| 0 | 7 | L | X | V | Z | Cycle Begins; Addresses, E2 Latched |
| 1 | L | X | X | X | Z | Internal Operations Only |
| 2 | L | X | L | X | A | Outputs Active Under Control of $\overline{\mathrm{E}}, \overline{\mathrm{S}}$ |
| 3 | L | X | L | X | V | Outputs Valid After Access Time |
| 4 | $\sim$ | X | L | X | V | Read Complete |
| 5 | H | X | X | X | Z | Cycle Ends (Same as -1) |

Absolute Maximum Ratings (IM6654 $1,-11, M$ )
Supply Voltages
vDD-vSS
$+8.0 \mathrm{~V}$

VCC - VSS
.+8.0 V
Input or Output Voltage. . . . . . . . . . . . . . . . . .VSS-0.3V to VDD+0.3V
Storage Temperature Range . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10s).
$+300^{\circ} \mathrm{C}$
CAUTION: Stresses above those listed in "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.

DC Electrical Characteristics $\quad \mathrm{VCC}=\mathrm{VDD}=5 \mathrm{~V} \pm 10 \% \mathrm{VSS}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=$ Operating Temperature Range

| SYMBOL | PARAMETER | TEST CONDITIONS | IM6654 I, -11, M |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |
| VIH | Logical "1" Input Voltage | $\overline{\mathrm{E}}$ 1, $\overline{\mathrm{S}}$ | VDD - 2.0 | - | V |
|  |  | Address Pins | 2.7 | - | V |
| VIL | Logical "0" Input Voltage | - | - | 0.8 | V |
| 11 | Input Leakage | $\mathrm{GND} \leq \mathrm{VIN} \leq$ VDD | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| VOH | Logical "1" Output Voltage | $10 \mathrm{H}=-0.2 \mathrm{~mA}$ | 2.4 | - | V |
| VOL | Logical "0" Output Voltage | $10 \mathrm{~L}=2.0 \mathrm{~mA}$ | - | 0.45 | V |
| IOLK | Output Leakage | $\mathrm{GND} \leq \mathrm{VO} \leq \mathrm{VCC}$ | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| ISTBY | Standby Supply Current | $\mathrm{VIN}=\mathrm{VDD}$ | - | 100 | $\mu \mathrm{A}$ |
| ICC | Standby Supply Current | $\mathrm{VIN}=\mathrm{VDD}$ | - | 40 | $\mu \mathrm{A}$ |
| IDD | Operating Supply Current (1) | $f=1 \mathrm{MHz}$ |  | 6.0 | mA |
| Cl | Input Capacitance | Note 1 |  | 7.0 | pF |
| CO | Output Capacitance | Note 1 |  | 10.0 | pF |

NOTE: 1. For design reference only, not $100 \%$ tested.
AC Electrical Characteristics $\mathrm{VCC}=\mathrm{VDD}=5 \mathrm{~V} \pm 10 \% \mathrm{VSS}=0 \mathrm{~V}, \mathrm{CL}=50 \mathrm{pF}, \mathrm{T}_{\mathrm{A}}=$ Operating Temperature Range

| SYMBOL | PARAMETER | IM6654-11 |  | IM6654 I |  | IM6654 M |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| TE1LQV | Access Time From $\bar{E}_{1}$ | - | 450 | - | 550 | - | 600 | ns |
| TSLQV | Output Enable Time | - | 110 | - | 140 | - | 150 | ns |
| TE1HQZ | Output Disable Time | - | 110 | - | 140 | - | 150 | ns |
| TE1HE1L | E1 Pulse Width (Positive) | 130 | - | 150 | $\bullet$ | 150 | - | ns |
| TE1LE1H | $\overline{\mathrm{E}} 1$ Pulse Width (Negative) | 450 | - | 550 | - | 600 | - | ns |
| TAVE1L | Address Setup Time | 0 | - | 0 | - | 0 | $\bullet$ | ns |
| TE1LAX | Address Hold Time | 80 | - | 100 | - | 100 | $\bullet$ | ns |
| TE2VE1L | Chip Enable Setup Time | 0 | - | 0 | - | 0 | - | ns |
| TE1LE2X | Chip Enable Hold Time | 80 | - | 100 | - | 100 | $\bullet$ | ns |

## Absolute Maximum Ratings (IM6654AI, AM)



DC Electrical Characteristics $\quad \mathrm{VCC}=\mathrm{VDD}=4.5 \mathrm{~V}$ to $10.5 \mathrm{~V} \mathrm{VSS}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=$ Operating Temperature Range

| SYMBOL | PARAMETER | TEST CONDITIONS | IM6654 I, AM |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |
| VIH | Logical "1" Input Voltage | $\overline{\mathrm{E}}$, $\overline{\mathrm{S}}$ | VDD - 2.0 | - | V |
|  |  | Address Pins | VDD - 2.0 | - | V |
| VIL | Logical "0" Input Voltage | - | - | 0.8 | V |
| 11 | Input Leakage | GND $\leq$ VIN $\leq$ VDD | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| VOH | Logical "1" Output Voltage | IOUT $=0($ Note 1) | VCC - 0.01 | - | V |
| VOL | Logical "0" Output Voltage | IOUT $=0$ (Note 1) | - | VSS +0.01 | V |
| IOLK | Output Leakage | VSS $\leq$ VO $\leq$ VCC | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| ISTBY | Standby Supply Current | VIN = VDD | - | 100 | $\mu \mathrm{A}$ |
| ICC | Standby Supply Current | $\mathrm{VIN}=\mathrm{VDD}$ | - | 40 | $\mu \mathrm{A}$ |
| IDD | Operating Supply Current (1) | $f=1 \mathrm{MHz}$ | - | 12 | mA |
| Cl | Input Capacitance | Note 1 | - | 7.0 | pF |
| CO | Output Capacitance | Note 1 | - | 10.0 | pF |

NOTE: 1. For design reference only, not $100 \%$ tested.
AC Electrical Characteristics $V C C=V D D=5 \mathrm{~V} \pm 10 \% \mathrm{VSS}=0 \mathrm{~V}, \mathrm{CL}=50 \mathrm{pF}, \mathrm{T}_{\mathrm{A}}=$ Operating Temperature Range

| SYMBOL | PARAMETER | IM6654 AI |  | IM6654 AM |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| TE1LQV | Access Time From $\bar{E}_{1}$ | - | 300 | - | 350 | ns |
| TSLQV | Output Enable Time | - | 60 | - | 70 | ns |
| TE1HQZ | Output Disable Time | - | 60 | - | 70 | ns |
| TE1HE1L | $\overline{E 1}$ Pulse Width (Positive) | 125 | - | 125 | - | ns |
| TE1LE1H | E1 Pulse Width (Negative) | 300 | - | 350 | - | ns |
| TAVE1L | Address Setup Time | 0 | - | 0 | - | ns |
| TE1LAX | Address Hold Time | 60 | - | 60 | - | ns |
| TE2VE1L | Chip Enable Setup Time | 0 | - | 0 | - | ns |
| TE1LE2X | Chip Enable Hold Time | 60 | - | 60 | - | ns |

Using IM6654 CMOS EPROM to Extend Program Memory


## APPLICATION NOTES

PAGE
App Note 108 82C52 Programmable UART ..... 7-3
App Note 109
82C59A Priority Interrupt Controller ..... 7-15
App Note 111 Harris 80C286 Performance Advantages Over the 80386. ..... 7-29
App Note 112 80C286/80386 Hardware Comparison ..... 7-41
App Note 120Interfacing the 80C286-16 with the 80287-107-45
App Note 121Harris 80C286 Performance Advantages Over the 80386SX7-47
App Note 400 Using the HS-3282 Bus Interface Circuit ..... 7-61
App Note 6565 Design of Clock Generators for Use with COMSAC Microprocessor CDP1802 ..... 7-67
App Note 7275 User's Guide to the CDP1879 and CDP1879C1 CMOS Real-Time Clocks ..... 7-70
App Note 7374 The CDP1871A Keyboard Encoder ..... 7-88


No. 108

## 82C52 PROGRAMMABLE UART

PAGE
INTRODUCTION ..... 7-4
1.0 GLOSSARY OF DATA COMMUNICATION TERMS ..... 7-4
1.1 Clear to Send ..... 7-4
1.2 Data Set Ready ..... 7-4
1.3 Data Terminal Ready ..... 7-4
1.4 Framing Error ..... 7-4
1.5 Interrupt Driven I/O ..... 7-4
1.6 I/O Polling ..... 7-4
1.7 Overrun Error ..... 7-5
1.8 Parity ..... 7-5
1.9 Parity Error. ..... 7-5
1.10 Percentage Error in Baud Rate Generation ..... 7-5
1.11 Request to Send ..... 7-6
2.0 CONTROL REGISTERS ..... 7-6
2.1 UART Control Register ..... 7-6
2.2 Baud Rate Select Register ..... 7-7
2.3 Modem Control Register ..... 7-8
3.0 STATUS REGISTERS ..... 7-10
3.1 UART Status Register ..... 7-10
3.2 Modem Status Register ..... 7-11
4.0 TRANSMIT/RECEIVE BUFFER REGISTERS ..... 7-11
4.1 Receiver Buffer Register ..... 7-11
4.2 Transmitter Buffer Register ..... 7-12
5.0 VO MAPPED ADDRESSING. ..... 7-12
5.1 I/O Mapped Addressing ..... 7-12
5.2 Memory Mapped I/O ..... 7-13
5.3 I/O Addressing for the 82C52 ..... 7-13
6.0 RESET OF THE 82C52 ..... 7-13
7.0 PROGRAMMING THE 82C52 ..... 7-14

## 82C52 PROGRAMMABLE UART

## Introduction

The 82C52 CMOS Programmable UART can be utilized for serial communications at data rates from DC to 1 M baud using clock speeds in the range of $0-16 \mathrm{MHz}$. In addition, the device provides an internal baud rate generator.

In the following discussion, we will look at the functional capabilities of the 82C52, and give information on how the device can be programmed. The following topics will be discussed:
(1) Glossary of communications terms
(2) Control registers
(3) Status registers
(4) Transmit/Receive Buffer Registers
(5) I/O Addressing methods
(6) Reset of the 82C52
(7) Programming the 82C52

### 1.0 Glossary of Data Communication Terms

### 1.1 Clear to Send ( (CTS):

Clear-to-send is an input signal to the 82C52. It is provided by the device with which the 82C52 is communicating, such as a modem. When this signal is in its active state (active low), the 82C52 is being told that the modem will accept data sent to it from the 82C52 Serial Data Out (SDO) pin.
The $\overline{\mathrm{CTS}}$ signal is specified in the RS-232C protocol and is used in conjunction with the Request to Send ( $\overline{\mathrm{RTS}}$ ) signal. This signal is used mainly in half-duplex systems. In a halfduplex system communications can be performed in both directions, but in only one direction at a time.

To illustrate this: Suppose we are using the 82C52 to communicate over an RS-232C link to a modem. In half-duplex operation the UART tells the modem that it wishes to transmit a character by putting RTS into its active state (active low for the 82C52). The modem, if ready for the data, will respond by driving the 82C52's $\overline{\mathrm{CTS}}$ line to its active state (low). When the 82C52 recognizes this, it will then begin data transmission.

### 1.2 Data Set Ready ( $\overline{\mathrm{DSR}}$ ):

This is also an input signal to the 82C52. When in its active state, it signifies that the device with which it is to communicate is powered on and ready for communications. When using a modem, an active state for this signal indicates that the modem is also connected to a communications line (is on line).

### 1.3 Data Terminal Ready (DTR):

This is an output signal generated by the 82C52. Its purpose is to inform the target (i.e. modem) that it is ready for communications.

### 1.4 Framing Error:

Each time the 82C52 receives a character of data, it will check for 3 types of errors: (1) Parity error, (2) Framing error, and (3) Overrun error.
When reading characters through the Serial Data In (SDI) pin, the 82C52 will first encounter a start bit. This start bit is a logical zero, and is detected by the first falling edge of the signal on SDI. Next, the 82C52 will see a specified number of data bits followed by the parity bit. The parity bit is checked for a parity error (see 1.8 and 1.9). The stop bits are then checked for a framing error.
A framing error occurs when an incorrect stop bit is found, or if there are too few stop bits. This happens most often when the baud rates between the communicating devices differ. The data will have a tendency to become skewed. For information on this skewing problem, see 1.10.

### 1.5 Interrupt Driven VO:

This is a method of handling interaction between a CPU and an I/O device. In this scheme, the I/O device will issue an interrupt to the CPU when it requires attention.

With the 82C52, an interrupt might occur when (1) the device receives a character on its SDI pin, (2) the device completes transmission of a character, (3) an error is found in a received character, or (4) a change was detected in one of the modem control lines.
After the interrupt is recognized by the CPU, it (the CPU) will go to the corresponding Interrupt Service Routine(ISR). This routine decides how the interrupt should be serviced, and then services it. Upon completion of the ISR, execution of the user's software will resume at the point where the interrupt occurred.

### 1.6 VO Polling:

A second method for handling interaction between a CPU and an I/O device. Rather than waiting for an I/O device to interrupt the CPU, the software assumes the responsibility of checking to see if an I/O device needs servicing.
When the system software needs to output to the 82C52, it will poll (look at) the device to see if it is ready to accept data. Similarly, in order to receive data from the 82C52, the software will poll to see if there is any data waiting to be read in. Once read, the software must test the status of the 82C52 to see if any errors were detected in the data received. The software must also look for status changes in the modem control lines.

### 1.7 Overrun Error:

With the 82C52, data is received on the SDI pin. From there it is shifted serially into the Receiver Register. Once in this register, it will be shifted (in parallel) into the Receive Buffer Register (RBR) should this register be empty. Should it not be empty, the data cannot be shifted into the RBR. However, subsequent data coming in on the SDI pin will be shifted into the Receiver Register, overwriting the data already there. This causes the 82C52 to flag an overrun error.

To clear the RBR, data must be read from it by the CPU.This data must be read faster than the data is being received on SDI and written to the Receiver Register. In most cases, this problem must be dealt with in software: (1) Either the receive data routine must be optimized for better performance, or (2) The baud rate must be lowered to compensate for the data loss.

### 1.8 Parity:

Parity is a form of error detection commonly used in serial communications. In parity checking, the sending device generates and sends an extra bit with each character transmitted. The state of this bit ( 0 or 1 ) is determined by (1) the number of 1 bits in the character transmitted, and (2) by whether parity was defined to be even or odd.

With even parity, the parity bit is generated such that the number of one' bits in the character (including the parity bit) is an even number. For example, if a word has 5 bits that are ones, the parity bit must be set to a one so that the total number of 'one' bits is an even number. If a character being sent has 6 bits set to a one, the parity bit will be zero.This still gives an even number of one bits in the character.

Conversely, in odd parity, the parity bit is generated such that the total number of 1 bits (including the parity bit) is an odd number. For a character having 5 one bits, the parity bit generated is a zero. For a character having 6 one bits, the parity bit is set to one

| CHARACTER SENT | (EVEN) <br> PARITY BIT | (ODD) <br> PARITY BIT |
| :---: | :---: | :---: |
| 01101110 | 1 | 0 |
| 11111010 | 0 | 1 |

FIGURE 1. PARITY

### 1.9 Parity Error:

This is caused by an invalid parity bit being detected in a character received. The condition occurs when (A) even parity is specified and an odd number of 'one' bits are detected in the character, or ( $B$ ) odd parity is specified and an even number of 'one' bits are detected.
For example, if the character 6EH ( 01101110 b ) is received by the device, and the parity bit read in is a 1, a parity error would be flagged if parity was defined to be ODD. Should parity be set to EVEN and the parity bit is a 1 for this same character, a parity error will not be flagged.

### 1.10 Percentage Error in Baud Rate Generation:

When exchanging data between two systems through serial links (i.e. RS-232C) it is important that the baud rates of the two systems be as equal as possible. Roughly speaking, these baud rates should not differ by more than $2 \%$. For example, if system X is using an 82C52 to generate 1200 bits per second (bps), and system Y with which it is communicating is generating 1244bps, there is a $3.67 \%$ difference in the baud rates. Errors may occur when data is received by system X .
The 82C52 samples the data being received on the SDI pin beginning from when the receiver detects a start bit.This is denoted by a high-to-low transition on the SDI pin. Based on the specified baud rate, the 82C52 will count and sample such that each bit is read at the center of a bit period. Figure 2 shows a character generated at 1200 bps , and sampled for 10 bit periods (S0-S10). The character is 1B Hex with even parity.

FIGURE 2. PERCENTAGE ERROR

Assume that system X is configured to transmit and receive at 1200 bps . The system we are communicating with is running slightly faster as stated above (1244bps). Our sampling rate will still be based upon 1200bps, but the sampling of the incoming signal will be off by a short time period. With each sample this error accumulates. Thus, the skewing to the right becomes greater over time. By the time we normally would be sampling the parity bit (S9), the stop bit(s) would be coming in over the SDI pin (see Figure 2A). In this case, the 82 C 52 thinks it is sampling the parity bit when in fact, what it is seeing is really the stop bit. This could cause a parity error to be flagged.
Conversely, if data is being received at a baud rate slightly less than our specified baud rate, we would get a skewing of the received data in the opposite direction. From Figure 2C, we see that at S10 we are checking the stop bit, but system Y is still transmitting the parity bit. Therefore, the Framing error will be flagged.

### 1.11 Request To Send ( $\overline{\mathrm{RTS}}$ ):

This signal is an output of the 82C52. It is used to inform a modem or remote system that it wishes to transmit data. The modem (remote system) would then respond by activating the $\overline{\mathrm{CTS}}$ signal. As with the $\overline{\mathrm{CTS}}$, this signal is of most value in half-duplex communications.

### 2.0 Control Registers

In order for the 82C52 to properly operate in a system, it must be configured for the desired form of operation. The user must decide how the device will be used in the system, and know the communications protocol of the device it will be communicating with. For example, in a system communicating with a modem we would need to utilize the modem control lines. When using the 82C52 in a local area network these modem control lines may be of no use to us.
The 82C52 is initialized and configured by writing a series of control words from the CPU to various control registers in the device. These registers include the UART Control Register (UCR), the Baud Rate Selector Register(BRSR), and the Modem Control Register (MCR).

UCR: Defines the format of characters being transmitted. The format of the characters includes the number of data bits, parity control, and the number of stop bits.
BRSR: Used in setting up the internal baud rate generator in the 82C52 for a specific baud rate. It will also be used to specify what the CO output is to be.
MCR: Defines which interrupts will be enabled, and will also set the modem control output lines ( $\overline{\mathrm{RTS}}$ and DTR). In addition, the MCR allows the user to select one of four modes of communications (normal mode, echo mode, transmit break, and loop test mode).

### 2.1 UART Control Register

The UART Control Register (UCR) is a write-only register. Writing a command word to the UCR configures the transmission and reception circuitry of the 82C52. The command word essentially describes the format of characters that are
to be transmitted or received. The format of these characters are made up of (1) a specific word length, (2) parity information, and (3) a selected number of stop bits, used to indicate transmission of that character is completed.


## FIGURE 3. UCR FORMAT

DO - Stop Bit Select. This bit is used to select the number of stop bits that the 82C52 will insert into a character to be transmitted, and the number to look for in received characters. The stop bit(s) denote where the end of a character occurs. The external device must be configured with the same number of stop bits as the 82C52. The setting(s) for this bit are as follows:

0 - If this bit is set to zero, then a single stop bit will be generated and checked for.

1 - Setting this bit to a one will cause either of two configurations. If we select a character length of 5 data bits, the 82C52 will generate 1.5 stop bits during transmission, and will look for a single stop bit when receiving data. If a character length of 6,7 , or 8 data bits is selected, then two (2) stop bits will be generated and checked for.
D3, D2 and D1 - Parity Control. These three bits are used to control the generation and checking of the parity bit. The 82 C 52 can be configured to perform this function one of seven ways. These are:

000 - Even parity is generated for transmitting data, and will be checked for when receiving data.

001 - Odd parity is generated for transmitting data, and checked for during data reception.

010 - Even parity is generated for data transmission, and odd parity will be checked for during data reception.

011 - Odd parity is generated for data transmission, and even parity will be checked for during data reception.

100 - Even parity is generated for data transmission, however, the 82C52 will do no parity checking on data that has been received.

101 - Odd parity is generated for data transmission. The 82C52 will not check parity on data received.

11X - The generation of a parity bit is disabled. Also, the 82C52 will not check for parity on incoming data. D1 is not used therefore, it can be either a 0 or a 1.
table 1. PARITY SELECTION

|  | TRANSMITTER | RECEIVER |
| :---: | :---: | :---: |
| 000 | Even | Even |
| 001 | Odd | Odd |
| 010 | Even | Odd |
| 011 | Odd | Even |
| 100 | Even | Disabled |
| 101 | Odd | Disabled |
| 11 X | Disabled | Disabled |

D5, D4 - Word Length Select. The state of these bits determines the number of bits that are transmitted as a data word. The word length can be $5,6,7$, or 8 bits long.

TABLE 2. WORD LENGTH SELECTION

| D5 | D4 | WORD LENGTH |
| :---: | :---: | :---: |
| 0 | 0 | 5 Bits |
| 0 | 1 | 6 Bits |
| 1 | 0 | 7 Bits |
| 1 | 1 | 8 Bits |

D7, D6 - Reserved. These bits have been reserved for future product upgrade compatibility. To insure that the future upgrades of the 82C52 will operate with existing software, these bits must both be set to zero (00).

### 2.2 Baud Rate Select Register

The Baud Rate Select Register (BRSR) is a write-only register used to set the internal 82C52 baud rate generator to the desired data transfer rate. Essentially, this baud rate will depend upon the clock speed of the crystal being used with the device. However, to provide more flexibility, the 82C52 provides two separate counters for selecting a divide ratio to fit the user's needs.

These two counters are the Prescaler, and the Divisor select. The Prescaler allows the input clock rate to be divided by one of four values: $1,3,4$, and 5 . This new data rate can then be further divided by using the values available
with the Divisor select. This final clock speed will be 16 times the actual baud rate used by the 82C52.

The 16X clock speed can be output to the CO pin of the device through the CO Select function of the BRSR. If CO select is not selected, the output of the CO pin will reflect the crystal frequency input by the part on the IX pin. Note, this output (CO) is a buffered version of the IX input or 16X baud rate


FIGURE 4. BRSR FORMAT

D1 and D0 - Prescaler Select. This allows the user to choose one of four values that the input clock frequency (IX) will be divided by.

TABLE 3. PRESCALER SELECTION

| D1 | D0 | PRESCALER <br> DIVISOR |
| :---: | :---: | :---: |
| 0 | 0 | +1 |
| 0 | 1 | +3 |
| 1 | 0 | +4 |
| 1 | 1 | +5 |

D6, D5, D4, D3, and D2 - Divisor Select. The state of these bits determines the value of the Divisor select. The possible values are as follows in Table 4:

Application Note 108

TABLE 4. DIVISOR SELECTION

| D6 - D2 | DIVISOR |
| :---: | :---: |
| 00000 | +2 |
| 00001 | +4 |
| 00010 | $+16 / 3$ |
| 00011 | +8 |
| 00100 | $+32 / 3$ |
| 00101 | +16 |
| 00110 | $+58 / 3$ |
| 00111 | +22 |
| 01000 | +32 |
| 01001 | +64 |
| 01010 | +128 |
| 01011 | +192 |
| 01100 | +256 |
| 01101 | +288 |
| 01110 | +352 |
| 01111 | +512 |
| 10000 | +768 |
| 11111 | +1 |
|  |  |
|  |  |

By using a crystal or external frequency with one of the common crystal frequencies $(1.8432 \mathrm{MHz}, 2.4576 \mathrm{MHz}$, or 3.072 MHz ) and a prescaler of divide by 3,4 , or 5 respectively, standard baud rates can easily be generated by selecting the Divisor as shown in Table 5 below:

TABLE 5. STANDARD DIVISORS

| 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 |

NOTE: All baud rates are exact except for:
TABLE 6. PERCENT DIFFERENTIAL

| BAUD RATE | ACTUAL | \% DIFFERENCE |
| :---: | :---: | :---: |
| 2000 | 1986.2 | $0.69 \%$ |
| 800 | 1745.45 | $3.03 \%$ |
| 134.5 | 133.33 | $0.87 \%$ |
| 110 | 109.09 | $0.83 \%$ |

To illustrate how a baud rate can be determined, let us look at the following example:

## EXAMPLE 2.1:

Assume that we are using a clock frequency of 2.4576 MHz with the 82C52, and we wish to configure the device to run at a baud rate of 9600 bits per second (bps). First, select a prescaler of divide-by-four. Therefore, bits D1 and D0 will be set to 1 and 0 . This will give an effective clock frequency of $614,400 \mathrm{~Hz}$.

Next, look at Table 5 to determine which divisor is needed to generate 9600 bps . The divisor is four (4). Bits 6 through 2 will be set to 0000 and 1 . The $614,400 \mathrm{~Hz}$ clock has then been divided by 4 to give the appropriate 16X clock, which is $153,600 \mathrm{HZ}$ ( $16 \times 9600$ ).
To determine what the actual baud rate is, take $153,600 \mathrm{~Hz}$ and divide it by 16 . This will give us our 9600 bits per second (bps). A 16X clock rate is required by the internal circuitry of the 82C52. That is why the prescaler and divisor are selected to yield a clock rate that is 16 times the desired baud rate.
Finally, set the CO Select bit to 1 so that the CO output will be the same as the BRG output. This is the 16X frequency calculated above $(153,600 \mathrm{~Hz})$.

The command word written to the BRSR will be:

$$
10000110 \text { or } 86 \mathrm{Hex}
$$

D7 - CO Select. This tells the 82C52 what the source will be for the output pin CO.

0 - The output on CO will be a buffered version of the clock input (IX) to the device. The frequency of this signal will be the actual crystal frequency (or external frequency) used to run the 82C52.

1 - The output of CO will be a buffered version of a clock rate that is 16 times the actual baud rate generated by the 82C52. This signal is suitable for driving a second 82C52 or UART in a system.

### 2.3 Modem Control Register

The Modem Control Register (MCR) is a general purpose register controlling various operation parameters within the device. These parameters include: (1) setting modem control lines $\overline{\text { RTS }}$ and $\overline{\text { DTR, }}$, (2) Enabling the interrupt structure of the device, (3) enabling the receiver on the device, and (4) selecting one of four operating modes in the device.

## 



## FIGURE 5. MCR FORMAT

D0 - Request to Send. This bit allows the user to set the state of the RTS output pin. This pin is used as a modem control line in the RS-232C interface protocol. It is important to remember that the RTS output pin is active low.

0 - Setting this bit to a zero causes a one (1) to be output on the $\overline{\mathrm{RTS}}$ pin. In effect, this is setting the pin to its logical false state.

1 - If this bit is set to a one, the $\overline{R T S}$ pin will be forced to a zero (0). This puts the RTS signal in its logical true state.
D1 - Data Terminal Ready. This is a modem control line for an RS-232C-like interface. It is an output pin and is also active low.

0 - A zero in bit D1 causes $\overline{\text { DTR }}$ pin to be put in a logical false state. The $\overline{\text { DTR }}$ pin outputs a one (1).

1 - By writing a one to this bit, the 82C52 DTR output pin is set to its logical true state (zero).
D2 - Interrupt Enable (INTEN). This bit is an overall control for the INTR pin on the 82C52. With it, all 82C52 interrupts to the processor can either be enabled or disabled. When D2 is reset to disable interrupts, no status changes including modem status changes can cause an interrupt to the processor.

0 - Interrupts are disabled. The INTR pin will be held in a false state (low) so that no interrupt requests to the processor are generated.

1 - Interrupts are enabled. Interrupts will be discussed in more detail later.

D4 and D3 - Mode Select. These two bits allow the user to select one of the four possible operating modes for the 82C52. These are:

00 - Normal mode - The 82C52 is configured for normal full or half duplex communications. Data will not be looped
back in any form or fashion between the serial data input pin and the serial data output pin (see Figure 6a).

01 - Transmit break - Selecting this mode of operation will cause the transmitter to transmit break characters only. A break character is composed of all logical zeros for the start, data, parity, and stop bits.

10 - Echo mode - When this is selected, the 82C52 will retransmit data received on the SDI pin out to the SDO pin. In this mode of operation, any data written to the Transmitter Buffer Register will not be sent out on the SDO pin (See Figure 6b).

11 - Loop Test mode - If this mode is selected, the data that normally would be transmitted is internally routed back to the receiver circuitry. The transmitted data will not appear at the SDO pin. Also, data that is received on the SDI pin will be ignored by the device. This mode of operation is useful for performing self test(s) on the device (see Figure 6c).


6c. LOOP TEST MODE
FIGURE 6. OPERATING MODES
D5 - Receiver Enable (REN). Controls the reception of data through the SDI pin into the Receiver Register. Disabling the receiver is useful when performing a software reset on the device. This locks out any errant data from being received. This would also prevent interrupts from occurring due to data reception. Other possible reasons for disabling the receiver might be so that sections of software can execute without interruption, so that software only accepts data when ready
for it, or so that a software reset/reconfiguration can be performed.

0 - A zero for this bit prevents the device from recognizing data sent to the SDI pin. The receive circuitry will remain in an idle state.

1-Writing a one to this bit enables the receiver. Data will then be recognized at the SDI pin.
D6 - Modem Interrupt Enable. Enabling this bit will allow any change in the modem status line inputs ( $\overline{\mathrm{CTS}}$ and $\overline{\mathrm{DSR}}$ ) to cause an interrupt. The Modem Status register (MSR) will contain information pertaining to which condition(s) caused the interrupt.

0 - Modem interrupts not enabled.
1 - Modem interrupts enabled.
D7 - This bit must always be set to a logic zero to insure device compatibility for future product upgrades. Should this bit be set to a one (1)during initialization, the device will not respond to any data at the SDI pin, and no data will be transmitted from the Transmitter Register to the SDO pin.

### 3.0 Status Registers

In addition to the various Control registers, the 82C52 has two read only status registers that can be accessed by the CPU to determine the status of the device at any given time. These are the UART Status Register (USR), and the Modem Status Register (MSR). The registers are used for keeping track of any changes in (1) the modem lines on the device (2) the status of data transmission or reception, and (3) whether any error(s) were detected in received data.

The USR deals with the different types of data errors, the status of data transmission, as well as data waiting to be read. The MSR, on the other hand, reflects the status of the various modem control lines in the device (i.e. $\overline{\text { CTS }}$ and $\overline{\mathrm{DSR}}$ ).

Normally, in an interrupt-driven system, after an interrupt occurs, the user's software would check the status register(s) to determine what caused the interrupt. The software then should deal with the various types of interrupts in an appropriate manner.

### 3.1 UART Status Register

The UART Status Register (USR) contains information pertaining to the status of the 82C52 operation. The information that is kept in the USR includes: data reception error information, modem status, and the status of data transmission. This register will normally be the first 82C52 register read when servicing an 82C52 interrupt, or when polling the device.

NOTE: The USR will be cleared upon reading its contents.
After reading and clearing the status register, the bits will remain as zeros until a status change occurs to set the proper bit(s).


FIGURE 7. USR FORMAT
DO - Parity error (PE). This bit indicates whether a parity error was detected in the last character read into the Receive Buffer Register. If parity is disabled, this bit will always be a zero.
0 - No error detected.
1 - Parity error detected.
D1 - Framing error (FE). A one in this bit indicates that the last character received contained an improper number of stop bits. This might be caused by no stop bits being sent, or by the length of the stop bits being too short.
0 - No framing error.
1 - Framing error detected.
D2 - Overrun error (OE). When this status bit is set to a one, it indicates that data in the RBR is not being read by the CPU fast enough to permit data in the Receiver Buffer to be shifted to the RBR before the next character comes in on the SDI pin. Data is then lost because it is overwritten by incoming characters.
0 - No overrun error detected.
1 - Overrun error detected.
D3 - Received Break (RBRK). This status bit indicates that the last character received was a break character. A break character consists of all logic zeros including the parity and stop bits. The most common usage of this character is to indicate a special condition in the communications taking place. For example, the device sending information to the 82C52 might send a break character to it to indicate that it has completed transmitting its stream of data.
O-No break.
1 - Break detected.
D4 - Modem Status (MS). This bit indicates whether or not there has been a change in the states of any of the modem
control lines on the device. These lines include: $\overline{C T S}$ and $\overline{\mathrm{DSR}}$. To determine which of these lines has changed, the user can read the Modem Status Register (MSR).

Also, should both the MIEN and INTEN bits be set in the MCR register, an interrupt will be generated when the MS bit gets set.

0 - No status change.
1 - Status change detected.
D5 - Transmission Complete (TC). When a character is writen to the 82C52 Transmitter Buffer Register (TBR), it will be transferred to the Transmitter Register before actually being shifted out serially through the SDO pin. When the character has finally been transmitted on SDO, and both the TBR and Transmitter Registers are empty, the TC bit will be set.

NOTE: The TC bit getting set does not always mean that an end of transmission has occurred. It indicates that both the TBR and the Transmitter Register are empty. For instance, if we are running the 82C52 at a high baud rate, it could transmit data faster than the user's software can write characters to the device. In this case, the TC bit could get set between each character being transmitted.
Assertion of this bit will cause an interrupt when the INTEN bit of the MCR has been set.

0 - Not complete.
1 - Transmission complete.
D6 - Transmitter Buffer Register Empty (TBRE). When a character written to the TBR has been transferred to the Transmitter Register and the TBR is ready for another character, this bit will get set.
The user should check the TBRE bit before writing another character to the Transmitter Buffer Register. This insures that the previous character written to the TBR no longer resides there, but is being shifted out on the SDO pin.

0 - Not empty.
1 - Empty.
D7 - Data Ready (DR). Is set when the Receive Buffer Register (RBR) has been loaded with a received character through the SDI pin. The CPU can access this data by reading the RBR. For example, if the user wishes to see if there is any data waiting to be read from the Receiver Register, this bit can be checked.

0 - No data ready.
1 - Data ready in RBR.
NOTE: In an interrupt driven system, interrupts caused by the DR signal should have a higher priority than those caused by the TBRE signal. This will guard the software against Overrun errors. You have no control over the information being sent to you, but you can control how and when you are transmitting data.

### 3.2 Modem Status Register

The Modem Status Register (MSR), a read-only register, allows the user to determine the status of the Modem Status pins. The status of these pins is reflected by the corresponding bit(s) being set to a one if the state of the pin is in its true
state (low), and by being set to a zero if the pin is in its false state (high). This will apply regardless of whether the pin is set up to be active high or active low.

A change in any of the status bits will cause an interrupt if the INTEN and MIEN bits of the MCR are enabled.


## FIGURE 8. MSR FORMAT

DO - Clear to Send (CTS). This is both a status and control signal from the modem. It tells the 82C52 that the modem is ready to receive data from the 82C52 transmitter output (SDO). If this line is inhibited (false), then the 82C52 will not be able to begin transmission of data. Should this line go false in the middle of a transmission, the UART will only be able to finish transmission of the current character.
$0-$ CTS in false state.
1 -CTS is true.
D1 - Data Set Ready (DSR). This is a status indicator from the modem to the 82C52 indicating that the modem is ready to provide data to the 82C52.
$0-$ DSR in false state.
1 -DSR is true.

### 4.0 Transmit/Receive Buffer Registers

In addition to the control and status registers, the 82C52 has two buffer registers that allow for the actual serial communications to be performed. These registers are used for sending characters out to the SDO pin, and for reading data from the SDI pin.

### 4.1 Receiver Buffer Register

The Receiver Buffer Register (RBR) is a read-only register which contains the character received via the SDI pin. When data is received by the 82C52, it is read serially into the Receiver Register from the SDI pin, and then transferred to the RBR for the CPU's access. This double buffering allows for higher transmission rates without loss of data. However, should additional characters be received by the 82C52 before this register is read, then the Receiver Register will be overwritten with the subsequent characters. This will cause the Overrun Error (OE) flag to be asserted.
The RBR is 8 bits long and can accept data lengths of 5 to 8 bits. The data will be right justified in the register. When selecting data lengths of less than 8 bits, the 82C52 will insert zeros (0) into the RBR for the unused (most significant) bits. For example, if the 82C52 is configured for 6 data
bits, and the character 31 H is received, the RBR will look as follows when read:

| D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 |

FIGURE 9. RECEIVED DATA
Bits D7 and D6 are automatically zeroed out by the 82C52.



NOTE: THE LSB, BIT O IS THE FIRST SERIAL DATA BIT RECEIVED
FIGURE 10. RBR FORMAT

### 4.2 Transmitter Buffer Register

The Transmitter Buffer Register (TBR) is a write only register used for sending characters out through the SDO pin. Characters to be transmitted should only be written to this register when it is empty. This condition can be checked for by reading the UART Status Register (USR) TBRE bit, or waiting for an interrupt to signal this condition.

Like the Receiver circuitry, the Transmitter also uses double buffering. Here, we are taking advantage of the double buffering to increase throughput with the 82C52. The user would first write a character to the TBR. From here it is shifted (in parallel) into a second register known as the Transmit Register. After this transfer has been completed, the TBRE bit is set.

The character shifted into the Transmit Register is then shifted serially out onto the SDO pin. Meanwhile, because the TBR is empty, another character can be written by the CPU to the TBR. In effect, the transmitter circuitry is then performing two operations simultaneously. This double buffering technique allows continuous data flow transmission.

The Transmit Buffer Register is also 8 bits wide. Because we can specify data lengths as being from 5 to 8 bits wide, the 82 C 52 right justifies the data when it is written to the TBR, and fills the unused bits with zero's. In other words, unused (most significant) bits are truncated. For example, if we set up the device so that 6 data bits are specified and we write the character 71H (01110001 b) to the TBR, we will effec-
tively be transmitting the character:

| D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | $=31 \mathrm{H}$ |

FIGURE 11. TRANSMITTED DATA
The two most significant bits are zeroed out automatically by the 82C52.

## 



NOTE: THE LSB, BIT O IS THE FIRST SERIAL DATA BIT TRANSMITTED

FIGURE 12. TBR FORMAT

### 5.0 I/O Addressing Methods

To utilize the 82C52 in a microprocessor based system, it is necessary for the system to be designed such that we can easily access (address) the device. In the following discussion, we will look at two I/O device addressing schemes that can be applied to the 82C52:

- I/O Mapped Addressing, and
- Memory Mapped I/O Addressing

We will look at these two modes as they apply to an 80C86/ 80C88-based system.

### 5.1 VO Mapped Addressing

In this scheme of I/O addressing, the microprocessor uses one set of instructions for accessing memory, and a different set for accessing I/O devices. The CPU will generate different control signals ( $\overline{\mathrm{O}} / \mathrm{M}$ ) to select either memory or I/O based upon the type of instruction it is executing. Because of this, the system needs two sets of control logic for accessing memory and I/O. As we can see in Figure 13, the control logic for each is essentially the same.

When addressing I/O, we would use either the IN instruction or the OUT instruction. The port address specified in the instruction is placed on the address bus, and the $\overline{\mathrm{IO}} / \mathrm{M}$ signal selects and activates the control logic for I/O. If we used one of the memory commands (MOV, CMP, TEST, etc.), the $\overline{\mathrm{IO}} / \mathrm{M}$ signal would activate the control logic for the system memory.


FIGURE 13. VO MAPPED ADDRESSING


FIGURE 14. MEMORY MAPPED VO ADDRESSING

### 5.2 Memory Mapped VO

Memory Mapped I/O uses the same control logic for accessing both memory and I/O devices within a system. This is illustrated in Figure 14. Because we are using one set of control logic, we reduce the number of devices in the system, and save board space.

When I/O devices are placed within the Memory Space of a system, it is possible to take advantage of the memory instruction set. This would now allow us to utilize the full register set in I/O operations, as opposed to only being able to use the accumulator (AX/AL) for the I/O instructions. Also, conditional testing can be applied to the I/O devices (i.e. TEST, CMP). When using memory mapped I/O, it should be noted that the I/O devices can no longer be accessed through the I/O instructions (IN and OUT).There are disadvantages to using memory mapped I/O as well:

- The I/O devices are treated as memory, therefore the amount of available memory in the system is reduced.
- Memory instructions will execute slower than the I/O commands (IN and OUT). In certain situations (i.e. I/O polling), this could lead to loss of data during communications (overrun errors).


### 5.3 VO Addressing For The 82C52

The actual addressing of the 82C52 internal registers takes place through the address pins A0 and A1. These two signals are taken from the address bus. In the following example(s), address lines AD0 and AD1 from the 80C86/88 drive AO and A1, respectively, on the 82C52. Control logic will decode the remaining address lines from the CPU to generate a 'chip select' for enabling the 82C52. The control logic consists of a 74XX138 Chip Select Decoder.

The addresses for the 82C52 set up as described above are shown in Table 7.

TABLE 7. EXAMPLE ADDRESSES

| REGISTER | ADDRESS | REGISTER TYPE |
| :--- | :---: | :--- |
| Transmit Buffer Register | 10 H | Write only register |
| Receiver Buffer Register | 10 H | Read only register |
| UART Control Register | 11 H | Write only register |
| UART Status Register | 11 H | Read only register |
| Modem Control Register | 12 H | Write/Read register |
| Baud Rate Selector Register | 13 H | Write only register |
| Modem Status Register | 13 H | Read only register |

### 6.0 Reset Of The 82C52

There are two distinct ways in which the 82C52 can be reset to a known initial state: (1) By applying a reset pulse for at least two clock cycles on the RST pin, or (2) through software.

A hardware reset is accomplished by forcing the RST pin to a high state for a minimum of two clock cycles. This should be for two cycles of the 82C52's IX clock input as opposed to the system clock. This reset will cause the UART Status Register (USR) to be set to 60H (TC and TBRE bits will be
set), and the Modem Control Register(MCR) will be cleared. Any lines associated with the bits in the USR and MCR will be cleared or disabled.

During the reset of the device, the Baud Rate Select Register (BRSR) and the UART Control Register (UCR) will not be affected. However, if the reset comes due to power on, these registers will have an indeterminate value associated with them. After this reset, the 82C52 will remain in an idle state until programmed to its desired configuration.
A second method of resetting the 82C52 is through a software reset. This will allow the device to be set to a known state. The procedure for performing a software reset is outlined below:
(1) $M C R=00 \mathrm{H}$. Write a zero to the MCR. This will disable the receiver as well as the modem control lines, and interrupts.
(2) Read the RBR to clear out any residual data.
(3) Read the USR to reset status, thus keeping status lines from causing possible interrupts to the CPU.
(4) Reconfigure the device for the desired mode of operation.

### 7.0 Programming The 82C52

In order to configure the 82C52 for proper operation, three separate command words need to be written to the command (control) registers that were specified earlier.

These registers include (1) the UART Control Register,(2) the Baud Rate Select Register, and (3) the Modem Control Register. When programming the device, these registers can be written to in any order. It is advisable to initialize the Modem Control Register last because it controls the enabling of interrupts, and the receiver circuitry. Once initialized, the 82C52 can be reconfigured at any time by writing new command word(s) to the control registers. However, the device should not be actively transmitting or receiving data when reconfiguring the control registers.
Addressing of the internal registers on the 82C52 occurs by using the address lines A1 and AO, as well as the WR and $\overline{R D}$ lines. A more complete description of this is shown in Table 8.

## 82C52 Polling Operation

When utilizing a polling scheme for communications with the 82C52, it is important to note that the UART status register will be cleared of its contents when it is read by the processor. Therefore, subsequent reads of this register will show the contents to be 00 H unless the status of the device has changed between reads. Because of this, it would be necessary for a copy of the status to be saved so that the proper status can be seen.

## Interrupt Driven Operation

In this example, the 82C59A Interrupt Controller is being used to handle interrupts generated by the 82C52. The 82C59A then communicates this interrupt information to the CPU so that it may be properly serviced. An example of how the 82C59A and 82C52 are interfaced to the CPU is shown in Figure 15.


FIGURE 15. INTERRUPT DRIVEN SYSTEM

TABLE 8. ADDRESSING THE $82 C 52$

| ALE | $\overline{\text { CSO }}$ | CS1 | A1 | AO | $\overline{W R}$ | $\overline{\mathrm{RD}}$ | OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 or 7 | 0 | 1 | 0 | 0 | 5 | 1 | Data bus $\longrightarrow$ TBR |
| 1 or 7 | 0 | 1 | 0 | 0 | 1 | 7 | RBR $\longrightarrow$ Data bus |
| 1 or Z | 0 | 1 | 0 | 1 | f | 1 | Data bus $\longrightarrow$ UCR |
| 1 or Z | 0 | 1 | 0 | 1 | 1 | $\underline{7}$ | USR $\longrightarrow$ Data bus |
| 1 or 7 | 0 | 1 | 1 | 0 | 5 | 1 | Data bus $\longrightarrow$ MCR |
| 1 or 7 | 0 | 1 | 1 | 0 | 1 | 7 | MCR $\longrightarrow$ Data bus |
| 1 or 7 | 0 | 1 | 1 | 1 | f | 1 | Data bus $\longrightarrow$ BRSR |
| 1 or 7 | 0 | 1 | 1 | 1 | 1 | 7 | MSR $\longrightarrow$ Data bus |

## Harris Semiconductor



## 82C59A PRIORITY INTERRUPT CONTROLLER

Author: J. A. Goss

PAGE
Introduction .......................................................................................... 7-16
1.0 Glossary of Terms For The 82C59A . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-16
1.1 Automatic End-of-Interrupt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-16
1.2 Automatic Rotation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-16
1.3 Buffered Mode . ................................................................................ . . . . . . . . 17
1.4 Cascade Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-17
1.5 End-of-Interrupt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-17
1.6 Fully Nested Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-18
1.7 Master. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-18
1.8 Slave............................................................................................. . . . . . . 18
1.9 Special Fully Nested Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-18
1.10 Special Mask Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-18
1.11 Specific Rotation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-18
2.0 Initialization Control Words . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-19
2.1 ICW1 ....................................................................................... . . . . 7 .19

2.3 ICW3............................................................................................ . . . . . . . . .
2.4 ICW4............................................................................................ . . . . . 7 -22
3.0 Operation Command Words ............................................................ 7-23

3.2 OCW2............................................................................................. . . . . . . . 7 .23
3.3 OCW3...................................................................................................... 7-24
4.0 Addressing the 82C59A. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-25
5.0 Programming the 82C59A . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-26
5.1 Example 1: Single 82C59A . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-26
5.2 Example 2: Cascaded 82C59As . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-27
6.0 Expansion Past 64 Interrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-28

# 82C59A CMOS PROGRAMMABLE INTERRUPT CONTROLLER 

By J. A. Goss

## Introduction

The Harris 82C59A is a CMOS Priority Interrupt Controller, designed to relieve the system CPU from the task of polling in a multi-level priority interrupt system. The 82C59A is compatible with microprocessors such as the 80C86, 80C88, 8086, 8088, 8080/85 and NSC800.

In the following discussion, we will look at the initialization and operation process for the 82C59A. We will focus our attention on $80 \mathrm{C} 86 / 80 \mathrm{C} 88$-based systems. However, the information presented will also be applicable to use of the 82C59A in 8080 or 8085 -based systems as well.
Let us look at the sequence of events that occur with the 82C59A during an interrupt request and service. In an 8080/85 based system:
(1) One or more of the INTERRUPT REQUEST lines (IR0 - IR7) are raised high, setting the corresponding bits in the Interrupt Request Register (IRR).
(2) The interrupt is evaluated in the priority resolver. If appropriate, an interrupt is sent to the CPU via the INT line (pin 17).
(3) The CPU acknowledges the interrupt by sending a pulse on the INTA line. Upon reception of this pulse, the 82C59A responds by forcing the opcode for a call instruction ( 0 ODH ) onto the data bus.
(4) A second $\overline{\mathrm{NTA}}$ pulse is sent from the CPU. At this time, the device will respond by placing the lower byte of the address of the appropriate service routine onto the data bus. This address is derived from ICW1.
(5) A final (third) pulse of $\overline{\mathrm{NTA}}$ occurs, and the 82C59A responds by placing the upper byte of the address onto the data bus. This address is taken from ICW2
(6) The three byte call instruction is then complete. If the AEOI mode has been chosen, the bit set during the first INTA pulse in the ISR is reset at the end of the third INTA pulse. Otherwise, it will not get reset until an appropriate EOI command is issued to the 82C59A.

For 80C86- and 80C88-based systems:
(1) and (2) same as above.
(3) The CPU responds to the interrupt request by pulsing the INTA line twice. The first pulse sets the appropriate ISR bit and resets the IRR bit while the second pulse causes the interrupt vector to be placed on the data bus. This byte is composed of the interrupt number in bits 0 through 2, and bits 3 through 7 are taken from bits 3-7 of ICW2.
(4) The interrupt sequence is complete. If using the AEOI mode, the bit set earlier in the ISR will be reset. Otherwise, the interrupt controller will await an appropriate EOI command at the end of the interrupt service routine.

### 1.0 Glossary of Terms for the 82C59A

### 1.1 Automatic End of Interrupt (AEOI):

When the 82C59A is programmed to operate in the Automatic EOI mode, the device will produce its own End-of-Interrupt (EOI) at the trailing edge of the last Interrupt Acknowledge pulse (INTA) from the CPU. Using this mode of operation frees the software (service routines) from needing to send an EOI manually to the 82C59A.

However, using the Automatic EOI mode will upset the priority structure of the 82C59A. When the AEOI is generated, the bit that was set in the In-Service Register (ISR) to indicate which interrupt is being serviced, will be cleared. Because of this, while an interrupt is being serviced there will be no record in the ISR that it is being serviced. Unless interrupts are disabled by the CPU, there is a risk that interrupt requests of lower or equal priority will interrupt the current request being serviced. If this mode of operation is not desired, interrupts should not be re-enabled by the CPU when executing interrupt service routines.

### 1.2 Automatic Rotation:

During normal operation of the 82C59A, we have an assigned order of priorities for the IR lines. There are however, instances when it might be useful to assign equal priorities to all interrupts. Once a particular interrupt has been serviced, all other equal priority interrupts should have an opportunity to be serviced before the original peripheral can be serviced again. This priority equalization can be achieved through Automatic Rotation of priorities.

Assume, for example, that the assigned priorities of interrupts has IR0 as the highest priority interrupt and IR7 as the lowest. Figure 1A shows interrupt requests occuring on IR7 as well as IR3. Because IR3 is of higher priority, it will be serviced first. Upon completion of the servicing of IR3, rotation occurs and IR3 then becomes the lowest priority interrupt. IR4 will now have the highest priority (see Figure 1B).

There are two methods in which Automatic Rotation can be implemented. First, if the 82C59A is operating in the AEOI mode as described above, the 82C59A can be programmed for "Rotate in Automatic EOI mode". This is done by writing a command word to OCW2. The second method occurs when using normal EOIs. When an EOI is issued by the service routine, the software can specify that rotation be performed.

|  | IR7 | IR6 | IR5 | IR4 | IR3 | IR2 | \|R1 | IRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRR STATUS | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| PRIORITY | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  | LOWEST HIGHEST <br> PRIORITY PRIORITY  |  |  |  |  |  |  |  |

FIGURE 1A. IR PRIORITIES (BEFORE ROTATION)


## FIGURE 1B. IR PRIORITIES (AFTER ROTATION)

### 1.3 Buffered Mode:

When using the 82C59A in a large system, it may be necessary to use bus buffers to guarantee data integrity and guard against bus contention.

By selecting buffered mode when initializing the device, the $\overline{S P} / \overline{E N}$ pin (pin 16) will generate an enable signal for the buffers whenever the data outputs from the 82C59A are active. In this mode, the dual function $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ pin can no longer be used for specifying whether a particular 82C59A is being used as a master or a slave in the system. This specification must be made through setting the proper bit in ICW4 during the device initialization.

### 1.4 Cascade Mode:

More than one 82C59A can be used in a system to expand the number of priority interrupts to a maximum of 64 levels without adding any additional hardware. This method of expansion is known as "cascading". An example of cascading 82C59As is shown in Figure 2.
In a cascaded interrupt scheme, a single 82C59A is utilized as the "master" interrupt controller. As many as 8 "slave" 82C59As can be connected to the IR inputs of the "master" 82C59A. Each of these slaves can support up to 8 interrupt inputs, yielding 64 possible prioritized interrupts.

When in cascade mode, the determination of whether a device is a master or a slave can take either of two forms. The state of the $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ pin will select "master" or "slave" mode for a device when the buffered mode is not being used. Should buffered mode be used, then it is necessary that bit D2 (M/S) of ICW4 be set to indicate if the particular 82C59A is being used as a "master" or "slave" interrupt controller in the system.

The CASO-2 pins on the interrupt controllers serve to provide a private bus for the cascaded 82C59As These lines allow the "master" to inform the slaves which is to be serviced for a particular interrupt.

### 1.5 End of Interrupt (EOI):

When an interrupt is recognized and acknowledged by the CPU, its corresponding bit will be set in the In-Service Register (ISR). If the AEOI mode is in use, the bit will be cleared automatically through the interrupt acknowledge signal from the CPU. However, if AEOI is not in effect, it is the task of software to notify the 82C59A when servicing of an interrupt is completed. This is done by issuing an End-of-Interrupt (EOI).
There are 2 different types of EOIs that can be issued to the device; non-specIfic EOI and specific EOI. In most cases, when the device is operating in a mode that does not disturb the fully nested mode such as Special Fully Nested Mode, we will issue a non-specific EOI. This form of the EOI will automatically reset the highest priority bit set in the ISR. This is because for full nested operation, the highest priority IS bit set is the last interrupt level acknowledged and serviced.

The "specific" EOI is used when the fully nested structure has not been preserved. The 82C59A may not be able to determine the last level acknowledged. Thus, the software must specify which interrupt level is to be reset. This is done by issuing a "specific" EOI.


FIGURE 2. CASCADING THE 82C59A

### 1.6 Fully Nested Mode:

By default, the 82C59A operates in the Fully Nested Mode. It will remain in this mode until it is programmed otherwise. In the Fully Nested Mode, interrupts are ordered by priority from highest to lowest. Initially, the highest priority level is IRO with IR7 having the lowest. This ordering can be changed through the use of priority rotation (see 1.2).

In the Fully Nested Mode, when an interrupt occurs, its corresponding bit will get set in the Interrupt Request Register (IRR). When the processor acknowledges the interrupt, the 82C59A will look to the IRR to determine the highest priority interrupt requesting service. The bit in the In-service Register (ISR) corresponding to this interrupt will then be set. This bit remains set until an EOI is sent to the 82C59A.

While an interrupt is being serviced, only higher priority interrupts will be allowed to interrupt the current interrupt being serviced. However, lower priority interrupts can be allowed to interrupt higher priority requests if the 82C59A is programmed for operation in the Special Mask Mode.
When using the 82C59A in an 80C86- or 80C88-based system, interrupts will automatically be disabled when the processor begins servicing an interrupt request. The current address and the state of the flags in the processor will be pushed onto the stack. The interrupt-enable flag is then cleared. To allow interrupts to occur at this point, the STI instruction can be used. Upon exiting the service routine using the IRET instruction, execution of the program is resumed at the point where the interrupt occured, and the flags are restored to their original values, thus re-enabling interrupts.

A configuration in which the Fully Nested structure is not preserved occurs when one or more of the following conditions occur:
(a) The Automatic EOI mode is being used.
(b) The Special Mask Mode is in use.
(c) A slave 82C59A has a master that is not programmed to the Special Fully Nested Mode.

Cases (a) and (b) differ from case (c) in that the 82C59A would allow lower priority interrupt requests the opportunity to be serviced before higher priority interrupt requests.

### 1.7 Master:

When using multiple 82C59As in a system, one 82C59A has control over all other 82C59As. This is known as the "master" interrupt controller. Communication between the master and the other (slave) 82C59As occurs via the CAS0-2 lines. These lines form a private bus between the multiple 82C59As. Also, the INT lines from the slaves are routed to the master's IR input pin(s). See Figure 2.

### 1.8 Slave:

A "slave" 82C59A in a system is controlled by a master 82C59A. There is but one "master" in the system, but there can be up to 8 slave 82C59As. The INT outputs from the slaves act as inputs to the master through it's IR inputs.

Communications between the master and slaves occurs via the CASO - 2 lines. See Figure 2.

### 1.9 Special Fully Nested Mode:

The Special Fully Nested Mode (SFNM) is used in a system having multiple 82C59As where it is necessary to preserve the priority of interrupts within a slave 82C59A. Only the master is programmed for the Special Fully Nested Mode through ICW4. This mode is similar to the Fully Nested Mode with the following exceptions:
(a) When an interrupt from a particular slave is being serviced, additional higher priority interrupts from that slave can cause an interrupt to the master. Normally, a slave is masked out when its request is in service.
(b) When exiting the Interrupt Service routine, the software should first issue a non-specific EOI to the slave. The In-service Register (ISR) should then be read and checked to see if its contents are zero. If the register is empty, the software should then write a non-specific EOI to the master. Otherwise, a second EOI need not be written because there are interrupts from that slave still being processed.

NOTE: Because the Master 82C59A and its slave 82C59As must be in Fully Nested Mode for this mode to be functional, we could not utllize Automatic EOIs. These would disturb the Fully Nested structure, as described in section 1.6.

### 1.10 Special Mask Mode:

The Special Mask Mode is utilized in order to allow interrupts from all other levels (higher and lower as well) to interrupt the IR level that is currently being serviced. Invoking this mode of operation will disturb the fully nested priority structure.

Generally, the Special Mask Mode is selected during the servicing of an interrupt. The software should first set the bit corresponding to the IR level being serviced, in the Interrupt Mask Register (OCW1). The Special Mask Mode and interrupts should then be enabled. This will allow any of the IR levels except for those masked off by OCW1 to interrupt the IR level currently being serviced.
Because this disturbs the Fully Nested Structure, it is required that a Specific EOI be issued when servicing interrupts while the Special Mask Mode is in effect. Before exiting the original interrupt routine, the Special Mask Mode should be disabled.

### 1.11 Specific Rotation:

By issuing the proper command word to OCW2, the priority structure of the 82C59A can be dynamically altered. The command word written to OCW2 would specify which is to be the lowest priority IR level.

This specific rotation can be accomplished one of two ways. The first is through a specific EOI. The software can specify that rotation is to be applied to the IR level provided with the EOI. The second method is a simple "set priority" command, in which the lowest priority level is specified with the command word.

### 2.0 Initialization Control Words

The following section gives a description of the Initialization Control Words (ICW) used for configuring the 82C59A In terrupt controller. There are four (4) control words used for initialization of the 82C59A. These ICWs must be programmed in the proper sequence beginning with ICW1. If at any time during the course of operation the configuration of the 82C59A needs to be changed, the user must again write out the control words to the device in their proper order. The initialization sequence is shown in Figure 3.


FIGURE 3. 82C59A INITIALIZATION SEQUENCE

ICW1: The 82C59A recognizes the first Initialization Control Word (ICW) written to it based on two criteria: (1) the AO line from the address bus must be a zero, and (2) the D4 bit must be a one. If the D4 bit is set to a zero, we would be programming either OCW2 or OCW3 (these are explained later). The function of ICW1 is to tell the 82C59A how it is being used in the system (i.e. Single or cascaded, edge or level triggered interrupts etc.).

ICW2: This control word is always issued directly after ICW1. When addressing this ICW, the AO line from the address bus must be a one (high). ICW2 is utilized in providing the CPU with information on where to vector to in memory when servicing an interrupt.

ICW3: This control word is issued only if the SNGL (D1) bit of ICW1 has been programmed with a zero. When addressing this word, the AO line from the CPU must be high (1). This control word is for cascaded 82C59A's. It allows the master and slave 82C59As to communicate via the CASO-2 lines. With the master, this word indicates which IR lines have slaves connected to them. For the slave 82C59A(s), this word indicates to which IR line on the master it is connected.

ICW4: Issuance of this ICW is selectable through the IC4 (D0) bit of ICW4. If ICW4 is to be written to the 82C59A, AO from the CPU must be high (1) when writing to it. This word needs to be written only when the 82C59A is operating in modes other than the default modes. Instances when we would want to write to ICW4 are one or more of the following: An $80 C 86(80 \mathrm{C} 88)$ processor is being used, buffered outputs (DO-D7) are to be used, Automatic EOls are desired, or the Special Fully Nested mode is to be used.

### 2.1 ICW1:

ICW1 is the first control word that is written to the 82C59A during the initialization process. To access this word, the value of AO must be a zero (0) in the addressing, and bit D4 of ICW1 must be a one (1). The format of the command word is as follows:


* NOTE: This is an address bit, and not part of the ICW.


## FIGURE 4. ICW1 FORMAT

D7 thru D5 - A7, A6, A5: These bits are used in the 8080/ 85 mode to form a portion of the low byte call address. When using the 4 byte address interval, all 3 bits are utilized. When using the 8 byte interval, only bits A7 and A6 are used. Bit A5 becomes a "don't care" bit. If using an $80 C 86(80 C 88)$ system, the value of these bits can be set to either a one or zero.

## D3 - LTIM:

0 : The 82C59A will operate in an edge triggered mode. An interrupt request on one of the IR lines (IRO - IR7) is recognized by a low to high transition on the pin. The IR signal must remain high at least until the falling edge of the first sINTA pulse. Subsequent interrupts on the IR pin(s) will not occur until another low-tohigh transition occurs.
1: Sets up the 82C59A to operate in the level triggered mode. Interrupts occur when a "high" level is detected on one or more of the IR pins. The interrupt request must be removed from this pin before the EOI command is issued by the CPU. Otherwise, the 82C59A will see the IR line still in a high state, and consider this to be another interrupt request.


D2 - ADI: Call Address Interval (for 8080/8085 use only). If using the 82C59A in an 80C86/88 based system, the value of this bit can be either a 0 ora 1.

0 : The address interval generated by the 82C59A is 8 bytes. This option provides compatiblity with the RST interrupt vectoring in 8080/8085 systems since the vector locations are 8 bytes apart. This vector will be combined with the values specified in bits D7 and D6 of ICW1. The addresses generated are shown in Table 1.

TABLE 1. ADDRESS INTERVAL (8 BYTES)

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A7 | A6 | 1 | 1 | 1 | 0 | 0 | 0 |
| A7 | A6 | 1 | 1 | 0 | 0 | 0 | 0 |
| A7 | A6 | 1 | 0 | 1 | 0 | 0 | 0 |
| A7 | A6 | 1 | 0 | 0 | 0 | 0 | 0 |
| A7 | A6 | 0 | 1 | 1 | 0 | 0 | 0 |
| A7 | A6 | 0 | 1 | 0 | 0 | 0 | 0 |
| A7 | A6 | 0 | 0 | 1 | 0 | 0 | 0 |
| A7 | A6 | 0 | 0 | 0 | 0 | 0 | 0 |

1: The address interval generated by the interrupt controller will be 4 bytes. This provides the user with a compact jump table for 8080/8085 systems. The interrupt number is effectively multiplied by four and combined with bits D7, D6 and D5 to form the lower byte of the call instruction generated and sent to the 8080 or 8085 . Table 2 shows how these addresses are generated for the various Interrupt request (IR) levels.

TABLE 2. ADDRESS INTERVAL (4 BYTES)

| D7 | D6 | D5 | D4 | D3 | D2 | D2 | D0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A7 | A6 | A5 | 1 | 1 | 1 | 0 | 0 | IR7 |
| A7 | A6 | A5 | 1 | 1 | 0 | 0 | 0 | IR6 |
| A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 | IR5 |
| A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 | R4 |
| A7 | A6 | A5 | 0 | 1 | 1 | 0 | 0 | R3 |
| A7 | A6 | A5 | 0 | 1 | 0 | 0 | 0 | IR2 |
| A7 | A6 | A5 | 0 | 0 | 1 | 0 | 0 | R1 |
| A7 | A6 | A5 | 0 | 0 | 0 | 0 | 0 | IRO |

D1-SNGL:
0 . This tells the 82C59A that more than one 82C59A is being used in the system, and it should expect to receive ICW3 following ICW2. How the particular 82C59A is being used in the system will be determined either through ICW4 for buffered mode, or through the $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ pin for non-buffered mode operation.

1: Tells the 82C59A that it is being used alone in the system. Therefore, there will be no need to issue ICW3 to the device.

D0 - IC4: Specifies to the 82C59A whether or not it can expect to receive ICW4. If this device is being used in an 80C86/80C88 system, ICW4 must be issued.

0 : ICW4 will not be issued. Therefore, all of the parameters associated with ICW4 will default to the zero (0) state. This should only be done when using the 82C59A in an 8080 or 8085 based system.

1: ICW4 will be issued to the 82C59A.

### 2.2 ICW2:

ICW2 is the second control word that must be sent to the 82C59A. This byte is used in one of two ways by the 82C59A, depending on whether it is being used in an 8080/85 or an 80C86/88 based system.

When used in conjunction with the 8080/85 microprocessor, the value given to this register is taken as being the high byte of the address in the CALL instruction sent to the CPU.

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A 15 | A 14 | A 13 | A 12 | A 11 | A 10 | A 9 | A 8 |

FIGURE 5. ICW2 FORMAT

In an 80C86- or 80C88-based system, ICW2 is used to send the processor an interrupt vector. This vector is formed by taking the value of bits D7 through D3 and combining them with the interrupt request level to get an eight bit number. The processor will multiply this number by four and go to that absolute location in memory to find a starting address for the interrupt service routine corresponding to the interrupt request.

For example, if we set ICW2 to "00011000" and an interrupt is recognized on IR1, the vector sent to the 80 C 86 ( 80 C 88 ) will be $00011001(19 \mathrm{H})$. The processor will then look to the memory location 64 H to find the starting address of the corresponding interrupt service routine. It is the responsibility of the software to provide this address in the interrupt table.

| D7 | D6 |  | D5 | D4 | D3 | D2 | D1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D0 |  |  |  |  |  |  |  |
| A7 | A6 | A5 | A4 | A3 | x | x | x |

FIGURE 6. ICW2 FORMAT (80C86 MODE)

### 2.3 ICW3:

ICW3 is only issued when the SNGL bit in ICW1 has been set to zero. If not set, the next word written to the 82C59A will be interpreted as ICW4 if AO = 1 and IC4 from ICW4 was set to one, or it could see it as one of the Operation Command Words based upon the state of the AO line.

Like ICW2, this control word can be interpreted in two ways by the 82C59A. However the interpretation of this word depends on whether the 82C59A is being used as a "master" or a "slave" in the system. The definition of the particular devices role in the system is assigned through ICW4 (which will be discussed later), or through the state of the $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ pin (pin 16).

## 82C59A as a MASTER:

If the given 82C59A is being used as a master, the eight (8) bits in this command word are used to indicate which of the IR lines are being driven by a slave 82C59A.

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S 7 | S 6 | S 5 | S 4 | S 3 | S 2 | S 1 | S 0 |

## FIGURE 7. ICW3 FORMAT (MASTER)

## D7 thru D0:

0 : The corresponding IR line to this bit is not being driven by a slave 82C59A. This line can however then be connected to the interrupt output of another interrupting device such as a UART. If there are unused bits in this byte because not all eight of the IR lines are used, set them to zero.

1: The corresponding IR line to this bit is being driven by a slave 82C59A.

The bits in this command word are directly related to the IR lines. For example, to tell the 82C59A that there is a slave device connected to IR5 (pin 23), bit D5 of the command word should be set to a one (1).

## 82C59A as a SLAVE device:

When the device is being used as a slave device, we must use ICW3 to inform itself as to which IR line it will be connected to in the master. Therefore, only the three (3) least significant bits of ICW3 will be used to specify this value.

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 102 | 101 | 100 |

FIGURE 8. ICW3 FORMAT (SLAVE)

These bits are coded as follows:

TABLE 3. SLAVE 'IDENTIFICATION’ WITH ICW3

| MASTER IR number | IO2 | IO1 | IO0 |
| :---: | :---: | :---: | :---: |
| IR7 | 1 | 1 | 1 |
| IR6 | 1 | 1 | 0 |
| IR5 | 1 | 0 | 1 |
| IR4 | 1 | 0 | 0 |
| IR3 | 0 | 1 | 1 |
| IR2 | 0 | 1 | 0 |
| IR1 | 0 | 0 | 1 |
| IR0 | 0 | 0 | 0 |

For example, if the INT output of a "slave" 82C59A is connected to the input pin IR5 on the "master" 82C59A, ICW3 of the "slave" would be programmed with the value 00000101b, or 05H. This informs the "slave" as to which priority level it holds with the "master".

D7 thru D3: These bits must be set to zeros (0) for proper operation of the device.

### 2.4 ICW4:

This control register is written to only when the IC4 bit is set in ICW1. The purpose of this command word is to set up the 82C59A to operate in a mode other than the default mode of operation. The default mode of operation is the same as if a value of 00 H were to be written to ICW4 (i.e. all bits set to zero).


NOTE Slave IO is equal to the corresponding master IR input
FIGURE 9. ICW4 FORMAT

D7 thru D5: These bits must be set to zero for proper operation.

D4-SFNM: This bit is used in the selection of the Special Fully Nested Mode (SFNM) of operation. This mode should only be used when multiple 82C59As are cascaded in a system. It needs only to be programmed in the Master 82C59A in the system.

0 : Special Fully Nested Mode is not selected.
1: Special Fully Nested Mode is selected.

D3 - BUF. This bit tells the 82C59A whether or not the outputs from the data pins (D0 - D7) will be buffered. If they are buffered, this bit will cause the $\overline{S P} / \overline{E N}$ pin to become an output signal that can be used to control the "enable" pin on a buffering device(s).

0 The device will be used in a non-buffered mode. Therefore, (1) the M/S bit in ICW4 is a don't care, and (2) the $\overline{S P} / \overline{E N}$ pin becomes an input pin telling the device if it is being used as a master ( $p$ in $16=$ High) or a slave ( pin $16=$ Low). For systems using a single 82 C 59 A , the $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ input should be tied high

1 The device is used in buffered mode. An enable output signal will be generated on pin 16, and the M/S bit will be used for determining whether the partıcular 82C59A is a "master" or a "slave".

D2 - M/S This bit is of significance only when the BUF bit is set (BUF = 1). The purpose of this bit is to determine whether the particular 82C59A is being used as a "master" or a "slave" in the target system.

0 The 82C59A is being used as a slave
1 . The 82C59A is the master interrupt controller in the system

D1 - AEOI This bit is used to tell the 82C59A to automatically perform a non-specific End-of-Interrupt on the trailing edge of the last Interrupt Acknowledge pulse Users should note that when this is selected, the nested priority interrupt structure is lost

0 Automatıc End-of-Interrupt will not be generated.
1 Automatic End-of-Interrupt will be generated on the trailing edge of the last Interrupt Acknowledge pulse

DO - $\mu$ PM This bit tells the Interrupt Controller which microprocessor is being used in the system. An 8080/8085, or an 80C86/80C88.

0 : The 82C59A will be used in an $8080 / 8085$ based system.

1 82C59A to be used in the $80 \mathrm{C} 86 / 88$ mode of operation.

### 3.0 Operation Command Words

Once the Initialization Command Words, described in the previous section, have been written to the 82C59A, the device is ready to accept interrupt requests. While the 82C59A is operatıng, we have the ability to select various options that will put the device in different operating modes, by writing Operation Command Words (OCWs) to the 82C59A. These OCWs can be sent at any time after the device has been initialized and in any order. These words can be changed at any time as well. Note: If AO = 0 and D4 of the command word $=1$, the 82C59A will begin the ICW initialization sequence.

There are three different OCWs for the 82C59A. Each has a different purpose. The first control word (OCW1) is used for masking out interrupt lines that are to be inactive or ignored during operation. OCW2 is used to select from various priority resolution algorithms in the device. Finally, OCW3 is used for (1) controlling the Special Mask Mode, and (2) telling the 82C59A which Register will be read on the next RD pulse; the ISR (In-service Register) or the IRR (Interrupt Request Register).

### 3.1 OCW1:

This control word is used to set or clear the masking of the eight (8) interrupt lines input to the 82C59A. This control word performs this function via the Interrupt Mask Register (IMR). In it's initial state, the value of this register is 00 H . In other words, all of the interrupt lines are enabled. Therefore, we need only write this control word when we wish to disable specific interrupt lines.

A direct mapping occurs between the bits in this control word and the actual interrupt pins on the device. For example bit 7 (D7) controis interrupt line IR7 (pin 25), bit 6 controls IR6, and so on.


FIGURE 10. OCW1 FORMAT

Even though the user can mask off any of the IR lines, any interrupt occuring during that time will not be lost. The request for an interrupt is retained in the IRR; therefore when that IR is unmasked by issuing a new mask value to OCW1, the interrupt will be generated when it becomes the highest requesting priority.

## D7 thru D0:

0 - When any of the bits in the control word are reset $(0)$, the corresponding interrupt is enabled.

1: By setting a bit(s) to a one in the control word, the corresponding interrupt line(s) is disabled.

For example, if the value 34 H ( 00110100 b ) were written to OCW1, interrupts would be disabled from being serviced on lines IR2, IR4 and IR5.

### 3.2 OCW2:

In ICW4 bit D1 was used to specify whether the 82C59A should wait for an EOI (End of Interrupt) from the CPU, or generate its own EOI (Automatic EOI). If bit D1 of ICW4 had been programmed to be a zero, OCW2 would be used for sending the EOI to the 82C59A. Conversely, if this bit had been set to a one, OCW2 would be used for specifying whether or not the 82C59A should perform a priority rotation on the interrupts when the AEOI is detected.

OCW2 has several EOI options. The EOI issued can be either specific or non-specific. For each of these EOIs, the user can specify whether or not priority rotation should be performed.

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R | D |  |  |  |  |  |  |
| R | SL | EOI | 0 | 0 | L2 | L1 | L0 |

## FIGURE 11.

R, SL, and EOI:
These three bits are used for specifying how the device should handle AEOIs, or for issuing one of several different EOls. They are programmed as shown in the following table:

TABLE 4. ROTATE AND EOI MODES

| R | SL | EOI |  |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | Non-specific EOI command |
| 0 | 1 | 1 | * Specific EOI command |
| 1 | 0 | 1 | Rotate on non-specific EOI command |
| 1 | 0 | 0 | Rotate in Automatic EOI mode (set) |
| 0 | 0 | 0 | Rotate in Automatic EOI mode (clear) |
| 1 | 1 | 1 | Rotate on specific EOI command |
| 1 | 1 | 0 | * Set priority command |
| 0 | 1 | 0 | * No operation |

*LO - L2 are used

## L2, L1, and L0:

These three bits of the control word are used in conjunction with the issuance of specific EOIs or when specifically establishing a different priority structure. The bits tell the 82C59A which interrupt level is to be acted upon. Therefore, the software needs to know which interrupt is being serviced by the 82C59A.

TABLE 5. INTERRUPT LEVEL TO ACT UPON

| L2 | L1 | LO |  |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | IR level 0 |
| 0 | 0 | 1 | IR level 1 |
| 0 | 1 | 0 | IR level 2 |
| 0 | 1 | 1 | IR level 3 |
| 1 | 0 | 0 | IR level 4 |
| 1 | 0 | 1 | IR level 5 |
| 1 | 1 | 0 | IR level 6 |
| 1 | 1 | 1 | IR level 7 |

### 3.3 OCW3:

There are two main functions that OCW3 controls: (1) Interrupt Status, and (2) Interrupt Masking. Interrupt
status can be checked by looking at the ISR or IRR registers, or by issuing a Poll Command to manually identify the highest priority interrupt requesting service.

| D7 | D6 | D5 | D4 | D3 |  | D2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

## FIGURE 12.

D7: Must be set to zero for proper operation of the 82C59A.

D6 - ESMM: Enable Special Mask Mode - The ESMM bit when enabled allows the SMM bit to set or clear the Special Mask Mode. When disabled, this bit causes the SMM bit to have no effect on the 82C59A.
0 : Disables the effect of the SMM bit.
1: Enable the SMM bit to control the Special Mask Mode.

D5 - SMM: Special Mask Mode - The SMM bit is used to enable or disable the Special Mask Mode. This bit will only affect the 82C59A when the ESMM bit is set to 1.
0 : Disable the Special Mask Mode.
1: Put the 82C59A into the Special Mask Mode.

D4, D3: These bits are used to differentiate between OCW2, OCW3 and ICW1. To properly select OCW3, D4 must be set to zero and D3 must be set to one.

D2 - P: Poll Command - This bit is used to issue the poll command to the 82C59A. The next read of the 82C59A will cause a poll word to be returned which tells if an interrupt is pending, and if so, which is the highest requesting level.
NOTE The poll command must be issued each time the poll operation is desired.
0 : No poll command issued to the 82C59A.
1: Issue the poll command.

D1 - RR: Read Register - This bit is used to execute the "read register" command. When this bit is set, the 82C59A will look at the RIS bit to determine whether the ISR or IRR register is to be read. When issuing this command, the next instruction executed by the CPU should be an input from this same port to get the contents of the specified register.
0 : No "Read Register" comṃand will be performed.
1: The next input instruction by the CPU will read either the contents of the ISR or the IRR as specified by the RIS bit.

D0-RIS: This bit is used in conjunction with the RR bit to select which register is to be read when the "Read Regıster" command is issued.

0 : The next input instruction will read the contents of the Interrupt Request Register (IRR).

1: The next input instruction will read the contents of the In-Service Regıster (ISR)

The two registers that can be accessed through the Read Register command are used to determine which interrupts are requesting service, and which one(s) are currently beıng serviced.

The IRR bits get set when corresponding Interrupt requests are received. For instance, when IR4 is detected, bit D4 of the IRR will get set. When an interrupt acknowledge comes back from the CPU, the priority resolution logic will determine which interrupt request will be serviced. The corresponding bit in the In-service Register (ISR) will then be set. Clearing of the correct bits in the ISR occurs through out use of the AEOI, or by issuing an EOI to the device.

### 4.0 Addressing the 82C59A

There are two factors that must be taken into account when addressing the 82C59A in a system. To begin with, the 82C59A is accessed only when the $\overline{C S}$ pin (chip select) sees an active signal (low). This signal is generated using control circuitry in the system. Secondly, the various registers within the 82C59A are selected
based upon the state of the A0 (address pın) as well as specific bits in the command words (I.e for ICW1, OCW2, and OCW3 AO must be a zero).

The circuit in Figure 13 shows that the $\overline{\mathrm{CS}}$ signal is generated using an HPL-82C338 Programmable Chip Select Decoder (PCSD). This device is being used as a 3-to-8 decoder. Note that the G1 input is active high and G2 thru G5 have been programmed to be active low. The A, B, and C inputs to the 82C338 correspond to address lines AD2, AD3 and AD4 respectively, from the 80C88. The A0 input to the 82C59A is also taken from the CPUs address bus; ADO is used. It should be noted that address line AD1 from the 80 C 88 is not being used in the addressing of this particular peripheral. This is done to allow other peripheral devices that require two address inputs for internal register selection, to use address lines ADO and AD1 from the processor.

Because the AD1 address line from the 80 C 88 is not being used, the 82C59A will be addressed regardless of whether AD1 is high or low (1 or 0 ). The remainder of the address lines from the 80 C 88 can either be a zero or one when addressing the 82C59A. For the examples to be presented, it can be assumed that all unused address lines will be set to zero when addressing the 82C59A.

In Figure 13, output $\overline{Y 6}$ from the HPL-82C338 is being used as the $\overline{\mathrm{CS}}$ input to the 82C59A. This line is enabled when the inputs on $A, B$, and $C$ are: $A=0, B=1$, and $C=1$. Combining this with the A0 input to the 82C59A, we get the addresses 18 H and 19 H for accessing the 82C59A.


FIGURE 13. ADDRESSING THE 82C59A

### 5.0 Programming the 82C59A

As described earlier, there are two different types of command words that are used for controlling 82C59A operation; the Initialization Command Words (ICWs) and the Operation Command Words (OCWs). To properly program the 82C59A, it is essential that the ICWs be written first. When writing the ICWs to the 82C59A, they must be written in the following sequence:
(1) Write ICW1 to the 82C59A, AO $=0$.
(2) Write ICW2 to the 82C59A, $\mathrm{AO}=1$.
(3) If using cascaded 82C59As in system, write ICW3 to the $82 C 59 A, A 0=1$.
(4)If IC4 bit was set in ICW1, write ICW4 to the 82C59A.

NOTE: When using multiple 82C59As in the system (cascaded), each one must be initialized following the above sequence.
Once the 82C59A(s) has been configured through the ICWs, the OCWs can be used to select from the various operation mode options. These include: masking of interrupt lines,
selection of priority rotation, issuance of EOIs, reading of the ISR andsor IRR, etc. These OCWs can be written to the 82C59A at any time during operation of the 82C59A. The various command words are identified by the state of selected bits in the words, rather than by the sequence that they are written to the 82C59A; as with the ICWs. Therefore, it is imperative that the fixed bit values in the command words be written as such to insure proper operation of the device(s).

### 5.1 Example 1: Single 82C59A

In Example 1, we are using a single 82C59A in a system to handle the interrupts caused by an 82C52 Programmable UART. The system is driven using an 80C86 Microprocessor. The system configuration is shown in Figure 14.

Interrupts are initiated by the 82C52 anytime it receives data on its Serial Data In pin (SDI), or when it is ready to transmit more data via its Serial Data Out pin (SDO).


FIGURE 14. EXAMPLE 1: SINGLE 82C59A

### 5.2 Example 2: Cascaded 82C59As

Example 2 illustrates how we can use multiple 82C59As in Cascade Mode. Figure 15 shows the interconnections between the master and slave interrupt controllers. In this example, only one interrupt can occur. This is generated by
the 82C52 UART. Except for the fact that this system is configured with a Master-Slave interrupt scheme, it is the same as that in Example 1.


### 6.0 Expansion Past 64 Interrupts

In some instances, it may be desirable to expand the number of available interrupts in a system past the maximum of 64 imposed when using cascaded 82C59As. The easiest way to accomplish this is through the use of the Poll command with the 82C59A. Figure 16 illustrates one example of how this expansion can be accomplished. Notice that we are using two 3 -to- 8 decoders to address up to 16 82C59As. Selection of which decoder is active takes place using the OE pin driven by AD5 from the CPU's address bus.
With this type of interrupt structure, we are not using the INT and INTA lines from our processor (80C88 for this example). Because of this, no interrupts will break execution of the system software. Therefore, it is the task of the software to poll
the various 82C59As in the system to see if any interrupts are pending. Once it has been established which interrupt requires servicing, the software can take appropriate action.

There are disadvantages to using the poll mode for the systems interrupt structure: (1) the overhead of polling each of the 82C59As reduces the systems efficiency, and (2) realtime interrupt servicing cannot be guaranteed.

There are several advantages to using the poll mode in this manner: (1) there can be more than 64 priority interrupts in the system, and (2) memory in the system is freed because no interrupt vector table is required.


FIGURE 16. EXPANDING PAST 64 INTERRUPTS


# HARRIS 80C286 PERFORMANCE ADVANTAGES OVER THE 80386 

Author: Ted Dimbero

The Harris 80C286, operating at the same frequency as the 80386, has performance advantages over the 80386 when executing 16-bit industry standard 80C86 or 80C286 code. This is evident in the following areas:
(1) Input/Output Handling
(2) Interrupt Handling
(3) Control Transfer (Loop, Jump, Call)
(4) 286 Protected Mode Systems
(5) Multi-Tasking and Task Switching Operations.

This advantage is due to the 80C286 requirement of fewer clock cycles to execute the same instructions. In addition to these areas, the 80C286 executes many other instructions in the same number of clock cycles as the 80386.

This results in an 80C286 performance advantage in areas including:

- Multi-Tasking Systems.
- Control Applications - utilizing interrupt and I/O instructions.
- Structured Software - utilizing many Control transfer instructions.
- Operating Systems that rely on interrupts to perform functions.
- Upgrading 16-bit 80 C 86 applications for increased performance.

The 80 C 286 can be effectively used as a fast 80 C 86 . However, the 80386 is not a fast 80C286. This study shows that software written for the $80 \mathrm{C} 86 / 80 \mathrm{C} 286$ can execute more efficiently on the 80C286 than on the 80386. There is no significant performance advantage to be gained by simply moving a system design from an 80C286 to an 80386 at either 16 MHz or 20 MHz . The 80 C 286 is the processor best suited for executing 16-bit 80C86/80C286 code, which represents the world's largest base of microprocessor software.

## Architecture Background

The 80C286 Harris' newest static CMOS microprocessor combines low operating and standby power with high performance. The Harris 80 C 286 is available in speeds of $12.5 \mathrm{MHz}, 16 \mathrm{MHz}, 20 \mathrm{MHz}$ and 25 MHz .

The 80C286 evolved from the industry standard 80 C 86 microprocessor. The 80 C 286 has vast architectural enhancements over its predecessor that allow the 80C286 to execute the same code with a significant performance increase. Disregarding the clock speed increase, when upgrading from an 80 C 86 to an 80 C 286 , the 80 C 286 can execute the same code with an increase in throughput of up to 4 times that of the 80C86. This increase is solely due to the architectural enhancements.

It is a common belief that replacing an 80 C 286 with the 32 -bit 80386 microprocessor will yield similar performance increases. This is not the case. The new architecture gives the 80386 32-bit capability and increased protection features, but it does not significantly increase the throughput of 16 -bit 8086 or 80286 code. In most cases, when executing industry standard 8086 or 80286 code, replacing the 80 C 286 with an 80386 does not result in a significant performance increase. In some cases, such a replacement will actually cause a performance degradation.

Figure 1 illustrates a comparison of the number of clock cycles needed to execute several instructions available on all three microprocessors (80C86, 80C286, and 80386). This illustrates the dramatic effect of 80C286 architectural enhancements on performance when compared to the $80 C 86$ and the lack of similar performance improvement when executing 8086/80286 code on the 80386.

With an 80C86 to 80C286 upgrade, system designers can execute existing 8086 code on the $80 C 286$ and take advantage of an immediate performance upgrade. This same benefit is not realized when switching from an 80 C 286 to an 80386 . This comparison illustrates that changing from an 80 C 286 to an 80386 does


FIGURE 1. ARCHITECTURAL COMPARISON
not yield increased throughput when executing the same industry standard 80C86/80C286 code (the world's largest base of microprocessor software).

## Instruction Comparison

The Appendix in this document illustrates a direct comparison of the number of clock cycles needed to execute the same instructions on the 80C286 and the 80386. The table includes examples of instruction timing for all instructions available on both processors. Several addressing modes of each instruction type are included.

Of the 190 instruction examples analyzed, 74 of the instructions execute faster on the 80 C 286 than on the $80386 ; 66$ of the instructions analyzed execute in the same number of clock cycles on both processors. This leaves only 50 instructions with improved performance on the 80386 (See Figure 2). Over $70 \%$ of the instructions analyzed execute as fast or faster on the 80C286 than on the 80386.


FIGURE 2. EXECUTION SPEED COMPARISON (NUMBER OF INSTRUCTIONS)

This is vastly different than the previous 86-286 upgrade. With that upgrade, the 80 C 286 exhibits equal or better performance than the 80C86 with $100 \%$ of the instructions. This clearly indicates that the 80 C 286 is the processor best suited for executing industry standard 8086 family code.

The following discussion groups each of the instructions into one of several categories to analyze which applications will benefit from utilizing the 80C286. The categories used are:

- Jumps, Calls, Returns and Loops (Real Mode).
- I/O Instructions.
- Logic, Arithmetic, Data Transfer, Shift and Rotate Instructions.
- Interrupts.
- Miscellaneous Instructions.
- Protected Mode/Multi-Tasking Instructions.


## Jumps, Calls and Loops

In real mode, near calls, jumps, and conditional jumps (transfers within the current code segment) all take the same number of clock cycles to execute on the 80C286 and the 80386 . Since the segment sizes are larger on the 80386, the near transfer instructions on the 80386 can transfer a greater distance.

The far calls and jumps (transfers that switch to a new code segment; i.e., a code segment context switch) are faster on the 80C286: four clocks and one clock respectivley. The far return instruction executes in three less clock cycles on the 80 C 286 , and the near return takes one extra clock cycle. The protected mode calls, jumps, and returns are all faster
on the 80 C 286 and are discussed in the section on Protected Mode.

The loop instruction is three clock cycles faster on the 80 C 286 than the 80386. Thus, the 80C286 would save 300 clock cycles over the 386 if a LOOP instruction were executed 100 times.

| INSTRUCTION | - ADVANTAGE - |  |  |
| :--- | :---: | :---: | :---: |
|  | $\mathbf{8 0 C 2 8 6}$ | NONE | $\mathbf{8 0 3 8 6}$ |
| Near JMP and CALL |  | X |  |
| Far CALL, JMP and RET | X |  |  |
| LOOP | X |  |  |

## I/O Instructions

The 80 C 286 has a significant advantage with the $1 / 0$ instructions. The IN instruction is almost $21 / 2$ times faster on the 80C286; the 80386 takes 7 extra clock cycles to execute the same instruction. The OUT instruction is over 3 times faster on the 80C286; again the 80386 takes 7 extra clock cycles to execute the same instruction. Executing the I/O instructions on the 80386 is equivalent to executing on the 80C286 with 7 wait states.

The string I/O instructions (INS and OUTS) are also significantly faster on the 80C286. The INS instruction is 10 clock cycles faster on the 80C286, and the OUTS instruction is 9 clock cycles faster. This is particularly important if the string operations are going to be used to input or output a large block of data using the REP prefix. Inputing 100 words of data with the REP INS instruction is 208 clock cycles faster on the 80C286. An even more significant difference can be seen when outputing 100 words with the REP OUTS instruction. In this case, the 80C286 is 800 clock cycles faster than the 80386.

| INSTRUCTION |  | -ADVANTAGE - |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  |  | NONE | $\mathbf{8 0 3 8 6}$ |  |
| $\mathbb{I N}$ | X |  |  |  |
| OUT | x |  |  |  |
| INS | X |  |  |  |
| OUTS | x |  |  |  |

## Logic, Arithmetic, Data Transfer, Shift and Rotate Instructions

Most forms of the logic, arithmetic, and data transfer instructions execute in the same number of clock cycles on both processors. Certain operand combinations of these instructions (immediate to register for example) take one extra clock cycle to execute on the 80C286.

In real mode, the segment register transfer instructions execute as fast or faster on the 80C286 than they do on the 80386. For example, using the POP instruction to transfer data into a segment register is 2 clock cycles faster on the 80C286.

Most of the string manipulation instructions execute in the same number of clock cycles on both processors. The MOVS and STOS instructions are faster on the 80C286.

The divide instruction executes in the same number of clock cycles on both processors. The number of clocks to execute the multiply instruction on the 80386 is data dependent; the number of clocks to execute the same instruction on the 80C286 is fixed. On average, the multiply instruction is five clock cycles faster on the 80386, but depending on the data, the 80386 could be as many as 4 clock cycles slower than the 80C286.

The rotate and shift instructions are faster on the 80386. Unlike the 80C286, the 80386 rotate and shift instructions do not depend on the number of bits to be shifted or rotated. Thus, the 80386 has the advantage with multi-bit rotate and shift instructions. The 80C286 does, however, execute single bit rotate and shift instructions faster.

| INSTRUCTION | -ADVANTAGE - |  |  |
| :--- | :---: | :---: | :---: |
|  | 80C286 | NONE | $\mathbf{8 0 3 8 6}$ |
| Most Logic and Arithmetic |  | X |  |
| Certain Operand <br> Combinations of Logic <br> and Arithmetic |  |  | x |
| Divide |  |  |  |
| Multiply |  |  | x |
| Single Bit Shift or Rotate | x |  |  |
| Multi-Bit Shift or Rotate |  |  | x |
| String Instructions | x |  |  |

## Interrupt Instructions

Interrupts are serviced more quickly on the 80C286. The INT instruction, in real mode, executes 14 cycles faster on the 80C286 than it does on the 80386. The INTO, BOUND, and other instructions that can cause an interrupt all benefit from the faster interrupt handling features of the 80C286. The return from interrupt instruction (IRET) is 7 clock cycles faster on the 80C286. The PUSHA and POPA instructions, frequently used by interrupt handling procedures, are both faster on the 80C286. Protected Mode interrupt handling is discussed in the Protected Mode section.

| INSTRUCTION | - ADVANTAGE - |  |  |
| :--- | :---: | :---: | :---: |
|  | $80 C 286$ | NONE | 80386 |
| INT n | X |  |  |
| INTO | X |  |  |
| BOUND (If Interrupt) | X |  |  |
| Break Point Interrupt | X |  |  |

## Miscellaneous Instructions

The BCD instructions, HLT, and CBW execute from 1 to 5 clock cycles faster on the 80C286. The instructions to set and clear individual flags and the CWD instruction all execute in the same number of cycles on both processors. The ENTER, LEAVE, and BOUND instructions are from 1 to 3 cycles faster on the 80386. The BOUND instruction is only faster if an interrupt is not caused by the instruction.

| INSTRUCTION | ADVANTAGE - |  |  |
| :--- | :---: | :---: | :---: |
|  | $\mathbf{8 0 C 2 8 6}$ | NONE | $\mathbf{8 0 3 8 6}$ |
| BCD Instructions | X |  |  |
| Data Conversion <br> (CBW, CWD) | X |  |  |
| Flag Settling and Clearing |  | X |  |
| BOUND (If No Interrupt) |  |  | x |

## Protected Mode/Multi-Tasking

When executing 80286 protected mode code, the 80C286 significantly out-performs the 80386. Task switching operations execute 100 to 113 clock cycles faster on the 80C286. The instruction to return from a called task is 63 clock cycles faster on the 80 C 286 . This results in a very significant performance increase for systems utilizing the multi-tasking features.
Inter-segment JMP, CALL and segment loading instructions also operate faster on the 80C286. The 80C286 saves anywhere from 4 to 11 clock cycles depending on the particular inter-segment transfer instruction. In protected mode, the inter-segment return is also faster on the 80C286. The 80C286 is 7 clock cycles faster when executing an inter-segment return to the same privilege level and is 13 cycles faster on inter-segment returns to a different privilege level.

The instructions to initialize and check the protected mode registers execute as fast or faster on the 80C286. The IDTR access instructions are an exception to this in that they take one extra clock cycle to execute on the 80C286. The instruction to switch the processor to protected mode (LMSW) is 7 cycles faster on the 80C286.

Most of the 80286 protected mode access checking instructions operate as fast or faster on the 80C286 than on the 80386. The LAR instruction is one clock cycle faster on the 80 C 286 and the LSL instruction is 5 clock cycles faster. The VERW instruction executes in the same speed on both processors and the VERR is 5 cycles faster on the 80386. The ARPL instruction used in protected mode procedures for pointer validation is 10 clock cycles faster on the 80C286.

| INSTRUCTION | - ADVANTAGE - |  |  |
| :--- | :---: | :---: | :---: |
|  | $\mathbf{8 0 C 2 8 6}$ | NONE | $\mathbf{8 0 3 8 6}$ |
| Task Switching | X |  |  |
| Segment Register Loading | X |  |  |
| Inter-Segment Transfer | X |  |  |
| System Register Instructions |  | X |  |
| Inter-Segment Transfers | X |  |  |
| Access Checking <br> Instructions |  | X |  |

## Subroutine Analysis

This section lists several subroutines and then compares the number of clock cycles each subroutine will take to execute on the 80 C 286 and on the 80386.

## EXAMPLE 1

This interrupt routine outputs a character to a terminal via a UART. The AL register must contain the character to be output. The routine first checks the status of the UART to determine if it is busy. If it is busy, the routine loops until the UART is free; when the UART is free, the character is output. Following is a listing of the code and the clock clycle analysis for the OUT__CHAR routine.
This sample procedure executes about $25 \%$ faster on the 80 C 286 than on the 386. The advantage is realized through the 80C286's faster interrupt handling and faster I/O instructions.

| $\begin{gathered} 80 C 286 \\ \text { CLOCK CYCLES } \end{gathered}$ | $\begin{gathered} 80386 \\ \text { CLOCK CYCLES } \end{gathered}$ | OUT_CHARACTER PROC NEAR |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 3 | 4 |  | PUSHF | ; save callers flags. |
| 3 | 2 |  | PUSH AX | ; save data to be output. |
| 5 | 12 | CK_STATUS: | IN AL, PORT__STATUS | ; Input UART status. |
| 6 | 5 |  | CMP AL, BUSY | ; Check If UART Busy |
| 3/7 | 3/7 |  | JE CK_STATUS | ; If busy go check again. |
| 5 | 4 |  | POPAX | ; If not busy restore AX |
| 3 | 10 |  | OUT OUT__PORT, AL | ; and output data. |
| 5 | 5 |  | POPF | ; Restore Flags |
| 17 | 22 |  | IRET | ; Return. |
| 23 | 37 |  | INT x | ; Instruction to initiate OUTCHAR <br> ; Interrupt. |
| 73 | 104 | Total cycles if UART not busy. <br> Number of cycles added for each loop while UART is busy. |  |  |
| 18 | 24 |  |  |  |

EXAMPLE 1

## EXAMPLE 2

The second example outputs an entire string of characters using the previous interrupt routine (denoted by "INT x" in the code below). The DS:SI registers point to the beginning
of the string to be output. The string is variable in length and must be terminated with the " $\$$ " character.

| $\begin{gathered} 80 C 286 \\ \text { CLOCK CYCLES } \end{gathered}$ | $\begin{gathered} 80386 \\ \text { CLOCK CYCLES } \end{gathered}$ | OUT_STRING PROC FAR |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 17 | 18 |  | PUSHA | ; save caller's registers. |
| 5 | 5 | NEXT: | LODSB | ; Load first char to be output. |
| 3 | 2 |  | CMP AL, "\$" | ; Check to see if End of string. |
| 3/7 | 3/7 |  | JE done | ; If end then goto DONE. |
| 73 | 104 |  | INT $\times$ | ; If not end output character. |
| 7 | 7 |  | JMP next | ; Go get next char to output. |
| 19 | 24 | DONE: | POPA | ; Restore Registers when done. |
| 15 | 18 |  | RET | ; Far Return. |
| 13 | 17 |  | Call OUT__STRING | ; Far Call to initiate ; OUT__STRING procedure. |
| 79+91/char | 91+121/char | Total nu +Numb | ks to start and end ro nal clocks to output ea | cter in the output string |

To output a string of 20 characters, the 80 C 286 would take 1,899 clock cycles; using the same routine, the 80386 would take 2,511 cycles. Each time a string of 20 characters is output, the 80C286 will save 612 clock cycles; an

80 C 286 performance increase of almost $25 \%$. The advantage is realized through the 80C286's faster interrupt handling, faster I/O instructions, faster FAR transfer instructions and faster register saving and restoring instructions.

## EXAMPLE 3

This example adds all the values of a source array in memory to the values of a destination array in memory. The result is stored in the destination array. Both arrays are assumed to be in the current data segment. The count
(number of words in the array), offset of source array, and offset of destination array are all assumed to be placed on the stack (in that order) by the calling program. The source code for the procedure is listed below:

| 80C286 CLOCK CYCLES | $\begin{gathered} 80386 \\ \text { CLOCK CYCLES } \end{gathered}$ |  | ADD_ARRAY PROC NEAR |  |
| :---: | :---: | :---: | :---: | :---: |
| 17 | 18 | NEXT: | PUSHA | ; Save caller's registers. |
| 2 | 2 |  | MOV BP, SP | ; Point BP to current stack |
| 5 | 4 |  | MOV CX, [bp+22] | ; Load array size from stack ; into CX. |
| 5 | 4 |  | MOV SI, [bp+20] | ; Load offset of source array ; from stack into SI. |
| 5 | 4 |  | MOV DI, [ $b p+18$ ] | ; Load offset of destination ; array from stack into DI. |
| 2 | 2 |  | CLD | ; Clear Direction Flag. |
| 5 | 5 |  | LODSW | ; Load the source word into AX. |
| 7 | 7 |  | ADD [DI], AX | ; Add source to destination. |
| 3 | 2 |  | ADD DI, 02 | ; Point DI to next data. |
| 8/4 | 11 |  | LOOP NEXT | ; Continue to ADD all elements ; in the two arrays. |
| 19 | 24 |  | POPA | ; Restore Registers |
| 11 | 10 |  | RET 6 | ; Near return. |
|  |  | ; Following is the code necessary to set up and call the above procedure. |  |  |
| 5 | 5 |  | PUSH count | ; Put count parameter on stack |
| 3 | 2 |  | PUSH offset S_ARRAY | ; Put offset of source array ; on stack. |
| 3 | 2 |  | PUSH offset D_ARRAY | ; Put offset of destination ; array on stack. |
| 7 | 7 |  | CALL ADD_ARRAY | ; Near Call to initiate <br> ; ADD_ARRAY procedure. |
| $84+(23 * C X)-4$ | 84+(25*CX) | Total number of clocks to start and end routine. <br> + Number of additional clocks for each item in array to be added. |  |  |

Both processors take the same number of clock cycles for initialization before the call and closing up after the call (84). The loop that does the adding is faster on the 80C286. To add two 100 word arrays, the 80 C 286 would take 2,380
clock cycles; the 80386 takes 2,584 (an additional 204 clocks) to execute the same routine. In this example, the LOOP instruction gives the 80C286 the performance advantage over the 80386.

## EXAMPLE 4

This procedure is an example of an operating system procedure developed for a protected mode multi-privilege level system. The procedure INIT__SEGMENT is passed a segment selector on the stack and will load that entire segment with zero's. The procedure is designed to execute at privilege level zero with a call gate at privilege level 3 ; this
allows procedures executing at any level to utilize the INIT__SEGMENT procedure. INIT__SEGMENT provides protection checks to ensure that the procedure passing the parameter has valid access to the segment that it is trying to initialize. This prevents a procedure at privilege level three from initializing a segment at privilege level zero.

| $\begin{gathered} 80 C 286 \\ \text { CLOCK CYCLES } \end{gathered}$ | $\begin{gathered} 80386 \\ \text { CLOCK CYCLES } \end{gathered}$ | INIT_SEGMENT PROC FAR WC=1 |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 17 | 18 |  | PUSHA | ; save caller's registers. |
| 3 | 2 |  | PUSH ES | ; save ES register. |
| 2 | 2 |  | MOV BP, SP | ; Point BP to top of stack. |
| 5 | 4 |  | MOV AX, [BP+22] | ; Load AX with segment selector ; passed as parameter on stack. |
| 5 | 4 |  | MOV BX, [BP+20] | ; Load BX with return CS to ; determine caller's CPL. |
| 10 | 20 |  | ARPL AX, BX | ; Adjust the Privilege level of ; the segment selector according ; to the caller's CPL. |
| 16 | 16 |  | VERW AX | ; Test for valid write access |
| 3/7 | 3/7 |  | JNE ERROR | ; If no valid access goto error. |
| 17 | 18 |  | MOVES, AX | ; LOAD ES with segment to be ; initialized. |
| 14 | 20 |  | LSLCX, AX | ; Load segment size into CX. |
| 2 | 2 |  | XOR DI, DI | ; Load zero into DI. |
| 2 | 2 |  | XORAX, AX | ; Load zero into AX. |
| 2 | 2 |  | CLD | ; Clear decrement flag. |
| $4+3^{*} c x$ | $5+5^{*} \mathrm{cx}$ |  | REPSTOSB | ; Init entire segment to 00. |
| 2 | 2 |  | CLC | ; Clear carry to indicate segment ; initialized with no errors. |
| 20 | 21 | DONE: | POPES | ; Restore ES register. |
| 19 | 24 |  | POPA | ; Restore Register |
| 55 | 68 |  | RET 2 | ; Ret FAR to different privilege |
| 2 | 2 | ERROR: | STC | ; SET carry to indicate error. |
| 7 | 7 |  | JMP DONE |  |
|  |  | ; Code to | elector on stack and | EGMENT via call gate. |
| 3 | 2 |  | PUSH DATA_SEL | ; Place Selector on stack. |
| 82 | 86 |  | CALLINIT_SEGME | ; Instruction to initiate |
|  |  |  |  | ; INIT SEGMENT procedure. |
| 253 | 283 | Total cloc | ROR because segm | sible. |
| 283+(3*S) | $321+(5 *$ S | Total num in bytes. | clocks if segment is i | eros. " S " represents size of segmen |

This example shows that when executing instructions used for privilege verification and privilege level transitions the 80 C 286 is faster than the 80386. Without taking the LODS instruction into account, the 80 C 286 is 38 clock cycles
faster when executing the same procedure. With the LODS instruction, and assuming a segment size of 100 bytes, the 80 C 286 would execute this routine 238 clock cycles faster than the 80386.

## EXAMPLE 5

This Procedure is a task dispatcher that is invoked via an interrupt to cause a task switch to occur. This procedure utilizes a circular linked list of the tasks that need to be executed. A pointer called "CURRENT__TASK" points to the data structure for the current task being executed. The data structure contains the TSS for the task it is describing and a NEXT field that points to the data structure of the next task in the list to be executed. When the Task Dispatcher is invoked it switches the current pointer to the next task in the
list and then invokes the new task by jumping to the TSS for that task. The data structure for the linked list is illustrated below.

The task dispatcher is actually a separate task that is invoked via an interrupt that signals that a new task should be initiated. Following is a listing for the simple task dispatcher.


| 80C286 <br> CLOCK CYCLES | 80386 <br> CLOCK CYCLES | TASK_DISPATCH PROC FAR |  |
| :---: | :---: | :---: | :--- |
| 5 | 4 | START: | MOV BX, CURRENT TASK + 2 | | ; Load BX with contents of next |
| :--- |
| ; field of current TASK. BX will |
| 3 |

The advantage of the 80C286 in this case is in the faster task switch instruction. The task switch instruction is 101 clock cycles faster on the 80 C 286 than on the 80386 . This
performance increase makes the 80C286 the clear choice for muti-tasking applications.

## Application Note 111

## Appendix

This appendix contains a table directly comparing the number of clock cycles necessary to execute all the instructions available on both the 80C286 and the 80386. The table includes several addressing modes of each instruction.

The table has five columns. The first column list the instruction being compared. The second column lists the number of clock cycles that the 80C286 needs to execute that instruction. The third column lists the number of clock cycles needed by the 80386 to execute the same instruc-
tion. The fourth column divides the number of cycles needed by the 80386 by the number of cycles needed by the 80 C 286 . If this figure is greater than one, (see fifth column) then the 80C286 is faster than the 80386. For example, a 2.0 would indicate the 80 C 286 executes the same instruction twice as fast as the 80386. A 1.0 indicates that both processors execute the instruction in the same number of cycles. A number less than one indicates the 80386 is faster than the 80 C 286 .

| 80 C 286 INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON $80 C 286$ | NUMBER CLOCKS TO EXECUTE ON 80386 | $\begin{aligned} & 80386 / \\ & 80 C 286 \end{aligned}$ | 80 C 286 FASTER THAN OR EQUAL TO 80386 |
| :---: | :---: | :---: | :---: | :---: |
| AAA | 3 | 4 | 1.33 | $\checkmark$ |
| AAD | 14 | 19 | 1.36 | $\checkmark$ |
| AAM | 16 | 17 | 1.06 | $\checkmark$ |
| AAS | 3 | 4 | 1.33 | $\checkmark$ |
| ADC reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| ADC mem, reg | 7 | 7 | 1.00 | $\checkmark$ |
| ADC reg, immed | 3 | 2 | 0.67 |  |
| ADC mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| ADD reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| ADD mem, reg | 7 | 7 | 1.00 | $\checkmark$ |
| ADD reg, immed | 3 | 2 | 0.67 |  |
| ADD mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| AND reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| AND mem, reg | 7 | 7 | 1.00 | $\checkmark$ |
| AND reg, immed | 3 | 2 | 0.67 |  |
| AND mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| ARPL reg, reg | 10 | 20 | 2.00 | $\checkmark$ |
| ARPL mem, reg | 11 | 21 | 1.91 | $\checkmark$ |
| BOUND (no interrupt) | 13 | 10 | 0.77 |  |
| CALL immed (near) | 7 | 7 | 1.00 | $\checkmark$ |
| CALL immed (far real mode) | 13 | 17 | 1.31 | $\checkmark$ |
| CALL immed (far PVAM) | 26 | 34 | 1.31 | $\checkmark$ |
| CALL gate (same privilege PVAM) | 41 | 52 | 1.27 | $\checkmark$ |
| CALL gate (different privilege PVAM) | 82 | 86 | 1.05 | $\checkmark$ |
| CALL TSS (Task Switch PVAM) | 177 | 278 | 1.57 | $\checkmark$ |
| CALL task_gate (Task Switch PVAM) | 182 | 287 | 1.58 | $\checkmark$ |
| CBW | 2 | 3 | 1.50 | $\checkmark$ |
| CLC | 2 | 2 | 1.00 | $\checkmark$ |
| CLD | 2 | 2 | 1.00 | $\checkmark$ |
| CLI | 3 | 3 | 1.00 | $\checkmark$ |
| CLTS | 2 | 5 | 2.50 | $\checkmark$ |
| CMC | 2 | 2 | 1.00 | $\checkmark$ |
| CMP reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| CMP mem, reg | 6 | 5 | 0.83 |  |
| CMP reg, immed | 3 | 2 | 0.67 |  |
| CMP mem, immed | 6 | 5 | 0.83 |  |
| CMPS | 8 | 10 | 1.25 | $\checkmark$ |
| CWD | 2 | 2 | 1.00 | $\checkmark$ |

## Appendix (Continued)

| $80 \mathrm{C286}$ INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON 80C286 | NUMBER CLOCKS TO EXECUTE ON 80386 | $\begin{gathered} 80386 / \\ 80 C 286 \end{gathered}$ | $80 C 286$ FASTER THAN OR EQUAL TO 80386 |
| :---: | :---: | :---: | :---: | :---: |
| DAA | 3 | 4 | 1.33 | $\checkmark$ |
| DAS | 3 | 4 | 1.33 | $\checkmark$ |
| DEC reg | 2 | 2 | 1.00 | $\checkmark$ |
| DEC mem | 7 | 6 | 0.86 |  |
| DIV word, reg | 22 | 22 | 1.00 | $\checkmark$ |
| DIV word, mem | 25 | 25 | 1.00 | $\checkmark$ |
| ENTER immed1, immed2 (immed $2=6$ ) | 36 | 35 | 0.97 |  |
| HLT | 2 | 5 | 2.50 | $\checkmark$ |
| IDIV word, reg | 25 | 27 | 1.08 | $\checkmark$ |
| IMUL word, mem | 24 | 19 | 0.79 |  |
| IN | 5 | 12 | 2.40 | $\checkmark$ |
| INC reg | 2 | 2 | 1.00 | $\checkmark$ |
| INC mem | 7 | 6 | 0.86 |  |
| INS | 5 | 15 | 3.00 | $\checkmark$ |
| INT 3 (real mode) | 23 | 33 | 1.43 | $\checkmark$ |
| INT immed (real mode) | 23 | 37 | 1.61 | $\checkmark$ |
| INT immed (PVAM same privilege) | 40 | 59 | 1.48 | $\checkmark$ |
| INT immed (PVAM different privilege) | 78 | 99 | 1.27 | $\checkmark$ |
| INT TASK_GATE (PVAM Task Switch) | 167 | 280 | 1.68 | $\checkmark$ |
| INTO (No Jump) | 3 | 3 | 1.00 | $\checkmark$ |
| INTO (Yes Jump real mode) | 24 | 35 | 1.46 | $\checkmark$ |
| IRET (real mode) | 17 | 22 | 1.29 | $\checkmark$ |
| IRET (PVAM same privilege) | 31 | 38 | 1.23 | $\checkmark$ |
| IRET (PVAM different privilege) | 55 | 82 | 1.49 | $\checkmark$ |
| IRET (PVAM task switch) | 169 | 232 | 1.37 | $\checkmark$ |
| Jcond label (No jump) | 3 | 3 | 1.00 | $\checkmark$ |
| Jcond label (Yes jump) | 7 | 7 | 1.00 | $\checkmark$ |
| JMP near_label | 7 | 7 | 1.00 | $\checkmark$ |
| JMP Far__label (real mode) | 11 | 12 | 1.09 | $\checkmark$ |
| JMP FAR_LABEL (PVAM) | 23 | 27 | 1.17 | $\checkmark$ |
| JMP CALL_GATE (PVAM same privilege) | 38 | 45 | 1.18 | $\checkmark$ |
| JMP TASK_GATE (PVAM task switch) | 183 | 288 | 1.57 | $\checkmark$ |
| JMP TSS (PVAM task switch) | 178 | 279 | 1.57 | $\checkmark$ |
| LAHF | 2 | 2 | 1.00 | $\checkmark$ |
| LAR reg | 14 | 15 | 1.07 | $\checkmark$ |
| LAR mem | 16 | 16 | 1.00 | $\checkmark$ |
| LDS (real mode) | 7 | 7 | 1.00 | $\checkmark$ |
| LDS (PVAM) | 21 | 22 | 1.05 | $\checkmark$ |
| LEA | 3 | 2 | 0.67 |  |
| LEAVE | 5 | 4 | 0.80 |  |
| LGDT | 11 | 11 | 1.00 | $\checkmark$ |
| LIDT | 12 | 11 | 0.92 |  |
| LLDT reg | 17 | 20 | 1.18 | $\checkmark$ |
| LLDT mem | 19 | 20 | 1.05 | $\checkmark$ |
| LMSW reg | 3 | 10 | 3.33 | $\checkmark$ |
| LMSW mem | 6 | 13 | 2.17 | $\checkmark$ |
| LODS | 5 | 5 | 1.00 | $\checkmark$ |
| LOOP (Jump) | 8 | 11 | 1.38 | $\checkmark$ |
| LOOP (No Jump) | 4 | 11 | 2.75 | $\checkmark$ |

## Appendix (Continued)

| 80C286 INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON 80C286 | NUMBER CLOCKS TO EXECUTE ON 80386 | $\begin{aligned} & 80386 / \\ & 80 C 286 \end{aligned}$ | $80 C 286$ FASTER THAN OR EQUAL TO 80386 |
| :---: | :---: | :---: | :---: | :---: |
| LSL reg | 14 | 20 | 1.43 | $\checkmark$ |
| LSL mem | 16 | 21 | 1.31 | $\checkmark$ |
| LTR reg | 17 | 23 | 1.35 | $\checkmark$ |
| LTR mem | 19 | 27 | 1.42 | $\checkmark$ |
| MOV reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| MOV mem, reg | 3 | 2 | 0.67 |  |
| MOV reg, immed | 2 | 2 | 1.00 | $\checkmark$ |
| MOV mem, immed | 3 | 2 | 0.67 |  |
| MOV seg_reg, reg (real mode) | 2 | 2 | 1.00 | $\checkmark$ |
| MOV seg_reg, mem (real mode) | 5 | 5 | 1.00 | $\checkmark$ |
| MOV seg__reg, reg (PVAM) | 17 | 18 | 1.06 | $\checkmark$ |
| MOV seg_reg, mem (PVAM) | 19 | 19 | 1.00 | $\checkmark$ |
| MOVS | 5 | 7 | 1.40 | $\checkmark$ |
| MUL reg | 21 | 15 | 0.71 | $\checkmark$ |
| NEG reg | 2 | 2 | 1.00 | $\checkmark$ |
| NEG mem | 7 | 6 | 0.86 |  |
| NOP | 3 | 3 | 1.00 | $\checkmark$ |
| NOT reg | 2 | 2 | 1.00 | $\checkmark$ |
| NOT mem | 7 | 6 | 0.86 |  |
| OR reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| OR mem, reg | 7 | 6 | 0.86 |  |
| OR reg, immed | 3 | 2 | 0.67 |  |
| OR mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| OUT | 3 | 10 | 3.33 | $\checkmark$ |
| OUTS | 5 | 14 | 2.80 | $\checkmark$ |
| POP reg | 5 | 4 | 0.80 |  |
| POP mem | 5 | 5 | 1.00 | $\checkmark$ |
| POP seg__reg (real mode) | 5 | 7 | 1.40 | $\checkmark$ |
| POP seg_reg (PVAM) | 20 | 21 | 1.05 | $\checkmark$ |
| POPA | 19 | 24 | 1.26 | $\checkmark$ |
| POPF | 5 | 5 | 1.00 | $\checkmark$ |
| PUSH reg | 3 | 2 | 0.67 |  |
| PUSH mem | 5 | 5 | 1.00 | $\checkmark$ |
| PUSH seg__reg | 3 | 2 | 0.67 |  |
| PUSHA | 17 | 18 | 1.06 | $\checkmark$ |
| PUSHF | 3 | 4 | 1.33 | $\checkmark$ |
| RCR or RCL reg, 1 | 2 | 9 | 4.50 | $\checkmark$ |
| RCR or RCL mem, 1 | 7 | 10 | 1.43 | $\checkmark$ |
| RCR or RCL reg, $\mathrm{cl}(\mathrm{cl}=4)$ | 9 | 9 | 1.00 | $\checkmark$ |
| RCR or RCL mem, $\mathrm{cl}(\mathrm{cl}=4)$ | 12 | 10 | 0.83 |  |
| RCR or RCL reg, 4 | 9 | 9 | 1.00 | $\checkmark$ |
| RCR or RCL mem, 4 | 12 | 10 | 0.83 |  |
| ROR or ROL reg, 1 | 2 | 3 | 1.50 | $\checkmark$ |
| ROR or ROL mem, 1 | 7 | 7 | 1.00 | $\checkmark$ |
| ROR or ROL reg, $\mathrm{cl}(\mathrm{cl}=4)$ | 9 | 3 | 0.33 |  |
| ROR or ROL mem, $\mathrm{cl}(\mathrm{cl}=4)$ | 12 | 7 | 0.58 |  |
| ROR or ROL reg, 4 | 9 | 3 | 0.33 |  |
| ROR or ROL mem, 4 | 12 | 7 | 0.58 |  |


| Appendix (Continued) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $80 C 286$ INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON $80 C 286$ | NUMBER CLOCKS TO EXECUTE ON 80386 | 80386/ $80 C 286$ | $80 C 286$ FASTER THAN OR EQUAL TO 80386 |
| REP INS (cx = 100) | 405 | 613 | 1.51 | $\checkmark$ |
| REP MOVS ( $\mathrm{c} \times 100$ ) | 405 | 405 | 1.00 | $\checkmark$ |
| REP OUTS ( $\mathrm{cx}=100$ ) | 405 | 1205 | 2.98 | $\checkmark$ |
| REP STOS ( $\mathrm{cx}=100$ ) | 304 | 505 | 1.66 | $\checkmark$ |
| REP CMPS ( $\mathrm{c} \times 100$ ) | 905 | 905 | 1.00 | $\checkmark$ |
| $\operatorname{REPECMPS}(\mathrm{N}=100)$ | 905 | 905 | 1.00 | $\checkmark$ |
| REPE SCAS ( $\mathrm{N}=100$ ) | 805 | 805 | 1.00 | $\checkmark$ |
| RET (near) | 11 | 10 | 0.91 |  |
| RET (far real mode) | 15 | 18 | 1.20 | $\checkmark$ |
| RET (far PVAM same privilege) | 25 | 32 | 1.28 | $\checkmark$ |
| RET (far PVAM different privilege) | 55 | 68 | 1.24 | $\checkmark$ |
| SAHF | 2 | 3 | 1.50 | $\checkmark$ |
| SHIFT reg, 1 (SHIFT = SAL, SAR, SHR) | 2 | 3 | 1.50 | $\checkmark$ |
| SHIFT mem, 1 | 7 | 7 | 1.00 | $\checkmark$ |
| SHIFT reg, $\mathrm{Cl}(\mathrm{Cl}=4)$ | 9 | 3 | 0.33 |  |
| SHIFT mem, $\mathrm{Cl}(\mathrm{Cl}=4)$ | 12 | 7 | 0.58 |  |
| SHIFT reg, 4 | 9 | 3 | 0.33 |  |
| SHIFT mem, 4 | 12 | 7 | 0.58 |  |
| SBB reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| SBB mem, reg | 7 | 6 | 0.86 |  |
| SBB reg, immed | 3 | 2 | 0.67 |  |
| SBB mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| SCAS | 7 | 7 | 1.00 | $\checkmark$ |
| SGDT | 11 | 9 | 0.82 |  |
| SIDT | 12 | 9 | 0.75 |  |
| SLDT reg | 2 | 2 | 1.00 | $\checkmark$ |
| SLDT mem | 3 | 2 | 0.67 |  |
| SMSW reg | 2 | 2 | 1.00 | $\checkmark$ |
| SMSW mem | 3 | 2 | 0.67 |  |
| STS | 2 | 2 | 1.00 | $\checkmark$ |
| STD | 2 | 2 | 1.00 | $\checkmark$ |
| STI | 2 | 3 | 1.50 | $\checkmark$ |
| Stos | 3 | 4 | 1.33 | $\checkmark$ |
| STR reg | 2 | 23 | 11.50 | $\checkmark$ |
| STR mem | 3 | 27 | 9.00 | $\checkmark$ |
| SUB reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| SUB mem, reg | 7 | 6 | 0.86 |  |
| SUB reg, immed | 3 | 2 | 0.67 |  |
| SUB mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| TEST reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| TEST mem, reg | 6 | 5 | 0.83 |  |
| TEST reg, immed | 3 | 2 | 0.67 |  |
| TEST mem, immed | 6 | 5 | 0.83 |  |
| VERR reg | 14 | 10 | 0.71 |  |
| VERR mem | 16 | 11 | 0.69 |  |
| VERW reg | 14 | 15 | 1.07 | $\checkmark$ |
| VERW reg | 16 | 16 | 1.00 | $\checkmark$ |

## Appendix (Continued)

| $80 C 286$ INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON 80C286 | NUMBER CLOCKS TO EXECUTE ON 80386 | $\begin{aligned} & 80386 / \\ & 80 C 286 \end{aligned}$ | $80 C 286$ FASTER THAN OR EQUALTO 80386 |
| :---: | :---: | :---: | :---: | :---: |
| WAIT | 3 | 6 | 2.00 | $\checkmark$ |
| XCHG reg, reg | 3 | 3 | 1.00 | $\checkmark$ |
| XCHG reg, mem | 5 | 5 | 1.00 | $\checkmark$ |
| XLAT | 5 | 5 | 1.00 | $\checkmark$ |
| XOR reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| XOR mem, reg | 7 | 6 | 0.86 |  |
| XOR reg, immed | 3 | 2 | 0.67 |  |
| XOR mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| TOTAL number clocks to execute all instructions AVERAGE | 6978 | 9048 | 1.24 |  |
| Number of Instructions faster on 80C286 |  | 74 |  |  |
| Number of Instructions equal on both processors |  | 66 |  |  |
| Number of Instructions faster on 80386 |  | 50 |  |  |
| Total Number of instructions analyzed |  | 190 |  |  |



# 80C286/80386 HARDWARE COMPARISON 

Author: Ted Schaufelberger

The Harris 80C286 static CMOS microprocessor, available with maximum operating frequencies of $16-\mathrm{MHz}$ and $20-$ MHz , offers both performance and design advantages over the 80386 when operating at the same frequency. When both the 80C286 and 80386 are operated on a 16 -bit data bus, which fully supports industry standard 8086/80286 code, the 80 C 286 has better performance, and is significantly simpler to design with than the 80386. The 80C286 also uses significantly lower power than the 80386 , leading to less expensive, more reliable overall system design (see Figure 1).


FIGURE 1. 80C286/80386 POWER CONSUMPTION COMPARISON

The following comparison highlights some of the performance advantages that exist on the 80C286:

## Summary of 16-Bit Data Bus Performance

## - 80C286

- The 80C286 already has all necessary control lines needed to implement a 16-bit data bus (Ref. section on Control Signals Required to Implement a 16-Bit Data Bus).
- The 80C286 supports a fully pipelined mode of operation for maximum system performance (Ref. section on Pipelined Operation on a 16-Bit Data Bus).
- The 80C286 remains in a pipelined mode of operation even when idle bus cycles occur (Ref. section on Idle Cycles).
- The 80C286 instruction prefetch takes one bus cycle to execute, thereby minimizing the time that the processor Execution Unit must wait should it need the bus (Ref. section on Instruction Prefetching a 16-Bit Data Bus).
- 80386
- The 80386 requires five additional control lines to be generated by external logic in order to implement a 16bit data bus (Ref. section on Control Signals Required to Implement a 16-Bit Data Bus).
- The 80386 does not support a fully pipelined mode of operation. Some pipelining can be achieved, but to accomplish this, external bus 'monitor' logic must be added to the system (Ref. section on Pipelined Operation on a 16-Bit Data Bus).
- The 80386's pipelining is disrupted by idle bus cycles. A non-pipelined bus cycle, usually with an additional wait state, must be executed before the 80386 can return to pipelined mode. Idle bus cycles occur an average of $9 \%$ of the time (Ref. section on Idle Cycles).
- The 80386 instruction prefetch takes two bus cycles to execute, which can cause performance degradation by forcing the Execution Unit of the processor to wait a full bus cycle for use of the bus in order to complete an instruction (Ref. section on Instruction Prefetching on a 16-Bit Data Bus).


## 16-Bit Data Bus Operation

This section will discuss the control signals required to implement a 16-bit data bus, as well as pipelined operation, idle cycles, and instruction prefetching on a 16-bit bus.

## Control Signals Required to Implement a 16-Bit Data Bus

The 80C286 microprocessor has all the control lines needed to implement a 16 -bit data bus resident on chip, no further control lines are required.

| 80386 SIGNALS |  |  |  | 16-BIT BUS SIGNALS |  |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BE3\# | BE2\# | BE1\# | BEO\# | A1 | BHE\# | BLE\# (AO) |  |
| $\mathrm{H}^{*}$ | $\mathrm{H}^{*}$ | $\mathrm{H}^{*}$ | $H^{*}$ | X | X | X | X-No Active Bytes |
| H | H | H | L | L | H | L |  |
| H | H | L | H | L | L | H |  |
| H | H | L | L | L | L | 4 |  |
| H | L | H | H | H | H | L |  |
| $H^{*}$ | L* | $H^{*}$ | L* | X | X | X | X-Not Contiguous Bytes |
| H | L | L | H | L | L | H |  |
| H | $L$ | L | L | L | L | L |  |
| L* | $\mathrm{H}^{*}$ | $H^{*}$ | L* | X | X | X | X-Not Contiguous Bytes |
| L* | $H^{*}$ | L* | $H^{*}$ | X | X | X | X-Not Contiguous Bytes |
| L* | $\mathrm{H}^{*}$ | L* | L* | X | , X | X | X-Not Contiguous Bytes |
| L | L | H | H | H | L | L |  |
| L* | L* | $H^{*}$ | L* | X | X | X | X-Not Contiguous Bytes |
| L | L | L | H | L | L | H |  |
| L | L | L | L | L | L | L |  |
| BLE\# Asserted When DO-D7 of 16-Bit Bus is Active. BHE\# Asserted When D8-D15 of 16-Bit Bus is Active. A1 Low For All Even Words; A1 High For All Odd Words. |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
| Key: $\quad$ | X = Don't Care |  |  |  |  |  |  |
|  | $H$ = High Voltage Level |  |  |  |  |  |  |
|  | $L=$ Low Voltage Level |  |  |  |  |  |  |
|  | * $=$ A Non-Occurring Pattern of Byte Enables; Either None are Asserted, or the Pattern has Byte Enables Asserted for Non-Contiguous Bytes |  |  |  |  |  |  |

FIGURE 2. A1, BLE\#, AND BHE\# SIGNAL GENERATION TABLE

In order to implement a 16-bit data bus with the 80386 microprocessor, it is necessary to create at least the following five additional control signals: Address Line 1 (A1), Bus Low Enable (BLE\#), Bus High Enable (BHE\#), Bus Size 16-Bits (BS16\#), and Next Address (NA\#).

The first of these signals, $\mathbf{A} 1$, is an additional address line required to convert the granularity of the 80386 's address space from double-word size entities (32-bit) to word size entities (16-bit). The second two signals, BLE\# and BHE\#, primarily serve as chip selects which enable the appropriate byte or bytes onto the 16-bit data bus. These three signals are generated from the four 80386 byte enables (BEO\#BE3\#) as shown in Figure 2. The logic to implement these signals is shown in Figure 3.

In addition to these three control signals generated from 80386 signals as outputs, two input control signals to the 80386 must be generated by external logic (BS16\# and NA\#).

BS16\# is used to inform the 80386, on a cycle-by-cycle basis, that a 16-bit bus size is to be used for data transfer. NA\# is used to request that the 80386 put the next cycle address on the bus early, thereby pipelining that cycle.

The 80386, therefore, requires five additional control lines, three outputs and two inputs, in order to implement a 16-bit data bus. The generation of these control lines, in turn, requires additional 'glue' logic (which also introduces additional signal propagation delay, thereby reducing address access time available to the system), and finally, there is additional bus cycle 'monitor' logic necessary if the 16-bit data bus is to be pipelined for higher performance.


FIGURE 3. A1, BLE\#, AND BHE\# LOGIC

## Pipelined Operation on a 16-Bit Data Bus

At a given clock frequency, pipelined address operation increases a system's performance, while simultaneously allowing relatively slower memories and I/O devices to be used. Pipelined address operation provides the system increased address access time, and increased address decoding time.

The 80C286 is optimized for, and directly supports, fully pipelined bus operations on a 16-bit data bus. In other words, the 80C286 performs all bus operations in a fully pipelined mode.

The 80386 does not support fully pipelined operation on a 16- bit data bus. In order to pipeline a bus cycle on the 80386, the Next Address (NA\#) signal must be asserted to the processor. If the Next Address (NA\#) signal and the Bus Size 16-Bit (BS16\#) signal are both asserted in the same bus cycle, the NA\# signal will not be recognized. Since, the BS16\# signal must be asserted to the 80386 for many patterns of 16-bit and 8-bit transfers to take place correctly, the pipelining of transfers over a 16-bit bus is limited.

To allow pipelining of 16-bit data, external logic must be implemented to monitor the type of bus cycle taking place, decide if the cycle can be pipelined, and, if so, negate the BS16\# signal to the 80386 and assert the NA\# signal. Pipelining is possible only if the bus cycle is one of the following three types:
(1) A read operand cycle using only the lower half of the data bus
(2) A write operand cycle using only the lower half of the data bus
(3) A write operand cycle using only the upper half of the data bus

The 80386 will not allow 16-bit pipelining of read or write cycles that have byte alignments that do not conform to one of the previously mentioned three types.

The 80C286, then, fully supports address pipelining, yielding the highest possible system performance, while using relatively lower performance (and therefore cheaper) memories and peripherals. The 80386, however, does not support fully pipelined 16-bit bus operation, and, to support even partial pipelining, requires external bus 'monitor' logic.

## Idie Cycles

Another factor to consider when evaluating 80C286 and 80386 performance is the effect of idle cycles on pipelined operation. Calculations have shown that, on average, bus idle cycles occur in the system approximately $9 \%$ of the time. The effect of idle cycles on pipelining is quite different on the 80 C 286 than on the 80386.

The 80C286 pipelined operation is not affected by idle cycles. When an idle cycle or cycles occur in a stream of pipelined bus cycles, the 80C286 returns to pipelining bus cycles immediately after the last idle cycle. In this way, each device on the bus (e.g. memory, peripheral) maintains a fixed timing associated with that device, and therefore always uses the minimum number of wait states required for that device.

On the other hand, the 80386 pipelined operation is disrupted by idle cycles. With the 80386, an idle cycle or cycles occurring in a pipelined stream of bus cycles breaks the pipelining operation. Once an idle cycle has occurred, a non-pipelined bus cycle must always be executed prior to resuming pipelining. Since a non-pipelined bus cycle will have different timing than a pipelined bus cycle (even to the same device), an additional wait state must be added to this bus cycle. This not only degrades performance, but requires additional external logic to differentiate between a pipelined bus cycle access, and a non-pipelined bus cycle access, even to the same device with the same address.

From the preceding, it can be seen that when executing 16bit code, the 80 C 286 has a $9 \%$ performance increase over the 80386, due to the manner in which each processor handles idle cycles alone. Note, that with the 80386, a pipelined stream of bus cycles will always be disrupted when an idle cycle occurs, whether using a 16-bit data bus or a 32-bit data bus. In either case, a non-pipelined bus cycle must be executed prior to resuming pipelined operation.

## Instruction Prefetching on a 16-Bit Data Bus

One final factor needs to be considered in the evaluation of $80 C 286$ and 80386 performance on a 16-bit data bus; the effect that prefetching instructions has on instruction execution time. Prefetching of instructions is done by the processor Bus Unit on both the 80C286 and 80386. The prefetch is done when the bus would otherwise be idle for the upcoming cycle, and the prefetch queue is not full.

The 80C286 does word size (16-bit) prefetching of instructions, and therefore completes it's prefetch activities in one bus cycle. This minimizes the waiting period to gain access to the bus by other processor entities, such as the Execution Unit.

The 80386 does doubleword (32-bit) prefetching of instructions, even on a 16-bit bus. This means that once a prefetch has begun execution, two bus cycles are required to complete the prefetch. If, for instance, the processor's Execution Unit requires the bus for a data fetch or write in order to complete an executing instruction, it must wait for the two bus cycles of the prefetch to complete before it can access the bus. This can substantially degrade instruction execution time.

## 32-Bit Data Bus Operation

This section discusses operating the 80386 on a 32-bit bus in order to overcome some of the handicaps it suffers on a 16-bit bus. In addition, several advantages and disadvantages associated with the 80386 on a 32-bit bus are considered.

Hardware Advantages of the 80386 on a 32 -Bit Data Bus
There are several advantages to operating the 80386 on a 32-bit data bus as opposed to a 16-bit data bus. Some of the control lines that were required for a 16-bit data bus are eliminated (A1, BLE\#, BHE\#, and BS16\#). It is possible to come closer to a fully pipelined mode of operation, although idle cycles will still disrupt the pipelining $9 \%$ of the time. Finally, prefetching on a 32-bit bus executes in one bus cycle instead of two. Offsetting these advantages, however are several major disadvantages.

## Hardware Disadvantages of the 80386 on a 32-bit Data Bus

When using a full 32-bit data bus, the chip complexity of a 80386 based system is increased over a 16 -bit system. Twice as many transceivers (four instead of two) are required.

In addition, in order to accommodate the additional 16 data lines of the 32-bit bus, twice as many memory devices are typically required with the 32-bit system as compared to a 16-bit system. This amounts to an increase in DRAM, alone, of from 18 devices in a typical 16-bit system to 36 devices in a typical 32-bit system.

The 16 additional data lines of the 32-bit bus increase the EMI problems inherent in the system. The additional coupling and crosstalk between data lines must be taken into consideration when laying out the system PC board.

There is a significant increase in the amount of board space used as a result of the additional chips required to implement a 32-bit bus, as well as the 16 additional data lines. This results in a larger, more complex (and more expensive) PC board than with a 16-bit system, often requiring an increase in the number of board layers.

## References

Intel Corporation. 1987.
80386 Hardware Reference Manual.


# INTERFACING THE 80C286-16 WITH THE 80287-10 

Author: Ted Schaufelberger

An important requirement in many systems is the ability to off-load numeric data processing. In an 80C286 system, this can be accomplished with an 80287 numeric co-processor. However, as processor speeds increase, it may become necessary to interface a high speed 80C286 processor with a lower speed 80287. This Document will briefly describe the interface between a 16 MHz 80 C 286 ( $80 \mathrm{C} 286-16$ ) and a 10 MHz 80287 (80287-10).

Interfacing the 80C286 with an 80287 can be broken down into three main areas:
(1) Bus control lines and data lines which coordinate and implement the flow of data between the two processors (i.e. the data lines, chip select lines, and read/write lines).
(2) The clock line(s), which drive the two processors.
(3) The four status lines through which the 80C286 and 80287 directly communicate status information to one another - comprised of the $\overline{B U S Y}, \overline{E R R O R}$, Peripheral Request (PEREQ), and Peripheral Acknowledge (PEACK) lines.

## Bus Control Lines

The various bus control and data lines in most systems would be coordinated by either a bus controller (such as the 82 C 288 ), or a bus controller subsection of an 80 C 286 oriented chip set. All requisite bus control timing between a 16 MHz 80 C 286 , and a 10 MHz 80287 would then be handled by these devices (typically with one wait-state inserted to allow for the slower 80287-10).

## Clock Lines

A system using a 16 MHz 80 C 286 with a 10 MHz 80287 requires separate clock lines for the two processors. The 32 MHz system clock used by the 80C286-16 is too fast for the $80287 \pm 10$, necessitating a dedicated clock driver for the 80287 . This clock driver should supply a 10 MHz clock to the 80287 with a $1 / 3$ duty cycle to allow the 80287-10 to run at it's full 10 MHz capability. One solution for providing this clock is the 82C84A-1, which meets this specification with either a 30 MHz crystal at it's crystal inputs, or a 30 MHz external frequency input to it's EFI pin. In either case, a $10 \mathrm{MHz} 1 / 3$ duty cycle clock is output to the 80287. Note that when using a dedicated clock driver such as this, the CKM pin of the 80287 must be pulled up.

## Status Lines

The 80C286 and 80287 communicate status information with one another through four signals; the BUSY line, the $\overline{E R R O R}$ line, the peripheral request line (PEREQ), and the PEACK line.
The $\overline{B U S Y}$ and $\overline{E R R O R}$ lines can be connected from the 80287 to a 80 C 286 -oriented chipset, or from the 80287 directly to a 80C286. In the case of the chipset interface, the signal timing between the 80287 and 80C286 is coordinated by the chipset. In the case of the direct 80287 to 80C286 interface, the signal timing is handled by the 80C286, and, since the signal flow direction is from the 80287 to the 80C286 (i.e. from the slower device to the faster device), no additional hardware is required to achieve proper timing.


FIGURE 1. PEACK STRETCH CIRCUIT

The peripheral request (PEREQ) line should be connected directly from the 80287 to the 80 C 286 , and again, since the signal flow direction is from the 80287 to the 80 C 286 , no additional hardware is required.
The peripheral acknowledge ( $\overline{\text { PEACK }}$ ) line is normally connected directly from the 80C286 to the 80287. In this case the signal flow direction is from the 80 C 286 to the 80287 (i.e. faster device to slower device), and the PEACK active time is not guaranteed to meet the requirements of the slower 80287-10. Worst case timing for the 80C286-16 reveals that PEACK output could be as short as 45.5 ns (i.e. $\overline{\text { PEACK }}(\min )=45.5 n s)$. The $80287-10$ input requirement is $\overline{\text { PEACK }}(\mathrm{min})=60 \mathrm{~ns}$.

The proper $\overline{\text { PEACK }}$ timing can be achieved using the circuit shown in Figure 1 comprised of a 74AC04, 74ACO8, and a 74AC112. Referring to the timing diagram shown in Figure 2, it can be seen that this circuit effectively 'stretches' the 80C286's PEACK output (in the form of GPEACK) to 72.7 ns , which satisfies the 80287-10 requirement.

The operation of the circuit shown in Figure 1 is as follows:
(1) The RESET signal (which is also applied to the 80C286) is used to initialize the 'AC112 to a known inactive state ( $\mathrm{Q}=1$ ).
(2) When the 80 C 286 asserts the $\overline{\text { PEACK }}$ signal, the gated version of this signal (GPEACK) is asserted with minimal delay ( 7.9 ns through the 'ACO8).
(3) On the falling edge of the 80C286 CLK at the beginning of Phase 2 of the TS cycle, the low state of PEACK is clocked into the 'AC112. This effectively holds GPEACK low for an additional clock cycle longer than standard $\overline{\text { PEACK }}$ timing.
(4) On the falling edge of the 80 C 286 CLK at the beginning of phase 2 of the first $T_{C}$ cycle, the high state of PEACK is clocked into the 'AC112, which then causes GPEACK to go inactive.
The net effect of this circuit operation is to extend the 80C286's Peripheral Acknowledge signal to the 80287-10 sufficiently to meet it's requirements.

figure 2. PEACK CyCle timing


# HARRIS 80C286 PERFORMANCE ADVANTAGES OVER THE 80386SX 

Author: Ted Dimbero

The Harris 80C286, operating at the same frequency as the 80386SX, can outperform the 80386SX when executing software written for the 80286 and 8086 , including all MS-DOS ${ }^{\text {TM }}, \mathrm{PC}-$ DOS $^{\text {miw }}$ and OS $/ 2^{\text {Tw }}$-based programs. This performance advantage comes from the 80 C 286 requirement of fewer clock cycles to execute the same instructions as the 80386SX.

Industry standard 16-bit 8086/80286 code can execute $15-25 \%$ more efficiently on the 80C286 than on the 80386SX. There is no performance advantage gained by simply moving a system design from an 80C286 to an $803865 \times$. The 80 C 286 is the processor best suited for executing 16-bit 8086/80286 code.

The difference in clock cycle requirements is summarized in Figure 1. Of the 182 common instructions, the 80C286 executes 79 instructions faster than the 80386SX. Another 64 instructions execute in the same number of clock cycles on both processors.

Overall, 143 instructions (78\% of all common instructions) execute as fast or faster on the 80 C 286 than on the 80386SX.

286-16


FIGURE 1. EXECUTION SPEED COMPARISON (NUMBER OF INSTRUCTIONS)

Taking this comparison one step further and looking at the performance contribution of each subset of instructions, those instructions that execute faster on the 80386SX are executed an average of 1.6 clock cycles faster. However, the instructions which execute faster on the 80C286 execute in an average of 23.1 clock cycles less than on the 80386SX.

## Operating Speeds

The Harris 80C286 is available with operating frequencies of $12.5,16,20$ and 25 MHz . The 80386 SX maximum operating frequency is limited to 16 MHz . The instruction comparisons in Figure 1 (and throughout this document) evaluate the number of clock cycles required to execute the same instructions on both the 80386SX and the 80C286. Therefore, it illustrates the performance differences when the two processors are running at the same speed.

As this analysis shows, the 80C286 has the performance advantage when the two processors are running at the same speed. This 80 C 286 advantage is significantly greater when speed differences are taken into consideration.

The 80C286-25, for example, can execute $100 \%$ of the instructions available on both processors faster than a 16 MHz 80386 SX . In some cases, a 2 X performance increase can be seen with the 80C286-25 compared to the 80386SX-16 (see Table 1).

This is not a benchmark number that can be credited to differences in system design; it illustrates a one-to-one comparison of the length of time it takes to execute the same instruction on the two processors. That is, given two equivalent systems (both having the same disk access speed, same number of wait states, similar cache controllers, etc), the 80C286-25 system would outperform the 80386SX system on any benchmark.

PC-DOS ${ }^{\text {tw }}$, OS $/ 2^{\text {mu }}$ are Trademarks of Internatıonal Business Machınes Corporation Xenix ${ }^{\text {™ }}$, MS-DOS ${ }^{\text {™ }}$ are Trademarks of Microsoft Corporation

TABLE 1.

|  |  |  |  | 80C286-16 |  | 80C286-20 |  | 80C286-25 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{gathered} \text { SUB- } \\ \text { ROUTINES } \\ \text { (PGS 6-9) } \end{gathered}\right.$ | 80386SX <br> \# CLOCK CYCLES | $\begin{aligned} & 80 C 286 \\ & \text { \# CLOCK } \\ & \text { CYCLES } \end{aligned}$ |  | EXECUTION TIME ( $\mu \mathrm{sec})$ | PERFORMANCE INCREASE OVER 80386SX-16 | EXECUTION TIME ( $\mu \mathrm{sec}$ ) | PERFORMANCE INCREASE OVER 80386SX-16 | EXECUTION TIME $(\mu \mathrm{sec})$ | PERFORMANCE INCREASE OVER 80386SX-16 |
| Example <br> 1 | 104 | 73 | 6.5 | 4.6 | 141\% | 3.6 | 180\% | 2.92 | 223\% |
| Example <br> 2 | 2511 | 1899 | 156.9 | 118.7 | 132\% | 94.9 | 165\% | 75.9 | 132\% |
| $\begin{aligned} & \text { Example } \\ & 3 \end{aligned}$ | 2584 | 2380 | 161.5 | 148.7 | 108\% | 119.0 | 135\% | 95.2 | 170\% |
| Example <br> 4 | 837 | 583 | 52.3 | 36.4 | 143\% | 29.1 | 179\% | 23.3 | 224\% |
| Example <br> 5 | 307 | 193 | 19.2 | 12.1 | 158\% | 9.65 | 198\% | 7.7 | 249\% |

Table 1 illustrates a performance comparison of the 80386SX-16, 80C286-16, 80C286-20 and 80C286-25. The table lists the number of clock cycles needed to execute five different subroutines (see examples 1-5 in Subroutine Analysis section) and the total execution times for each subroutine for the two processors at varying operating frequencies.

In each of these examples, the results show that the 80C286 outperforms the 80386SX. In addition, the 80C286-25 shows performance increases of $170 \%-250 \%$ over the 80386 SX-16. The 80C286 not only outperforms the 80386 SX at similar operating frequencies, it also provides a path to increased performance by offering operating frequencies up to 25 MHz which are not available with the 80386SX.

## Architecture Background

The 80C286 static CMOS microprocessor combines low operating and standby power with high performance and operating frequencies up to 25 MHz .

The 80C286 evolved from the industry standard 80C86 microprocessor and has vast architectural enhancements over its predecessor that allow the 80 C 286 to execute the same code with a significant performance increase.

Disregarding the clock speed increase, when upgrading from an 80C86 to an 80C286, the 80C286 can execute the same code with an increase in throughput of up to 4 times that of the 80 C 86 . This increase is solely due to the architectural enhancements.

It is a common belief that replacing an 80C286 with the 80386SX microprocessor will yield similar performance increases. This is not the case. The new architecture gives the 80386SX 32-bit internal capability but it does not significantly increase the throughput of 16-bit 8086 or 80286 code.

When executing industry standard 8086 or 80286 code, replacing the 80C286 with an 80386SX does not result in a significant performance increase. In many cases, such a replacement will actually cause a performance degradation. This is evident in the following areas:
(1) Input/Output Handling
(2) Interrupt Handling
(3) Control Transfer (Loop, Jump, Call)
(4) 80286 Protected Mode Systems
(5) Multi-Tasking and Task Switching Operations.

The performance advantage of the 80 C 286 is especially evident in areas such as:

- Protected Mode Operating System - such as OS/2 and Xenix ${ }^{\text {™ }}$.
- Multi-Tasking Systems.
- Control Applications - utilizing interrupt and I/O instructions.
- Structured Software - utilizing many Control transfer instructions.
- Operating Systems that rely on interrupts to perform functions - such as MS-DOS, PC-DOS and OS/2.
- Upgrading 16-bit 80C86 applications for increased performance.

Figure 2 illustrates a comparison of the number of clock cycles needed to execute several instructions available on all three microprocessors (80C86, 80C286, and 80386SX). This illustrates the dramatic effect of 80 C 286 architectural enhancements on performance when compared to the 80C86 and the lack of similar performance improvement when executing 8086/80286 code on the 80386SX.


FIGURE 2. ARCHITECTURAL COMPARISON

## Hardware System Comparison

## Pipelined Operation on a 16-Bit Data Bus

At a given clock frequency, pipelined address operation increases a system's performance, while simultaneously allowing relatively slower memories and I/O devices to be used. Pipelined address operation provides the system increased address access time, and increased address decoding time.

## 80C286

The 80C286 supports a fully pipelined mode of operation for maximum system performance.
The 80C286 remains in a pipelined mode of operation even when idle bus cycles occur.

## 80386SX

The 80386SX does not support a fully pipelined mode of operation. Some pipelining can be achieved, but to accomplish this, external bus 'monitor' logic must be added to the system.

The 80386SX's pipelining is disrupted by idle bus cycles. A non-pipelined bus cycle, usually with an additional wait state, must be executed before the 80386 SX can return to pipelined mode. Idle bus cycles occur an average of $9 \%$ of the time.

## Idle Cycles

Another factor to consider when evaluating 80 C 286 and 80386SX performance is the effect of idle cycles on pipelined operation. Calculations have shown that, on average, bus idle
cycles occur in the system approximately $9 \%$ of the time. The effect of idle cycles on pipelining is quite different on the 80C286 than on the 80386SX.

The 80C286 pipelined operation is not affected by idle cycles. When an idle cycle or cycles occur in a stream of pipelined bus cycles, the 80 C 286 returns to pipelining bus cycles immediately after the last idle cycle. In this way, each device on the bus (e.g. memory, peripheral) maintains a fixed timing associated with that device, and therefore always uses the minimum number of wait states required for that device.

On the other hand, the 80386SX pipelined operation is disrupted by idle cycles. With the 803865 S , an idle cycle or cycles occurring in a pipelined stream of bus cycles breaks the pipelining operation. Once an idle cycle has occurred, a non-pipelined bus cycle must always be executed prior to resuming pipelining. Since a non-pipelined bus cycle will have different timing than a pipelined bus cycle (even to the same device), an additional wait state must be added to this bus cycle. This not only degrades performance, but requires additional external logic to differentiate between a pipelined bus cycle access, and a non-pipelined bus cycle access, even to the same device with the same address.

From the preceding, it can be seen that when executing 16-bit code, the 80C286 has a 9\% performance increase over the 80386 SX , due to the manner in which each processor handles idle cycles alone.

## Instruction Comparison

The Appendix in this document illustrates a direct comparison of the number of clock cycles needed to execute the same instructions on the 80C286 and the 80386SX. The table includes examples of instruction timing for all instructions available on both processors. Several addressing modes of each instruction type are included.

Of the 182 instruction examples analyzed, 79 of the instructions execute faster on the 80C286 than on the 80386SX; 64 of the instructions analyzed execute in the same number of clock cycles on both processors. This leaves only 39 instructions with improved performance on the 80386SX (See Figure 1). Over $78 \%$ of the instructions analyzed execute as fast or faster on the 80 C 286 than on the 80386SX.

This is vastly different than the previous 8086-to-80286 upgrade. With that upgrade, the 80 C 286 exhibits equal or better performance than the 80C86 with $100 \%$ of the instructions.

This clearly indicates that the 80 C 286 is the processor best suited for executing industry standard 8086 and 80286 code.

The following discussion groups each of the instructions into one of several categories to analyze which applications will benefit from utilizing the 80C286. The categories used are:

- Jumps, Calls, Returns and Loops (Real Mode).
- I/O Instructions.
- Logic, Arithmetic, Data Transfer, Shift and Rotate Instructions.
- Interrupts.
- Miscellaneous Instructions.
- Protected Mode/Multi-Tasking Instructions.


## Jumps, Calls and Loops

In real mode, near calls, jumps, and conditional jumps (transfers within the current code segment) all take the same number of clock cycles to execute on the 80C286 and the 80386SX. Since the segment sizes are larger on the 80386SX, the near transfer instructions on the 80386SX can transfer a greater distance.

The far calls and jumps (transfers that switch to a new code segment; i.e., a code segment context switch) are faster on the 80C286: four clocks and one clock respectively. The far return instruction executes in three less clock cycles on the 80C286, and the near return takes one extra clock cycle. The protected mode calls, jumps, and returns are all faster on the 80C286 and are discussed in the section on Protected Mode.
The loop instruction is three clock cycles faster on the 80C286 than the 80386SX. Thus, the 80C286 would save 300 clock cycles over the 80386 SX if a LOOP instruction were executed 100 times.

| INSTRUCTION | -ADVANTAGE- |  |  |
| :--- | :---: | :---: | :---: |
|  | 80 C 286 | NONE | 803865 X |
| Near JMP and CALL |  | X |  |
| Far CALL, JMP and RET | X |  |  |
| LOOP | X |  |  |

## I/O Instructions

The 80C286 has a significant advantage with the I/O instructions. The IN instruction is almost $21 / 2$ times faster on the 80C286; the 80386SX takes 7 extra clock cycles to execute the same instruction. The OUT instruction is over 3 times faster on the 80C286; again the 80386SX takes 7 extra clock cycles to execute the same instruction. Executing the I/O instructions on the 80386SX is equivalent to executing on the 80C286 with 7 wait states.
The string I/O instructions (INS and OUTS) are also significantly faster on the 80C286. The INS instruction is 10 clock cycles faster on the 80C286, and the OUTS instruction is 9 clock cycles faster. This is particularly important if the string operations are going to be used to input or output a large block of data using the REP prefix. Inputing 100 words of data with the REP INS instruction is 208 clock cycles faster on the 80 C 286 . An even more significant difference can be seen when outputing 100 words with the REP OUTS instruction. In this case, the 80 C 286 is 800 clock cycles faster than the 80386SX.

| INSTRUCTION | -ADVANTAGE- |  |  |
| :--- | :---: | :---: | :---: |
|  | $80 C 286$ | NONE | 80386SX |
| IN | $x$ |  |  |
| OUT | $x$ |  |  |
| INS | $x$ |  |  |
| OUTS | $x$ |  |  |

## Logic, Arithmetic, Data Transfer, Shift and Rotate Instructions

Most forms of the logic, arithmetic, and data transfer instructions execute in the same number of clock cycles on both processors. Certain operand combinations of these instructions (immediate to register for example) take one extra clock cycle to execute on the 80 C 286 .

In real mode, the segment register transfer instructions execute as fast or faster on the 80C286 than they do on the 80386SX. For example, using the POP instruction to transfer data into a segment register is 2 clock cycles faster on the 80C286.
Most of the string manipulation instructions execute in the same number of clock cycles on both processors. The MOVS and STOS instructions are faster on the 80C286.
The divide instruction executes in the same number of clock cycles on both processors. The number of clocks to execute the multiply instruction on the 80386SX is data
dependent; the number of clocks to execute the same instruction on the 80C286 is fixed. On average, the multiply instruction is five clock cycles faster on the 80386SX, but independing on the data, the 80386SX could be as many as 4 clock cycles slower than the 80C286.

The rotate and shift instructions are faster on the 80386SX. Unlike the 80C286, the 80386SX rotate and shift instructions do not depend on the number of bits to be shifted or rotated. Thus, the 80386 SX has the advantage with multibit rotate and shift instructions. The 80C286 does, however, execute single bit rotate and shift instructions faster.

| INSTRUCTION | -ADVANTAGE- |  |  |
| :--- | :---: | :---: | :---: |
|  | $80 C 286$ | NONE | 80386SX |
| Most Logic and Arithmetic |  | X |  |
| Certain Operand <br> Combinations of Logic <br> and Arithmetic |  |  | X |
| Divide |  | X |  |
| Multiply |  |  | X |
| Single Bit Shift or Rotate | X |  |  |
| Multi-Bit Shift or Rotate |  |  | X |
| String Instructions | x |  |  |

## Interrupt Instructions

Interrupts are serviced more quickly on the 80C286. The INT instruction, in real mode, executes 14 cycles faster on the 80C286 than it does on the 80386SX. The INTO, BOUND, and other instructions that can cause an interrupt all benefit from the faster interrupt handling features of the 80C286. The return from interrupt instruction (IRET) is 7 clock cycles faster on the 80C286. The PUSHA and POPA instructions, frequently used by interrupt handling procedures, are both faster on the 80C286. Protected Mode interrupt handling is discussed in the Protected Mode section.

| INSTRUCTION | -ADVANTAGE- |  |  |
| :--- | :---: | :---: | :---: |
|  | $80 C 286$ | NONE | 803865 XX |
| INT $n$ | X |  |  |
| INTO | X |  |  |
| BOUND (If Interrupt) | X |  |  |
| Break Point Interrupt | X |  |  |

## Miscellaneous Instructions

The BCD instructions, HLT, and CBW execute from 1 to 5 clock cycles faster on the 80C286. The instructions to set and clear individual flags and the CWD instruction all execute in the same number of cycles on both processors. The ENTER, LEAVE, and BOUND instructions are from 1 to 3 cycles faster on the 80386SX. The BOUND instruction is only faster if an interrupt is not caused by the instruction.

| INSTRUCTION | -ADVANTAGE- |  |  |
| :--- | :---: | :---: | :---: |
|  | $\mathbf{8 0 C 2 8 6}$ | NONE | $\mathbf{8 0 3 8 6 5 X} \mathrm{X}$ |
| BCD Instructions | X |  |  |
| Data Conversion <br> (CBW, CWD) | X |  |  |
| Flag Settling and Clearing |  | X |  |
| BOUND (If No Interrupt) |  |  | X |

## Protected Mode/Multi-Tasking

When executing 80286 protected mode code, the 80C286 significantly out-performs the 80386SX. Task switching operations execute 100 to 271 clock cycles faster on the 80 C 286 . The instruction to return from a called task is 63 clock cycles faster on the 80C286. This results in a very significant performance increase for systems utilizing the mul-ti-tasking features. The 80C286 is clearly better suited than the 80386 SX for running protected mode operating systems such as OS/2 and Xenix.

Inter-segment JMP, CALL and segment loading instructions also operate faster on the 80 C 286 . The 80 C 286 saves anywhere from 4 to 11 clock cycles depending on the particular inter-segment transfer instruction. In protected mode, the inter-segment return is also faster on the 80 C 286 . The 80 C 286 is 11 clock cycles faster when executing an inter-segment return to the same privilege level and is 17 cycles faster on inter-segment returns to a different privilege level.

The instructions to initialize and check the protected mode registers execute as fast or faster on the 80C286. The IDTR access instructions are an exception to this in that they take one extra clock cycle to execute on the 80C286. The instruction to switch the processor to protected mode (LMSW) is 7 cycles faster on the 80C286.

Most of the 80286 protected mode access checking instructions operate as fast or faster on the 80C286 than on the 80386SX. The LAR instruction is one clock cycle faster on the 80C286 and the LSL instruction is 5 clock cycles faster. The VERW instruction executes in the same speed on both processors and the VERR is 5 cycles faster on the 80386SX. The ARPL instruction used in protected mode procedures for pointer validation is 10 clock cycles faster on the 80C286.

| INSTRUCTION | -ADVANTAGE- |  |  |
| :--- | :---: | :---: | :---: |
|  | $\mathbf{8 0 C 2 8 6}$ | NONE | $\mathbf{8 0 3 8 6 5 X}$ |
| Task Switching | X |  |  |
| Segment Register Loading | X |  |  |
| Inter-Segment Transfer | X |  |  |
| System Register Instructions |  | X |  |
| Inter-Segment Transfers | X |  |  |
| Access Checking <br> Instructions |  | X |  |

## Subroutine Analysis

This section lists several subroutines and then compares the number of clock cycles each subroutine will take to execute on the 80C286 and on the 80386SX.

## EXAMPLE 1

This interrupt routine outputs a character to a terminal via a UART. The AL register must contain the character to be output. The routine first checks the status of the UART to
determine if it is busy. If it is busy, the routine loops until the UART is free; when the UART is free, the character is output. Following is a listing of the code and the clock clycle analysis for the OUT__CHAR routine.
This sample procedure executes about $25 \%$ faster on the 80 C 286 than on the 80386SX. The advantage is realized through the 80C286's faster interrupt handling and faster I/O instructions.

| $\begin{gathered} 80 C 286 \\ \text { CLOCK CYCLES } \end{gathered}$ | 80386SX CLOCK CYCLES | OUT_CHARACTER PROC NEAR |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 3 | 4 |  | PUSHF | ; save callers flags. |
| 3 | 2 |  | PUSHAX | ; save data to be output. |
| 5 | 12 | CK_StATUS: | IN AL, PORT_STATUS | ; Input UART status. |
| 6 | 5 |  | CMP AL, BUSY | ; Check If UART Busy |
| 3/7 | 3/7 |  | JECK_STATUS | ; If busy go check again. |
| 5 | 4 |  | POPAX | ; If not busy restore AX |
| 3 | 10 |  | OUT OUT__PORT, AL | ; and output data. |
| 5 | 5 |  | POPF | ; Restore Flags |
| 17 | 22 |  | IRET | ; Return. |
| 23 | 37 |  | INT x | ; Instruction to initiate OUTCHAR <br> ; Interrupt. |
| 73 | 104 | Total cycles if | not busy. |  |
| 18 | 24 | Number of cyc | ded for each loop while | is busy. |

## EXAMPLE 2

The second example outputs an entire string of characters using the previous interrupt routine (denoted by "INT $x$ " in the code below). The DS:SI registers point to the beginning
of the string to be output. The string is variable in length and must be terminated with the "\$"" character.

| $80 C 286$ <br> CLOCK CYCLES | 80386SX <br> CLOCK CYCLES | OUT_STRING PROC FAR |
| :---: | :---: | :--- | :--- |

To output a string of 20 characters, the 80 C 286 would take 1,899 clock cycles; using the same routine, the 80386SX would take 2,511 cycles. Each time a string of 20 characters is output, the 80 C 286 will save 612 clock cycles; an

80 C 286 performance increase of almost $25 \%$. The advantage is realized through the 80C286's faster interrupt handling, faster I/O instructions, faster FAR transfer instructions and faster register saving and restoring instructions.

## EXAMPLE 3

This example adds all the values of a source array in memory to the values of a destination array in memory. The result is stored in the destination array. Both arrays are assumed to be in the current data segment. The count
(number of words in the array), offset of source array, and offset of destination array are all assumed to be placed on the stack (in that order) by the calling program. The source code for the procedure is listed below:

| $80 C 286$ CLOCK CYCLES | 803865X CLOCK CYCLES |  | ADD_ARRAY PROC NEAR |  |
| :---: | :---: | :---: | :---: | :---: |
| 17 | 18 |  | PUSHA | ; Save caller's registers. |
| 2 | 2 |  | MOV BP, SP | ; Point BP to current stack |
| 5 | 4 |  | MOV CX, [bp+22] | ; Load array size from stack ; into CX. |
| 5 | 4 |  | MOV SI, [bp+20] | ; Load offset of source array ; from stack into SI. |
| 5 | 4 |  | MOV DI, [bp+18] | ; Load offset of destination ; array from stack into DI. |
| 2 | 2 |  | CLD | ; Clear Direction Flag. |
| 5 | 5 | NEXT: | LODSW | ; Load the source word into AX. |
| 7 | 7 |  | ADD [DI], AX | ; Add source to destination. |
| 3 | 2 |  | ADD DI, 02 | ; Point DI to next data. |
| 8/4 | 11 |  | LOOP NEXT | ; Continue to ADD all elements ; in the two arrays. |
| 19 | 24 |  | POPA | ; Restore Registers |
| 11 | 10 |  | RET 6 | ; Near return. |
|  |  | ; Following is the code necessary to set up and call the above procedure. |  |  |
| 5 | 5 |  | PUSH count | ; Put count parameter on stack |
| 3 | 2 |  | PUSH offset S_ARRAY | ; Put offset of source array ; on stack. |
| 3 | 2 |  | PUSH offset D__ARRAY | ; Put offset of destination ; array on stack. |
|  | 7 |  | CALLADD_ARRAY | ; Near Call to initiate ; ADD_ARRAY procedure. |
| $84+(23 * C X)-4$ | $84+(25 * C X)$ | Total number of clocks to start and end routine. |  |  |

Both processors take the same number of clock cycles for initialization before the call and closing up after the call (84). The loop that does the adding is faster on the 80 C 286 . To add two 100 word arrays, the 80 C 286 would take 2,380
clock cycles; the 80386SX takes 2,584 (an additional 204 clocks) to execute the same routine. In this example, the LOOP instruction gives the 80C286 the performance advantage over the 80386SX.

## EXAMPLE 4

This procedure is an example of an operating system procedure developed for a protected mode multi-privilege level system. The procedure INIT__SEGMENT is passed a segment selector on the stack and will load that entire segment with zero's. The procedure is designed to execute at privilege level zero with a call gate at privilege level 3; this
allows procedures executing at any level to utilize the INIT_SEGMENT procedure. INIT__SEGMENT provides protection checks to ensure that the procedure passing the parameter has valid access to the segment that it is trying to initialize. This prevents a procedure at privilege level three from initializing a segment at privilege level zero.

| $\begin{gathered} 80 C 286 \\ \text { CLOCK CYCLES } \end{gathered}$ | $\begin{aligned} & \text { 80386SX } \\ & \text { CLOCK CYCLES } \end{aligned}$ | INIT__SEGMENT PROC FAR WC=1 |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 17 | 18 |  | PUSHA | ; save caller's registers. |
| 3 | 2 |  | PUSHES | ; save ES register. |
| 2 | 2 |  | MOV BP, SP | ; Point BP to top of stack. |
| 5 | 4 |  | MOV AX, [BP+22] | ; Load AX with segment selector ; passed as parameter on stack. |
| 5 | 4 |  | MOV BX, [BP+20] | ; Load BX with return CS to ; determine caller's CPL. |
| 10 | 20 |  | ARPL AX, BX | ; Adjust the Privilege level of ; the segment selector according ; to the caller's CPL. |
| 16 | 16 |  | VERW AX | ; Test for valid write access |
| 3/7 | $3 / 7$ |  | JNE ERROR | ; If no valid access goto error. |
| 17 | 18 |  | MOVES, AX | ; LOAD ES with segment to be ; initialized. |
| 14 | 20 |  | LSLCX, AX | ; Load segment size into CX. |
| 2 | 2 |  | XOR DI, DI | ; Load zero into DI. |
| 2 | 2 |  | XORAX, AX | ; Load zero into AX. |
| 2 | 2 |  | CLD | ; Clear decrement flag. |
| $4+3^{*} c x$ | $5+5^{*}$ cx |  | REP STOSB | ; Init entire segment to 00. |
| 2 | 2 |  | CLC | ; Clear carry to indicate segment ; initialized with no errors. |
| 20 | 21 | DONE: | POPES | ; Restore ES register. |
| 19 | 24 |  | POPA | ; Restore Register |
| 55 | 72 |  | RET 2 | ; Ret FAR to different privilege |
| 2 | 2 | ERROR: | STC | ; SET carry to indicate error. |
| 7 | 7 |  | JMP DONE |  |
|  |  | ; Code to | lector on stack and initiate INIT | EGMENT via call gate. |
| 3 | 2 |  | PUSH DATA _SELECTOR | ; Place Selector on stack. |
| 82 | 98 |  | CALL INIT_SEGMENT__GATE | ; Instruction to initiate <br> ; INIT SEGMENT procedure. |
| 253 | 299 | Total cloc | ROR because segment not acce | sible. |
| 283+(3*S) | $337+(5 * S)$ | Total num in bytes. | locks if segment is initialized to | ros. "S" represents size of segment |

This example shows that when executing instructions used for privilege verification and privilege level transitions the 80C286 is faster than the 80386SX. Without taking the LODS instruction into account, the 80C286 is 54 clock
cycles faster when executing the same procedure. With the LODS instruction, and assuming a segment size of 100 bytes, the 80C286 would execute this routine 254 clock cycles faster than the 80386SX.

## EXAMPLE 5

This Procedure is a task dispatcher that is invoked via an interrupt to cause a task switch to occur. This procedure utilizes a circular linked list of the tasks that need to be executed. A pointer called "CURRENT_TASK" points to the data structure for the current task being executed. The data structure contains the TSS for the task it is describing and a NEXT field that points to the data structure of the next task in the list to be executed. When the Task Dispatcher is invoked it switches the current pointer to the next task in the
list and then invokes the new task by jumping to the TSS for that task. The data structure for the linked list is illustrated below.

The task dispatcher is actually a separate task that is invoked via an interrupt that signals that a new task should be initiated. Following is a listing for the simple task dispatcher.


| $\begin{gathered} 80 C 286 \\ \text { CLOCK CYCLES } \end{gathered}$ | 80386SX CLOCK CYCLES | TASK_DISPATCH PROC FAR |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 5 | 4 | START: | MOV BX, CURRENT TASK + 2 | ; Load BX with contents of next <br> ; field of current TASK. BX will <br> ; contain the address of the data <br> ; structure for next task to run. |
| 3 | 2 |  | MOV CURRENT TASK, BX | ; Update Current Task to point to ; new task to be executed. |
| 178 | 294 |  | JMP DWORD PTR [BX-2] | ; Start new task by jumping to TSS |
| 7 | 7 |  | JMP START | ; JUMP to start for next time the ;TASK dispatcher is invoked. |
| 193 | 307 |  |  |  |

The advantage of the 80 C 286 in this case is in the faster task switch instruction. The task switch instruction is 116 clock cycles faster on the 80C286 than on the 80386SX.

This performance increase makes the 80C286 the clear choice for multi-tasking applications.

## Appendix

This appendix contains a table directly comparing the number of clock cycles necessary to execute all the instructions available on both the 80C286 and the 80386SX. The table includes several addressing modes of each instruction.

The table has five columns. The first column list the instruction being compared. The second column lists the number of clock cycles that the 80 C 286 needs to execute that instruction. The third column lists the number of clock cycles needed by the 80386SX to execute the same
instruction. The fourth column divides the number of cycles needed by the 80386SX by the number of cycles needed by the 80 C 286 . If this figure is greater than one, (see fifth column) then the 80C286 is faster than the 80386SX. For example, a 2.0 would indicate the 80C286 executes the same instruction twice as fast as the 80386SX. A 1.0 indicates that both processors execute the instruction in the same number of cycles. A number less than one indicates the 80386SX is faster than the 80C286.

| $80 C 286$ INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON $80 C 286$ | NUMBER CLOCKS TO EXECUTE ON 80386SX | $\begin{gathered} \text { 80386SX/ } \\ 80 C 286 \end{gathered}$ | 80C286-16 <br> FASTER <br> THAN OR EQUAL TO 80386SX-16 |
| :---: | :---: | :---: | :---: | :---: |
| AAA | 3 | 4 | 1.33 | $\checkmark$ |
| AAD | 14 | 19 | 1.36 | $\checkmark$ |
| AAM | 16 | 17 | 1.06 | $\checkmark$ |
| AAS | 3 | 4 | 1.33 | $\checkmark$ |
| ADC reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| ADC mem, reg | 7 | 7 | 1.00 | $\checkmark$ |
| ADC reg, immed | 3 | 2 | 0.67 |  |
| ADC mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| ADD reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| ADD mem, reg | 7 | 7 | 1.00 | $\checkmark$ |
| ADD reg, immed | 3 | 2 | 0.67 |  |
| ADD mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| AND reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| AND mem, reg | 7 | 7 | 1.00 | $\checkmark$ |
| AND reg, immed | 3 | 2 | 0.67 |  |
| AND mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| ARPL reg, reg | 10 | 20 | 2.00 | $\checkmark$ |
| ARPL mem, reg | 11 | 21 | 1.91 | $\checkmark$ |
| BOUND (no interrupt) | 13 | 10 | 0.77 |  |
| CALL immed (near) | 7 | 7 | 1.00 | $\checkmark$ |
| CALL immed (far real mode) | 13 | 17 | 1.31 | $\checkmark$ |
| CALL immed (far PVAM) | 26 | 42 | 1.61 | $\checkmark$ |
| CALL gate (same privilege PVAM) | 41 | 64 | 1.56 | $\checkmark$ |
| CALL gate (different privilege PVAM) | 82 | 98 | 1.19 | $\checkmark$ |
| CALL TSS (Task Switch PVAM) | 177 | 285 | 1.61 | $\checkmark$ |
| CALL task_gate (Task Switch PVAM) | 182 | 297 | 1.63 | $\checkmark$ |
| CBW | 2 | 3 | 1.50 | $\checkmark$ |
| CLC | 2 | 2 | 1.00 | $\checkmark$ |
| CLD | 2 | 2 | 1.00 | $\checkmark$ |
| CLI | 3 | 8 | 2.67 | $\checkmark$ |
| CLTS | 2 | 5 | 2.50 | $\checkmark$ |
| CMC | 2 | 2 | 1.00 | $\checkmark$ |
| CMP reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| CMP mem, reg | 6 | 5 | 0.83 |  |
| CMP reg, immed | 3 | 2 | 0.67 |  |
| CMP mem, immed | 6 | 5 | 0.83 |  |
| CMPS | 8 | 10 | 1.25 | $\checkmark$ |
| CWD | 2 | 2 | 1.00 | $\checkmark$ |

## Appendix (Continued)

| $80 C 286$ INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON 80C286 | NUMBER CLOCKS TO EXECUTE ON 80386SX | $\begin{aligned} & \text { 80386SX/ } \\ & \text { 80C286 } \end{aligned}$ | $\begin{gathered} \text { 80C286-16 } \\ \text { FASTER } \\ \text { THAN OR } \\ \text { EQUAL TO } \\ \text { 80386SX-16 } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| DAA | 3 | 4 | 1.33 | $\checkmark$ |
| DAS | 3 | 4 | 1.33 | $\checkmark$ |
| DEC reg | 2 | 2 | 1.00 | $\checkmark$ |
| DEC mem | 7 | 6 | 0.86 |  |
| DIV word, reg | 22 | 22 | 1.00 | $\checkmark$ |
| DIV word, mem | 25 | 25 | 1.00 | $\checkmark$ |
| ENTER immed1, immed2 (immed $2=6$ ) | 36 | 57 | 1.58 | $\checkmark$ |
| HLT | 2 | 5 | 2.50 | $\checkmark$ |
| IDIV word, reg | 25 | 27 | 1.08 | $\checkmark$ |
| IMUL word, mem | 24 | 19 | 0.79 |  |
| IN | 5 | 12 | 2.40 | $\checkmark$ |
| INC reg | 2 | 2 | 1.00 | $\checkmark$ |
| INC mem | 7 | 6 | 0.86 |  |
| INS | 5 | 15 | 3.00 | $\checkmark$ |
| INT 3 (real mode) | 23 | 33 | 1.43 | $\checkmark$ |
| INT immed (real mode) | 23 | 37 | 1.61 | $\checkmark$ |
| INT immed (PVAM same privilege) | 40 | 71 | 1.77 | $\checkmark$ |
| INT immed (PVAM different privilege) | 78 | 111 | 1.42 | $\checkmark$ |
| INT TASK_GATE (PVAM Task Switch) | 167 | 438 | 2.62 | $\checkmark$ |
| INTO (No Jump) | 3 | 3 | 1.00 | $\checkmark$ |
| INTO (Yes Jump real mode) | 24 | 35 | 1.46 | $\checkmark$ |
| IRET (real mode) | 17 | 24 | 1.41 | $\checkmark$ |
| IRET (PVAM same privilege) | 31 | 42 | 1.35 | $\checkmark$ |
| IRET (PVAM different privilege) | 55 | 86 | 1.56 | $\checkmark$ |
| IRET (PVAM task switch) | 169 | 285 | 1.68 | $\checkmark$ |
| Jcond label (No jump) | 3 | 3 | 1.00 | $\checkmark$ |
| Jcond label (Yes jump) | 7 | 7 | 1.00 | $\checkmark$ |
| JMP near_label | 7 | 7 | 1.00 | $\checkmark$ |
| JMP Far_label (real mode) | 11 | 12 | 1.09 | $\checkmark$ |
| JMP FAR__LABEL (PVAM) | 23 | 31 | 1.34 | $\checkmark$ |
| JMP CALL_GATE (PVAM same privilege) | 38 | 53 | 1.35 | $\checkmark$ |
| JMP TASK_GATE (PVAM task switch) | 183 | 298 | 1.63 | $\checkmark$ |
| JMP TSS (PVAM task switch) | 178 | 289 | 1.62 | $\checkmark$ |
| LAHF | 2 | 2 | 1.00 | $\checkmark$ |
| LAR reg | 14 | 15 | 1.07 | $\checkmark$ |
| LAR mem | 16 | 16 | 1.00 | $\checkmark$ |
| LDS (real mode) | 7 | 7 | 1.00 | $\checkmark$ |
| LDS (PVAM) | 21 | 23 | 1.33 | $\checkmark$ |
| LEA | 3 | 2 | 0.67 |  |
| LEAVE | 5 | 4 | 0.80 |  |
| LGDT | 11 | 11 | 1.00 | $\checkmark$ |
| LIDT | 12 | 11 | 0.92 |  |
| LLDT reg | 17 | 20 | 1.18 | $\checkmark$ |
| LLDT mem | 19 | 24 | 1.26 | $\checkmark$ |
| LMSW reg | 3 | 10 | 3.33 | $\checkmark$ |
| LMSW mem | 6 | 13 | 2.17 | $\checkmark$ |
| LODS | 5 | 5 | 1.00 | $\checkmark$ |
| LOOP (Jump) | 8 | 11 | 1.38 | $\checkmark$ |
| LOOP (No Jump) | 4 | 11 | 2.75 | $\checkmark$ |

## Appendix (Continued)

| 80 C 286 INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON $80 C 286$ | NUMBER CLOCKS TO EXECUTE ON 80386SX | $\begin{gathered} 803865 X / \\ 80 C 286 \end{gathered}$ | 80C28-16 FASTER THAN OR EQUALTO 80386SX-16 |
| :---: | :---: | :---: | :---: | :---: |
| LSL reg | 14 | 20 | 1.43 | $\checkmark$ |
| LSL mem | 16 | 21 | 1.31 | $\checkmark$ |
| LTR reg | 17 | 23 | 1.35 | $\checkmark$ |
| LTR mem | 19 | 27 | 1.42 | $\checkmark$ |
| MOV reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| MOV mem, reg | 3 | 2 | 0.67 |  |
| MOV reg, immed | 2 | 2 | 1.00 | $\checkmark$ |
| MOV mem, immed | 3 | 2 | 0.67 |  |
| MOV seg__reg, reg (real mode) | 2 | 2 | 1.00 | $\checkmark$ |
| MOV seg_reg, mem (real mode) | 5 | 5 | 1.00 | $\checkmark$ |
| MOV seg__reg, reg (PVAM) | 17 | 22 | 1.29 | $\checkmark$ |
| MOV seg_reg, mem (PVAM) | 19 | 23 | 1.21 | $\checkmark$ |
| MOVS | 5 | 7 | 1.40 | $\checkmark$ |
| MUL reg | 21 | 15 | 0.71 | $\checkmark$ |
| NEG reg | 2 | 2 | 1.00 | $\checkmark$ |
| NEG mem | 7 | 6 | 0.86 |  |
| NOP | 3 | 3 | 1.00 | $\checkmark$ |
| NOT reg | 2 | 2 | 1.00 | $\checkmark$ |
| NOT mem | 7 | 6 | 0.86 |  |
| OR reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| OR mem, reg | 7 | 6 | 0.86 |  |
| OR reg, immed | 3 | 2 | 0.67 |  |
| OR mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| OUT | 3 | 10 | 3.33 | $\checkmark$ |
| OUTS | 5 | 14 | 2.80 | $\checkmark$ |
| POP reg | 5 | 5 | 1.00 | $\checkmark$ |
| POP mem | 5 | 7 | 1.40 | $\checkmark$ |
| POP seg__reg (real mode) | 5 | 7 | 1.40 | $\checkmark$ |
| POP seg_reg (PVAM) | 20 | 25 | 1.25 | $\checkmark$ |
| POPA | 19 | 24 | 1.26 | $\checkmark$ |
| POPF | 5 | 5 | 1.00 | $\checkmark$ |
| PUSH reg | 3 | 2 | 0.67 |  |
| PUSH mem | 5 | 7 | 1.40 | $\checkmark$ |
| PUSH seg__reg | 3 | 2 | 0.67 |  |
| PUSHA | 17 | 18 | 1.06 | $\checkmark$ |
| PUSHF | 3 | 4 | 1.33 | $\checkmark$ |
| RCR or RCL reg, 1 | 2 | 9 | 4.50 | $\checkmark$ |
| RCR or RCL mem, 1 | 7 | 10 | 1.43 | $\checkmark$ |
| RCR or RCL reg, $\mathrm{cl}(\mathrm{cl}=4)$ | 9 | 9 | 1.00 | $\checkmark$ |
| RCR or RCL mem, $\mathrm{cl}(\mathrm{cl}=4)$ | 12 | 10 | 0.83 |  |
| RCR or RCL reg, 4 | 9 | 9 | 1.00 | $\checkmark$ |
| RCR or RCL mem, 4 | 12 | 10 | 0.83 |  |
| ROR or ROL reg, 1 | 2 | 3 | 1.50 | $\checkmark$ |
| ROR or ROL mem, 1 | 7 | 7 | 1.00 | $\checkmark$ |

## Appendix (Continued)

| $80 C 286$ INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON 80C286 | NUMBER CLOCKS TO EXECUTE ON 80386SX | $\begin{gathered} 803865 \times / \\ 80 C 286 \end{gathered}$ | 80C286-16 FASTER THAN OR EQUALTO 80386SX-16 |
| :---: | :---: | :---: | :---: | :---: |
| REP INS ( $\mathrm{cx}=100$ ) | 405 | 613 | 1.51 | $\checkmark$ |
| REP MOVS ( $\mathrm{cx}=100$ ) | 405 | 407 | 1.00 | $\checkmark$ |
| REP OUTS ( $\mathrm{cx}=100$ ) | 405 | 512 | 1.26 | $\checkmark$ |
| REP STOS ( $c x=100$ ) | 304 | 505 | 1.66 | $\checkmark$ |
| REP CMPS ( $\mathrm{cx}=100$ ) | 905 | 905 | 1.00 | $\checkmark$ |
| REPE CMPS ( $\mathrm{N}=100$ ) | 905 | 905 | 1.00 | $\checkmark$ |
| REPESCAS $(\mathrm{N}=100)$ | 805 | 805 | 1.00 | $\checkmark$ |
| RET (near) | 11 | 12 | 1.09 |  |
| RET (far real mode) | 15 | 20 | 1.33 | $\checkmark$ |
| RET (far PVAM same privilege) | 25 | 36 | 1.44 | $\checkmark$ |
| RET (far PVAM different privilege) | 55 | 72 | 1.31 | $\checkmark$ |
| SAHF | 2 | 3 | 1.50 | $\checkmark$ |
| SHIFT reg, 1 (SHIFT = SAL, SAR, SHR ) | 2 | 3 | 1.50 | $\checkmark$ |
| SHIFT mem, 1 | 7 | 7 | 1.00 | $\checkmark$ |
| SBB reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| SBB mem, reg | 7 | 6 | 0.86 |  |
| SBB reg, immed | 3 | 2 | 0.67 |  |
| SBB mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| SCAS | 7 | 7 | 1.00 | $\checkmark$ |
| SGDT | 11 | 9 | 0.82 |  |
| SIDT | 12 | 9 | 0.75 |  |
| SLDT reg | 2 | 2 | 1.00 | $\checkmark$ |
| SLDT mem | 3 | 2 | 0.67 |  |
| SMSW reg | 2 | 2 | 1.00 | $\checkmark$ |
| SMSW mem | 3 | 2 | 0.67 |  |
| STC | 2 | 2 | 1.00 | $\checkmark$ |
| STD | 2 | 2 | 1.00 | $\checkmark$ |
| STI | 2 | 3 | 1.50 | $\checkmark$ |
| STOS | 3 | 4 | 1.33 | $\checkmark$ |
| STR reg | 2 | 22 | 1.00 | $\checkmark$ |
| STR mem | 3 | 2 | 0.67 |  |
| SUB reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| SUB mem, reg | 7 | 7 | 1.00 | $\checkmark$ |
| SUB reg, immed | 3 | 2 | 0.67 |  |
| SUB mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| TEST reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| TEST mem, reg | 6 | 5 | 083 |  |
| TEST reg, immed | 3 | 2 | 0.67 |  |
| TEST mem, immed | 6 | 5 | 0.83 |  |
| VERR reg | 14 | 10 | 0.71 |  |
| VERR mem | 16 | 11 | 0.69 |  |
| VERW reg | 14 | 15 | 1.07 | $\checkmark$ |
| VERW reg | 16 | 16 | 1.00 | $\checkmark$ |

## Appendix (Continued)

| $80 C 286$ INSTRUCTION | NUMBER CLOCKS TO EXECUTE ON 80C286 | NUMBER CLOCKS TO EXECUTE ON 80386SX | $\begin{gathered} \text { 80386SX/ } \\ 80 \mathrm{C} 286 \end{gathered}$ | $\begin{aligned} & \text { 80C286-16 } \\ & \text { FASTER } \\ & \text { THAN OR } \\ & \text { EQUAL TO } \\ & \text { 80386SX-16 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| WAIT | 3 | 6 | 2.00 | $\checkmark$ |
| XCHG reg, reg | 3 | 3 | 1.00 | $\checkmark$ |
| XCHG reg, mem | 5 | 5 | 1.00 | $\checkmark$ |
| XLAT | 5 | 5 | 1.00 | $\checkmark$ |
| XOR reg, reg | 2 | 2 | 1.00 | $\checkmark$ |
| XOR mem, reg | 7 | 6 | 0.86 |  |
| XOR reg, immed | 3 | 2 | 0.67 |  |
| XOR mem, immed | 7 | 7 | 1.00 | $\checkmark$ |
| TOTAL number clocks to execute all instructions AVERAGE | 6894 | 8664 | 1.25 |  |
| Number of Instructions faster on 80C286 |  | 79 |  |  |
| Number of Instructions equal on both processors |  | 64 |  |  |
| Number of Instructions faster on 80386 |  | 39 |  |  |
| Total Number of instructions analyzed |  | 182 |  |  |



# USING THE HS-3282 ARINC BUS INTERFACE CIRCUIT 

Daniel B. Clifton

## Introduction

The Harris HS-3282 is a high performance CMOS programmable bus interface circuit that was designed to meet the requirements of ARINC Specification 429, and similarly encoded, time multiplexed serial data protocols. Its simple but efficient design allows the HS-3282 to be used without major complications in a variety of applications. By setting an internal control register, the HS-3282 can be programmed to operate at different data rates and with different word lengths, and to transmit either even or odd parity. The device can also be programmed to operate with or without a unique address (SDI - source/destination identifier), and with or without its self test mode implemented. Although the HS-3282 was designed to transmit and receive high-speed data rates (100K BPS or 12.5 K BPS), standard baud rates of 9600 or 1200 BPS can be implemented by reducing the input clock frequency. The timing requirements of the HS-3282 make it compatible with 8086 microprocessor or other similarly based systems operating at 5 MHz or less. Designed to meet the critical needs of today's advanced aircraft, the HS-3282 is a cornerstone of reliability for systems that cannot tolerate a wide margin of error.

## Functional Operation of the HS-3282

In order to clarify and expand on the basic details given in the data sheet, the following information has been provided to point out some of the particularities of the HS3282.

## Clock Frequencies

The two receiver output signals, $\overline{D / R 1}$ and $\overline{D / R 2}$, have a minimum pulse width of one clock period. Because of this, when using a slower clock rate than 1 MHz to drive the HS-3282, these outputs may remain in a low state for a few microseconds after the data in the receivers is fetched. This could cause the same data to be fetched more than once if these outputs are used to drive state sensitive interrupt requests; therefore, it is necessary to use edge sensitive interrupt requests, as mentioned in the typical application of the HS-3282 below.

## Bi-Directional Data Bus

Data transfer to and from the host is accomplished via a 16-bit bidirectional, three-stated bus. The control of this bus is completely internal to the HS-3282. When data is written to the transmitter or the control word register, the bus is automatically enabled as an input; when data is read from the receivers, the bus is automatically enabled as an output, at all other tımes, the bus is in a high impedance state and will not interfere with external operations.

## Setting Up the Control Word Register

When a low to high transition occurs on the CWSTR pin, the data on the eleven most significant bits of the bidirectional bus is latched into the control word register. The location and function of each of these bits is shown in the data sheet.

## Receiver Operation

Incoming data from the line receiver (or from the self test circuit) is shifted into the data shift register by the word gap tımer on an edge sensitive basis. This results in a high data rate tolerance; although ARINC specification 429 requires at least a $\pm 1 \%$ tolerance, the HS-3282 has at least a $\pm 10 \%$ tolerance at all data rates. In order to prevent reception errors, the word gap timer is designed to disable and reset the receiver upon reception of two consecutive null times (or two consecutive data times), and re-enable the receiver after four additional null times. If a word of the proper length (and SDI) has been received by this time, the word will be latched and the $\overline{D / R}$ flag of the corresponding receiver will go low to signal the host that a valid word is ready to be fetched. (For the most efficient operation, the $\overline{\mathrm{D} / R}$ flags should be used to generate interrupt requests to the host system.) It should be noted that the parity bit that is stored in the receiver latch may be different than the parity bit of the word that was received. This is because the parity bit that is stored in the receiver latch is actually a parity flag, indicating by its status the parity of the word that was received: if the parity of the word received was odd, the parity flag will be a logic " 0 "; if the parity of the word received was even, the parity flag will be a logic " 1 ".

Once a word is ready to be fetched, it may be read by the host system in two 16-bit parts over the bi-directional bus by strobing the appropriate EN line low twice, once with the SEL line low to read "word 1" and once with the SEL line high to read "word 2". (If preferred, "word 2" may be read before "word 1", or the EN line may be held low for one long pulse while the SEL input is toggled to select first one word and then the other.) The actual ARINC contents of these two 16-bit "words" (or the contents of the 25 bit word length) is shown in the data sheet. It should be noted that the $\overline{D / R}$ flag will not be reset unless both words are read.

## Transmitter Operation

As mentioned in the data sheet, the transmitter has a FIFO that can hold up to eight data words. Although the HS3282 has two inputs, $\overline{P L 1}$ and $\overline{P L 2}$, used to write data into the FIFO, the data is not actually entered into the FIFO until the sscond input ( $\overline{\mathrm{PL} 2}$ ) is pulsed low. Therefore, the first half of each data word must be written to the HS-3282 first. Then, when the PL2 input is pulsed low to write the second half of the word, the proper data will be transferred into the FIFO.

The HS-3282 transmitter is designed to transmit data in sets containing from one to eight 32 or 25 bit words. It is of primary importance that the transmitter FIFO not be disturbed while this transmission is taking place; therefore, systems should be designed to disallow writing to the FIFO while transmission is taking place. The only exception to this rule is that words can be written into the FIFO while the first word (only) is being transmitted; if transmission of a second word is started before the TX/R has returned to a high state, the FIFO must remain undisturbed until the entire transmission sequence is completed and the TX/R flag goes high. The TX/R flag becomes useful here as an interrupt request output to the host system, signaling that the FIFO is ready for another set of data words.

It is also of primary importance that the ENTX input remain high for the duration of the transmission sequence or the integrity of the data in the FIFO will be broken. This can best be accomplished by feeding the TX/R flag through an inverter and back into the ENTX input. This application will enable the transmitter as soon as the first word is written into the FIFO, and keep it enabled until the transmission sequence is completed; since most host systems operate at much greater speeds than the transmitter, an additional seven words could easily be written into the FIFO while the first word is still being transmitted.

The value of the parity bit as written into the FIFO makes no difference since the transmitter sets the parity bit at transmission time according to the type of parity that it has been programmed to transmit.

## Lightning Protection

Although the bus driver has been protected by a 100 mW fuse capable of sinking up to 1A for short periods of time (100ms) and internal zener diodes which saturate at about 8.7 volts, the bus interface circuit has no such protection for its receiver inputs. Because of the possibility of a lighting strike to aircraft, additional protection should be used to protect both the HS-3282 and the bus driver from high voltage spikes. External avalanche diodes with high power ratings (five or ten watts) should be used to clamp the bus at about $\pm 6.8$ volts. This will prevent the fuse and the zeners in the driver from being burned out by current surges, and it will keep the voltage level on the inputs of the receiver within acceptable limits.

## A Typical Application of the HS-3282

The following example shows one possible way to interface the HS-3282 with a host system. Although different applications may require different approaches, most systems will have requirements similar to those that have been met here.

## Logical Control

As shown in Figure 1, the support circuitry necessary to integrate the HS-3282 into a system primarily involves a logic circuit to drive the control inputs. In most cases, this can be achieved using microprocessor $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ bus control signals and two address lines in conjunction with a decoded chip select line and a DEN (data enable) line. During READ operations, the particular function (EN1 or EN2) is selected when the proper address is present while the $\overline{R D}$ line is low; note that the second LSB of the address bus is used to select either word 1 or word 2. The DEN line is used to signal the BIU to place its data on the bus.

Therefore, for read operations, the only timing requirement the host system must meet is a minimum DEN pulse of 200 ns plus the propagation delay of the enable gates. During write operations, the $\overline{\mathrm{WR}}$ line is inverted and used instead of the DEN line to enable the particular function (CWSTR, $\overline{\mathrm{PL} 1}$, or $\overline{\mathrm{PL} 2}$ ) previously selected by the address bus. Since the minimum data hold time of the HS-3282 is Ons, the timing requirement for write operations, besides the minimum 200ns $\overline{W R}$ pulse, is a minimum data disenable delay equal to the total propagation delay caused by the function enable gates.


FIGURE 1. TYPICAL HOST TO HS-3282 INTERFACE LOGIC

## Address Decoding

In the system shown, the transmitter FIFO is decoded as addresses F8 (first word) and FA (second word), and the control word register is at FC; writing to these addresses will load the corresponding registers of the HS-3282. Receiver latch \#1 is at addresses F8 (first word) and FA (second word), and Receiver latch \#2 is at addresses FC (first word) and FE (second word); reading these addresses will load the data from the corresponding receiver latch of the HS-3282. Note that an address line can be connected directly to the SEL input of the HS-3282 to perform the receiver latch word select function. Since it is impossible to write to the receiver latches or to read the transmitter FIFO and the control word register, the addresses of the read functions can overlap the addresses of
the write functions without presenting a problem. See Table 1.

| $\overline{\mathrm{RD}}$ | $\overline{W R}$ | ADDRESS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | F8 | FA | FC | FE |
| 1 | 0 | $\overline{\text { PL1 }}$ | $\overline{\mathrm{PL} 2}$ | CWSTR | CWSTR |
| 0 | 1 | $\begin{aligned} & \overline{\text { EN1 }} \\ & \text { (1st } \\ & \text { word) } \end{aligned}$ | $\begin{aligned} & \overline{E N 1} \\ & \text { (2nd } \\ & \text { word) } \end{aligned}$ | $\begin{aligned} & \text { EN2 } \\ & \text { (1st } \\ & \text { word) } \end{aligned}$ | $\begin{aligned} & \text { EN2 } \\ & \text { (2nd } \\ & \text { word) } \end{aligned}$ |

TABLE 1. TYPICAL HS-3282 FUNCTIONAL DECODING

## Interrupts

For the most efficient operation, any system incorporating the HS-3282 should provide conditions by which the device can generate interrupt requests to the host system. If both receivers are being used, then a minimum of three interrupt vectors are needed: one (TX/R) to signal the end of a data set transmission, and one for each of the receivers ( $\overline{D / R}$ ) to signal the presence of a valid word ready to be fetched. Since the TX/R signal can remain high for indeterminate periods of time while the transmitter is inactive, the requests should be received by the host on an edge sensitive basis.

## Software Requirements

A flowchart of a simple algorithm that the host system could use to exercise and monitor the functions of the HS-3282 is shown in Figure 2. In order to begin, the HS-3282 must be initialized with a control word, then the host should set some flag in system memory to indicate that the transmitter is available. If data is ready to be transmitted, the host should store the data in a temporary buffer until the transmitter becomes available. At this time, the data is taken from the buffer and loaded into the transmitter FIFO (eight 32 bit words maximum). After loading the FIFO, the host should reset the flag in system memory mentioned previously to indicate that the transmitter is no longer available. Unless an interrupt is received by this time, the host can move on to other tasks or continue storing data in the temporary buffer (as shown by the broken arrow). If a $\overline{D / R}$ interrupt is received, data can be read from the receiver latch and any corresponding action taken. If a TX/R interrupt is received, the transmitter available flag should be set once again, and any ready data in the buffer could be written into the FIFO.


FIGURE 2. SIMPLE HS-3282 DRIVER ALGORITHM

## Adapting the HS-3282 to an 8-Bit Data Bus

Although designed for a sixteen bit data bus, the HS-3282 can be used in systems with an eight bit data bus by adding a few external components. The following example shows how this can be done.

## Logical Control

Figure 3 shows the circuitry necessary to integrate the HS-3282 into a system that utilizes an 8 bit data bus. The circuit is very similar to the one in Figure 1, the primary difference being the addition of the logic circuitry necessary to drive two input/output latches. The primary purpose of this additional circuitry is to latch the high order byte of data so that the host system can accomplish each 16 bit data transfer with the HS-3282 by using two separate 8 bit operations. Each of the two latches serves a specific purpose: the output latch provides the HS-3282 with the high order byte during write operations ( $\overline{\mathrm{PL} 1}, \overline{\mathrm{PL} 2}$, and $\overline{\text { CWSTR }}$ ), and the input latch receives the high order byte during read operations (EN1 and EN2). The outputs on
these latches should be three-stated to avoid bus contention. The least significant bit of the address bus is used to activate the latches onto the host system data bus whenever the host system is performing high order byte operations, and this same address bit is inverted and added as an input to each of the function enable gates to prevent the HS-3282 from being activated at the same time. During low order byte operations, the outputs of the function enable gates are used to activate the latches onto the high order byte of the bidirectional bus of the HS-3282, allowing the BIU to instantaneously transfer a full 16 bit word. Since the latches are automatically activated in unison with the BIU during low order byte operations, the high order byte must be handled first during write operations so that the proper data will be present in the output latch when the lower byte is written to the BIU. Conversely, the low order byte must be handled first during read operations since the high order byte is automatically strobed into the input latch when the
low order byte is read. Timing requirements are increased by the additional logic gates; read operations now require a minımum DEN pulse equal to 200 ns plus the propagation delays of two logic gates, a one-shot, and the input latch; write operations now require a minimum delay from address valid to $\overline{W R}$ enable equal to the propagation delays of two gates and a mınımum $\overline{W R}$ pulse of 200ns plus the propagation delays of two gates and the output latch.

Note that one shots are used to drive the strobes on the latches. This is necessary so that the falling edge of the strobe occurs while the data is still active on the bus, otherwise, the propagation delays of the additional gates would cause the latches to close after the data had been disenabled.


FIGURE 3. TYPICAL HOST TO HS-3282 INTERFACE LOGIC USING AN EIGHT BIT DATA BUS

## Address Decoding

The system in Figure 3 will have the same functional addresses as the system in Figure 1 except that in this case each particular byte of each register has its own address. Therefore, the FIFO is still located at addresses

F8 (first word, low byte) and FA (second word, low byte); however, the high bytes must be addressed as F9 (first word) and FB (second word). The receivers are addressed in the same way as shown in Table 2.

|  |  | ADDRESS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathbf{R D}}$ | $\overline{W R}$ | F8 | F9 | FA | FB | FC | FD | FE | FF |
| 1 | 0 | $\overline{\mathrm{PLL}}$ <br> Low Byte | $\overline{\mathrm{PLI}}$ <br> High Byte | $\begin{gathered} \overline{\mathrm{PL2}} \\ \text { Low Byte } \end{gathered}$ | $\begin{gathered} \overline{\text { PL2 }} \\ \text { High Byte } \end{gathered}$ | CWSTR <br> Low Byte | $\begin{aligned} & \overline{\text { CWSTR }} \\ & \text { High Byte } \end{aligned}$ | CWSTR <br> Low Byte | $\begin{aligned} & \overline{\text { CWSTR }} \\ & \text { High Byte } \end{aligned}$ |
| 0 | 1 | $\overline{\text { EN1 }}$ <br> Low Byte 1st Word | $\overline{\mathrm{EN} 1}$ <br> High Byte 1st Word | $\overline{\mathrm{EN} 1}$ <br> Low Byte 2nd Word | $\overline{\mathrm{EN} 1}$ <br> High Byte 2nd Word | $\begin{aligned} & \overline{\mathrm{EN} 2} \\ & \text { Low Byte } \\ & \text { 1st Word } \end{aligned}$ | $\overline{E N 2}$ <br> High Byte 1st Word | EN2 Low Byte 2nd Word | EN2 High Byte 2nd Word |

TABLE 2. TYPICAL HS-3282 FUNCTIONAL DECODING USING AN EIGHT BIT DATA BUS

## Conclusion

Although it was designed for ARINC applications, the HS-3282 bus interface circuit is a very versatile device, capable of serving any type of communications purpose. Its high speed capability and its high reliability make it especially useful in scientific and real time operations
where large volume data gathering and time critical transmission of control signals is required. These qualities, in combination with the simplicity with which the device may be incorporated into a system, make the HS-3282 a wise choice for a wide spectrum of applications.

## ARINC Specification 429 A Brief Overview

ARINC Specification 429, otherwise known as the Mark 33 Digital Information Transfer System (DITS), is a definition of standards used extensively by the air transport industry for the transfer of digital data between avionics systems elements. Systems utilizing this standard have been installed in a wide range of aircraft including the Boeing 737, 747, 757, and 767; the European Airbus; Bell Helicopter; and a large number of small aircraft. Replacing the earlier ARINC Specification 419 which had standardized the various forms of serial transmission developed during the emergent period of digital avionics technology, Specification 429 eliminates much of the previous confusion by defining the standard for a single form of serial transmission.

According to Specification 429, digital data is transmitted via a differential signal over a uni-directional bus composed of two twisted and shielded wires. The data is sent
in thirty-two bit words, each word containing a parity bit and an eight-bit label that defines the flight function to which the remaining data pertains. This data, encoded in either numeric (binary or BCD) or alphabetic (ISO No. 5) format, is further divided into various fields according to label type. In order to completely standardize communication and prevent conflicts, all flight functions have been assigned a particular label and data format.

The ARINC Specification 429, by defining a single standard for the transfer of digital information, eliminates the need for complex interfaces between avionics systems produced by different manufacturers. This provides those avionics components that conform to this standard with a virtual "plug-in" capability, and gives such components a certain measure of universality. For more information about this specification, contact Aeronautical Radio, Inc., 2551 Riva Road, Annapolis, Maryland 21401.


# DESIGN OF CLOCK GENERATORS FOR USE WITH COSMAC MICROPROCESSOR CDP1802 

Author: D. Hillman

## Introduction

Clock signal generation for the CDP1802 COSMAC Microprocessor is simple and straightforward. The CDP1802 features of static operation, single-phase clock input, and the on-chip oscillator amplifier make practical the use of a lowcost, highly stable, crystal-controlled oscillator as its clock generator. The design of external oscillators for this purpose, crystal or RC controlled, is equally straightforward and they require only minimal circuitry. In addition to the oscillator amplifier, the CDP1802 incorporates all necessary start/stop logic on-chip. This application note describes clock generator designs suitable for various applications.

## Crystal Oscillator Design

The basic oscillator circuit for the CDP1802 consists of the on-chip amplifier and an external feedback network as illustrated in Figure1. For oscillation to occur, the gain of the amplifier ( $\alpha$ ) times the attenuation ( $\beta$ ) of the feedback network must be greater than or equal to one. In addition, the total phase shift through the amplifier and feedback network must be equal to $\mathbf{N}$ times 360 degrees, where $\mathbf{N}$ is an integer. Oscillations occur in any system in which the amplified signal is returned in phase to the amplifier after being attuned less than it was originally amplified.


FIGURE 1. BASIC OSCILLATOR CIRCUIT
The frequency stability of an oscillator is primarily dependent
upon the phase-changing properties of the feedback network. Because of their high Q and inherent frequency stability, quartz crystals are commonly used in the feedback network.

A parallel resonant oscillator circuit is shown in Figure 2. The phase angle for the type of feedback network shown in this figure is extremely sensitive to a change in frequency, a condition necessary for stable oscillation. If the equivalent resistance of the crystal is in fact zero (infinite Q), a change in phase angle of the feedback circuit would not cause any change in oscillator frequency. Therefore, for an oscillator of highest stability, the Q of the crystal should be as high as possible. In general, $Q$ increases with increasing frequency.


FIGURE 2. PARALLEL RESONANT OSCILLATOR CIRCUIT
The crystal load capacitance, $C_{L}$, is defined as the series sum of $\mathrm{C}_{1}$ and $\mathrm{C}_{2}$. Higher values of crystal load capacitance generally improve frequency stability, but also increase power consumption. The choice of equivalent load capacitance (usually specified to the crystal suppliers) only fixes the series sum of the two capacitors $\mathrm{C}_{1}$ and $\mathrm{C}_{2}$. The value of
the amplifier output capacitance $\mathrm{C}_{1}$ should not be fixed. A trimmer should be connected in parallel with, or used in place of, a fixed output capacitor to permit compensation for variation in stray capacitance and circuit component values.

The required capacitance range for the oscillator trimmer capacitor is determined by the variation in oscillation frequency with load capacitance. The total trimming range is mainly a function of the crystal characteristics. For a more detailed analysis, see Reference 4.

## Practical Oscillator Circuits

The amplifier, feedback network, and crystal considerations discussed in the preceding paragraphs can be combined for the design of a crystal-controlled oscillator for the CDP1802. The majority of microprocessor applications do not require the frequency of oscillation to be so exact as to require oscillator trimming. An "untrimmed" crystal oscillator will be within $1 \%$ of its specified crystal frequency. For most microprocessor applications the following simple guidelines can be used.

1. The crystal should be connected between terminals 1 and 39 of the CDP1802.
2. For crystal frequencies between 100 KHz and 6.4 MHz , a 10 to 22 megohm feedback resistor should be used in parallel with the crystal.
3. Capacitors $C_{1}$ and $C_{2}$ are not required but a value of between 20 and 30 pF for each is recommended to improve stability.

It should be noted that the on-chip oscillator and timing generator are capable of operating at frequencies higher than the microprocessor maximum operating frequency. For reliable operation, the crystal frequency must always be less than or equal to the maximum operating frequency specified in the CDP1802 data sheet.

A practical example, the CDP18S020 Evaluation Kit oscillator, consists of a 10 megohm feedback resistor and a 2 MHz AT cut crystal, both connected in parallel across terminals 1 and 39 of the CDP1802. (Crystal: Part No. X023303; $\mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$; Series M1; holder, series HC330; made by Turotel, Inc., 13402 S. 71 Highway, Grandview, Missouri 68030.) Provisions for oscillator capacitors are made in the Evaluation Kit, but their use is not required. The increase in oscillator stability with respect to supply voltage that can be obtained by adding the capacitors is shown in Figure 3.


FIGURE 3. STABILITY OF CDP1802 CRYSTAL OSCILLATOR AS A FUNCTION OF LOAD CAPACITANCE VALUE.

The amplifier stability also depends upon the value of the resistor in the feedback network. Figure 4 shows the relationship between the feedback resistor value and oscillator stability. The curve indicates that 10 megohms is an adequate value for the feedback resistor.


FIGURE 4. STABILITY OF CDP1802 CRYSTAL OSCILLATOR as a function of feedback resistance VALUE.

## External Clock Generators

For low-frequency applications (less than 500 KHz ) a costeffective approach may be to use external RC-controlled oscillators. Three simple RC-controlled oscillators that may be used to clock the CDP1802 are shown in Figure 5. When an external clock is used in high-noise environments, a 20 to 30pF capacitor between terminal 39 (XTAL) of the CDP1802 and ground may be used to increase the microprocessor noise immunity.

(a)

(b)

(1/4 CD4093B)
(c)

FIGURE 5. THREE SIMPLE RC-CONTROLLED OSCILLATOR CIRCUITS SUITABLE FOR USE AS EXTERNAL CLOCK FOR CDP1802 MICROPROCESSOR (OUTPUT CONNECTED TO PIN 1 THROUGH EVALUATION KIT P2-W).
(a) INVERTER TYPE OSCILLATOR (SEE REFERENCES 5 AND 6).
(b) RC OSCILLATOR USING DIGITAL IC CD4047A (SEE REFERENCES 5 AND 6).
(c) SCHMITT-TRIGGER-TYPE RC OSCILLATOR (SEE CD4093B DATA SHEET).

The selection of the R and C should be compatible with system requirements. The capacitor should be non-polarized and have low leakage. There is no upper limit for either $\mathbf{R}$ or C values to maintain oscillation. However, C should be larger than the inherent stray capacitance. R must be larger than the output impedance of the COS/MOS device, which is typically hundreds of ohms. In addition, with very large values of R, some short-term instability with respect to time may be noted. Based on these considerations recommended values for these components are:

> C - greater than 100 pF , up to any practical value
> R - greater than 10 kilohms, but less than one megohm

With large values of $R$ and $C$, the circuit in Figure 5(c) can be used. This circuit, because of its hysteresis, eliminates multiple output pulses caused by noise on the input RC waveform. For a more detailed analysis, see References 5 and 6.

## Clock Buffering

In some applications it may be desirable to supply the CPU clock signal to other system components. In such cases the loading on the oscillator circuit should be minimized by buffering the clock through a COS/MOS inverter, as shown in Figure 2. The loading presented by the inverter will be mainly capacitive, about 5 picofarads, and can usually be neglected in non-critical designs. The buffer should be located close to the crystal in order to minimize stray capacitance.
When the crystal oscillator is being trimmed to its desired frequency, the buffered clock technique should also be used to prevent the oscillator from being loaded by the frequency counter.

## References:

1.CDP1802 data sheet.
2. CD4047A data sheet, File No. 623.
3. CD4093B data sheet, File No. 836.
4. "Timekeeping Advances Through COS/MOS Technology", ICAN-6086.
5. "Using the CD4047A in COS/MOS Timing Applications", ICAN-6230.
6. "Astable and Monostable Oscillators Using Harris COS/ MOS Digital Integrated Circuits", ICAN-6267.
7. User Manual for the Harris CDP1802 COSMAC Microprocessor MPM-201.


# USER'S GUIDE TO THE CDP1879 AND CDP1879C1 CMOS REAL-TIME CLOCKS 

Author: D. Derkach

## Introduction

The CDP 1879 and CDP1879C1 Real-Time Clocks ${ }^{1}$ are 24pin devices, each consisting essentially of a long string of counters that supply standard clock time and date information in BCD format, Figure 1. In addition, the CDP1879 features an alarm circuit that activates the interrupt output pin and a separate clock output pin that provides a programmable square-wave output signal. Both the internal-alarm and clock-out signals can trigger the interrupt output pin, so that a status register is available to indicate the interrupt source. Users can supply a signal to the power-down pin that allows the interrupt-output pin level to control external power-down and wake-up circuits. Software generally required by other real-time clocks to prevent clock rollover is eliminated by a transparent "freeze" circuit that assures data integrity when accessing the clock. The clock's counters, plus a control register that regulates operation, are individually selectable using three address lines. Internal control signals governing read and write operations are selected through the I-O/MEM pin, which places the device in a memory-mapped or I/Omapped mode of operation.

The real time clocks were designed using Harris PaCMOS standard-cell approach and are manufactured under a sili-con-gate CMOS process. Both the CDP1879 and CDP1879C1 have guaranteed dc and dynamic parameters that allow operation at temperatures of -40 to $+85^{\circ} \mathrm{C}$ in a plastic package. In addition, both versions can operate in a ceramic package from -55 to $125^{\circ} \mathrm{C}$ (see data sheet ${ }^{1}$ for complete static and dynamic values).

The CDP1879 operates from a supply of 4 to 10.5 volts. It accepts a parallel resonant crystal or will keep time with an external clock source. Crystal frequencies are $1.048576 \mathrm{MHz}, 2.097152 \mathrm{MHz}$, and 4.194304 MHz . The CDP1879C1 is the lower voltage version with an operating voltage range of 4 to 6.5 volts. Like the CDP1879, it also operates with either an external clock source or at the same crystal frequencies. It can also run with a $32,768-\mathrm{Hz}$ crystal.

## Interfacing - Hardware Considerations

 VO-Control and Device-Enable PinsThe real-time clocks, shown in block diagram form in Figure 1, are designed to interface directly to Harris CDP1800series processors (described briefly below). Therefore, pin labels on the clocks, Figure 2, match the pin names of these processors. Figure 3 indicates clock I/O control and direction
pins; the functions of these pins are explained immediately below. Figure 4 is an I/O-control and device-enabled schematic. Table 1 shows I/O pin connections.
TPA (Timing Pulse A) - TPA refers to a timing signal from the CDP1800-series processors that occurs early in the machine cycle, and that is used to latch the processor's multiplexed high-order address. In the real-time clock, this pin carries a strobe input used to latch the value of the CS pin. In memory-mapped operation, the pin may be tied high, requiring that CS be held for the duration of each read or write cycle. When the I/O-mapping mode is selected, this pin must be pulsed when the CS input is high.
CS (Chip Select) - The chip-select pin is an active high input that is used to enable the clock.
I-O/MEM (VO or Memory-Mode Select) - This pin is tied low to place the clock in the memory-mapped mode, and high when I/O operation is desired. Most processors will use the memory-mapped mode of operation.
$\overline{\mathrm{RD}}$ (Read) - When the clock is in the memory-mapped mode, $\overline{\mathrm{RD}}$ is an active low signal that enables data from the counters or status register to be placed on the data bus for the processor to read. When the clock is in the I/O mode, the read operation occurs when $\overline{\mathrm{RD}}$ is high; a write operation occurs when $\overline{R D}$ is low and TPB $\overline{W R}$ is high.
TPB/WR (Timing Pulse B/Write) - TPB refers to a timing signal from the CDP1800-series processors that appears late in each machine cycle and that is used to write data into accessed peripherals. When the clock is in the memorymapped mode, TPB/WR is an active low signal used to write data into the clock's counters or control register. During I/Omapping, a high level on this pin allows data latched on the trailing edge of the signal to be written into the counters or register.

## CD1800-Series Interface

The clocks interface to CDP1800-series processors that use memory-mapping and I/O-mapping techniques to communicate with peripherals and memory. Memory-mapping implies address-line decoding to select memory locations and chip selects. With this technique, the real-time clock's counters and registers are treated as memory locations. Read and write signals are active low. The CDP1800-series processors include three separate N -lines that are active during the 14 I/O instructions. These instructions are memory refer-
enced so that data traveling in either direction is transferred between the peripherals and memory.
When I/O instructions are executed, the memory location is the reference for data transfer. Therefore, when an output instruction is performed (write cycle) the processor's $\overline{\mathrm{RD}}$ line
is activated and puts the data in memory onto the data bus. Late in the same cycle, the TPB from the processor is used to write data into the peripheral. An input instruction (read cycle) allows external data to be placed in memory. The processor's $\overline{W R}$ line is activated, and the data is written in.


FIGURE 1. BLOCK DIAGRAM OF REAL-TIME CLOCK


FIGURE 2. REAL-TIME-CLOCK PIN FUNCTIONS


FIGURE 3. VO CONTROL AND DIRECTION PINS


FIGURE 4. VO-CONTROL AND DEVICE-ENABLE SCHEMATIC

TABLE 1. VO PIN CONNECTIONS

| PROCESSOR | CDP1879 PIN |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TPA | CS | $\overline{\mathrm{RD}}$ | TPB/WR | HEM | A0-A2 |
| Harris CDP1800-series (Memory-mapped) | TPA (Note 1) | Hi or decoded address | $\overline{\text { MRD }}$ | $\overline{M W R}$ | $\mathrm{V}_{\text {ss }}$ | MA0, MA1, MA2 |
| Harris CDP1800-series (I/O mapped) | TPA | $N$ or decoded N lines | $\overline{\text { MRD }}$ | TPB | $V_{D D}$ | N0, N1, N2 |
| CDP6805 | AS | Hi or decoded address | $\mathrm{R} \bar{W}$ | DS | $\mathrm{V}_{\mathrm{DD}}$ | B0(Note 2), B1, B2 |
| Zilog Corp. $\mathrm{Z}-80^{\text {® }}$ | $V_{D D}$ | Hi or decoded address | $\overline{\mathrm{RD}}$ | $\overline{\text { WR }}$ | $V_{\text {ss }}$ | A0, A1, A2 |
| 8085/NSC800 | ALE(Note 1) | Hi or decoded address | $\overline{\mathrm{RD}}$ | $\overline{\mathrm{WR}}$ | $\mathrm{V}_{\text {Ss }}$ | AD0 (Note 2), AD1, AD2 |

1. May be connected to VDD when CS is externally latched.
2. Latch externally.

Figure 5 shows a typical memory-mapped interface utilizing the CDP1802. This interface places the clock and countertimer in selectable 4k memory blocks. Figure 6 shows the
interface of the clock to an 8085 processor, Figure 7 the interface to a CDP6805, and Figure 8 the interface to a Zilog Corporation Z-80 ${ }^{\text {® }}$.


FIGURE 5. REAL-TIME CLOCK AND COUNTER-TIMER IN MEMORY-MAPPED INTERFACE


FIGURE 6. 8085 INTERFACE AND TIMING: (a) MEMORY-MAPPED INTERFACE, (b) VO-MAPPED INTERFACE, (c) TIMING CYCLES


FIGURE 7. CDP6805 VO-MAPPED INTERFACE (a), AND TIMING DIAGRAM (b)


FIGURE 8. ZILOG CORPORATION $\mathbf{Z - 8 0}{ }^{\boldsymbol{*}}$ INTERFACE TO THE CDP1879

## Timing Considerations

Figures 9 and 10 show read and write-cycle timing waveforms, respectively. The read and write limits shown must be observed to successfully access the clock. Three of the characteristics, hold after read and write, and read access time, may represent critical limit values when the clock is interfaced to processors operating at their maximum frequency limit.

| READ CYCLE TIMES (Note1) |  | LIMITS ( ns ) |  |
| :--- | :---: | :---: | :---: |
|  | MINIMUM (Note 2) |  | MAXIMUM |
| Data Access From Address | $\mathrm{t}_{\mathrm{DA}}$ | - | 400 |
| Read Pulse Width | $\mathrm{t}_{\mathrm{RD}}$ | - | - |
| Data Access From Read | $\mathrm{t}_{\mathrm{DR}}$ | 270 | 375 |
| Address Hold After Read | $\mathrm{t}_{\mathrm{RH}}$ | - | - |
| Output Hold After Read | $\mathrm{t}_{\mathrm{DH}}$ | 0 | 230 |
| Chip Select Setup to TPA | $\mathrm{t}_{\mathrm{CS}}$ | 50 | - |

NOTES: 1. Characteristics at $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$; Input $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{4}=10 \mathrm{~ns} ; \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ and 1 TTL load.
2. Time required by a limit device to allow for the indicated function.

(b)

FIGURE 9. READ-CYCLE TIMING CHARACTERISTICS (a), AND WAVEFORMS (b)

## Application Note 7275

| WRITE CYCLE TIMES (Note 1) |  | LIMITS (ns) |  |
| :--- | :---: | :---: | :---: |
|  |  | MINIMUM (Note 2) | MAXIMUM |
| Address Setup to Write | $t_{\text {AS }}$ | 225 | - |
| Write Pulse Width | $\mathrm{t}_{\text {WR }}$ | 150 | - |
| Data Setup to Write | $\mathrm{t}_{\mathrm{OS}}$ | 65 | - |
| Address Hold After Write | $\mathrm{t}_{\text {AH }}$ | 0 | - |
| Data Hold After Write | $\mathrm{t}_{\text {WH }}$ | 150 | - |
| Chip Select Setup to TPA | $\mathrm{t}_{\mathrm{CS}}$ | 50 | - |

## NOTES:

1. Characteristics at $T_{A}=-40$ to $+85^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$; Input $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{4}=10 \mathrm{~ns} ; C L=50 \mathrm{pF}$ and 1 TTL load
2. Time required by a limit device to allow for the indicated function
(a)

(b)

FIGURE 10. WRITE-CYCLE TIMING CHARACTERISTICS (a) AND WAVEFORMS (b)

## Output Hold After Read ( $\mathrm{t}_{\mathrm{dh}}$ )

When multiplexed bus processors, in which address and data share the same pins, are interfaced to the clock, the output-hold-after-read parameter ( 230 nanoseconds) may cause bus contention. As an example, at 5 MHz , the CDP6805 requires data to be off the bus within 160 nanoseconds after data strobe. The 8085A operating with a 6MHz crystal requires 150 nanoseconds after read. Since the clock may hold data for 230 nanoseconds, bus contention may occur if these processors are interfaced to the clock at their maximum operating frequencies.

## Data Hold After Write ( $\mathbf{t w h}_{\text {w }}$ )

The real-time clocks require that data be held after the trailing edge of the write pulse for 150 nanoseconds. Neither the 8085/NSC800, Z-80 ${ }^{\oplus}$, nor CDP6805 meet this requirement at their maximum operating frequencies.

## Data Access From Read ( $\mathrm{t}_{\mathrm{dr}}$ )

The clock will supply data a maximum of 375 nanoseconds from the leading edge of the read pulse. The data set-up requirements for processors operating at their maximum frequencies may require faster access.

## Hold and Access-Time Solutions

All of the above parameters are frequency dependent. Often, simply lowering the frequency when accessing the clock will solve any timing problems. Access times can be extended by inserting wait states. Write and read-hold-time problems are more difficult to correct; glue parts, such as latches and buffers, are required to meet the requirements of these timing parameters.

## Interfacing - Software Considerations

## Programming Model

Figure 11 illustrates the counters, alarm latches, and registers that must be accessed to write in and read out time and date information. The functions are selected through internal decoding of three address lines. Table 2 contains the register access codes for different combinations of address inputs. Figure 12, a programming model of the same registers, shows their read and/or write availability. These address lines and data lines, in conjunction with the I/O control pins, constitute the interface to the clock.

When the clock is configured for memory-mapped operation, it can be considered as six memory locations that reside in
an area of memory determined by the definitive decoding of the upper address bits. The clock's I/O-mapped mode utilizes the N -lines (I/O lines) and I/O instructions of the CDP1800-series processor. The processor's N -lines are decoded for use as a chip select, and in a two-level scheme, are also used as the address input signals.

When other processors are interfaced to the clock, the clock will generally be placed in its memory-mapped mode. An exception is interface with the CDP6805, where the clock is usually wired for I/O operation.

Writing to and reading from the clock is as straightforward as accessing memory. Software considerations regarding clock rollover (when the one-second clock may pulse the counters during read or write cycles) are eliminated by utilizing the freeze circuit (described below), which requires only one additional instruction. Use of the freeze circuit eliminates the software burden of looking for a signal or register bit that guarantees valid data. A write cycle with address 1 and don't -care data before any series of counter accesses (read or write cycles) assures that the one-second clock has been held and will not interfere with accesses for 250 milliseconds.


## FIGURE 11. FUNCTIONS THAT MUST BE ACCESSED TO WRITE IN AND READ OUT TIME AND DATE INFORMATION

## Freeze Circuit

The freeze circuit is designed to allow the user easy access to the real-time clock without the fear that clock rollover will cause erroneous time data. Clock rollover problems occur during counter reads while the asynchronous one-second clock input to the counter-divider chain is ripping through the counters.

As an example. in Figure 13(a), the one-second clock is about to set the time to 0 seconds, 0 minutes and 3 hours. $A$ read is performed, and the hours counter indicates 2 hours.

But before the second and minute counters are read, the one-second clock ripples through them, with the result that the counters hold the time shown in Figure 13(b). When the seconds and minutes counters are read (b), their values are correct, but the hours time, read before the ripple, is 1 hour off. It is apparent that this type of error can be a substantial problem, particularly if the date and month counters are involved.


FIGURE 12. PROGRAMMER'S MODEL OF THE REGISTERS OF FIGURE

## Operation

The counter-series string is clocked by the negative transition of the one-second clock. This clock transition must pass through the freeze circuit before toggling the counter-series string, as shown in Figure 14. The freeze circuit creates a "window" 250 milliseconds wide shown as time (A) in Figure 15. If the counter reads or writes (for addresses other than address 7) are performed during this window, the clock transition is held and is not allowed through the freeze circuit until time (C) Figure 15, when the transition is inserted into the counter series string. If counter accesses are initiated just before the one-second-clock transition, the clock would toggle the counters 250 milliseconds later. Therefore, a requirement when using the real-time clocks is to finish operations within 250 milliseconds of the initial access.
If the clock is accessed during time ( $A$ ), Figure 15, and then accessed again at time (C), when the counter is allowed to toggle, ripple problems would occur. To preclude this problem, a second window is created by the freeze circuit during time (B). This window will allow a write to address 1 to immediately reset the freeze circuit and clock the counters. Subsequent accesses to the real-time clock will occur well after the clock has rippled through the counters.
If read or write operations are performed during time periods other than $(A)$ or $(B)$, the freeze circuit is not functional.

Figure 16 shows a simplified freeze circuit (a), and the sequence of freeze-circuit operation (b).

TABLE 2. REGISTER TRUTH TABLE

| ADDRESS |  |  | ACTIVE SIGNAL |  | BIT 3 CONTROL REGISTER | REGISTER OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A2 | A1 | A0 | TPB/ $\overline{W R}$ | RD |  |  |
| 0 | 1 | 0 | X |  | 0 | Write seconds counter |
| 0 | 1 | 0 |  | X | 0 | Read seconds counter |
| 0 | 1 | 1 | X |  | 0 | Write minutes counter |
| 0 | 1 | 1 |  | X | 0 | Read minutes counter |
| 1 | 0 | 0 | X |  | 0 | Write hours counter |
| 1 | 0 | 0 |  | X | 0 | Read hours counter |
| 1 | 0 | 1 | X |  | 0 | Write date counter |
| 1 | 0 | 1 |  | X | 0 | Read date counter |
| 1 | 1 | 0 | X |  | 0 | Write month counter |
| 1 | 1 | 0 |  | X | 0 | Read month counter |
| 0 | 1 | 0 | X |  | 1 | Write seconds alarm latch |
| 0 | 1 | 1 | X |  | 1 | Write minutes alarm latch |
| 1 | 0 | 0 | X |  | 1 | Write hours alarm latch |
| 1 | 1 | 1 | X |  |  | Write control register |
| 1 | 1 | 1 |  | X |  | Read int. status register |



FIGURE 13. FREEZE-CIRCUIT READ EXAMPLE


FIGURE 14. COUNTER SERIES STRING


FIGURE 15. FREEZE-CIRCUIT TIMING WAVEFORMS


FIGURE 16. SIMPLIFIED FREEZE CIRCUIT (a), AND FREEZE-CIRCUIT OPERATION (b)
NOTES:

1. Set freeze during time period $A$, (one second clock is held high)
2. Reset freeze at time period C ,
3. or during time period B if address 1 is present during a write cycle

## Restrictions on Accuracy

The data sheet for the real-time clock states that when the seconds counter is written to, the last 7 stages of the prescaler are reset, resulting in a 10-millisecond accuracy. Normally, the seconds counter will be clocked 1 second from the time of the write to the seconds counter. However, if the freeze circuit has been activated, this sequence may not occur, therefore, to assure the 10-millisecond accuracy, the following procedure should be used:

1. Write to seconds counter - don't care data - address 2
2. Dummy write - don't care data - address 1
3. Write to seconds counter - valid data - address 2

The mild restrictions on accesses to the real-time clock require no additional software or hardware considerations to assure data integrity. In all other known clocks, software solutions to clock rollover problems range from reading and comparing the time data twice to sampling register values. Hardware solutions vary between stopping any internal clock updates to monitoring output-pin transitions. The addition of an address 1 write operation preceding accesses to the CDP1879 real-time clock in conjunction with the requirements to finish accesses in 250 milliseconds will guarantee stable and accurate time data.

## Register Descriptions

The real-time clock contains a control register to configure its operation, and a status register to identify interrupts, five registers or counters to hold the time from seconds to months, and three additional registers that are referred to as alarm latches, which hold the alarm time.

## Control Register

The control register is a write-only register that shares the same address as the status register, address 7. A brief explanation of the functions of the eight bits in the control register are shown in Figure 17; more detail is given in the paragraphs that follow.

Bits 0 and 1 - Frequency Select - The logic levels in bits 0 and 1 are decoded and used to select the appropriate input to the last 14 stages of the prescaler chain, Figure 18. Their selection must match the crystal or external clock source used to drive the oscillator selection of the real-time clock.

Bit 2 - Start/Stop - As shown in Figure 18, a 1 in bit 2 enables the input to last through 14 stages of the prescaler chain. A zero in this position inhibits counting.


FIGURE 17. CONTROL REGISTER


FIGURE 18. FREQUENCY-SELECT OPERATION

Bit 3 - Counter/Latch Control - Figure 19 is a simplified diagram of the counter/alarm latch access. Bit 3 has two functions. First, if set to zero, it directs written data to the time counters. If set to 1 , data is written into the alarm latches. This bit function is necessary because the time counters and their comparable alarm latches have the same addresses. The second function of bit 3 is to enable the alarm-out signal. An alarm signal (interrupt output low and bit 7 set in the status register) will only appear if this bit (bit 3 ) is a logic 1 .

Bits 4, 5, 6 and 7 - Clock Select - Figure 20 is a block diagram of the clock-out select function; Figure 21 is a table of
clock-out selections. Bits $4,5,6$, and 7 are decoded, and enable the required prescaler or time counter output to toggle the clock-out pin.

## Status Register

The status register, Figure 22, is used to indicate the interrupt source. Bits 0 through 5 are held low. Bit 6 high indicates that a programmed negative clock-out transition has occurred, and bit 7 high identifies the alarm circuit as the interrupt source. These bits are reset by an external reset or by writing to the control register. Note, in Figure 23, the delay of approximately 30 microseconds before the alarm signal sets bit 7 .


FIGURE 19. SIMPLIFIED DIAGRAM OF COUNTER/ALARM LATCH ACCESS.


FIGURE 20. BLOCK DIAGRAM, CLOCK-OUT SELECT


FIGURE 21. CLOCK-OUT SELECTIONS


FIGURE 22. STATUS REGISTER


FIGURE 23. DEBOUNCE WAVEFORMS

## Operating Sequence

Although accessing of the clock is similar to accessing of memory, certain procedures should be followed when writing the data to assure correct operation.

The control register is accessed first to set the operating characteristics and to direct subsequent accesses to the counters or alarm latches. The upper nibble of the controlregister byte selects one of 15 square-wave output signals that appear at the clock-out pin. If a clock-out is selected before the time counters are accessed and loaded, an inadvertent interrupt may be generated. To preclude this occurrence when the interrupt signal is utilized, the upper nibble of the control register byte is set to zero during the initial con-trol-register write cycle. The time counters and/or alarm latches are then loaded. The control register is then written to again, and the value in the upper nibble selects the required clock.

## Data Format Required (BCD)

1. Seconds and Minutes counters and alarm latches 00 to 59
2. Hours counter: 01 to 12 for AM/PM

00 to 23 for 24-hour time
Bit 7: $0=A M, 1=P M$
Bit 6: $0=24$ hour, $1=12$ hour
Hour alarm latch: 01 to 12 for AM/PM, 00 to 23 for 24 hour.

12 hour (AM/PM): Bit 7: $0=A M, 1=P M$
If the time counter is set for 24 -hour time, bit 7 is don't care.
3. Day-of-month counter: 01 to $28,29,30$ or 31.
4. Month counter: Jan. $=1$, Dec. $=12$

Bit 7: $0=$ No leap year, $1=$ leap year

## Setting the Time

The time counters, from seconds to months, are accessed and written into using the procedure described below. Data entered is in BCD format. For example, 12 seconds in the
seconds counter would be represented as 00010010. The hours counter, however, utilizes its upper bits for AM/PM designation and 12/24-hour selection. Moreover, bit 7 in the months counter is set by the user to indicate leap year. All of these bits must be set as required in addition to the BCD hour and month information. For example, if 4 PM is written to the hours counter, a BCD code of 00000100 for the hours plus a 1 in bits 6 and 7 to enable PM and 12-hour operation would require a data byte of 11000100 (Hex C4).

## Procedure to Set the Time

1. Chip selected and address 7 present on the address lines to access the control register.
2. Write to control register with the required data byte. Bit 3 must be set to zero.
3. Use addresses 2 to 6 to access seconds-to-months counters, in any order, and load appropriate data byte. (BCD data plus bits 6 and 7 in hours counter and bit 7 in month counter.)
4. Writing to the seconds counter resets the last 7 stages of the prescaler, thereby setting an accuracy of 10 milliseconds.

## Setting the Alarm

Figure 24 shows the alarm logic. As previously described, bit 3 in the control register must be a 1 to direct subsequent data to the alarm latches. A comparator circuit compares the time and alarm latch seconds, minutes, and hour outputs. When this comparison is true and bit 3 in the control register is set to 1 , an alarm is generated that activates the interruptout pin and sets bit 7 in the status register to a high logic level. The two most significant bits in the hours time counter are used for an AM/PM indication (User set for AM or PM with subsequent toggling every 12 hours) and to set 12/24out operation.

If bit 6 , the $12 / 24$-hour control bit, is set to zero (24-hours), a match of bit 7 (AM/PM) between the hours time counter and alarm latch is not required to generate a true comparison.


FIGURE 24. ALARM LOGIC

When an alarm occurs, there is a delay of 30 microseconds before the alarm bit is set in the status register. The inter-rupt-out pin signal is also delayed for this period. Additionally, if a clock out was selected that also activates the interrupt-out in coincidence with the alarm-out signal (for example, clock-out set for one second and any alarm-time set), the status register will indicate a clock-out transition (bit $6=1$ ) 30 microseconds before bit 7 is set to 1 in the status register.

## Resetting the Interrupt-Out Signal and Status Register

There are two methods of resetting the interrupt-out signal and status register once an alarm or clock-out transition has occurred.

## Reset Pin (Schmitt Input)

A low on the reset pin will accomplish the following:

1. Set the interrupt-out pin high.
2. Clear the status register.
3. Place $\mathbf{3 0}$ Hex in the hour alarm latch. This entry will prevent an inadvertent interrupt when programming the time.

## Control Register Write

Writing to the control register sets the interrupt-out high and clears the status register.

## Power-Down Operation

Figure 25 shows power-down input-control logic. A low on the power-down pin (Schmitt input) activates the real-timeclock's power-down function. This function is enabled at the trailing edge of a read or write signal and, therefore, power down will not occur until the read or write cycle is concluded.

When power down is activated, the following events occur:

1. Read and write control signals and disabled.
2. The data bus is placed in an input condition and logic transitions are ignored. (Therefore, the bus must be terminated.)
3. The clock-out signal is set low.
4. The interrupt-out pin is tri-stated.

The clock continues to keep time and there is no appreciable
change in operating power. The interrupt output will go low if an alarm or clock transition (internal clock transition) occurs after power down has been initiated. An application using the power-down feature to control a microprocessor's clock signal is illustrated in Figure 26. This application is especially appealing in a CMOS circuit design where only quiescent current will be drawn when the processor's clock input is disabled.


FIGURE 25. POWER-DOWN INPUT-CONTROL LOGIC
In an operational sequence utilizing the circuitry of Figure 26, the serial Q output of the CPU is activated after the clock is configured with an alarm time. The oscillator then stops and the device enters the power-down mode. When the alarm activates and the INT output is set low, the CPU resets and polls the EF1 flag to determine whether a cold or warm start routine is in order. The control register is then written to, an event that resets the interrupt requests.

Any general-purpose microprocessor can utilize the low operating power of the real-time clock. Typical operating current with a crystal-controlled oscillator at 32 kHz and 5 V is 100 microamperes, and at $4 \mathrm{MHz}, 600$ microamperes. The trade-off between high frequency and accuracy and low-frequency operation with lower power consumption must be resolved by the user. The ease of programming and the features offered by the real-time clock aid the designer and lower the level of programmed support required.


FIGURE 26. APPLICATION OF REAL-TIME CLOCK THAT USES POWER-DOWN FEATURE TO CONTROL A MICROPROCESSOR'S CLOCK SIGNAL

## Power Considerations

The CDP1879 power requirements are shown in Table 3. The values listed are maximum limits with a $V_{D D}$ of $\pm 5 \%$ and a temperature range of -40 to $85^{\circ} \mathrm{C}$.

Table 4 shows output drive capabilities under the same conditions. All inputs must meet CMOS requirements with a minimum high of 3.5 V and a maximum low of 1.5 V at a VDD of 5 V .

## Standby Operation (Low Voltage)

When utilizing an external crystal with its on-board oscillator as the frequency source, the CDP1879 and CDP1879C1 can operate at a supply voltage no lower than 4 volts. However, if a $32-\mathrm{kHz}$ external frequency source is provided at the XTAL input pin, the clock can operate in a standby mode down to 2.5 volts at 0 to $70^{\circ} \mathrm{C}$, and 3 volts at -40 to $+85^{\circ} \mathrm{C}$. Figure 27 shows the typical minimum standby voltage. Figure 28 shows that the real-time clock must be disabled by CS (chip-select signal) a minimum of 2 microseconds before reaching the standby voltage level, and enabled again after the same period of time then the voltage is raised again.
When the clock is in the standby mode, it functions only as a timekeeping device; all read/write data accesses are disallowed.

TABLE 3. POWER REQUIREMENTS OF THE REAL-TIME CLOCK

| MODE |  | POWER-SUPPLY VOLTAGE |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  | (NPUT FREQUENCY | 5 V | 10 V |  |
| Operating current with |  | - | milliamperes |  |
| crystal oscillator | 1 MHz | 0.25 | 3.0 |  |
|  | 2 MHz | 0.5 | 3.5 |  |
| Operating current with | 4 MHz | 0.6 | 5.0 | milliamperes |
| external clock source | 32 kHz | 0.8 | 0.25 |  |
|  | 1 MHz | 0.15 | 2.0 |  |
|  | 2 MHz | 1.0 | 4.0 |  |

*CDP1879C1 only

TABLE 4. OUTPUT DRIVE CAPABILITIES

| POWER-SUPPLY VOLTAGE | 5 V | 10 V | UNITS |
| :--- | :---: | :---: | :---: |
| Data-but and interrupt-out drive |  |  | milliamperes |
| (Sink) | 1.8 | 3.6 |  |
| (Source) | -1.10 | -2.6 |  |
| Clock Out (Sink) | 0.6 | 1.2 | milliamperes |
| (Source) | -1.1 | -2.6 |  |



FIGURE 27. TYPICAL MINIMUM STANDBY VOLTAGE

## Oscillator Operation

The CDP1879 operates with a crystal connected to its XTAL and XTAL inputs, or accepts an external clock source at its XTAL input that has a rise and fall time of less that 10 microseconds. Typical oscillator parameters are listed in Table 5; suggested circuits are described in Figures 29 through 32.


Standby Characteristics - Full Standby Temperature Range

| CHARACTERISTIC | $\mathrm{V}_{\mathrm{DD}}$ | $\begin{gathered} \mathbf{v} \\ \text { (STBY) } \end{gathered}$ | CDP1879 |  | CDP1879C1 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX |  |
| Chip deselect to stby voltage time $\mathrm{t}_{\text {(STBY) }}$ | 5 | 2.5, 3 | 2 | - | 2 | - | $\mu \mathrm{s}$ |
|  | 10 | 2.5, 3 | 1 | - | - | $\cdot$ |  |
| Recovery to normal operation time $\mathrm{t}_{\text {RC }}$ | 5 | 2.5, 3 | 2 | - | 2 | - |  |
|  | 10 | 2.5, 3 | 1 | - | - | - |  |

(b)

FIGURE 28. STANDBY-VOLTAGE WAVEFORMS AND TIMING DIAGRAM (a), AND CHARACTERISTICS (b).


FIGURE 29. CONNECTIONS FOR CDP1879 WHEN AN EXTERNAL FREQUENCY SIGNAL IS SUPPLIED

CDP1879


FIGURE 31. SUGGESTED OSCILLATOR CIRCUIT FOR 1, 2, OR 4-MHz OPERATION


FIGURE 30. SUGGESTED OSCILLATOR CIRCUIT FOR 32 kHz CRYSTAL OPERATION


FIGURE 32. TYPICAL EXTERNAL-CLOCK-SOURCE DIAGRAM

## Design Considerations for a Stable Crystal Oscillator

1. Stray capacitance should be minimized for best oscillator performance. Circuit-board traces connected to the oscillator pins should be kept to a maximum of 1 inch , and there should be no parallel traces.
2. A signal or power-source line must not cross or approach the oscillator-circuit line.
3. It is advisable to put a nonelectrolytic 0.1-microfarad capacitor between $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$ of the CDP1879.

## Real-Time-Clock System

Figure 33 illustrates a working system in which the CDP1879 is configured for I/O operation to display time in minutes and hours. Figure 34 shows the real-time-clock flowchart. A CDP1802 processor outputs instructions and data in a twolevel device-selection scheme. An output instruction of OUT 1 (Hex 61) activates the processors N lines, and is decoded by the CDP1873C to provide a chip-select signal to the CDP1875C output port. The data present on the data bus during the output instruction is latched in the CDP1875C and provides the chip-select signal for the clock or the CD22105A LCD driver.

If no other OUT 1 instruction with different bus data is issued by the processor, the device will remain selected. Subsequent output and input instructions will then address the clock, if it is selected, to read or write to its registers. When the LCD driver is selected, the processor's OUT 2 instructions load the driver with the display information.
The backplane signal from the LCD driver is input to one of the processor's flag lines, and is sampled to flash the colon by placing the colon input, via the processor's $Q$ line, in or out of phase with the backplane signal. The CDP1879's clock-out signal is set for one second, and drives the processor's interrupt to turn the display colon off. A routine in the main program turns the colon on when the interrupt is not present.

A sample program that illustrates the CDP1879's clock-out signal and alarm capability is listed in Figure 35. The alarm routine is written to flash eights when the alarm activates. The clock will continue to keep time and will display it along with the alarm display.

## Reference

"CMOS Real-Time Clock," CDP1879/CDP1879C-1, Harris Data Sheet, File No. 1360

TABLE 5. TYPICAL OSCILLATOR-CIRCUIT PARAMETERS FOR SUGGESTED OSCILLATOR CIRCUITS

| PARAMETER |  | OSCILLATOR FREQUENCY |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | 2.097 MHz | 1.049 MHz | $32768 \mathrm{~Hz}^{*}$ |  |
| $\mathrm{R}_{\mathrm{f}}$ | 22 | 22 | 22 | 22 | megohms |
| $\mathrm{C}_{\mathrm{O}}$ | 39 | 39 | 39 | 39 | pF |
| $\mathrm{C}_{\mathrm{I}}$ | 5 | 5 | 5 | 5 | pF |
| $\mathrm{R}_{\mathrm{S}}$ | - | - | - | 200 | kilohms |
| $\mathrm{C}_{\mathrm{L}}$ | - | - | - | 91 | pF |
| Crystal Impedance | 73 | 200 | 200 | 50 K (max.) | ohms |

*CDP1879C1 Only


FIGURE 33. REAL-TIME CLOCK SYSTEM


FIGURE 34. REAL-TIME-CLOCK FLOWCHART


FIGURE 35. REAL-TIME-CLOCK PROGRAM


No. 7374

# Harris Digital 

# THE CDP1871A KEYBOARD ENCODER 

Author: D. Derkach

The CDP1871A Keyboard Encoder ${ }^{1}$ interfaces directly between a CDP1800-series (or other) processor and a mechanical keyboard array. It services up to 53 ASCII-coded keys and up to 32 Hex-coded keys. This note describes the encoder's operation, explains its dynamic electrical characteristics, and features those factors that will affect device operation when the encoder is used with a non-1800-series processor.

## Operation

The CDP1871A is made up of two major sections: the counter/scan-selection logic and the control logic. Figure 1 shows a block diagram of the device, Figure 2 the terminal diagram, and Figure 3 the control schematic; the Appendix contains operational information as well as recommended operating conditions and electrical characteristics.
The counter and scan-selection logic scans the keyboard array using the drive lines (D1-D11) and the sense lines (S1-S8). The outputs of the internal five stage scan counter
are conditionally encoded by the ALPHA, SHIFT, and CONTROL inputs, Appendix Table A-1, and are used to drive the D1 - D11 output lines high, one at a time. Each D1 - D11 output may drive up to eight keys, which are sampled by the sense-line inputs ( $\mathrm{S} 1-\mathrm{S} 8$ ). The $\mathrm{S} 1-\mathrm{S} 8$ inputs are enabled by the internal three stage scan counter.
The control logic interfaces with the CDP1800-series I/O and timing signals to establish timing and status conditions for the CDP1871A.
The TPB input clocks the scan counters, and is also used to reset the data available output ( $\overline{\mathrm{DA}}$ ). When a valid keydown condition is detected on a sense line, the control logic inhibits the clock to the scan counters on the next low-tohigh transition of TPB, and the $\overline{D A}$ output is set low. The scan-counter outputs (C1 - C8) represent the ASCII and HEX key codes (Appendix Table A-2), and are used to drive the BUS 0 - BUS 7 outputs, which interface directly to the CDP1800-series data bus.


Copyright © Harris Corporation 1992

The BUS 0-BUS 7 outputs, which are normally tristated, are enabled by decoding the CS inputs during a CPU input instruction. The low-to-high transition of TPB during the input instruction resets the $\overline{D A}$ output high. Once the $\overline{D A}$ output has been reset, it cannot go low again until the present key is released and a new keydown condition is detected. (This arrangement prevents unwanted repeated keycode outputs, which may be caused by fast software routines.)
After the depressed key is released and the debounce delay (determined by $\mathrm{R}_{\mathrm{X}}, \mathrm{C}_{\mathrm{X}}$ ) has occurred, the scan clock inhibit is removed, allowing the scan counters to advance on the following high-to-low transitions of TPB. This condition provides an N-key lockout feature, which prevents the entry of erroneous codes when two or more keys are pressed simultaneously. The first key pressed in the scanning order is recognized, while all other keys pressed are ignored until the first key is released and read by the CPU, at which time the next key pressed in the scanning order is detected.
If the first key remains closed after the CPU reads the data and resets the $\overline{D A}$ output (on the low-to-high transition of the TPB), an auxiliary signal ( $\overline{R P T}$ ) is generated. This signal is available to the CPU, and indicates an auto-repeat condition. The $\overline{\text { RPT }}$ output is reset high at the end of the debounce delay after the depressed key is released.
The debounce input (pin 36) provides a terminal connection for an external user-selected RC circuit designed to eliminate detection of a keydown condition caused by keyboard noise. The operation of the debounce circuit is explained below with the aid of Figures 1 and 3.

When a valid keydown is detected, the on chip active-resistor device $\left(R_{N}\right)$ is enabled, and the external capacitor $\left(C_{X}\right)$ is discharged, providing a key closure debounce time of approximately $R_{N} C_{x}$. The discharge of $C_{x}$ is sensed by the Schmitt trigger inverter, which clocks the $\overline{D A}$ flip-flop (latching the $\overline{D A}$ output low and inhibiting the scan clock). (The DA flip-flop is reset by the low-to-high transition of TPB when the CS inputs are enabled.)
When a valid key release is detected, $R_{N}$ is disabled and $C_{X}$ begins charging through the external resistor ( $R_{X}$ ), providing a key release debounce time of approximately $R_{x} C_{x}$. The change in charge is, again, sensed by the Schmitt trigger inverter, enabling the scan clock to continue on the next high-to-low transitions of TPB, after the current keycode data is read by the CPU.

## Functions of Terminals

## D1-D11 (Outputs)

Drive lines for the $11 \times 8$ keyboard switch matrix. These outputs are connected through the external switch matrix to the sense lines (S1-S8).

## S1-S8 (Inputs)

Sense lines for the $11 \times 8$ keyboard matrix. These inputs have internal pull-down resistors, and are driven high by the drive line when a keyboard switch is closed.

## CS1, CS2, CS3, CS4 (Inputs)

Chip-select inputs, which are used to enable the tristate data bus outputs (BUS 0 - BUS 7), and to enable the resetting of the status flag ( $\overline{\mathrm{DA}})$ on the low-to-high transition of TPB.

These four inputs are normally connected to the N -lines (NO - N2) and MRD output of the CDP1800-series microprocessor.

## BUS 0 - BUS 7 (Outputs)

Tristate data bus outputs that provide the ASCII and HEX codes of the detected keys. The outputs are normally connected to the BUS 0 - BUS 7 terminals of the CDP1800-series microprocessor.

## $\overline{D A}$ (Output)

The data available output flag, which is set low when a valid key closure is detected. It is reset high by the low-to-high transition of TPB when data is read from the CDP1871A. This output is normally connected to a flag input (EF1 - $\overline{\mathrm{EF}} 4$ ) of the CDP1800-series microprocessor.

## TPB (Input)

The input clock used to drive the scan generator and reset the status flag ( $\overline{\mathrm{DA}}$ ). This input is normally connected to the TPB output of the CDP1800-series microprocessor.
RPT (Output)
The repeat-output flag used to indicate that a key is still closed after data has been read from the CDP1871A ( $\overline{\mathrm{DA}}$ high). It remains low as long as the key is closed, and is used for an autorepeat function, under CPU control. This output is normally connected to a flag input (EF1 - EF4) of the CDP1800-series microprocessor.

## Debounce (Input)

This input is connected to the junction of an external resistor to $\mathrm{V}_{\mathrm{DD}}$ and an external capacitor to $\mathrm{V}_{\mathrm{SS}}$. It provides a debounce time delay $(t=R C)$ after the release of a key. The external pull-up resistor is required under all circumstances.

## Alpha, Shift, Control (Inputs)

A high on the shift or control input will be internally latched (after the debounce time), and the drive and sense line decoding will be modified as shown in Appendix Table A-1. These inputs are normally connected to the keyboard, but produce no code by themselves. The shift and control inputs have internal pull-down resistors to simplify use with momentary-contact switches. The alpha input is not latched and is designed to provide an alpha-lock function when used with a standard SPDT switch. When alpha $=1$, the drive and sense line decoding will be modified as shown in Appendix Table A-1.
$\mathbf{V}_{\mathrm{DD}}, \mathbf{V}_{\mathrm{SS}}$
$V_{D D}$ is the positive supply voltage input. $V_{S S}$ is the most negative supply voltage terminal, and is normally connected to ground. All outputs swing from $V_{S S}$ to $V_{D D}$. The recommended input-voltage swing is also from $V_{S S}$ to $V_{D D}$ -
Figure 4 shows a CDP1800-series processor operating in its I/O mapped mode with the keyboard encoder. CDP1800-series processors have fourteen I/O instructions and three dedicated output lines (NO - N2) that are used for I/O functions. The N lines are toggled when the I/O instructions are used; otherwise, they remain at a low level.
Unlike memory-mapping, when the processor outputs and inputs data, the memory is the source of the system data when the input or output instructions are executed.


FIGURE 3. CDP1871A CONTROL SCHEMATIC


FIGURE 4. TYPICAL CDP1800-SERIES MICROPROCESSOR SYSTEM USING THE CDP1871A

For example, an input instruction writes data to the memory and the processor; therefore, the read line remains high while the write line goes low. An output instruction outputs data from the memory. In this case, the read line goes low and the write line remains high.
An important input to the encoder is the TPB signal. This timing signal occurs at the end of the machine cycle of a CDP1800-series processor and is used to clock the encoder's scan counter. It also resets the data available
signal when the encoder is selected. It is synchronous in that it must not toggle when the chip is selected and data is being read from the encoder.
The TPB signal is used to strobe data into a peripheral. Note in Figure 4 that the read line is used in addition to the $N$ lines to select the encode; therefore, the only time the encoder will drive the data bus is when the proper input instruction is executed. The encoder is not selected until the N lines are at the required levels and the read line is high. When a key


- CS $=\overline{\operatorname{CS1}} \cdot \operatorname{Cs} 2 \cdot \operatorname{Cs} 3 \cdot \operatorname{Cs} 4$

FIGURE 5. CDP1871A DYNAMIC TIMING DIAGRAM (NON-REPEAT)


FIGURE 6. CDP1871A DYNAMIC TIMING DIAGRAM (REPEAT)
closure is detected by the CDP1871A, the data available signal is activated; the processor is alerted by sensing its EF flag input. The processor then performs an input instruction to capture the key data.

## Dynamic Electrical Characteristics

The dynamic electrical characteristics of the CDP1871A are shown in Table 1, and the timing diagrams in Figure 5. The clock cycle time, the first entry, A, Table 1, and curve 1 in the timing diagram of Figure 5, TPB, define the high and low limits of the clock cycle as $\mathrm{t}_{\mathrm{CC}}+\mathrm{t}_{\mathrm{CWH}}+\mathrm{t}_{\mathrm{CWL}}$. TPB must remain high for at least 100 nanoseconds (B). The low portion of the clock cycle ( $\mathrm{t}_{\mathrm{CWL}}$ ) consists of $\mathrm{t}_{\mathrm{CD}}{ }^{1}(\mathrm{E})$ and the keyboard capacitance. This parameter is selected to allow the TPB clock pulse time to ripple through the scan counters. The maximum frequency of TPB is 400 kHz at 5 volts $V_{D D}$ and 800 kHz at 10 volts $\mathrm{V}_{\mathrm{DD}}$ -
Table parameters $C$ and $D$ and curve 3 define the data available valid and invalid (reset) delays. The delays are measured from the leading edge of the TPB signal. The valid delay signal is activated on the first TPB signal after the leading edge debounce time when a key closure is detected, and returns high when the encoder is selected on the low-tohigh transition of TPB. The valid data out delay and hold
times from chip select are shown in table entries F, G and curve 8. The final parameters, H and J , refer to the repeat signal set and reset level delays measured from the leading edge of the TPB; curve 10, Figure 6.
Note in Figure 5 that the action starts when a key closure is sensed by the encoder; curve 2. On the next low-to-high transition of TPB, the debounce time of $R_{N} C_{X}$ occurs as $C_{X}$ discharges through the transistor and the Schmitt trigger clocks the data available flip-flop; curve 3 . The $R_{N}$ value of the transistor is about 200 ohms, so that, with an external capacitor of 0.1 micro farads, a 20 microsecond delay can be expected. The key release trailing edge debounce time is calculated from the values of the external capacitor and resistor ( $R_{X}, C_{X}$ ). With a 0.1 microfarad capacitor and a 100 kilohm resistor, the debounce time will be 10 milliseconds.

Once the data available signal has been reset (chip selected and TPB high), the scan counter operates again on the next trailing edge of TPB, curve 6, and table parameter E. Note in Figure 6 that the repeat signal is activated when the data available signal is reset high while the key is still closed; curves 9 and 10. The repeat signal is reset after the debounce time on the next leading edge of the TPB signal when the key is no longer closed.

TABLE 1. DYNAMIC ELECTRICAL CHARACTERISTICS OF THE CD1871A

| CHARACTERISTIC |  |  | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \text { CDP1871AD } \\ & \text { CDP1871AE } \end{aligned}$ | CDP1871ACD CDP1871ACE |  |  |  |
|  |  |  | MIN | TYP* | MAX | MIN | TYP* | MAX |  |
| Clock Cycle Time | A | $\mathrm{tac}_{\text {c }}$ |  | 5 | - | - | - | - | - | - | Note 1 |
|  |  |  |  | 10 | - | - | - | - | - | - |  |
| Clock Pulse Width High | B | $\mathrm{t}_{\text {cWh }}$ | 5 | 100 | 40 | - | 100 | 40 | - | ns |
|  |  |  | 10 | 50 | 20 | $\bullet$ | - | - | - |  |
| Data Available Valid Delay | C | $t_{\text {DAL }}$ | 5 | - | 260 | 500 | - | 260 | 500 | ns |
|  |  |  | 10 | - | 130 | 250 | - | - | - |  |
| Data Available Invalid Delay | D | $t_{\text {DAH }}$ | 5 | $\bullet$ | 70 | 150 | - | 70 | 150 | ns |
|  |  |  | 10 | - | 35 | 75 | - | - | - |  |
| Scan Count Delay (Non-Repeat) | E | $\mathrm{t}_{\mathrm{CD} 1}$ | 5 | 1900 | - | - | 1900 | - | - | ns |
|  |  |  | 10 | - | 425 | 950 | - | - | - |  |
| Data Out Valid Delay | F | tcov | 5 | - | 120 | 250 | - | 120 | 250 | ns |
|  |  |  | 10 | - | 60 | 125 | - | - | - |  |
| Data Out Hold Time | G | $\mathrm{t}_{\mathrm{COH}}$ | 5 | - | 100 | 200 | $\bullet$ | 100 | 200 | ns |
|  |  |  | 10 | - | 50 | 100 | - | - | - |  |
| Repeat Valid Delay | H | $\mathrm{t}_{\text {RPL }}$ | 5 | $\bullet$ | 150 | 400 | - | 150 | 400 | ns |
|  |  |  | 10 | - | 75 | 200 | - | - | - |  |
| Repeat Invalid Delay | J | $\mathrm{t}_{\text {RPM }}$ | 5 | - | 350 | 700 | - | 350 | 700 | ns |
|  |  |  | 10 | - | 170 | 350 | - | - | - |  |

*Typical Values are for $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and Nominal $\mathrm{V}_{\mathrm{DD}}$
NOTE:

1. $\mathrm{t}_{\mathrm{CC}}=\mathrm{t}_{\mathrm{CWH}}+\mathrm{t}_{\mathrm{CWL}}, \mathrm{t}_{\mathrm{CWL}}=\mathrm{t}_{\mathrm{CD} 1}+\mathrm{K}, \mathrm{k}=0.9$ per pF of keyboard capacitance

## Use With Other Processors

Although the keyboard encoder has been designed to operate with CDP1800-series processors, it can be used with other processors if certain precautions are followed.
The encoder is designed as an I/O port; it is not intended to operate with its chip selects active at all times. If this feature is desired, connect an external Schmitt trigger to the debounce pin and place a tristate latch on the data bus.
The most likely use of the CDP1871A will be as an I/O port, and the concern here is the synchronization of the TPB input. The TPB must be held high when the chip selects are active to reset the data available signal. If the TPB is allowed to toggle with the chip selected before it is read, it can hold the data available flip-flop in reset continuously, and can clock the scan counter.

Figure 7 shows the encoder connected to a CDP6805 processor. It can interface directly in this arrangement since the DS output from the CDP6805 is similar to the timing of the TPB timing signal of the CDP1800. However, in a 5 MHz system, DS occurs every microsecond, too fast for the encoder's requirement of a TPB input less than 400 kHz at 5 volts. If a divider is used to lower the TPB input, synchronization will be lost. A way around this problem is to use a NAND gate in front of the TPB input and to have one of its inputs tied to the active-low chip select; Figure 8. Then, when the CDP1871A is selected, the TPB input will be forced high and TPB will only toggle again after the encoder is read and the chip select signal is again false.


FIGURE 7. APPLICATION OF THE CDP1871A AND CDP6805 PROCESSOR


FIGURE 8. CIRCUIT FOR PREVENTING LOSS OF SYNCHRONIZATION IN CDP1871A/CDP6805 INTERFACE

Note that DS enables the decoder, so that during the time that the processor is placing its low address on the data bus, the CDP1871A is disabled. If an asynchronous clock is used for the TPB input, as shown in Figure 9, the NAND gate can be used to assure that TPB remains high during the CDP1871A select times.


FIGURE 9. METHOD OF ASSURING THAT TPB REMAINS HIGH DURING CDP1871A SELECT TIMES

The keyboard encoder can be used to advantage with another popular processor, the 8085 . Figure 10 shows a circuit that interfaces the two devices with an OR gate and a NAND gate. In this circuit, the only time the encoder can drive the data bus is when it is selected and the read signal is active. Since there is no DS equivalent in the 8085 processor, the additional device shown in the figure is needed.


FIGURE 10. A CDP1871A/CDP6805 INTERFACE EMPLOYING AN OR AND A NAND GATE

Figure 11 shows the encoder connected to the 6502 processor. The timing for this part is similar to that for the CDP6805, and the same concerns apply.


FIGURE 11. A CDP1871ACDP6502 INTERFACE

## Reference

1. "CMOS Keyboard Encoder, CD1871A," RCA Solid State File No. 1374. (The CDP1871A comes in two versions: CDP1871A and CDP1871AC. The two are identical except for recommended
operating voltage range: 4 to 10.5 volts for the $\mathbf{A}$ version, and 4 to 6.5 volts for the $A C$ version.)

## Appendix

TABLE A-1. DRIVE AND SENSE LINE KEYBOARD CONNECTIONS $\ddagger$

| $\begin{aligned} & \text { SENSE } \\ & \text { LNES } \end{aligned}$ | DRIVE LINES |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{1}$ |  | $\mathrm{D}_{2}$ |  | $\mathrm{D}_{3}$ |  | $\mathrm{D}_{4}$ |  | $\mathrm{D}_{5}$ |  | $\mathrm{D}_{6}$ |  |  | $\mathrm{D}_{8} \mathrm{t}$ | $\mathrm{D}_{9} \mathrm{t}$ | $\mathrm{D}_{10} \dagger$ | $\mathrm{D}_{11} \dagger$ |
| $\mathrm{S}_{1}$ | SP | 0 | 1 | 8 | - | © | H | H | P | P | X | X | Space | $80_{16}$ | $88_{16}$ | ${ }^{90} 16$ | $98_{16}$ |
|  | 0 |  | 8 |  | © | NUL | h | BS | p | DLE | X | CAN |  |  |  |  |  |
| $\mathrm{S}_{2}$ | $!$ | 1 | ) | 9 | A | A | 1 | 1 | Q | Q | $Y$ | $Y$ |  | $81_{16}$ | $89_{16}$ | $91{ }_{16}$ | ${ }^{99} 16$ |
|  | 1 |  | 9 |  | a | SOH | i | HT | q | DC1 | y | EM | , |  |  |  |  |
| $\mathrm{S}_{3}$ | * | 2 | * | : | B | B | J | $J$ | R | R | Z | Z | Line Feed | $82_{16}$ | $8 \mathrm{~A}_{16}$ | 9216 | $9 A_{16}$ |
|  | 2 |  | : | $\because$ | b | STX | j | LF | $r$ | DC2 | $z$ | SUB |  |  |  |  |  |
| $\mathrm{S}_{4}$ | \# | 3 | + | ; | C | C | K | K | S | S | \{ | [ | Escape | $83_{16}$ | $88_{16}$ | $93_{16}$ | $9 \mathrm{~B}_{16}$ |
|  | 3 |  | ; |  | c | ETX | k | VT | s | DC3 | [ | ESC |  |  |  |  |  |
| $\mathrm{S}_{5}$ | \$ | 4 | < | , | D | D | L | L | T | T | 1 | 1 |  | $84_{16}$ | $8 C_{16}$ | $94_{16}$ | ${ }^{9} C_{16}$ |
|  | 4 |  | , |  | d | EOT | 1 | FF | t | DC4 | 1 | FS |  |  |  |  |  |
| $\mathrm{S}_{6}$ | \% | 5 | = | - | E | E | M | M | U | U | ) | ] | Carriage Return | $85_{16}$ | $8 \mathrm{D}_{16}$ | $95_{16}$ | $9 D_{16}$ |
|  | 5 |  | $\bullet$ |  | e | ENQ | m | CR | u | NAK | ] | GS |  |  |  |  |  |
| $\mathrm{S}_{7}$ | \& | 6 | $>$ | . | F | F | N | N | V | V | $\sim$ | $\uparrow$ |  | $86_{16}$ | $8 \mathrm{E}_{16}$ | 9616 | $9 \mathrm{E}_{16}$ |
|  | 6 |  | . |  | $f$ | ACK | n | SO | $v$ | SYN | $\uparrow$ | RS |  |  |  |  |  |
| $\mathrm{S}_{8}$ | - | 7 | ? | 1 | G | G | 0 | 0 | W | W | DEL | - | Delete | $87_{16}$ | $8 F_{16}$ | $97_{16}$ | ${ }^{9} \mathrm{~F}_{16}$ |
|  | 7 | , | 1 |  | g | BEL | 0 | SI | w | ETB | - | US |  |  |  |  |  |

KEY:

| SHIFT* | ALPHA* |
| :--- | :--- |
| NORMAL | CONTROL* |

*CONTROL Overrides SHIFT and ALPHA
"
= No Response
$\ddagger$ Showing ASCll outputs for all combinations with and without SHIFT, ALPHA LOCK and CONTROL.
$\dagger$ Drive lines 8, 9, 10 and 11 generate non-ASCII hex values which can be used for special codes.

TABLE A-2. HEXADECIMAL VALUES OF ASCII CHARACTERS

|  | BITS |  |  |  |  | MSD |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{array}{ll} 0 & \\ 0 & \\ & 0 \end{array}$ | $0$ <br> 0 $1$ | $\begin{aligned} & 0 \\ & \\ & \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $1$ <br> 0 1 | $\begin{aligned} & 1 \\ & 1 \\ & \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \hline \\ & \hline \end{aligned}$ |
|  | b4 | b3 | b2 | b1 |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| LSD | 0 | 0 | 0 | 0 |  | 0 | NUL | DLE | SP | 0 | © | P | 1 | p |
|  | 0 | 0 | 0 | 1 | 1 | SOH | DC1 | $!$ | 1 | A | Q | a | q |
|  | 0 | 0 | 1 | 0 | 2 | STX | DC2 | " | 2 | B | R | b | r |
|  | 0 | 0 | 1 | 1 | 3 | ETX | DC3 | \# | 3 | C | S | c | $s$ |
|  | 0 | 1 | 0 | 0 | 4 | EOT | DC4 | \$ | 4 | D | T | d | $t$ |
|  | 0 | 1 | 0 | 1 | 5 | ENQ | NAK | \% | 5 | E | U | e | $u$ |
|  | 0 | 1 | 1 | 0 | 6 | ACK | SYN | \& | 6 | F | V | $f$ | $v$ |
|  | 0 | 1 | 1 | 1 | 7 | BEL | ETB | 1 | 7 | G | W | g | w |
|  | 1 | 0 | 0 | 0 | 8 | BS | CAN | $($ | 8 | H | X | h | x |
|  | 1 | 0 | 0 | 1 | 9 | HT | EM | ) | 9 | 1 | $Y$ | i | y |
|  | 1 | 0 | 1 | 0 | A | LF | SUB | * | : | $J$ | Z | j | $z$ |
|  | 1 | 0 | 1 | 1 | B | VT | ESC | + | ; | K | [ | k | \{ |
|  | 1 | 1 | 0 | 0 | C | FF | FS | , | < | L | 1 | 1 | 1 |
|  | 1 | 1 | 0 | 1 | D | CR | GS | - | = | M | ] | m | \} |
|  | 1 | 1 | 1 | 0 | E | SO | RS | . | $>$ | N | $\uparrow$ | $n$ | $\sim$ |
|  | 1 | 1 | 1 | 1 | F | SI | US | 1 | ? | 0 | - | 0 | DEL |

TABLE A-3. RECOMMENDED OPERATING CONDITIONS AT $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
For Maximum Reliability, Operating Conditions should be selected so that operation is always within the following ranges:

| CHARACTERISTIC | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { CDP1871AD } \\ & \text { CDP1871AE } \end{aligned}$ |  | *CDP1871ACD CDP1871ACE |  |  |
|  |  | MIN | MAX | MIN | MAX |  |
| Supply Voltage Range | - | 4 | 10.5 | 4 | 6.5 | V |
| Recommended Input Voltage Range | - | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\mathrm{DD}}$ | V |
| Clock Input Frequency, TPB (Keyboard Capacitance $=200 \mathrm{pF}$ ) | 5 | DC | 0.4 | DC | 0.4 | MHz |
|  | 10 | DC | 0.8 | - | - |  |

* $D$ in suffix indicates ceramic package; $E$ indicates plastic package.

Application Note 7374
TABLE A-4. STATIC ELECTRICAL CHARACTERISTICS at $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Except as Noted

| CHARACTERISTICS | SYMBOL | CONDITIONS |  |  | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & v_{0} \\ & \text { (V) } \end{aligned}$ | $\begin{aligned} & \mathbf{V}_{\mathbf{W}} \\ & \mathbf{( V )} \end{aligned}$ | $\begin{aligned} & V_{D D} \\ & (V) \end{aligned}$ | CDP1871ADCDP1871AE |  |  | CDP1871ACD CDP1871ACE |  |  |  |
|  |  |  |  |  | MIN | TYP* | MAX | MIN | TYP* | MAX |  |
| Quiescent Device Current | ID | - | 0,5 | 5 | - | 0.1 | 50 | - | 1 | 200 | $\mu \mathrm{A}$ |
|  |  | - | 0,10 | 10 | - | 1 | 200 | - | - | - |  |
| Output Low Drive (Sink) Current (except debounce and D1-D11) | IOL | 0.4 | 0,5 | 5 | 0.5 | 1 | - | 0.5 | 1 | - | mA |
|  |  | 0.5 | 0,10 | 10 | 1 | 2 | - | - | - | - |  |
| Debounce | loL | 0.4 | 0,5 | 5 | 0.75 | 1.5 | - | 0.75 | 1.5 | - |  |
|  |  | 0.5 | 0,10 | 10 | 1 | 2 | - | - | - | - |  |
| D1-D11 | IOL | 0.4 | 0,5 | 5 | . 05 | 0.1 | - | . 05 | 0.1 | - |  |
|  |  | 0.5 | 0,10 | 10 | 0.1 | 0.2 | - | - | - | - |  |
| Output High Drive (Source) Current | IOH | 4.6 | 0,5 | 5 | -0.3 | -0.6 | - | -0.3 | -0.6 | - |  |
|  |  | 9.5 | 0,10 | 10 | -0.75 | -1.5 | - | - | - | - |  |
| Input Low Voltage (except Debounce) | $\mathrm{V}_{\text {IL }}$ | $\begin{gathered} 0.5, \\ 4.5 \end{gathered}$ | - | 5 | - | - | 1.5 | - | - | 1.5 | V |
|  |  | 1,9 | - | 10 | - | - | 3 | - | - | - |  |
| Input High Voltage (except Debounce) | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & 0.5, \\ & 4.5 \end{aligned}$ | - | 5 | 3.5 | - | - | 3.5 | - | $\bullet$ |  |
|  |  | 1,9 | - | 10 | 7 | - | - | - | - | - |  |
| Debounce Schmitt Trigger Input Voltage <br> Positive Trigger Voltage | $\mathrm{V}_{\mathrm{D}}$ |  |  |  |  |  |  |  |  |  |  |
|  |  | 0.4 | - | 5 | 2.0 | 3.3 | 4.0 | 2.0 | 3.3 | 4.0 |  |
|  |  | 0.5 | $\cdot$ | 10 | 4.0 | 6.3 | 8.0 | - | - | - |  |
| Negative Trigger Voltage | $\mathrm{V}_{\mathrm{N}}$ | 0.4 | - | 5 | 0.8 | 1.8 | 3.0 | 0.8 | 1.8 | 3.0 |  |
|  |  | 0.5 | - | 10 | 1.9 | 4.0 | 6.0 | - | - | - |  |
| Hysteresis | $\mathrm{V}_{\mathrm{H}}$ | 0.4 | 0,5 | 5 | 0.3 | 1.6 | 2.6 | 0.3 | 1.6 | 2.6 |  |
|  |  | 0.5 | 0,10 | 10 | 0.7 | 2.3 | 4.7 | - | - | - |  |
| Output Voltage Low Level | V OL | - | 0,5 | 5 | - | 0 | 0.05 | - | 0 | 0.05 |  |
|  |  | - | 0,10 | 10 | - | 0 | 0.05 | - | - | - |  |
| Output Voltage High Level | $\mathrm{V}_{\mathrm{OH}}$ | - | 0,5 | 5 | 4.95 | 5 | - | 4.95 | 5 | $\bullet$ |  |
|  |  | - | 0,10 | 10 | 9.95 | 10 | - | - | - | - |  |
| Input Leakage Current (except S1-S8, Shift, Control) | $\mathrm{I}_{\mathbf{N}}$ | - | 0,5 | 5 | - | 0.01 | 1 | - | 0.01 | 1 | $\mu \mathrm{A}$ |
|  |  | - | 0,10 | 10 | - | 0.01 | 1 | - | - | - |  |
| 3-State Output Leakage Current | Iout | 0.5 | 0,5 | 5 | - | 0.01 | 1 | - | 0.02 | 2 |  |
|  |  | 0,10 | 0,10 | 10 | - | 0.02 | 2 | - | - | - |  |
| Pull-Down Resistor Value (S1-S8, Shift, Control) | $\mathrm{R}_{\text {PD }}$ | - | - | - | 7 | 14 | 24 | 7 | 14 | 24 | k $\Omega$ |
| Operating Current (All outputs unloaded) $\mathrm{f}_{\mathrm{CL}}=0.4 \mathrm{MHz}$ | Ioper | $\begin{aligned} & 0.5 \\ & 4.5 \end{aligned}$ | 0,5 | 5 | - | 0.6 | - | - | 0.6 | - | mA |
| $\mathrm{f}_{\mathrm{CL}}=0.8 \mathrm{MHz}$ |  | 1,9 | 0,10 | 10 | - | 2.7 | - | - | - | $\bullet$ |  |

* Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$ -


## miarappooessor Productis <br> 

## HARRIS QUALITY AND RELIABILITY

PAGEINTRODUCTION ..... 8-3
THE ROLE OF THE QUALITY ORGANIZATION ..... 8-3
THE IMPROVEMENT PROCESS ..... 8-3
HARRIS STANDARD FLOWS ..... 8-3
MEASUREMENT ..... 8-8
Analytical Services Laboratory ..... 8-8
Calibration Laboratory ..... 8-8
FIELD RETURN PRODUCT ANALYSIS SYSTEM ..... 8-8
Failure Analysis Laboratory ..... 8-9
PFAST Action Request Form ..... 8-10
RELIABILITY ..... 8-11
Reliability Assessment and Enhancement ..... 8-11
Qualifications ..... 8-11
In-Line Reliability Monitors ..... 8-11
PRODUCT/PACKAGE RELIABILTYY MONITORS ..... 8-11
Matrix I, II, III ..... 8-11
RELIABILITY FUNDAMENTALS ..... 8-11
Failure Rate Calculations ..... 8-11
Acceleration Factors ..... 8-13
Activation Energy ..... 8-14
QUALIFICATION PROCEDURES ..... 8-14
Document Control ..... 8-15
/883 DATA SHEET HIGHLIGHTS ..... 8-15
GENERAL TEST PHILOSOPHY ..... 8-17
NON-STANDARD PRODUCT OFFERINGS ..... 8-17
IC HANDLING PROCEDURES ..... 8-18
Handling Rules ..... 8-18
ESD HANDLING PROCEDURES ..... 8-18
Measures of Protection and Prevention ..... 8-18
Technical Brief \#52 -Electrostatic Discharge Control ..... 8-20
DIGITAL IC TECHNOLOGIES ..... 8-22
PACKAGING TECHNIQUES ..... 8-23

## Introduction

Success in the integrated circuit industry means more than simply meeting or exceeding the demands of today's market. It also includes anticipating and accepting the challenges of the future. It results from a process of continuing improvement and evolution, with perfection as the constant goal.

Harris Semiconductor's commitment to supply only top value integrated circuits has made quality improvement a mandate for every person in our work force - from circuit designer to manufacturing operator, from hourly employee to corporate executive. Price is no longer the only determinant in marketplace competition. Quality, reliability, and performance enjoy significantly increased importance as measures of value in integrated circuits.

Quality in integrated circuits cannot be added on or considered after the fact. It begins with the development of capable process technology and product design. It continues in manufacturing, through effective controls at each process or step. It culminates in the delivery of products which meet or exceed the expectations of the customer.

## The Role of The Quality Organization

The emphasis on building quality into the design and manufacturing processes of a product has resulted in a significant refocus of the role of the Quality organization. In addition to facilitating the development of SPC and DOX programs and working with manufacturing to establish control charts, Quality professionals are involved in the measurement of equipment capability, standardization of inspection equipment and processes, procedures for chemical controls, analysis of inspection data and feedback to the manufacturing areas, coordination of efforts for process and product improvement, optimization of environmental or raw materials quality, and the development of quality improvement programs with vendors.

At critical manufacturing operations, process and product quality is analyzed through random statistical sampling and product monitors. The Quality organization's role is changing from policing quality to leadership and coordination of quality programs or procedures through auditing, sampling, consulting, and managing Quality Improvement projects.

To support specific market requirements, or to ensure conformance to military or customer specifications, the Quality organization still performs many of the conventional quality functions (e.g., group testing for military products or wafer lot acceptance). But, true to the philosophy that quality is everyone's job, much of the traditional on-line measurement and control of quality characteristics is where it belongs - with the people who make the product. The

Quality organization is there to provide leadership and assistance in the deployment of quality techniques, and to monitor progress.

## The Improvement Process



FIGURE 1. Stages of statistical quality technology
Harris Semiconductor's quality methodology is evolving through the stages shown in Figure 1. In 1981 we embarked on a program to move beyond Stage I, and we are currently in the transition from Stage II to Stage III, as more and more of our people become involved in quality activities. The traditional "quality" tasks of screening, inspection, and testing are being replaced by more effective and efficient methods, putting new tools into the hands of all employees. Table 1 illustrates how our quality systems are changing to meet today's needs.

## Harris Standard Flows

Harris Semiconductor offers a variety of standard product flows which cover the myriad of application environments our customers experience. These flows run the gamut of low cost commercial parts to fully qualified JAN microcircuits. All of these grades have one thing in common. They result from meticulous attention to quality, starting with design decisions made during product development and ending with the labeling of shipping containers for delivery to our customers. The standard flows offered are:

## Commercial: Electrical performance guaranteed from $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ <br> /883: Mil-Std-883-compliant product: contact the factory or local Harris Sales Office for details on availability and specifications

Details of the individual process requirements are contained in the flow charts on the following pages.

(1) Example for a PGA Package Part

(2) Burn-in test temperatures can be increased and time reduced per regression tables in Mil-Std-883, Method 1015

## Advantages of Standard Flows

Wherever feasible, and in accordance with good value engineering practice, the IC user should specify device grades based on one of the five standard Harris manufacturing flows. These are more than adequate for the overwhelming majority of applications and may be utilized quite effectively if the user engineer bases designs on the standard data sheet, military drawing or slash sheet (as applicable) electrical limits.
Some of the more important advantages gained by using standard as opposed to custom flows are as follows:

- 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. 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 devices. A continuing flow of a given product permits the manufacturer to mointor trends which may bear on end-product performance or reliability and to implement corrective action, if necessary.
- Reduction of risk. Since each product is processed independent of specific customer orders, the manufacturer absorbs production variability within its scheduling framework without major impact on deliveries. In a custom flow, a lot failure late in the production cycle can result in significant delays in delivery due to the required recycling time.
Despite the advantages of using standard flows, there are cases where a special or custom flow is mandatory to meet design or other requirements. In such cases, the Harris Marketing groups stand ready to discuss individual customer needs and, where indicated, to accomodate appropriate custom flows.


## Product Flow Chart

Product Assurance Level /3

*LSI CRITERIA


Optional Groups B, C and D Inspection Lot Conformance Testing is performed only if specifically ordered.

Data Supplied
Data Supplied with / 3 Product Consists of:
a) a certificate processing and screening compliance
b) an attribute summary of Group A results
c) Group B, C and D attribute test results (when ordered)
$C$ of $C$ is provided for Generic Data

* Modified Class B Screening


## /3 Screening

Lot Screening Tests

| SCREEN | METHOD (MIL-STD-883) | REQUIREMENT | NOTES |
| :---: | :---: | :---: | :---: |
| Internal Visual | Condition B Modified for LSI Visual | 100\% | 1,2 |
| Pre-Seal Bake | - | 100\% |  |
| Stabilization Bake | 1008 Condition $\mathrm{C}\left(150^{\circ} \mathrm{C}\right.$ Min) 24 Hours | 100\% |  |
| Temperature Cycling | $\begin{gathered} 1010 \\ \left(-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}\right) \\ \text { Condition } \mathrm{C} \end{gathered}$ | 100\% |  |
| Constant Acceleration (Centrifuge) | 2001 Condition D or E $(30,000 \mathrm{~g})$ Y1 Dir. | 100\% | 4 |
| Seal <br> A) Fine <br> B) Gross <br> Initial (Pre-Burn-In) <br> Electrical Parameters at $+25^{\circ} \mathrm{C}$ | 1014 A or B C Per Applicable Device Specifications | $\begin{aligned} & 100 \% \\ & 100 \% \\ & 100 \% \end{aligned}$ |  |
| Burn-In Interim (Post Burn-In) <br> Electrical Parameters at $+25^{\circ} \mathrm{C}$ | 1015,160 Hours at $+125^{\circ} \mathrm{C}$ <br> Per Applicable Device Specifications | $\begin{aligned} & 100 \% \\ & 100 \% \end{aligned}$ | 3 |
| Final Electrical Test at at $-55^{\circ} \mathrm{C} /+125^{\circ} \mathrm{C}$ | Per Applicable Device Specifications | 100\% |  |
| Group A Quality Conformance Test | 5005 | Sample |  |
| External Visual | 2009 | 100\% |  |

NOTES:

1. Internal Visual Inspection Modifled for LSI

Internal Visual Inspection is performed to MIL-STD-883, Method 2010, Condition B except as follows.
A. High magnification Inspection is performed at 200X to 300X and applies to the high current areas of the chip. The remainder of the chip is inspected at 75 X to 150 X where high magnification is required.
B. Metalilzatlon Volds (3.2.1.2) Criteria 3.2.1.1a Metallization Scratches, and 3.2.1.2a Metallization Voids shall also apply to metallization over a passivation step (3.2.1.1d, 3.2.1.2b) Underlying oxide must also be exposed.
C. Metallization Allgnment (3.2.1.7), Diffusion and Passivation Layer(s) Faults (3.2.0).

High magnification inspection is performed at 200X to 300X, applied to the center and two opposite corners of the chip, consisting only of the area exposed to the immediate field of view
D. Scribing and Dle Defects (3.2.3) In addition:

A crack that exceeds 5.0 mils in length must also point towards or cross a scribe grid line to be unacceptable.

Semicircular cracks that point away from the active circuit area are acceptable.
2. SOS Technology Devices; CDP1821, 1822, 1823, MWS5114 Only

A Diffusion faults are not applicable. SOS devices are inspected for complete islands, bridging between islands and missing adjacent contacts from a row in a contact chain.
B. The 1.0 ml wire clearance criteria is not applicable.
C. Passivation faults are not applicable because a second free flow oxide is used prior to metallization.
D. Oxide gate bridge inspection is not applicable.
E. Semicircular cracks not in an active area which start and end at the pellet edge are acceptable.
3. See Individual Data Sheets for Burn-In Circuits.
4. Constant acceleration (Centrifuge) Is performed at $\mathbf{2 0 , 0 0 0} \mathbf{g}$ Condition D for the 40 lead DIC package (CDP1802).

## Measurement

## Analytical Services Laboratory

Harris facilities, engineering, manufacturing, and product assurance are supported by the Analytical Services Laboratory. Organized into chemical or microbeam analysis methodology, staff and instrumentation from both labs cooperate in fully integrated approaches necessary to complete analytical studies. The capabilities of each area are shown below.

SPECTROSCOPIC METHODS: Colorimetry, Optical Emission, Ultraviolet Visible, Fourier Transform-Infrared, Flame Atomic Absorption, Furnace Organic Carbon Analyzer, Mass Spectrometer.

CHROMATOGRAPHIC METHODS: Gas Chromatography, Ion Chromatography.

THERMAL METHODS: Differential Scanning Colorimetry, Thermogravimetric Analysis, Thermomechanical Analysis.

PHYSICAL METHODS: Profilometry, Microhardness, Rheometry.

CHEMICAL METHODS: Volumetric, Gravimetric, Specific Ion Electrodes.

ELECTRON MICROSCOPE: Transmission Electron Microscopy, Scanning Electron Microscope.

X-RAY METHODS: Energy Dispersive X-ray Analysis (SEM), Wavelength Dispersive X-ray Analysis (SEM), X-ray Fluorescence Spectrometry, X-ray Diffraction Spectrometry.
SURFACE ANALYSIS METHODS: Scanning Auger Microprobe, Electron Spectroscope/Chemical Analysis, Secondary Ion Mass Spectrometry, Ion Scattering Spectrometry, Ion Microprobe.

The department also maintains ongoing working arrangements with commercial, university, and equipment manufacturers' technical service laboratories, and can obtain any materials analysis in cases where instrumental capabilities are not available in our own facility.

## Calibration Laboratory

Another important resource in the product assurance system is Harris Semiconductor's Calibration Lab. This area is responsible for calibrating the electronic, electrical, electro/mechanical, and optical equipment used in both the production and engineering areas. The accuracy of instruments used at Harris in calibration is traceable to the National Bureau of Standards. The lab maintains a system which conforms to the current revision of MIL-STD-45662, "Calibration System Requirements."

Each instrument requiring calibration is assigned a calibration interval based upon stability, purpose, and degree of use. The equipment is labeled with an identification tag on which is specified both the date of the last calibration and of the next required calibration. The Calibration Lab reports on a regular basis to each user department. Equipment out of calibration is taken out of
service until calibration is performed. The Quality organization performs periodic audits to assure proper control in the using areas. Statistical procedures are used where applicable in the calibration process.

## Field Return Product Analysis System

The purpose of this system is to enable Harris' Field Sales and Quality operations to properly route, track and respond to our customers' needs as they relate to product analysis.

The Product Failure Analysis Solution Team (PFAST) consists of the group of people who must act together to provide timely, accurate and meaningful results to customers on units returned for analysis. This team includes the salesman or applications engineer who gets the parts from the customer, the PFAST controller who coordinates the response, the Product or Test Engineering people who obtain characterization and/or test data, the analysts who failure analyze the units, and the people who provide the ultimate corrective action. It is the coordinated effort of this team, through the system described in this document that will drive the Customer responsiveness and continuous improvement that will keep Harris on the forefront of the semiconductor business.

The system and procedures define the processing of product being returned by the customer for analysis performed by Product Engineering, Reliability Failure Analysis and/or Quality Engineering. This system is designed for processing "sample" returns, not entire lot returns or lot replacements.

The philosophy is that each site analyzes its own product. This applies the local expertise to the solutions and helps toward the goal of quick turn time.

Goals: quick, accurate response, uniform deliverable (consistent quality) from each site, traceability.

The PFAST system is summarized in the following steps:

1) Customer calls the sales rep about the unit(s) to return.
2) Fill out PFAST Action Request - see the PFAST form in this section. This form is all that is required to process a Field Return of samples for failure analysis. This form contains essential information necessary to perform root cause analysis. (See Figure 2).
3) The units must be packaged in a manner that prevents physical damage and prevents ESD. Send the units and PFAST form to the appropriate PFAST controller. This location can be determined at the field sales office or rep using "look-up" tables in the PFAST document.
4) The PFAST controller will log the units and route them to ATE testing for data log.
5) Test results will be reviewed and compared to customer complaint and a decision will be made to route the failure to the appropriate analytical group.
6) The customer will be contacted with the ATE test results and interim findings on the analysis. This may relieve a line down situation or provide a rapid disposition of material. The customer contact is valuable in analytical process to insure root cause is found.
7) A report will be written and sent directly to the customer with copies to sales, rep, responsible individuals with corrective actions and to the PFAST controller so that the records will capture the closure of the cycle.
8) Each report will contain a feedback form (stamped and preaddressed) so that the PFAST team can assess their performance based on the customers assessment of quality and cycle time.
9) The PFAST team objectives are to have a report in the customers hands in 28 days, or 14 days based on agreements. Interim results are given realtime.

## Failure Analysis Laboratory

The Failure Analysis Laboratory's capabilities encompass the isolation and identification of all failure modes/failure mechanisms, preparing comprehensive technical reports, and assigning appropriate corrective actions. Research vital to understanding the basic physics of the failure is also undertaken.


FIGURE 3. NON-DESTRUCTIVE

Failure analysis is a method of enhancing product reliability and determining corrective action. It is the final and crucial step used to isolate potential reliability problems that may have occurred during reliability stressing. Accurate analysis results are imperative to assess effective corrective actions. To ensure the integrity of the analysis, correlation of the failure mechanism to the initial electrical failure is essential.

A general failure analysis procedure has been established in accordance with the current revision of MIL-STD-883, Section 5003 . The analysis procedure was designed on the premise that each step should provide information on the failure without destroying information to be obtained from subsequent steps. The exact steps for an analysis are determined as the situation dictates. (See Figures 3 and 4). Records are maintained by laboratory personnel and contain data, the failure analyst's notes, and the formal Product Analysis Report.

figure 4. destructive

Request \# Customer Analysis \#

## PFAST ACTION REQUEST

Date:


FIGURE 2. PFAST ACTION REQUEST

## Reliability

## Reliability Assessment and Enhancement

At Harris Semiconductor, reliability is built into every product by emphasizing quality throughout manufacturing. This starts by ensuring the excellence of the design, layout, and manufacturing process. The quality of the raw materials and workmanship is monitored using statistical process control (SPC) to preserve the reliability of the product. The primary and ultimate goal of these efforts is to provide full performance to the product specification throughout its useful life. Product reliability is maintained through the following sources: Qualifications, In-Line Reliability Monitors, Failure Analysis.

## Qualifications

Qualifications at Harris de-emphasize the sole dependence on production product which is only available late in the development cycle. The focus is primarily on the use of test vehicles to establish design ground rules for the product and the process that will eliminate any wearout mechanisms during the useful life of the product. However, to comply with the military requirements concerning reliability, product qualifications are performed. (See Figure 5).

## In-line Reliability Monitors

In-line reliability monitors provide immediate feedback to manufacturing regarding the quality of workmanship, quality of raw materials, and the ultimate reliability implications. The rudimentary implementation of this monitoring is the "First Line of Defense," which is a pass/ fail acceptance procedure based on control charts and trend analysis. The second level of monitoring is referred to as the "Early Warning System" and incorporates wafer level reliability concepts for extensive diagnostic and characterization capabilities of various components that may impact the device reliability or stability. The quick feedback from these schemes allows more accurate correlation to process steps and corrective actions.

## Product/Package Reliability Monitors

Reliability of finished product is monitored extensively under a program called Matrix I, II, III monitor. All major technologies are monitored.
Matrix I - Has a higher sampling size and rate per week and uses short duration test, usually less than 48 hours to assess day to day, week to week reliability. High volume types are prevalent in this data. Stresses - Operating Life, Static Life and HAST. $\mathrm{T}_{\mathrm{A}}=+125^{\circ} \mathrm{C}$ to $+200^{\circ} \mathrm{C}$
Matrix II - Longer duration test, much like requalification. The sample sizes are reduced in number and frequency, yet meet or exceed the JEDEC Standard 29. Stresses Operating Life, Storage, THB, Autoclave, Temp Cycle, and Thermal Shock.
Matrix III - Package specific test. Tests Solderability, Lead Fatigue, Physical Dimensions, Brand Adhesion, Flammability, Bond Pull, Constant Acceleration, and Hermeticity.
Data from these Monitor Stress Test provides the following information:

- Routine reliability monitoring of products by die technology and package styles.
- Data base for determining FIT Rates and Failures Mode trends used drive Continuous Improvement.
- Major source of reliability data for customers.
- Customers have used this data to qualify Harris products.


## Reliability Fundamentals

Reliability, by its nature, is a mixture of engineering and probability statistics. This combination has derived a vocabulary of terms essential for describing the reliability of a device or system. Since reliability involves a measurement of time, it is necessary to accelerate the failures which may occur. This, then, introduces terms like "activation energy" and "acceleration factor," which are needed to relate results of stressing to normal operating conditions (see Table 1). Also, to assess product reliability requires failures. Therefore, only a statistical sample can be used to determine the model of the failure distribution for the entire population of product.

## Failure Rate Calculations

Reliability data for products may be composed of several different failure mechanisms and requires careful combining of diverse failure rates into one comprehensive failure rate. Calculating the failure rate is further complicated because failure mechanisms are thermally accelerated at varying rates and thereby have differing accelerating factors. Additionally, this data is usually obtained from a variety of life tests at unique stress temperatures. The equation below accounts for these considerations and then inserts a statistical factor to obtain the confidence interval for the failure rate.

| $\mathrm{FIT}=$ | $\left(\begin{array}{llll} B & x_{i} & \\ \sum_{i=1} & \sum_{j=1}^{K} & & T D H_{j} \end{array} A F_{i j}\right) \times 10^{9} \quad \times M$ |
| :---: | :---: |
| $B=$ | \# of distinct possible failure mechanisms |
| $K=$ | \# of life tests being combined |
| $\mathrm{x}_{\mathrm{i}}=$ | \# of failures for a given failure mechanism $i=1,2, \ldots B$ |
| TDG ${ }_{j}=$ | Total device hours of test time (unaccelerated) for Life Test ${ }^{j}$ |
| $A F_{i j}=$ | Acceleration factor for appropriate failure mechanism $i=1,2, \ldots K$ |
| $\mathrm{M}=$ | Statistical factor for calculating the upper confidence limit ( $M$ is a function of the total number of failures and an estimate of the standard deviation of the failure rates) |

In the failure rate calculation, Acceleration Factors ( $\mathrm{AF}_{\mathrm{ij}}$ ) are used to derate the failure rate from thermally accelerated Life Test conditions to a failure rate indicative of use temperatures. Though no standards exist, a temperature of $+55^{\circ} \mathrm{C}$ has been popular and allows some comparison of product failure rates. All Harris Semiconductor Reliability Reports will derate to $+55^{\circ} \mathrm{C}$ at both the $60 \%$ and $95 \%$ confidence intervals.


## Acceleration Factors

The Acceleration Factors (AF) are determined from the Arrhenius Equation. This equation is used to describe physiochemical reaction rates and is an appropriate model for expressing the thermal acceleration of semiconductor failure mechanisms.


Both $T_{\text {use }}$ and $T_{\text {stress }}$ (in degrees Kelvin) include the internal temperature rise of the device and therefore represent the junction temperature. With the use of the Arrhenius Equation, the thermal Activation Energy ( $\mathrm{E}_{\mathrm{a}}$ ) term is a major influence on the result. This term is usually empirically derived and can vary widely.
table 1. FAILURE RATE PRIMER

## GLOSSARY OF TERMS

| TERMS/DEFINITION | UNITS/DESCRIPTION |
| :---: | :---: |
| FAILURE RATE $\lambda$ <br> For Semiconductors, usually expressed in FITs. <br> Represents useful life failure rate (which implies a constant failure rate). <br> FITs are not applicable for infant mortality or wearout failure rate expressions. | FIT - Failure in Time <br> 1 FIT-1 failure in $10^{9}$ device hours. <br> Equivalent to $0.0001 \% / 1000$ hours <br> FITs = <br> \# Failures $\times 10^{9} \times m$ <br> \# Devices $\times$ \# hours stress $\times$ AF <br> $m$ - Factor to establish Confidence Interval <br> $10^{9}$ - Establishes in terms of FITs <br> AF - Acceleration Factor at temperature for a given failure mechanism |
| MTTF - Mean Time To Failure <br> For semiconductors, MTTF is the average or mean life expectancy of a device. <br> If an exponential distribution is assumed then the mean time to fail of the population will be when $63 \%$ of the parts have failed. | Mean Time is measured usually in hours or years. <br> 1 Year $=8760$ hours <br> When working with a constant failure rate the MTTF can be calculated by taking the reciprocal of the failure rate. <br> MTTF $=1 / \lambda$ (exponential model) <br> Example: $=10$ FITs at $+55^{\circ} \mathrm{C}$ <br> The MTTF is: MTTF $=1 / \lambda=0.1 \times 10^{9}$ hours <br> $=100 \mathrm{M}$ hours |
| CONFIDENCE INTERVAL (C. I.) <br> Establishes a Confidence Interval for failure rate predictions. Usually the upper limit is most significant in expressing failure rates. | Example: <br> "10 FITs @ a 95\% C. I. @ 55 ${ }^{\circ} \mathrm{C}$ " means only that you are 95\% certain the the FITs $<10$ at $+55^{\circ} \mathrm{C}$ use conditions. |

## Activation Energy

To determine the Activation Energy ( $E_{a}$ ) of a mechanism (see Table 2) you must run at least two (preferably more) tests at different stresses (temperature and/or voltage). The stresses will provide the time to failure (Tf) for the populations which will allow the simultaneous solution for the Activation Energy by putting the experimental results into the following equations.


Then, by subtracting the two equations, the Activation Energy becomes the only variable, as shown.
$\ln \left(t_{f 1}\right)-\ln \left(t_{f 2}\right)=E_{a} / k(1 / T 1-1 / T 2)$
$E_{a}=K^{*}\left(\left(\ln \left(t_{f 1}\right)-\ln \left(t_{\mathrm{f}}\right)\right) /(1 / T 1-1 / T 2)\right)$
The Activation Energy may be estimated by graphical analysis plots. Plotting In time and In temperature then provides a convenient nomogram that solves (estimates) the Activation Energy.
Table 3 is a summary for the $L 7$ process.
All Harris Reliability Reports from qualifications and Group C1 (all high temperature operating life tests) will provide the
data on all factors necessary to calculate and verify the reported failure rate (in FITs) using the methods outlined in this primer.

## Qualification Procedures

New products are reliably introduced to market by the proper use of design techniques and strict adherence to process layout ground rules. Each design is reviewed from its conception through early production to ensure compliance to minimum failure rate standards. Ongoing monitoring of reliability performance is accomplished through compliance to 883 C and standard Quality Conformance Inspection as defined in Method 5005.
New process/product qualifications have two major requirements imposed. First is a check to verify the proper use of process methodology, design techniques, and layout ground rules. Second is a series of stress tests designed to accelerate failure mechanisms and demonstrate the reliability of integrated circuits.
From the earliest stages of a new product's life, the design phase, through layout, and in every step of the manufacturing process, reliability is an integral part of every Harris Semiconductor product. This kind of attention to detail "from the ground up" is the reason why our customers can expect the highest quality for any application.

TABLE 2. FAILURE MECHANISM

| FAILURE MECHANISM | ACTIVATION ENERGY | SCREENING AND TESTING METHODOLOGY | CONTROL METHODOLOGY |
| :---: | :---: | :---: | :---: |
| Oxide Defects | $0.3-0.5 \mathrm{eV}$ | High temperature operating life (HTOL) and voltage stress. Defect density test vehicles. | Statistical Process Control of oxide parameters, defect density control, and voltage stress testing. |
| Silicon <br> Defects (Bulk) | $0.3-0.5 \mathrm{eV}$ | HTOL \& voltage stress screens. | Vendor Statistical Quality Control programs, and Statistical Process Control on thermal processes. |
| Corrosion | 0.45 eV | Highly accelerated stress tesing (HAST) | Passivation dopant control, hermetic seal control, improved mold compounds, and product handling. |
| Assembly Defects | $0.5-0.7 \mathrm{eV}$ | Temperature cycling, temperature and mechanical shock, and environmental stressing. | Vendor Statistical Quality Control programs, Statistcal Process Control of assembly processes proper handling methods. |
| Electromigration <br> - Al Line <br> - Contact | $\begin{aligned} & 0.6 \mathrm{eV} \\ & 0.9 \mathrm{eV} \end{aligned}$ | Test vehicle characterizations at highly elevated temperatures. | Design ground rules, wafer process statistical process steps, photoresist, metals and passivation |
| Mask Defects/ <br> Photoresist <br> Defects | 0.7 eV | Mask FAB comparator, print checks, defect density monitor in FAB, voltage stress test and HTOL. | Clean room control, clean mask, pellicles Statistical Process Control or photoresistletch processes. |
| Contamination | 1.0 eV | C-V stress at oxide/interconnect, wafer FAB device stress test (EWS) and HTOL. | Statistical Process Control of C-V data, oxide/ interconnect cleans, high integrity glassivation and clean assembly processes. |
| Charge Injection | 1.3 eV | HTOL \& oxide characterization. | Design ground rules, wafer level Statistical Process Control and critical dimensions for oxides. |

TABLE 3. HIGH TEMPERATURE OPERATING LIFE TEST SUMMARY

| GENERIC GROUP | GROUP NAME | PROCESS DESCRIPTION | QUANTITY | QUANTITY <br> FAILURE | HOURS <br> @ $125^{\circ} \mathrm{C}$ | FAILURE RATE FITs @ $55^{\circ} \mathrm{C} 60 \% \mathrm{Cl}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C-105-5 | Microprocessor and Peripherals | SAJI CMOS L7 | 1452 | 0 | 5.72 E + 06 | 2 |

## Harris High Reliability Product Specification Highlights

Harris Semiconductor is a leading supplier of high reliability integrated circuits to the military and aerospace community and takes pride in offering products tailored to the most demanding applications requirements. Our Manufacturing facilities are JAN-Certified to MIL-M-38510 and provide JAN-qualified and MIL-STD-883 compliant products as standard data book items. This Data Book contains detailed information on high-reliability integrated circuits presently available from Harris Semiconductor.

The intent of the /883 data sheet is to provide to our customers a clear understanding of the testing being performed in conformance with MIL-STD-883 requirements. Additionally, it is our intent to provide the most effective and comprehensive testing feasible.

## Document Control

Harris has established each of the /883 data sheets as an internally revised controlled document. Any product revision or modification must be approved and signed-off throughout the manufacturing and engineering sections. Harris has made every effort to ensure accuracy of the information in this data book through quality control methods. Harris reserves the right to make changes to the products contained in this data book to improve performance, reliability and producibility. Each data sheet will use the printed date as the revision control identification. Contact Harris for the latest available specifications and performance data.

## /883 Data Sheet Highlights

Each specific /883 data sheet documents the features, description, pinouts, tested electrical parameters, test circuits, burn-in circuits, die characteristics, packaging and design information. The following are notes and clarifications that will help in applying the information provided in the data sheet.

Absolute Maximum Ratings: These ratings are provided as maximum stress ratings and should be taken into consideration during system design to prevent conditions which may cause permanent damage to the device. Operation of the device at or above the "Absolute Maximum Ratings" is not intended, and extended exposure may affect the device reliability.

Reliability Information: Each /883 data sheet contains thermal information relating to the package and die. This information is intended to be used in system design for determining the expected device junction temperatures for overall system reliability calculations.

Packaging: Harris utilizes MIL-M-38510, Appendix C for packages used for $/ 883$ products. The mechanical dimensions and materials used are shown for each individual product to complete each data sheet as a self contained document.
D.C. and A.C. Electrical Parameters: Tables 1 and 2 define the D.C. and A.C. Electrical Parameters that are $100 \%$ tested in production to guarantee compliance to MIL-STD-883. The subgroups used are defined in MIL-STD-883, Method 5005 and designated under the provisions of Paragraph 1.2.1a. Test Conditions and Test Circuits are provided for specific parameter testing.

Table 3 provides additional device limits that are guaranteed by characterization of the device and are not directly tested in production. Characterization takes place at initial device design and after any major process or design changes. The characterization data is on file and available demonstrating the test limits established.

Table 4 provides a summary of the test requirements and the applicable MIL-STD-883 subgroups.

Burn-in Circuits: The Burn-in circuits defined in the individual data sheets are those used in the actual production process. Burn-in is conducted per MIL-STD883, Method 1015.

Design Information Sections: Harris provides an additional Design Information Section in many of the data sheets to assist in system application and design. This information may be in the form of applications circuits, typical device parameters, or additional device related user information such as programming information. While this information cannot be guaranteed, it is based on actual characterization of the product and is representative of the data sheet device.

## High Reliability Products Information

Harris' High Reliability Products are all produced in accordance with military specifications and standards, primarily MIL-M-38510 (General Specifications for Microcircuits) and MIL-STD-883 (Test Methods and Procedures for Microelectronics).

MIL-STD-883 contains test methods and procedures for various electrical, mechanical and environmental tests as well as requirements for screening, qualification and quality conformance inspection. Method 5004 of MIL-STD-883 lists the $100 \%$ screening tests which are required for each of the product assurance classes defined above.

Following the device screening, samples are removed from the production lot(s) for Quality Conformance Inspection testing. This testing is divided into four inspection groups: A, B, C and D, which are performed at prescribed intervals per MIL-M-38510 to assure the processes are in control and to ensure the continued quality level of the product being produced.

Group A electrical inspection involves dynamic, static, functional and switching tests at maximum, minimum and room operating temperatures. Sample sizes and specific tests performed depend upon the particular product assurance class chosen. Electrical test sampling is performed on all subgroups as defined in MIL-STD-883, Method 5005.

Group B inspection includes tests for marking permanency, internal visual and mechanical correctness, bond strength, and solderability. It is intended to provide assurance of the absence of lot-to-lot fabrication and manufacturing variances. Group B tests are again defined in test Method 5005.

Group C is oriented toward die integrity and consists of operating life testing as defined in MIL-STD-883, Method 5005.

Group $\mathbf{D}$ environmental testing is provided to verify die and package reliability. Among the Group D tests are lead integrity, hermeticity, temperature cycling, thermal and mechanical shock, and constant acceleration.

MIL-M-38510 requires that Group A and Group B inspection be performed on each lot, while Group C inspection must be done every 3 months and Group D every 6 months to be in compliance with MIL-M-38510 JAN requirements. To limit the amount of testing, MIL-M-38510 allows the multitude of micro- circuits to be grouped by technology, commonly known as "generic families". Thus, one group C performed will cover all parts included in that generic family for three months. For Group $D$, which is package related, although there are some restrictions, one Group D performed on a 24-pin ceramic dual-in-line packaged part will cover all devices in the same package regardless of the technology group.

For MIL-STD-883 products, Groups A and B are required on each lot, Groups C and D are required every 52 weeks by generic die family and package fabricated and manufactured from the same plant as the die and package represented.

## General Test Philosophy

The general philosophy for test set development is to supply test software that guarantees the high performance and quality of the products being designed and manufactured by Harris. The general final test set includes a guardbanded initial test program and a QA test program for the quality test step. Characterization software is an additional test program that parametrically measures and records the performance of the device under test. This test set is used to evaluate the performance of a product and to determine the acceptability of non-standard Source Control Drawings. BSPEC and RSPEC test programs are custom final test programs written to conform to customer specifications.

The general test development strategy is to develop software using a "shell" programming technique which creates standard test program flows, and reduces test development and execution times. Statistically derived guardbands are utilized in the "shell" programs to null out test system variability. High performance hardware interface designs are incorporated for maximized test effectiveness, and efficient fault graded vector sets are utilized for functional and $A C$ testing.

The initial step in generating the test set is the test vector generation. The test vectors are the binary stimulus applied to the device under test to functionally test the operation of the product. The vectors are developed against a behavioral model that is a software representation of the device functionality. The output of the behavioral model can be translated directly to ATE test vectors or prepared for CAD simulation.

The philosophy in the generation of test vectors is to develop efficient fault graded patterns with a goal of greater than $90 \%$ fault coverage. There is no intent to generate a worst case or best case noise vector set. The intent is to maximize fault coverage through efficient vector use. Generally only one vector set will be required to enable complete test coverage within a given test program.

Exceptions to this would be vector generation to test certain identified critical AC speed paths or DC vectors for testing VIH/VIL parameters. These vector sets typically will not increase fault coverage and can not be substituted for fault graded vector sets.

The ultimate goal for testing all /883 products is data sheet compliancy, thoroughness, and quality of testing. By taking this approach to test set generation, Harris is capable of supplying high performance semiconductors of the highest quality to the marketplace.

## Non-Standard Product Offerings

Harris understands the need for customer generated Source Control Drawings with non-standard parameter and/or screening requirements. A Customer Engineering Department is responsible for efficiently expediting your SCDs through a comprehensive review process. The Customer Engineering Group compares your SCD to its closest equivalent grade device type and works closely with the Product Engineer, Manufacturing Engineer, Design Engineer, or applicable individual to compare Harris' screening ability against your non-standard requirement(s). For product processed to non-standard requirements, a unique part number suffix is assigned.

Harris shares the military's objective to utilize standards wherever possible. We recommend using our /883 data sheet as the guideline for your SCD's. In instances where an available military specification or Harris /883 datasheet is inappropriate, it is Harris' sincerest wish to work closely with the buyer in establishing an acceptable procurement document. For this reason, the customer is requested to contact the nearest Harris Sales Office or Representative before finalizing the Source Control Drawing. Harris looks forward to working with the customer prior to implementation of the formal drawing so that both parties may create a mutually acceptable procurement document.

## IC Handling Procedures

Harris IC processes are designed to produce the most rugged products on the market. However, no semiconductor is immune from damage resulting from the sudden application of many thousands of volts of static electricity. While the phenomenon of catastrophic failure of devices containing MOS transistors or capacitors is well known, even bipolar circuits can be damaged by static discharge, with altered electrical properties and diminished reliability. None of the common IC internal protection networks operate quickly enough to positively prevent damage.

It is suggested that all semiconductors be handled, tested, and installed using standard "MOS handling techniques" of proper grounding of personnel and equipment. Parts and subassemblies should not be in contact with untreated plastic bags or wrapping material. High impedance IC inputs wired to a P.C. connector should have a path to ground on the card.

## HANDLING RULES

Since the introduction of integrated circuits with MOS structures and high quality junctions, a safe and effective means of handling these devices has been of primary importance. One method employed to protect gate oxide structures is to incorporate input protection diodes directly on the monolithic chip. However, there is no completely foolproof system of chip input protection in existence in the industry. In addition, most compensation networks in linear circuits are located at high impedance nodes, where protection networks would disturb normal circuit operation. If static discharge occurs at sufficient magnitude ( 2 kV or more), some damage or degradation will usually occur. It has been found that handling equipment and personnel can generate static potentials in excess of 10 kV in a low humidity environment. Thus it becomes necessary for additional measures to be implemented to eliminate or reduce static charge. It is evident, therefore, that proper handling procedures or rules should be adopted.

Elimination or reduction of static charge can be accomplished as follows:

- Use static-free work stations. Static-dissipative mats on work benches and floor, connected to common point ground through a $1 \mathrm{M} \Omega$ resistor, help eliminate static build-up and discharge. Do not use metallic surfaces.
- 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 electroshock injury to personnel). Transient product personnel should wear grounding heel straps when conductive flooring is present.
- Smocks and clothing 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. Where they cannot be eliminated, natural materials such as cotton should be used to minimize charge generation capacity. Conductive smocks are also available as an alternative.
- Control relative humidity to as high a level as practical. $50 \%$ is generally considered sufficient. (Operations should cease if R.H. falls below $25 \%$ ).
- lonized air blowers reduce charge build-up in areas where grounding is not possible or practical.
- Devices should be in conductive static-shielded containers during all phases of transport. Leads may be shorted by tubular metallic carriers, conductive foam, or foil.
- In automated handling equipment, the belts, chutes, or other surfaces should be of conducting non-metal material. If this is not possible, ionized air blowers or ionizing bars may be a good alternative.


## ESD Handling Procedures

Harris has developed a static control program that enables employees to detect problems generated by static electricity whether on site, in transit, or in the field. Controlling the requirements, methods, materials, and training for static protection of our products is ongoing and updated with new developments in electrostatic prevention. Harris has responded with controls and procedures as part of daily operations to be followed in all areas.

The challenge is to insure all electrostatic control procedures are followed throughout the system - from manufacturing through end use. Unprotected integrated circuits can be destroyed or functionally altered by merely passing them through the electrostatic field of something as simple as Styrofoam ${ }^{\text {Th }}$ or human contact.

## Measures of Protection and Prevention

When handling static sensitive devices, three standard procedures must be followed:

1. Prior to any handling of static-sensitive components, the individual must be properly grounded.
2. All static-sensitive components must be handled at static safeguarded work stations.
3. Containers and packing materials that are static-protective must be used when transporting all static-sensitive components.

Special handling equipment (static-safeguarded work stations, conductive wrist straps, static-protected packaging, ionized air blowers) should be used to reduce damaging effects of electrostatic fields and charges.

Static-safeguarded work station is an area that is free from all damaging electricity, including people. To accomplish this, static on conductors and nonconductors must be controlled.

Controlling electrically conductive items can be accomplished by bonding and grounding techniques. The human body is considered a conductor of electricity and is by far the greatest generator of static electricity. Personnel handling ICs must use con- ductive wrist straps to ground themselves. Simple body moves act like a variable capacitor, and can create static charges. In addition, conductive clothing is recommended for minimizing electrostatic build up.

Static protective packaging prevents electric field from influencing or damaging ICs. An effective static-protective package exhibits three types of features:

1. Antistatic protection that prevents triboelectric or frictional charging,
2. Dielectric protection that insulates discharging, and
3. Shielding or Faraday cage protection that prevents transient field penetration.

Harris uses only packaging that exhibits all three features. Employees are required to adhere to the same static-protective packaging techiques during handling and shipment to assure device integrity is maintained.
lonized air blowers aid in neutralizing charges on nonconductors such as synthetic clothing, plastics, and Styrofoam ${ }^{\mathrm{mm}}$. The blowers are placed at the work site and in close proximity to the IC handling area, since nonconductors do not lose or drain charges using normal grounding techniques.

By using wrist straps, static-protected work stations and static-protected containers, Harris product quality is maintained throughout the product cycle.


FIGURE 2. STATIC-SAFEGUARDED WORK STATION

NOTE 1. All electrical equipment on the conductive table top must be hard grounded and isolated from the table top.
2. Earth ground is not computer ground or RF ground or any other limited ground.

# ELECTROSTATIC DISCHARGE CONTROL A GUIDE TO HANDLING INTEGRATED CIRCUITS 

This paper discusses methods and materials recommended for protection of ICs against ESD damage or degradation during manufacturing operations vulnerable to ESD exposure. Areas of concern include dice prep and handling, dice and package inspection, packing, shipping, receiving, testing, assembly and all operations where ICs are involved.
All integrated circuits are sensitive to electrostatic discharge (ESD) to some degree. Since the introduction of integrated circuits with MOS structures and high quality junctions, safe and effective means of handling these devices have been of primary importance.
If static discharge occurs at a sufficient magnitude, 2 kV or greater, some damage or degradation will usually occur. It has been found that handling equipment and personnel can generate static potentials in excess of 10 kV in a low humidity environment; thus it becomes necessary for additional measures to be implemented to eliminate or reduce static charge. Avoiding any damage or degradation by ESD when handling devices during the manufacturing flow is therefore essential.

## ESD Protection and <br> Prevention Measures

One method employed to protect gate oxide structures is to incorporate input protection diodes directly on the monolithic chip. However, there is no completely foolproof system of chip input protection in existence in the industry.
In areas where ICs are being handled, certain equipment should be utilized to reduce the damaging effects of ESD. Typically, equipment such as grounded work stations, conductive wrist straps, conductive floor mats, ionized air blowers and conductive packaging materials are included in the IC handling environment. Any time an individual intends to handle an IC, in any way, they must insure they have been grounded to eliminate circuit damage.
Grounding personnel can, practically, be performed by two methods. First, grounded wrist straps which are usually made of a conductive material, such as Velostat or metal. A resistor value of 1 megohm ( $1 / 2$ watt) in series with the strap to ground completes a discharge path for ESD when the operator wears the strap in contact with the skin. Another method is to insure direct physical contact with a grounded, conductive work surface.
This consists of a conductive surface like Velostat, covering the work area. The surface is connected to a 1 megohm ( $1 / 2$ watt) resistor in series with ground.

In addition to personnel grounding, areas where work is being performed with ICs, should be equipped with an ionized air blower. lonized air blowers force positive and negative ions simultaneously over the work area so that any nonconductors that are near the work surface would have their static charge neutralized before it would cause device damage or degradation.
Relative humidity in the work area should be maintained as high as practical. When the work environment is less than $40 \%$ RH, a static build-up condition can exist on nonconductors allowing stored charges to remain near the ICs causing possible static electricity discharge to ICs.
Integrated circuits that are being shipped or transported require special handling and packaging materials to eliminate ESD damage. Dice or packaged devices should be in conductive carriers during all phases of transport and handling. Leads of packaged devices can be shorted by tubular metalic carriers, conductive foam or foil.

## Do's and Don'ts for <br> Integrated Circuit Handling <br> Do's

Do keep paper, nonconductive plastic, plastic foams and films or cardboard off the static controlled conductive bench top. Placing devices, loaded sticks or loaded burn-in boards on top of any of these materials effectively insulates them from ground and defeats the purpose of the static controlled conductive surface.
Do keep hand creams and food away from static controlled conductive work surfaces. If spilled on the bench top, these materials will contaminate and increase the resistivity of the work area.
Do be especially careful when using soldering guns around conductive work surfaces. Solder spills and heat from the gun may melt and damage the conductive mat.
Do check the grounded wrist strap connections daily. Make certain they are snugly fitted before starting work with the product.
Do put on grounded wrist strap before touching any devices. This drains off any static build-up from the operator.
Do know the ESD caution symbols.
Do remove devices or loaded sticks from shielding bags only when grounded via wrist strap at grounded work station. This also applies when loading or removing devices from the antistatic sticks or the loading on or removing from the burn-in boards.

Do wear grounded wrist straps in direct contact with the bare skin - never over clothing.

Do use the same ESD control with empty burn-in boards as with loaded boards if boards contain permanently mounted ICs as part of driver circuits.

Do insure electrical test equipment and solder irons at an ESD control station are grounded and only uninsulated metal hand tools be used. Ordinary plastic solder suckers and other plastic assembly aids shall not be used.
Do use ionizing air blowers in static controlled areas when the use of plastic (nonconductive) materials cannot be avoided.

## Don'ts

Don't allow anyone not grounded to touch devices, loaded sticks or loaded burn-in boards. To be grounded they must be standing on a conductive floor mat with conductive heel straps attached to footwear or must wear a grounded wrist strap.

Don't touch the devices by the pins or leads unless grounded since most ESD damage is done at these points.
Don't handle devices or loaded sticks during transport from work station to work station unless protected by shielding bags. These items must never be directly handled by anyone not grounded.

Don't use freon or chlorinated cleaners at a grounded work area.
Don't wax grounded static controlled conductive floor and bench top mats. This would allow build-up of an insulating layer and thus defeating the purpose of a conductive work surface.

Don't touch devices or loaded sticks or loaded burn-in boards with clothing or textiles even though grounded wrist strap is worn. This does not apply if conductive coats are worn.

Don't allow personnel to be attached to hard ground. There must always be 1 megohm series resistance ( $1 / 2$ watt between the person and the ground).

Don't touch edge connectors of loaded burn-in boards or empty burn-in boards containing permanently mounted
driver circuits when not grounded. This also applies to burn-in programming cards containing ICs.
Don't unload stick on a metal bench top allowing rapid discharge of charged devices.

Don't touch leads. Handle devices by their package even though grounded.

Don't allow plastic "snow or peanut" polystyrene foam or other high dielectric materials to come in contact with devices or loaded sticks or loaded burn-in boards.

Don't allow rubber/plastic floor mats in front of static controlled work benches.

Don't solvent-clean devices when loaded in antistatic sticks since this will remove antistatic inner coating from sticks.
Don't use antistatic sticks for more than one throughput process. Used sticks should not be reused unless recoated.

## Recommended Maintenance Procedures

## Daily:

Perform visual inspection of ground wires and terminals on floor mats, bench tops, and grounding receptacles to ensure that proper electrical connections via 1 megohm resistor (1/2 watt) exist.
Clean bench top mats with a soft cloth or paper towel dampened with a mild solution of detergent and water.

## Weekly:

Damp mop conductive floor mats to remove any accumulated dirt layer which causes high resistivity.

## Annually:

Replace nuclear elements for ionized air blowers.
Review ESD protection procedures and equipment for updating and adequacy.

## Static Controlled Work Station

The figure below shows an example of a work bench properly equipped to control electro-static discharge. Note that the wrist strap is connected to a 1 megohm resistor. This resistor can be omitted in the setup if the wrist strap has a 1 megohm assembled on the cable attached.

GROUND, i.e. COLD WATER PIPE OR EQUIVALENT

## Harris Digital IC Technologies

## Self Aligned Junction Isolation (SAJI)

The most prevalent CMOS Technology was patented by Harris ( $\# 4,135,955$ ) and has been in production at Harris since 1980. It incorporates self-aligned guard ring techniques and more recently planarization prior to first metal into the traditional complementary transistor structures.

The process begins on $1-0-0 \mathrm{~N}$ - type silicon, although a process option is available with $\mathbf{N}$ epi over $\mathrm{N}++$ starting material to eliminate circuit latch-up due to parasitic SCR action. A sequence of oxidation, photo resist delineation, Boron implant and diffusion create the $P$ well for the $N$ channel devices. A critical feature of the diffusion causes all of the silicon crystal defects to be annihilated, resulting in a defect free zone for the transistors to be fabricated.

Next, silicon nitride is deposited and etched to define the active NMOS and PMOS areas followed by implants which create the self aligned guard rings around the active devices. These guard rings provide electrical isolation between transistors and also raise the field thresholds of the parasitic MOS devices to allow leakage-free circuit operation. The self aligning of these guard rings allows a substantial reduction in circuit area.

Following is the local oxidation and the conventional formation of the poly gate MOS transistors. The electrical channel length of these all implanted devices is 1.5 micron.

The field oxide and metalization structure are based on a time proved reflowed glass process with one important improvement. Prior to metal deposition the surface is planarized and the walls of the contacts are sloped which creates a final topography with excellent interconnect step coverage. The aluminum interconnect is silicon doped to prevent contact
spiking and improved reliability. The passivation, metalization and layout rules guarantee electromigration free operation at $+125^{\circ} \mathrm{C}$ for over ten years.

The principal advantages of the process can be sum-
marized as: - Low leakage operation

- Latch-up free option
- Good packing density
- Excellent step coverage
- Electromigration free designs

This process has been successfully applied to numerous designs including static RAMs, microprocessors, peripherals, and custom ROM circuits.

L7
A newer, higher performance process, named L7, builds on and enhances the basic CMOS technology. This 1.5 micron process has several advantages over the older 2.5 micron version. The epi over N++ starting material is standard with the epi thickness being scaled down in concert with the $P$ well and device junctions. This brings even more latch-up immunity to all circuits on this technology.

Transistors achieve electrical channel lengths of $1.0 \mu$ typical with the N channel incorporating a double diffused LDD structure which eliminates susceptibility to hot electron damage. Of greatest impact is the use of a planarized double layer metal structure allowing greater layout freedom without introducing step coverage or electromigration concerns. The low stress oxinitride passivation provides moisture protection in plastic packages.

The $L 7$ process with its added features has been successfully employed on numerous semicustom and standard cell designs as well as supplying production quantities of the 80 C 286 microprocessor.


FIGURE 3. SILICON-GATE PFET STRUCTURE CROSS-SECTION SHOWS THE HEAVILY DOPED SOURCE AND DRAIN REGION. THEY ARE SEPARATED BY THE NARROW GAP OVER WHICH LIES A THIN-GATE OXIDE AND GATE MATERIAL.

## Packaging Techniques

Harris Semiconductor offers Leadless Chip Carriers (LCC) as a packaging option on various Digital integrated circuits. An LCC is a square or rectangular package for an Integrated Circuit (IC) that is manufactured in the same manner as a conventional side-braze dual-in-line package (DIP). The LCC is comprised of the cavity and seal ring section of a standard DIP and offers the user a means of achieving high density system configurations while retaining the reliability benefits of hermetic IC Packaging. Figure 1 provides a comparison of the construction of an LCC and a conventional side-braze DIP.


FIGURE 1. EXPLODED VIEW OF CHIP CARRIER AND DIP
The LCC's two principle advantages over conventional side-braze DIPs are packaging density and electrical performance. Packaging density is the number one advantage to an LCC over a side-braze DIP. The size of a DIP is governed primarily by the number of leads required and not by the size of the IC. As pin count increases, more and more of the DIP package is used only to provide an electrical trace path to the external leads. The size of an LCC is dependent on the size of the die not on the number of leads. As pin count increases, overall size increases but at a much slower rate. Table 1 provides a comparison between the areas of 18,28 and 48 lead LCCs to 18,28 and 48 lead side-braze DIPs.

TABLE 1.

| LEAD <br> COUNT | LCC <br> AREA | DIP <br> AREA | DIP AREA vs. <br> LCC AREA |
| :---: | :---: | :---: | :---: |
| 18 | 0.10 | 0.22 | $220 \%$ |
| 28 | 0.20 | 0.84 | $420 \%$ |
| 48 | 0.31 | 1.68 | $542 \%$ |

(All Units in Square Inches)

The chart indicates a 220\% improvement in packaging area for the 18 lead LCC, and $542 \%$ improvement for the 48 lead LCC. Obviously, sizeable savings in circuit board area can be achieved with this packaging option. The second major advantage of the LCC is in electrical performance. The package size and geometry also dictates trace length and uniformity. Figure 2 provides a comparison between the trace lengths for various LCCs and side-braze DIPs. As pin count goes up, trace lengths get longer, adding resistance and capacitance unequally around the package. As ICs get faster and more complex these factors start to become a limiting factor on performance. LCCs minimize this effect by maintaining, as close as possible, uniform trace length so that the package is a significantly smaller determinant of system performance.

| LEAD <br> COUNT | LONGEST TRACE DIP <br> LONGEST TRACE LCC | LONGEST TRACE <br> SHORTEST TRACE |  |
| :---: | :---: | :---: | :---: |
|  |  | LCC | DIP |
| 18 | $2: 1$ | $1.5: 1$ | $6: 1$ |
| 24 | $4: 1$ | $1.5: 1$ | $3: 1$ |
| 40 | $5: 1$ | $1.5: 1$ | $6: 1$ |
| 54 | $6: 1$ | $1.5: 1$ | $7: 1$ |

FIGURE 2. ELECTRICAL PERFORMANCE (RESISTANCE AND SPEED)

The LCC also offers environmental advantages over "chip-and-wire" manufacturing techniques used in high density hybrid circuits. An IC can be fully tested, burned-in and processed in an LCC, thereby guaranteeing its performance.

The IC is further protected by a small hermetic package in which internal vapor content can be carefully controlled during production.

Harris Semiconductor Leadless Chip Carriers in both Ceramic and Epoxy provide reliable, high density, high performance packaging options for today's systems.

Consult the factory or your Harris sales representative for pricing and availability.

## Microprocessor Productis

ORDERING AND PACKAGING
PAGE
Ordering Information ..... 9-3
Packaging Availability ..... 9-5
Package Outlines ..... 9-7

## Ordering Information

Harris Semiconductor products are represented by an extensive network of factory sales personnel, sales representatives, and authorized distributors throughout the world. Please contact your nearest sales office, representative, or distributor for product information, pricing, ordering, or delivery details. A complete list of sales offices is available by contacting the Harris Semiconductor literature department at (407) 724-3739. Headquarters are also listed at the end of this book.

## Product Code

Harris products are designated by a "Product Code". This code includes designators for the product family, device type, performance grade, temperature grade and package style. Examples of the product codes are shown below:

80CXXX MICROPROCESSOR/PERIPHERAL PRODUCT CODE


MEMORY/PERIPHERAL PRODUCT CODE


## Ordering Information

## CDP1800-SERIES PRODUCT CODE



PART NUMBER
CDP18XX: Microprocessor/Periphera/RAM MWS51XX: RAM


## PACKAGE

D: Side-Brazed Ceramic DIP
E: Plastic DIP
Q: Plastic Leaded Chip Carrier (PLCC)

## ENHANCED SCREENING

X: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ with Burn-In /3: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ with Burn-In

ICLICMIMXXXX PRODUCT CODE

| ICM | 7170 |
| :---: | :---: |
|  |  |
| FAMILY |  |
| ICL: Linear IC <br> ICM: Peripheral <br> IM: EPROM |  |

PART NUMBER


PACKAGE
B: Small Outline (SOIC)
D: Side-Brazed Ceramic DIP
J: Ceramic DIP
P: Plastic DIP

Package Availability

| PART NUMBER | CERAMIC DIP | PLASTIC DIP | CERAMICLEADLESS CHIP CARRIER | PLASTIC LEADED CHIP CARRIER |
| :---: | :---: | :---: | :---: | :---: |
| MICROPROCESSORS |  |  |  |  |
| CDP1802A, CDP1802AC | 40 LEAD* | 40 LEAD | - | 44 LEAD |
| CDP1802BC | 40 LEAD* | 40 LEAD | - | 44 LEAD |
| CDP1804AC | 40 LEAD* | 40 LEAD | - | 44 LEAD |
| CDP1805AC | 40 LEAD* | 40 LEAD | - | 44 LEAD |
| CDP1806AC | 40 LEAD* | 40 LEAD | - | 44 LEAD |
| 80 C 286 | 68 LEAD (PGA) | - | - | 68 LEAD |
| 80 C 86 | 40 LEAD | 40 LEAD | 44 LEAD | 44 LEAD |
| $80 \mathrm{C88}$ | 40 LEAD | 40 LEAD | 44 LEAD | 44 LEAD |
| PERIPHERALS |  |  |  |  |
| CDP1851, CDP1851C | 40 LEAD* | 40 LEAD | - | - |
| CDP1852, CDP1852C | 24 LEAD* | 24 LEAD | - | - |
| CDP1853, CDP1853C | 16 LEAD* | 16 LEAD | - | - |
| CDP1855, CDP1855C | 28 LEAD* | 28 LEAD | - | - |
| CDP1857, CDP1857C | 16 LEAD* | 16 LEAD | - | - |
| CDP1871A, CDP1871AC | 40 LEAD* | 40 LEAD | - | 44 LEAD |
| CDP1872C | 22 LEAD* | 22 LEAD | - | - |
| CDP1874C | - | 22 LEAD | - | $\cdot$ |
| CDP1875C | 22 LEAD* | 22 LEAD | - | - |
| CDP1877, CDP1877C | 28 LEAD* | 28 LEAD | - | - |
| CDP1878, CDP1878C | 28 LEAD* | 28 LEAD | - | - |
| CDP1879, CDP1879C | 24 LEAD* | 24 LEAD | - | - |
| CDP1881, CDP1881C | - | 20 LEAD | - | - |
| CDP1882, CDP1882C | 18 LEAD* | 18 LEAD | - | - |
| CDP1883, CDP1883C | - | 20 LEAD | - | - |
| ICM7170 | 24 LEAD* | 24 LEAD** | - | - |
| 82 C 237 | 40 LEAD | 40 LEAD | 44 LEAD | 44 LEAD |
| 82C284 | 18 LEAD | - | $\cdot$ | - |
| 82C37A | 40 LEAD | 40 LEAD | 44 LEAD | 44 LEAD |
| 82 C 54 | 24 LEAD | 24 LEAD | 28 LEAD | 28 LEAD |
| 82C55A | 40 LEAD | 40 LEAD | 44 LEAD | 44 LEAD |
| 82C59A | 28 LEAD | 28 LEAD | 28 LEAD | 28 LEAD |
| 82 C 82 | 20 LEAD | 20 LEAD | 20 LEAD | 20 LEAD |
| 82C83H | 20 LEAD | 20 LEAD | 20 LEAD | 20 LEAD |
| 82C84A | 18 LEAD | 18 LEAD | 20 LEAD | 20 LEAD |
| 82 C 85 | 24 LEAD SLIM | $\cdot$ | 28 LEAD | 28 LEAD |
| 82C86H | 20 LEAD | 20 LEAD | 20 LEAD | 20 LEAD |
| 82C87H | 20 LEAD | 20 LEAD | 20 LEAD | 20 LEAD |
| 82 C 88 | 20 LEAD | 20 LEAD | 20 LEAD | 20 LEAD |
| 82C89 | 20 LEAD | 20 LEAD | 20 LEAD | 20 LEAD |
| DATA COMMUNICATIONS |  |  |  |  |
| CDP1854A, CDP1854AC | 40 LEAD* | 40 LEAD | - | 44 LEAD |
| CDP6402, CDP6402C | 40 LEAD* | 40 LEAD | $\bullet$ | $\bullet$ |
| HD-15530 | 24 LEAD | - | 28 LEAD | $\bullet$ |
| HD-15531 | 40 LEAD | 40 LEAD | - | $\bullet$ |

## Package Availability

| PART NUMBER | CERAMIC DIP | PLASTIC DIP | CERAMICLEADLESS CHIP CARRIER | PLASTIC LEADED CHIP CARRIER |
| :---: | :---: | :---: | :---: | :---: |
| DATA COMMUNICATIONS (Continued) |  |  |  |  |
| HD-4702 | 16 LEAD MSI | 16 LEAD | 18 LEAD | - |
| HD-6402 | 40 LEAD | 40 LEAD | - | - |
| HD-6408 | 24 LEAD | 24 LEAD | - | - |
| HD-6409 | 20 LEAD | 20 LEAD** | 20 LEAD | - |
| HS-3182 | 16 LEAD* | - | 28 LEAD | - |
| HS-3282 | 40 LEAD | - | 44 LEAD | - |
| ICL232 | 16 LEAD | 16 LEAD** | - | $\bullet$ |
| 82C50A | 40 LEAD | 40 LEAD | - | 44 LEAD |
| 82 C 52 | 28 LEAD | 28 LEAD | 28 LEAD | 28 LEAD |
| MEMORY |  |  |  |  |
| CDP1821C | 16 LEAD* | - | - | - |
| CDP1822, CDP1822C | 22 LEAD* | 22 LEAD | - | - |
| CDP1823, CDP1823C | 24 LEAD* | 24 LEAD | - | - |
| CDP1824, CDP1824C | 18 LEAD* | 18 LEAD | $\cdot$ | - |
| CDP1826C | 22 LEAD* | 22 LEAD | - | - |
| HM-6504 | 18 LEAD | 18 LEAD | 18 LEAD | $\bullet$ |
| HM-6508 | 16 LEAD LSI | 16 LEAD | - | $\bullet$ |
| HM-6514 | 18 LEAD | 18 LEAD | 18 LEAD | $\bullet$ |
| HM-6516 | 24 LEAD | 24 LEAD | 32 LEAD RECT. | $\bullet$ |
| HM-65162 | 24 LEAD | 24 LEAD | 32 LEAD RECT. | $\bullet$ |
| HM-6518 | 18 LEAD | 18 LEAD | - | $\bullet$ |
| HM-65262 | 20 LEAD | 20 LEAD | 20 LEAD RECT. | $\bullet$ |
| HM-6551 | 22 LEAD | 22 LEAD | - | $\bullet$ |
| HM-6561 | 18 LEAD | 18 LEAD | - | - |
| HM-65642 | 28 LEAD | 28 LEAD | 32 LEAD RECT. | $\bullet$ |
| HM-6617 | 24 LEAD*** | - | 32 LEAD RECT. | $\bullet$ |
| HM-6642 | 24 LEAD*** | - | 28 LEAD | $\bullet$ |
| IM-6654 | 24 LEAD* | $\bullet$ | - | $\bullet$ |
| MWS5101 | 22 LEAD* | 22 LEAD | $\bullet$ | $\bullet$ |
| MWS5114 | 18 LEAD* | 18 LEAD | $\bullet$ | $\bullet$ |

* Dual-in-Line Metal-Seal Ceramic Package (Side-Braze).
** Available in Plastic DIP and SOIC.
*** Available in Slim and Wide DIP.

| PART NUMBER | MODULE SUBSTRATE |
| :--- | :---: |
| RAM MODULES |  |
| HM-6564 | 40 LEAD |
| HM-8808,A | 28 LEAD |
| HM-8816H | 28 LEAD |
| HM-8832 | 28 LEAD |
| HM-92560 | 48 LEAD |
| HM-92570 | 48 LEAD |
| HM-91M2 | 48 LEAD |

## Package Outlines

Dual-In-Line Glass-Sealed Ceramic Package, 0.300

| LEAD COUNT | $\underset{A}{\text { DIM. }}$ | $\begin{gathered} \text { DIM. } \\ \mathbf{B}^{* *} \end{gathered}$ | $\begin{gathered} \text { DiM. } \\ \mathrm{B1} \end{gathered}$ | DIM. $\mathbf{C}^{* *}$ | $\overline{\mathrm{DIM} .}$ | DIM. $\mathrm{E}$ | DIM. E1 | $\underset{\theta}{\text { DIM. }}$ | DIM. L | DIM. L1 | $\begin{gathered} \text { DIM. } \\ \mathbf{Q} \end{gathered}$ | $\begin{gathered} \text { DIM. } \\ \mathbf{S} \end{gathered}$ | DIM. S1 | DIM. $\alpha$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 16 MSI* | - | 0.016 | 0.050 | 0.008 | 0.753 | 0.265 | 0.290 | 0.100 | 0.125 | 0.150 | 0.015 | - | 0.005 | $0^{\circ}$ |
|  | 0.200 | 0.023 | 0.065 | 0.015 | 0.785 | 0.285 | 0.310 | BSC | 0.180 | - | 0.060 | 0.080 | - | $15^{\circ}$ |
| 16 LSI* | - | 0.016 | 0.050 | 0.008 | 0.753 | 0.285 | 0.300 | 0.100 | 0.125 | 0.150 | 0.015 | - | 0.005 | $0^{\circ}$ |
|  | 0.200 | 0.023 | 0.065 | 0.015 | 0.785 | 0.305 | 0.320 | BSC | 0.180 | - | 0.060 | 0.080 | - | $15^{\circ}$ |
| 18* | - | 0.016 | 0.050 | 0.008 | 0.882 | $\underline{0.285}$ | 0.300 |  | $\underline{0.125}$ | $\underline{0.150}$ | $\underline{0.015}$ |  | $\underline{0.005}$ | $0^{\circ}$ |
|  | 0.200 | 0.023 | 0.065 | 0.015 | 0.915 | 0.305 | 0.320 |  | 0.180 | - | 0.060 | 0.098 | - | $15^{\circ}$ |
| 20* | - | 0.016 | 0.050 | $\underline{0.008}$ | 0.940 | 0.285 | 0.300 | 0.100 | 0.125 | 0.150 | 0.015 |  | 0.005 | $0^{\circ}$ |
|  | 0.200 | 0.023 | 0.065 | 0.015 | 0.990 | 0.305 | 0.320 | BSC | 0.180 | - | 0.060 | 0.080 | - | $15^{\circ}$ |
| 24 SLIM | $\bullet$ | 0.016 | 0.050 | 0.008 | $\underline{1.240}$ | 0.285 | 0.300 | 0.100 | 0.125 | 0.150 | 0.015 | - | 0.005 | $0^{\circ}$ |
|  | 0.200 | 0.023 | 0.065 | 0.015 | 1.280 | 0.305 | 0.320 | BSC | 0.180 | - | 0.060 | 0.098 | - | $15^{\circ}$ |

* End leads are half leads where B remains the same and B1 is $0.035-0.045$.
** Dimensions B and C maximum limits are increased by 0.003 for solder dip finish.


## Dual-In-Line Glass-Sealed Ceramic Package, 0.400

| LEAD COUNT | DIM. A | DIM. B* | DIM. B1 | DIM. C* | $\begin{gathered} \text { DIM. } \\ \mathrm{D} \end{gathered}$ | DIM. E | DIM. E1 | $\begin{gathered} \text { DIM. } \\ \text { e } \end{gathered}$ | DIM. L | DIM. L1 | $\begin{gathered} \text { DIM. } \\ \mathbf{Q} . \end{gathered}$ | $\begin{gathered} \text { DIM. } \\ \mathrm{s} \end{gathered}$ | DIM. S1 | DIM. $\alpha$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 22 | - | 0.016 | 0.050 | 0.008 | 1.055 | 0.375 | 0.400 | $\begin{aligned} & 0.100 \\ & \text { BSC } \end{aligned}$ | 0.125 | 0.150 | 0.015 | - | 0.005 | $0^{\circ}$ |
|  | 0.225 | 0.023 | 0.065 | 0.015 | 1.085 | 0.395 | 0.420 |  | 0.180 |  | 0.060 | 0.080 | - | $15^{\circ}$ |

* Dimensions B and C maximum limits are increased by 0.003 for solder dip finish.


## Dual-In-Line Glass-Sealed Ceramic Package, 0.600

| LEAD COUNT | DIM. A | DIM. B* | DIM. B1 | DIM. C* | $\begin{gathered} \text { DIM. } \\ \text { D } \end{gathered}$ | DIM. E | DIM. E1 | DIM. e | DIM. L | DIM. L1 | $\begin{gathered} \text { DIM. } \\ \mathbf{Q} \end{gathered}$ | $\overline{\mathrm{DIM} .}$ | DIM. S1 | DIM. $\alpha$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 24 |  | 0.016 | 0.050 | 0.008 | 1.24 | 0.515 | 0.595 | 0.100 | 0.125 | 0.150 | 0.015 |  | 0.005 | $0^{\circ}$ |
|  | 0.225 | 0.023 | 0.065 | 0.015 | 1.27 | 0.535 | 0.615 | BSC | 0.180 |  | 0.060 | 0.098 |  | $15^{\circ}$ |
| 28 |  | 0.016 | 0.050 | 0.008 | 1.44 | 0.515 | 0.595 | 0.100 | 0.125 | 0.150 | 0.015 |  | 0.005 | $0^{\circ}$ |
|  | 0.225 | 0.023 | 0.065 | 0.015 | 1.47 | 0.535 | 0.615 | BSC | 0.180 |  | 0.060 | 0.098 | - | $15^{\circ}$ |
| 40 |  | 0.016 | 0.050 | 0.008 | 2.035 | 0.515 | 0.595 | 0.100 | 0.125 | $\underline{0.150}$ | 0.015 | - | $\underline{0.005}$ | $0^{\circ}$ |
|  | 0.225 | 0.023 | 0.065 | 0.015 | 2.096 | 0.535 | 0.615 | BSC | 0.180 |  | 0.060 | $\overline{0.098}$ |  | $15^{\circ}$ |

* Dimensions B and C maximum limits are increased by 0.003 for solder dip finısh.



## Dual-In-Line Metal-Seal Ceramic Packages




81 星.000 8-.0301.76) MAX[C][AO]

- A.040(1.02) बC AQE


18 LEAD DUAL-IN-LINE METAL-SEAL CERAMIC PACKAGE (JEDEC MS-015-AD)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.085 | 0.200 | 2.16 | 5.08 | 4 |
| $\mathrm{A}_{1}$ | 0.025 | 0.070 | 0.635 | 1.78 | 4 |
| B | 0.015 | 0.022 | 0.38 | 0.56 | 9 |
| $\mathrm{B}_{1}$ | 0.045 | 0.065 | 1.14 | 1.65 | - |
| C | 0.009 | 0.015 | 0.23 | 0.38 | 9 |
| D | 0.800 | 0.920 | 22.35 | 23.37 | 5 |
| E | 0.300 | 0.325 | 7.62 | 8.26 | 6 |
| $\mathrm{E}_{1}$ | 0.280 | 0.310 | 7.11 | 7.87 | 5 |
| e | 0.100 BSC |  | 2.54 BSC |  | - |
| $e_{\text {A }}$ | 0.300 BSC |  | 7.62 BSC |  | 6 |
| L | 0.125 | 0.200 | 3.18 | 5.08 | 4 |
| N | 18 |  | 18 |  | 8 |
| $\mathrm{Q}_{1}$ | 0.005 | - | 0.13 | $\bullet$ | 12 |
| $\mathrm{e}_{8}$ | - | 0.400 | - | 10.16 | 7 |
| ${ }^{\text {e }}$ | $0^{\circ}$ | - | $0^{\circ}$ | - | 7 |
| $\mathrm{S}_{1}$ | 0.005 | - | 0.13 | - | 13 |

NOTES:

1. Controlling dimension: Inch. In case of conflict between English and metric dimensions, the inch dimensions control.
2. Dimensioning and Tolerancing per ANSI Y14.5M-1982.
3. Symbols are defined in the "MS Series Symbol List" in Section 2.2 of publication No. 95.
4. Dimensions $A, A_{1}$ and $L$ are measured with the package seated in JEDEC seating plane gauge GS-3. Dimension $A$ includes the lid thickness, and may increase to 0.260 inches maximum when an EPROM lid is used.
5. D and $\mathrm{E}_{1}$ dimensions do not include particles (burrs and/or projections) of package material. Such particles shall not exceed 0.010 inches ( 0.25 mm ) per side. Includes allowances for glass overrun and meniscus, and lid-to-base mismatch.

16 LEAD DUAL-IN-LINE METAL-SEAL CERAMIC PACKAGE (JEDEC MS-015AC)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.085 | 0.200 | 2.16 | 5.080 | 4 |
| $A_{1}$ | 0.025 | 0.070 | 0.64 | 1.78 | 4 |
| B | 0.015 | 0.022 | 0.38 | 0.56 | 9 |
| $\mathrm{B}_{1}$ | 0.045 | 0.065 | 1.14 | 1.65 | - |
| C | 0.009 | 0.015 | 0.23 | 0.38 | 9 |
| D | 0.780 | 0.820 | 19.81 | 20.83 | 5 |
| E | 0.300 | 0.325 | 7.62 | 8.26 | 6 |
| $E_{1}$ | 0.280 | 0.310 | 7.11 | 7.87 | 5 |
| e | 0.100 BSC |  | 2.54 BSC |  | - |
| $\mathrm{e}_{\mathrm{A}}$ | 0.300 BSC |  | 7.62 BSC |  | 6 |
| L | 0.125 | 0.200 | 3.18 | 5.08 | 4 |
| N | 16 |  | 16 |  | 8 |
| $\mathrm{Q}_{1}$ | 0.005 | - | 0.13 | - | 12 |
| $e_{B}$ | - | 0.400 | $\bullet$ | 10.16 | 7 |
| ${ }^{\text {e }}$ | $0^{\circ}$ | - | $0^{\circ}$ | - | 7 |
| $\mathrm{S}_{1}$ | 0.005 | - | 0.13 | - | 13 |

22 LEAD DUAL-IN-LINE METAL-SEAL CERAMIC PACKAGE (JEDEC MS-015-BB)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.085 | 0.200 | 2.16 | 5.08 | 4 |
| $A_{1}$ | 0.025 | 0.070 | 0.64 | 1.78 | 4 |
| B | 0.015 | 0.022 | 0.38 | 0.56 | 9 |
| $\mathrm{B}_{1}$ | 0.045 | 0.065 | 1.14 | 1.65 | - |
| C | 0.009 | 0.015 | 0.23 | 0.38 | 9 |
| D | 1.060 | 1.100 | 26.92 | 27.94 | 5 |
| E | 0.400 | 0.425 | 10.16 | 10.80 | 6 |
| $E_{1}$ | 0.380 | 0.410 | 9.65 | 10.41 | 5 |
| e | 0.100 BSC |  | 2.54 BSC |  | - |
| $\mathrm{e}_{\mathrm{A}}$ | 0.400 BSC |  | 10.16 BSC |  | 6 |
| L | 0.125 | 0.200 | 3.18 | 5.08 | 4 |
| N | 22 |  | 22 |  | 8 |
| Q | 0.005 | - | 0.13 | - | 12 |
| $e_{8}$ | - | 0.500 | - | 12.70 | 7 |
| $\mathrm{e}_{\mathrm{C}}$ | $0^{\circ}$ | - | $0^{\circ}$ | - | 7 |
| $\mathrm{S}_{1}$ | 0.005 | - | 0.13 | - | 13 |

6. E and $e_{A}$ are measured with the leads constrained to be perpendicular to plane $C$.
7. $e_{\mathrm{B}}$ and $e_{\mathrm{C}}$ are measured at the lead tips with the leads unconstrained.
8. $N$ is the maximum number of terminal leads.
9. Maximum lead thickness includes all lead finishes. Minimum base material shall be 0.009 inches thick.
10. Any raised irregularity on the top surface (step, mass, etc.) shall be symmetrical about the lateral and longitudinal package centerlines.
11. Maximum fillet, including solder coat, if any.
12. Measured from the top of the ceramic body to the nearest metallization or lead.
13. Measured from the end of the ceramic body to the nearest metallization or lead.

## Dual-In-Line Metal-Seal Ceramic <br> Packages (Continued)



28 LEAD DUAL-IN-LINE METAL-SEAL CERAMIC PACKAGE (JEDEC MS-015-CB)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.085 | 0.200 | 2.16 | 5.08 | 4 |
| $\mathrm{A}_{1}$ | 0.025 | 0.070 | 0.64 | 1.78 | 4 |
| B | 0.015 | 0.022 | 0.38 | 0.56 | 9 |
| $\mathrm{B}_{1}$ | 0.045 | 0.065 | 1.14 | 1.65 | - |
| C | 0.009 | 0.015 | 0.23 | 0.38 | 9 |
| D | 1.380 | 1.420 | 35.05 | 36.07 | 5 |
| E | 0.600 | 0.625 | 15.24 | 15.88 | 6 |
| $\mathrm{E}_{1}$ | 0.580 | 0.610 | 14.73 | 15.49 | 5 |
| e | 0.100 BSC |  | 2.54 BSC |  | - |
| $\mathrm{e}_{\mathrm{A}}$ | 0.600 BSC |  | 15.24 BSC |  | 6 |
| L | 0.125 | 0.200 | 3.18 | 5.08 | 4 |
| N | 28 |  | 28 |  | 8 |
| $Q_{1}$ | 0.005 | - | 0.13 | - | 12 |
| $\mathrm{e}_{8}$ | - | 0.700 | - | 17.78 | 7 |
| $e_{C}$ | $0^{\circ}$ | - | $0^{\circ}$ | - | 7 |
| $\mathrm{S}_{1}$ | 0.005 | - | 0.13 | - | 13 |

NOTES:

1. Controlling dimension: Inch. In case of conflict between English and metric dimensions, the inch dimensions control.
2. Dimensioning and Tolerancing per ANSI Y14.5M-1982.
3. Symbols are defined in the "MS Series Symbol List" in Section 2.2 of publication No. 95.
4. Dimensions $A, A_{1}$ and $L$ are measured with the package seated in JEDEC seating plane gauge GS-3. Dimension $A$ includes the lid thickness, and may increase to 0.260 inches maximum when an EPROM lid is used.
5. $\mathbf{D}$ and $\mathrm{E}_{1}$ dimensions do not include particles (burrs and/or projections) of package material. Such particles shall not exceed 0.010 inches ( 0.25 mm ) per side. Includes allowances for glass overrun and meniscus, and lid-to-base mismatch.

## 24 LEAD DUAL-IN-LINE METAL-SEAL CERAMIC PACKAGE

 (JEDEC MS-015CA)| SYMBOL | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MAX | MIN | MAX | NOTES |  |
| A | 0.085 | 0.200 | 2.16 | 5.08 | 4 |
| $A_{1}$ | 0.025 | 0.070 | 0.64 | 1.78 | 4 |
| $B$ | 0.015 | 0.022 | 0.38 | 0.56 | 9 |
| $B_{1}$ | 0.045 | 0.065 | 1.14 | 1.65 | - |
| $C$ | 0.009 | 0.015 | 0.23 | 0.38 | 9 |
| $D$ | 1.180 | 1.220 | 29.97 | 30.99 | 5 |
| $E$ | 0.600 | 0.625 | 15.24 | 15.88 | 6 |
| $E_{1}$ | 0.580 | 0.610 | 14.73 | 15.49 | 5 |
| $\theta$ | 0.100 BSC |  | 2.54 BSC |  | - |
| $e_{A}$ | 0.600 BSC |  | 15.24 BSC | 6 |  |
| $L$ | 0.125 | 0.200 | 3.18 | 5.08 | 4 |
| $N^{2}$ | 24 |  |  | 24 | 8 |
| $Q_{1}$ | 0.005 | - | 0.13 | - | 12 |
| $e_{B}$ | - | 0.700 | - | 17.78 | 7 |
| $e_{C}$ | $0^{\circ}$ |  | - | $0^{\circ}$ | - |
| $S_{1}$ | 0.005 | - | 0.13 | - | 13 |

## 40 LEAD DUAL-IN-LINE METAL-SEAL CERAMIC PACKAGE

 (JEDEC MS-015-CE)| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.085 | 0.200 | 2.16 | 5.08 | 4 |
| $\mathrm{A}_{1}$ | 0.025 | 0.070 | 0.64 | 1.78 | 4 |
| B | 0.015 | 0.022 | 0.38 | 0.56 | 9 |
| $\mathrm{B}_{1}$ | 0.045 | 0.065 | 1.14 | 1.65 | - |
| C | 0.009 | 0.015 | 0.23 | 0.38 | 9 |
| D | 1.980 | 2.020 | 50.29 | 51.31 | 5 |
| E | 0.600 | 0.625 | 15.24 | 15.88 | 6 |
| $\mathrm{E}_{1}$ | 0.580 | 0.610 | 14.73 | 15.49 | 5 |
| e | 0.100 BSC |  | 2.54 BSC |  | - |
| $\theta_{\text {A }}$ | 0.600 BSC |  | 15.24 BSC |  | 6 |
| L | 0.125 | 0.200 | 3.18 | 5.08 | 4 |
| N | 40 |  | 40 |  | 8 |
| $Q_{1}$ | 0.005 | - | 0.13 | - | 12 |
| $\mathrm{e}_{8}$ | - | 0.700 | $\bullet$ | 17.78 | 7 |
| $e_{C}$ | $0^{\circ}$ | - | $0^{\circ}$ | - | 7 |
| $\mathrm{S}_{1}$ | 0.005 | - | 0.13 | - | 13 |

6. E and $e_{A}$ are measured with the leads constrained to be perpendicular to plane $C$.
7. $e_{B}$ and $e_{C}$ are measured at the lead tips with the leads unconstrained.
8. $N$ is the maximum number of terminal leads.
9. Maximum lead thickness includes all lead finishes. Minimum base material shall be 0.009 inches thick.
10. Any raised irregularity on the top surface (step, mass, etc.) shall be symmetrical about the lateral and longitudinal package centerlines.
11. Maximum fillet, including solder coat, if any.
12. Measured from the top of the ceramic body to the nearest metallization or lead.
13. Measured from the end of the ceramic body to the nearest metallization or lead.

## Dual-In-Line Plastic Packages


figure 1

18 LEAD DUAL-IN-LINE PLASTIC PACKAGE (JEDEC MS-001-AD)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.210 | - | 5.33 | 4 |
| $\mathrm{A}_{1}$ | 0.015 | - | 0.39 | - | 4 |
| $\mathrm{A}_{2}$ | 0.115 | 0.195 | 2.93 | 4.95 | - |
| B | 0.014 | 0.022 | 0.356 | 0.558 | $\cdot$ |
| $\mathrm{B}_{1}$ | 0.045 | 0.070 | 1.15 | 1.77 | 9 |
| C | 0.008 | 0.015 | 0.204 | 0.381 | - |
| D | 0.845 | 0.925 | 21.47 | 23.49 | 5 |
| D1 | 0.005 | - | 0.13 | - | - |
| E | 0.300 | 0.325 | 7.62 | 8.25 | 6 |
| $\mathrm{E}_{1}$ | 0.240 | 0.280 | 6.10 | 7.11 | 5 |
| e | 0.1 | SC |  | BSC | - |
| $\mathrm{e}_{\mathrm{A}}$ |  | SC |  | BSC | 6 |
| ${ }^{\text {e }}$ | - | 0.430 | - | 10.92 | 7 |
| L | 0.115 | 0.160 | 2.93 | 4.06 | 4 |
| N | 18 |  | 18 |  | 8 |

NOTES:

1. Controlling Dimensions: Inch. In case of conflict between English and Metric dimensions, the inch dimensions control.
2. Dimensioning and tolerancing per ANSI Y14.5M-1982.
3. Symbols are defined in the "MO Series Symbol List" in Section 2.2 of Publication No. 95.
4. Dimensions $A, A_{1}$ and $L$ are measured with the package seated in JEDEC seating plane gauge GS-3.
5. D and $\mathrm{E}_{1}$ dimensions do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.010 inch $(0.25 \mathrm{~mm})$.

16 LEAD DUAL-IN-LINE PLASTIC PACKAGE (JEDEC MS-001-AA)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.210 | - | 5.33 | 4 |
| $\mathrm{A}_{1}$ | 0.015 | - | 0.39 | - | 4 |
| $\mathrm{A}_{2}$ | 0.115 | 0.195 | 2.93 | 4.95 | - |
| B | 0.014 | 0.022 | 0.356 | 0.558 | - |
| $\mathrm{B}_{1}$ | 0.045 | 0.070 | 1.15 | 1.77 | 9 |
| C | 0.008 | 0.015 | 0.204 | 0.381 | - |
| D | 0.745 | 0.840 | 18.93 | 21.33 | 5 |
| D1 | 0.005 | - | 0.13 | - | - |
| E | 0.300 | 0.325 | 7.62 | 8.25 | 6 |
| $\mathrm{E}_{1}$ | 0.240 | 0.280 | 6.10 | 7.11 | 5 |
| e |  | BSC |  | BSC | - |
| $e_{A}$ |  | SC |  | BSC | 6 |
| $e_{B}$ | - | 0.430 | - | 10.92 | 7 |
| L | 0.115 | 0.160 | 2.93 | 4.06 | 4 |
| N | 16 |  | 16 |  | 8 |

20 LEAD DUAL-IN-LINE PLASTIC PACKAGE (JEDEC MS-001-AE)

| SYMBOL | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX | NOTES |
| $A$ | - | 0.210 | - | 5.33 | 4 |
| $A_{1}$ | 0.015 | - | 0.39 | - | 4 |
| $A_{2}$ | 0.115 | 0.195 | 2.93 | 4.95 | - |
| $B$ | 0.014 | 0.022 | 0.356 | 0.558 | - |
| $B_{1}$ | 0.045 | 0.070 | 1.15 | 1.77 | 9 |
| $C$ | 0.008 | 0.015 | 0.204 | 0.381 | - |
| $D$ | 0.925 | 1.060 | 23.50 | 26.90 | 5 |
| $D_{1}$ | 0.005 | - | 0.13 | - | - |
| $E$ | 0.300 | 0.325 | 7.62 | 8.25 | 6 |
| $E_{1}$ | 0.240 | 0.280 | 6.10 | 7.11 | 5 |
| $e$ | $0.100 ~ B S C$ | 2.54 BSC | - |  |  |
| $e_{A}$ | 0.300 BSC |  | 7.62 BSC |  | 6 |
| $e_{B}$ | - | 0.430 | - | 10.92 | 7 |
| $L$ | 0.115 | 0.160 | 2.93 | 4.06 | 4 |
| $N$ | 20 |  |  | 20 |  |
| 8 |  |  |  |  |  |

6. E and $e_{A}$ are measured with the leads constrained to be perpendicular to plane $C$.
7. $e_{\mathrm{B}}$ and $\mathrm{e}_{\mathrm{C}}$ are measured at the lead tips with the leads uncon strained. ect must be zero or greater.
8. $N$ is the maximum number of terminal positions.
9. Corner leads ( $1, N, N / 2$ and $N / 2+1$ ) may be configured as shown in Figure 2.

## Dual-In-Line Plastic Packages (Continued)



24 LEAD DUAL-IN-LINE PLASTIC PACKAGE (JEDEC MS-011-AA)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.250 | - | 6.35 | 4 |
| $\mathrm{A}_{1}$ | 0.015 | - | 0.39 | - | 4 |
| $\mathrm{A}_{2}$ | 0.125 | 0.195 | 3.18 | 4.95 | - |
| B | 0.014 | 0.022 | 0.356 | 0.558 | - |
| $\mathrm{B}_{1}$ | 0.030 | 0.070 | 0.77 | 1.77 | 9 |
| C | 0.008 | 0.015 | 0.204 | 0.381 | - |
| D | 1.150 | 1.290 | 29.3 | 32.7 | 5 |
| D1 | 0.005 | - | 0.13 | - | - |
| E | 0.600 | 0.625 | 15.24 | 15.87 | 6 |
| $E_{1}$ | 0.485 | 0.580 | 12.32 | 14.73 | 5 |
| e | 0.10 | SC |  | BSC | - |
| $\mathrm{e}_{\mathrm{A}}$ | 0.60 | SC |  | BSC | 6 |
| $\mathrm{e}_{\mathrm{B}}$ | - | 0.700 | - | 17.78 | 7 |
| L | 0.115 | 0.200 | 2.93 | 5.08 | 4 |
| N | 24 |  | 24 |  | 8 |

NOTES:

1. Controlling Dimensions: Inch

In case of conflict between English and Metric dimensions, the inch dimensions control.
2. Dimensioning and tolerancing per ANSI Y14.5M-1982.
3. Symbols are defined in the "MO Series Symbol List" in Section 2.2 of Publication No. 95.
4. Dimensions $A, A_{1}$ and $L$ are measured with the package seated in JEDEC seating plane gauge GS-3.
5. D and E1 dimensions do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.010 inch $(0.25 \mathrm{~mm})$.

22 LEAD DUAL-IN-LINE PLASTIC PACKAGE (JEDEC MS-010-AA)

| SYMBOL | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX | NOTES |
| $A$ | - | 0.210 | - | 5.33 | 4 |
| $A_{1}$ | 0.015 | - | 0.39 | - | 4 |
| $A_{2}$ | 0.125 | 0.195 | 3.18 | 4.95 | - |
| $B$ | 0.014 | 0.022 | 0.356 | 0.558 | - |
| $B_{1}$ | 0.030 | 0.070 | 0.77 | 1.77 | 9 |
| $C$ | 0.008 | 0.015 | 0.204 | 0.381 | - |
| $D$ | 1.050 | 1.120 | 26.67 | 28.44 | 5 |
| $D_{1}$ | 0.005 | - | 0.13 | - | - |
| $E$ | 0.390 | 0.425 | 9.91 | 10.79 | 6 |
| $E_{1}$ | 0.330 | 0.380 | 8.39 | 9.65 | 5 |
| $e$ | 0.100 BSC |  | 2.54 BSC |  | - |
| $e_{A}$ | 0.400 BSC |  | 10.16 BSC | 6 |  |
| $e_{B}$ | - | 0.500 | - | 12.70 | 7 |
| $L$ | 0.115 | 0.160 | 2.93 | 4.06 | 4 |
| $N$ | 22 |  | 22 |  | 8 |

28 LEAD DUAL-IN-LINE PLASTIC PACKAGE (JEDEC MS-011-AB)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.250 | - | 6.35 | 4 |
| $\mathrm{A}_{1}$ | 0.015 | - | 0.39 | - | 4 |
| $\mathrm{A}_{2}$ | 0.125 | 0.195 | 3.18 | 4.95 | - |
| B | 0.014 | 0.022 | 0.356 | 0.558 | - |
| $\mathrm{B}_{1}$ | 0.030 | 0.070 | 0.77 | 1.77 | 9 |
| C | 0.008 | 0.015 | 0.204 | 0.381 | - |
| D | 1.380 | 1.565 | 35.1 | 39.7 | 5 |
| D1 | 0.005 | - | 0.13 | - | - |
| E | 0.600 | 0.625 | 15.24 | 15.87 | 6 |
| $\mathrm{E}_{1}$ | 0.485 | 0.580 | 12.32 | 14.73 | 5 |
| e |  |  |  | BSC | - |
| $\mathrm{e}_{\mathrm{A}}$ |  |  |  | BSC | 6 |
| $e_{B}$ | - | 0.700 | - | 17.78 | 7 |
| L | 0.115 | 0.200 | 2.93 | 5.08 | 4 |
| N | 28 |  | 28 |  | 8 |

6. $E$ and $e_{A}$ are measured with the leads constrained to be perpendicular to plane $\mathbf{C}$.
7. $e_{B}$ and $e_{C}$ are measured at the lead tips with the leads unconstrained. ec must be zero or greater.
8. $N$ is the maximum number of terminal positions.
9. Corner leads ( $1, N, N / 2$ and $N / 2+1$ ) may be configured as shown in Figure 2.

## Dual-In-Line Plastic Packages (Continued)


figure 1
40 LEAD DUAL-IN-LINE PLASTIC PACKAGE (JEDEC MS-011-AC)

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.250 | - | 6.35 | 4 |
| $\mathrm{A}_{1}$ | 0.015 | - | 0.39 | - | 4 |
| $\mathrm{A}_{2}$ | 0.125 | 0.195 | 3.18 | 4.95 | - |
| B | 0.014 | 0.022 | 0.356 | 0.558 | - |
| $\mathrm{B}_{1}$ | 0.030 | 0.070 | 0.77 | 1.77 | 9 |
| C | 0.008 | 0.015 | 0.204 | 0.381 | - |
| D | 1.980 | 2.095 | 50.3 | 53.2 | 5 |
| D1 | 0.005 | $\bullet$ | 0.13 | - | - |
| E | 0.600 | 0.625 | 15.24 | 15.87 | 6 |
| $\mathrm{E}_{1}$ | 0.485 | 0.580 | 12.32 | 14.73 | 5 |
| e | 0.10 | BSC |  | BSC | - |
| $\mathrm{e}_{\mathrm{A}}$ |  | BC |  | BSC | 6 |
| ${ }^{\text {e }}$ | - | 0.700 | - | 17.78 | 7 |
| L | 0.115 | 0.200 | 2.93 | 5.08 | 4 |
| N | 40 |  | 40 |  | 8 |

6. $E$ and $e_{A}$ are measured with the leads constrained to be perpendicular to plane C .
7. $e_{\mathrm{B}}$ and $e_{\mathrm{C}}$ are measured at the lead tips with the leads unconstrained. ec must be zero or greater.
8. N is the maximum number of terminal positions.
9. Corner leads ( $1, N, N / 2$ and $N / 2+1$ ) may be configured as shown in Figure 2.

Small Outline（SO）Plastic Packages


20 LEAD DUAL－IN－LINE SMALL OUTLINE PLASTIC PACKAGE （JEDEC MS－013－AC）

| SYMBOL | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.0926 | 0.1043 | 2.35 | 2.65 | - |
| A $_{1}$ | 0.0040 | 0.0118 | 0.10 | 0.30 | - |
| B | 0.013 | 0.0200 | 0.33 | 0.51 | 9 |
| C | 0.0091 | 0.0125 | 0.23 | 0.32 | - |
| D | 0.4961 | 0.5118 | 12.60 | 13.00 | 3 |
| E | 0.2914 | 0.2992 | 7.40 | 7.60 | 4 |
| e | 0.050 BSC |  | 1.27 BSC |  | - |
| H | 0.394 | 0.419 | 10.00 | 10.65 | - |
| h | 0.010 | 0.029 | 0.25 | 0.75 | 5 |
| L | 0.016 | 0.050 | 0.40 | 1.27 | 6 |
| N | 20 |  | 20 |  | 7 |
| $\propto$ | $0^{\circ}$ |  | $8^{\circ}$ | 0 | $8^{\circ}$ |

NOTES：
1．Refer to applicable symbol list．
2．Dimensioning and tolerancing per ANSI Y14．5M－1982．
3．Dimension＂D＂does not include mold flash，protusions or gate burrs． Mold flash，protusion and gate burrs shall not exceed $015 \mathrm{~mm}(0.006$ in．）per side．
4．Dimension＂E＂does not include interlead flash or protusions．
Interlead flash and protrusions shall not exceed 0.25 mm （ 0010 in ） per side．
5．The chamfer on the body is optional．If it is not present，a visual index feature must be located within the crosshatched area．

16 LEAD DUAL－IN－LINE SMALL OUTLINE PLASTIC PACKAGE （JEDEC MS－013－AA）

| SYMBOL | INCHES |  | MILLIMETERS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |  |  |  |  |
| A | 0.0926 | 0.1043 | 2.35 | 2.65 | - |  |  |  |  |  |
| A $_{1}$ | 0.0040 | 0.0118 | 0.10 | 0.30 | - |  |  |  |  |  |
| B | 0.0138 | 0.020 | 0.35 | 0.508 | - |  |  |  |  |  |
| C | 0.0091 | 0.0125 | 0.23 | 0.32 | - |  |  |  |  |  |
| D | 0.3977 | 0.4133 | 10.10 | 10.50 | 4 |  |  |  |  |  |
| E | 0.2914 | 0.2992 | 7.40 | 7.60 | 4 |  |  |  |  |  |
| $e$ | 0.050 |  | BSC | 1.27 |  |  |  |  |  |  |
| BSC |  |  |  |  |  |  |  |  |  |  |
| H | 0.394 | 0.419 | 10.00 | 10.65 | - |  |  |  |  |  |
| $h$ | 0.010 | 0.029 | 0.25 | 0.75 | 5 |  |  |  |  |  |
| L | 0.016 | 0.050 | 0.40 | 1.27 | 6 |  |  |  |  |  |
| N | 16 |  |  |  |  |  |  |  | 16 | 7 |
| $\alpha$ | $0^{\circ}$ | $8^{\circ}$ | $0^{\circ}$ | $8^{\circ}$ | - |  |  |  |  |  |

24 LEAD DUAL－IN－LINE SMALL OUTLINE PLASTIC PACKAGE （JEDEC MS－013－AD）

| SYMBOL | INCHES |  | MILLIMETERS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |
| A | 0.0926 | 0.1043 | 2.35 | 2.65 | - |  |
| A $_{1}$ | 0.0040 | 0.0118 | 0.10 | 0.30 | - |  |
| B | 0.0138 | 0.0200 | 0.35 | 0.508 | - |  |
| C | 0.0091 | 0.0125 | 0.23 | 0.32 | - |  |
| D | 0.5985 | 0.6141 | 15.20 | 15.60 | 4 |  |
| E | 0.2914 | 0.2992 | 7.40 | 7.60 | 4 |  |
| e | 0.050 BSC |  | 1.27 BSC |  | - |  |
| H | 0.394 | 0.419 | 10.00 | 10.65 | - |  |
| h | 0.010 | 0.029 | 0.25 | 0.75 | 5 |  |
| L | 0.016 | 0.050 | 0.40 | 1.27 | 6 |  |
| N | 24 |  | 24 |  | 7 |  |
| $\propto$ | $0^{\circ}$ |  | $8^{\circ}$ | $0^{\circ}$ |  | $8^{\circ}$ |

6．＂$L$＂is the length of terminal for soldering to a substrate．
7．＂ N ＂is the number of terminal positions．
8．Terminal numbers are shown for reference only．
9．The lead width＂$B$＂，as measured 0.36 mm （ 0.014 in ．）or greater above the seating plane，shall not exceed a maximum value of 0.61 mm （ 0.024 in ）

10．Controlling dimension：MILLIMETER．Converted inch dimensions are not necessarily exact．

## Leadless Chip Carriers

| LEAD COUNT | DIM. A | DIM. A1 | DIM. $\mathrm{B1}$ | DIM. D | DIM. E | DIM. $e$ | DIM. L | DIM. L2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 18 Rectangular | $\frac{0.054}{0.075}$ | $\frac{0.040}{0.063}$ | $\frac{0.020}{0.030}$ | $\frac{0.280}{0.295}$ | $\frac{0.345}{0.360}$ | 0.050 BSC | $\frac{0.040}{0.050}$ | $\frac{0.090}{0.110}$ |
| 20 Square | $\frac{0.070}{0.097}$ | $\frac{0.050}{0.080}$ | $\frac{0.022}{0.028}$ | $\frac{0.342}{0.358}$ | $\frac{0.342}{0.358}$ | 0.050 BSC | $\frac{0.045}{0.055}$ | $\frac{0.075}{0.095}$ |
| 20 Rectangular | $\frac{0.070}{0.097}$ | $\frac{0.050}{0.080}$ | $\frac{0.022}{0.028}$ | $\frac{0.280}{0.296}$ | $\frac{0.419}{0.440}$ | 0.050 BSC | $\frac{0.045}{0.055}$ | $\frac{0.075}{0.095}$ |
| 28 Square | $\frac{0.070}{0.097}$ | $\frac{0.050}{0.080}$ | $\frac{0.022}{0.028}$ | $\frac{0.440}{0.460}$ | $\frac{0.440}{0.460}$ | 0.050 BSC | $\frac{0.045}{0.055}$ | $\frac{0.075}{0.095}$ |
| 32 Rectangular | $\frac{0.070}{0.097}$ | $\frac{0.050}{0.080}$ | $\frac{0.022}{0.028}$ | $\frac{0.442}{0.458}$ | $\frac{0.540}{0.560}$ | 0.050 BSC | $\frac{0.045}{0.055}$ | $\frac{0.075}{0.095}$ |
| 44 Square | $\frac{0.073}{0.096}$ | $\frac{0.063}{0.084}$ | $\frac{0.022}{0.028}$ | $\frac{0.643}{0.662}$ | $\frac{0.643}{0.662}$ | 0.050 BSC | $\frac{0.045}{0.055}$ | $\frac{0.075}{0.095}$ |



## 68 Pin Grid Array (PGA)

80C286



28 LEAD PLASTIC LEADED CHIP CARRIER PACKAGE (JEDEC MO-047AB)

| SYMBOL | INCHES |  | MILLIMETERS |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |  |  |
| A | 0.165 | 0.180 | 4.20 | 4.57 | - |  |  |  |
| $A_{1}$ | 0.090 | 0.120 | 2.29 | 3.04 | - |  |  |  |
| $D$ | 0.485 | 0.495 | 12.32 | 12.57 |  |  |  |  |
| $D_{1}$ | 0.450 | 0.456 | 11.430 | 11.582 | 2 |  |  |  |
| $D_{2}$ | 0.390 | 0.430 | 9.91 | 10.92 | 1 |  |  |  |
| $D_{3}$ | 0.300 REF |  | 7.62 BSC |  | - |  |  |  |
| $E_{1}$ | 0.485 | 0.495 | 12.32 | 12.57 | - |  |  |  |
| $E_{1}$ | 0.450 | 0.456 | 11.430 | 11.582 | 2 |  |  |  |
| $E_{2}$ | 0.390 | 0.430 | 9.91 | 10.92 | 1 |  |  |  |
| $E_{3}$ | 0.300 REF |  |  | 7.62 BSC |  |  |  |  |
| $N$ | 28 |  |  |  | 28 |  |  | 3 |

20 LEAD PLASTIC LEADED CHIP CARRIER PACKAGE (JEDEC MO-047AA)

|  | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | MIN | MAX | MIN | MAX |  |
| A | 0.165 | 0.180 | 4.20 | 4.57 | - |
| $A_{1}$ | 0.090 | 0.120 | 2.29 | 3.04 | - |
| $D$ | 0.385 | 0.395 | 9.78 | 10.03 | - |
| $D_{1}$ | 0.350 | 0.356 | 8.89 | 9.042 | 2 |
| $D_{2}$ | 0.290 | 0.330 | 7.37 | 8.38 | 1 |
| $D_{3}$ | 0.200 REF |  | 5.08 BSC |  | - |
| $E$ | 0.385 | 0.395 | 9.78 | 10.03 | - |
| $E_{1}$ | 0.350 | 0.356 | 8.89 | 9.042 | 2 |
| $E_{2}$ | 0.290 | 0.330 | 7.37 | 8.38 | 1 |
| $E_{3}$ | 0.200 REF |  | 5.08 BSC |  |  |
| $N$ | 20 |  |  |  |  |

44 LEAD PLASTIC LEADED CHIP CARRIER PACKAGE (JEDEC MO-047AC)

| SYMBOL | INCHES |  | MILLIMETERS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |
| A | 0.165 | 0.180 | 4.20 | 4.57 | - |  |
| $A_{1}$ | 0.090 | 0.120 | 2.29 | 3.04 | - |  |
| $D$ | 0.685 | 0.695 | 17.40 | 17.65 |  |  |
| $D_{1}$ | 0.650 | 0.656 | 16.510 | 16.662 | 2 |  |
| $D_{2}$ | 0.590 | 0.630 | 14.99 | 16.00 | 1 |  |
| $D_{3}$ | 0.500 REF |  | 12.70 BSC |  | - |  |
| $E$ | 0.685 | 0.695 | 17.40 | 17.65 | - |  |
| $E_{1}$ | 0.650 | 0.656 | 16.510 | 16.662 | 2 |  |
| $E_{2}$ | 0.590 | 0.630 | 14.99 | 16.00 | 1 |  |
| $E_{3}$ | 0.500 REF |  | 12.70 BSC |  | - |  |
| $N$ | 44 |  |  |  | 44 |  |

68 LEAD PLASTIC LEADED CHIP CARRIER PACKAGE (JEDEC MO-047AE)

| SYMBOL | INCHES |  | MILLIMETERS |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |  |  |
| A | 0.165 | 0.200 | 4.20 | 5.08 | - |  |  |  |
| $A_{1}$ | 0.090 | 0.130 | 2.29 | 3.30 | - |  |  |  |
| $D^{2}$ | 0.985 | 0.995 | 25.02 | 25.27 |  |  |  |  |
| $D_{1}$ | 0.950 | 0.958 | 24.13 | 24.33 | 2 |  |  |  |
| $D_{2}$ | 0.890 | 0.930 | 22.61 | 23.62 | 1 |  |  |  |
| $D_{3}$ | 0.800 REF |  | 20.32 BSC |  | - |  |  |  |
| $E^{2}$ | 0.985 | 0.995 | 25.02 | 25.27 | - |  |  |  |
| $E_{1}$ | 0.950 | 0.958 | 24.13 | 24.33 | 2 |  |  |  |
| $E_{2}$ | 0.890 | 0.930 | 22.61 | 23.62 | 1 |  |  |  |
| $E_{3}$ | 0.800 REF |  | 20.32 BSC |  | - |  |  |  |
| $N$ | 68 |  |  |  | 68 |  |  | 3 |

NOTES:

1. To be determined at seating plane.
2. Dimensions D1 and E1 do not include mold protrusions.

Allowable mold protrusion is $0.254 \mathrm{~mm} / 0.010 \mathrm{in}$.
3. " N " is the number of terminal positions.
4. Controlling dimensions: Inch.

## Module Substrate

28 LEAD
HM-8808/08A, HM-8832


## 40 LEAD <br> HM-6564



48 LEAD
HM-92570, HM-91M2



## SALES OFFICES

A complete and current listing of all Harris Sales, Representative and Distributor locations worldwide is available. Please order the Harris Sales Listing, BR-007 from the Literature Center or Harris AnswerFAX (see page i).
HARRIS HEADQUARTER LOCATIONS BY COUNTRY:
U.S. HEADQUARTERS

Harris Semiconductor 2401 Palm Bay Road N. E. Palm Bay, Florida 32905
TEL: (407) 724-7000

## SOUTH ASIA

Harris Semiconductor H.K. Ltd 13/F Fourseas Building 208-212 Nathan Road Tsimshatsui, Kowloon Hong Kong TEL: (852) 723-6339

## EUROPEAN HEADQUARTERS

Harris Semiconductor
Mercure Center
100, Rue de la Fusee
1130 Brussels, Belgium
TEL: 3227242111
NORTH ASIA
Harris K.K.
Kojimachi-Nakata Bldg. 4F
5-3-5 Kojimachi
Chiyoda-ku, Tokyo 102 Japan
TEL: (81) 3-3265-7571
TEL: (81) 3-3265-7572 (Sales)

HARRIS TECHNICAL ASSISTANCE AVAILABILITY:
UNITED STATES

|  | CALIFORNIA |  |
| :---: | :---: | :---: |
|  | FLORIDA | Palm Bay . . . . . . . . . . . . . . . . . . . . . . . . . 407-729-4984 |
|  | GEORGIA | Duluth. . . . . . . . . . . . . . . . . . . . . . . . . . . 404-476-2035 |
|  | ILLINOIS | Schaumburg. . . . . . . . . . . . . . . . . . . . . . 708-240-3480 |
|  | INDIANA | Carmel . . . . . . . . . . . . . . . . . . . . . . . . . . 317-843-5180 |
|  | MASSACHUSETTS | Burlington. . . . . . . . . . . . . . . . . . . . . . . . 617-221-1850 |
|  | NEW JERSEY | Voorhees . . . . . . . . . . . . . . . . . . . . . . . . 609-751-3425 |
|  | NEW YORK | Hauppauge . . . . . . . . . . . . . . . . . . . . . . . . . . . 916-342-0291 Wappingers Falls . . . . . . . . . . . . . . |
|  | TEXAS | Dallas. . . . . . . . . . . . . . . . . . . . . . . . . . 214-733-0800 |
| INTERNATIONAL |  |  |
|  | FRANCE | Paris. . . . . . . . . . . . . . . . . . . . . . . . . .33-1-346-54046 |
|  | GERMANY | Munich . . . . . . . . . . . . . . . . . . . . . . . . . 49-89-63813-0 |
|  | HONG KONG | Kowloon . . . . . . . . . . . . . . . . . . . . . . . . . 852-723-6339 |
|  | ITALY | Milano . . . . . . . . . . . . . . . . . . . . . . . . .39-2-262-0761 |
|  | JAPAN | Tokyo . . . . . . . . . . . . . . . . . . . . . . . . .81-3-3265-7571 |
|  | KOREA | Seoul . . . . . . . . . . . . . . . . . . . . . . . . . .82-2-551-0931 |
|  | SINGAPORE | Singapore. . . . . . . . . . . . . . . . . . . . . . . . . 65-291-0203 |
|  | TAIWAN | Taipei . . . . . . . . . . . . . . . . . . . . . . . . .886-2-716-9310 |
|  | UNITED KINGDOM | Camberley . . . . . . . . . . . . . . . . . . . . . .44-2-766-86886 |

For literature requests, please contact Harris at 1-800-442-7747 (1-800-4HARRIS),


* Field Application Assistance Avallable


North American Authorized Distributors and Corporate Offices
Hamilton Hallmark and Zeus are the only authorized North American distributors for stocking and sale of Harris Rad Hard Space products．

## Alliance Electronics

7550 E．Redfield Rd． Scottsdale，AZ 85260
TEL：（602）483－9400
FAX：（602） 4433898
Arrow／Schweber
Electronics Group
25 Hub Dr．
Melville，NY 11747
TEL：（516）391－1300
FAX： 5163911644
Electronics Marketing
Corporation（EMC）
1150 West Third Avenue
Columbus，OH 43212
TEL：（614）299－4161
FAX： 6142994121

Farnell Electronic Services
（Formerly ITT Multicomponents） 300 North Rivermede Rd．
Concord，Ontario
Canada L4K 3N6
TEL：（416）798－4884
FAX： 4167984889
Gerber Electronics
128 Carnegie Row Norwood，MA 02062
TEL：（617）769－6000，x156
FAX： 6177628931

Hamilton Hallmark
10950 W．Washington Blvd．
Culver City，CA 90230
TEL：（310）558－2000
FAX： 3105582809 （Mil）
FAX： 214343 5988（Com）
Newark Electronics
4801 N．Ravenswood
Chicago，IL 60640
TEL：（312）784－5100
FAX： 312 275－9596
Wyle Laboratories
（Commercial Products）
3000 Bowers Avenue
Santa Clara，CA 95051
TEL：（408）727－2500
FAX： 408 988－2747

## Zeus Electronics，

An Arrow Company 100 Midiand Avenue Pt．Chester，NY 10573 TEL：（914）937－7400 TEL：（800）52－HI－REL FAX： 914 937－2553
Obsolete Products：
Rochester Electronic
10 Malcom Hoyt Drive Newburyport，MA 01950
TEL：（508）462－9332
FAX： 5084629512

## North American Authorized Distributors

ALABAMA
Arrow／Schweber
Huntsville
TEL：（205）837－6955
Hamilton Hallmark
Huntsville
TEL：（205）837－8700
Wyle Laboratories
Huntsville
TEL：205）830－1119
Zeus，An Arrow Company Huntsville
TEL：（407）333－3055
TEL：（800）52－HI－REL

| ARIZONA |
| :--- |
| Alliance Electronics，Inc． |
| GIlbert |
| TEL：（602）813－0233 |
| Scottsdale |
| TEL：（602）483－9400 |
| Arrow／Schweber |
| Tempe |
| TEL：（602）431－0030 |
| Hamilton Hallmark |
| Phoenix |
| TEL：（602）437－1200 |
| Wyle Laboratories |
| Phoenix |
| TEL：（602）437－2088 |


| Zeus，An Arrow Company |
| :--- |
| Tempe |
| TEL：（408）629－4789 |
| TEL：（800）52－HI－REL |
| CALIFORNIA |
| Alliance Electronics，Inc． |
| Santa Clarta |
| TEL：（805）297－6204 |
| Arrow／Schweber |
| Calabasas |
| TEL：（818）880－9686 |
| Fremont |
| TEL：（408）432－7171 |
| Irvine |
| TEL：（714）587－0404 |

San Diego
TEL：（619）565－4800
San Jose
TEL：（408）441－9700
Hamilton Hallmark
Costa Mesa
TEL：（714）641－4100
Los Angeles
TEL：（818）594－0404
Sacramento
TEL：（916）624－9781
San Diego
TEL：（619）571－7540
San Jose
TEL：（408）435－3500

[^27]| Wyle Laboratories Calabasas <br> TEL: (818) 880-9000 | Zeus, An Arrow Company <br> TEL: (408) 629-4789 <br> TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ | Wyle Laboratories Addison <br> TEL: (708) 620-0969 | Zeus, An Arrow Company Wilmington, MA <br> TEL: (508) 658-4776 |
| :---: | :---: | :---: | :---: |
| Irvine TEL: (714) 863-9953 | CONNECTICUT | Zeus, An Arrow Company Itasca | TEL: (800) HI-REL |
| Rancho Cordova <br> TEL: (916) 638-5282 | Alliance Electronics, Inc. Shelton <br> TEL: (203) 926-0087 | TEL: (708) 250-0500 <br> TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ | MICHIGAN Arrow/Schweber Livonia |
| San Diego <br> TEL: (619) 565-9171 | Arrow/Schweber Wallingford | $\begin{aligned} & \text { INDIANA } \\ & \text { Arrow/Schweber } \end{aligned}$ | TEL: (313) 462-2290 |
| Santa Clara | TEL: (203) 265-7741 | Indianapolis | Detroit |
| TEL: (408) 727-2500 | Hamilton Hallmark | TEL: (317) 299-2071 | TEL: (313) 347-4271 |
| Zeus, An Arrow Company | Danbury | Hamilton Hallmark | Zeus, An Arrow Company |
| San Jose | TEL: (203) 271-2844 | Indianapolis | TEL: (708) 250-0500 |
| TEL: (408) 629-4789 | Zeus, An Arrow Company | TEL: (317) 872-8875 | TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ |
| TEL: (800) 52-HI-REL | TEL: (914) 937-7400 | Zeus, An Arrow Company |  |
| Irvine <br> TEL: (714) 921-9000 | TEL: (800) 52-HI-REL | TEL: (708) 250-0500 <br> TEL: (800) 52-HI-REL | MINNESOTA Arrow/Schweber |
| TEL: (800) 52-HI-REL | FLORIDA <br> Arrow/Schweber | IOWA | Eden Prarie <br> TEL: (612) 941-5280 |
| CANADA | Deerfield Beach | Arrow/Schweber | Hamilton Hallmark |
| Arrow/Schweber | TEL: (305) 429-8200 | Cedar Rapids | Minneapolis |
| Burnaby, British Columbia | Lake Mary | TEL: (319) 395-7230 | TEL: (612) 881-2600 |
| TEL: (604) 421-2333 | TEL: (407) 333-9300 | Hamilton Halimark | Wyle Laboratories |
| Dorval, Quebec <br> TEL: (514) 421-7411 | Hamilton Hallmark Miami | Cedar Rapids <br> TEL: (319) 362-4757 | Minneapolis <br> TEL: (612) 853-2280 |
| Nepan, Ontario <br> TEL: (613) 226-6903 | TEL: (305) 484-5482 Orlando | Zeus, An Arrow Company <br> TEL: (214) 380-4330 | Zeus, An Arrow Company TEL: (214) 380-4330 |
| Mississagua, Ontario | TEL: (407) 657-3300 | TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ | TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ |
| TEL: (905) 670-7769 | Largo | KANSAS | MISSOURI |
| Farnell Electronic Services | TEL: (816) 541-7440 | Arrow/Schweber | Arrow/Schweber |
| Burnaby, British Columbia <br> TEL: (604) 291-8866 | Wyle Laboratories Fort Lauderdale | $\begin{aligned} & \text { Lenexa } \\ & \text { TEL: (913) 541-9542 } \end{aligned}$ | St. Louis TEL: (314) 567-68 |
| Calgary, Alberta | TEL: (305) 420-0500 | Hamilton Hallmark | Hamilton Hallmark |
| TEL: (403) 273-2780 | St. Petersburg | Kansas City | St. Louis |
| Concord, Ontario | TEL: (813) 576-3004 | TEL: (913) 888-4747 | TEL: (314) 291-5350 |
| TEL.: (416) 798-4884 | Zeus, An Arrow Company | Zeus, An Arrow Company | Zeus, An Arrow Company |
| V. St. Laurent, Quebec TEL: (514) 335-7697 | Lake Mary | TEL: (214) 380) $52-\mathrm{HI}$-REL | TEL: (214) 380-4330 <br> TEL: (800) 52 -HI-REL |
| Nepean, Ontario <br> TEL: (613) 596-6980 | TEL: (800) 52-HI-REL | MARYLAND | NEW JERSEY |
| Winnipeg, Manitoba TEL: (204) 786-2589 | GEORGIA Arrow/Schweber Duluth | Columbia <br> TEL: (301) 596-7800 | Arrow/Schweber <br> Marlton <br> TEL: (609) 596-8000 |
| Hamilton Hallmark Mississagua, Ontario | TEL: (404) 497-1300 | Hamilton Hallmark Baltimore | Pinebrook |
| MEL: (905) 564-6060 | Hamilton Hallmark | TEL: (410) 988-9800 | TEL: (201) 227-7880 |
| Montreal <br> TEL: (514) 335-1000 | Attanta TEL: (404) 623-5475 Wyle Laboratories | Wyle Laboratories Columbia | Hamilton Hallmark Cherry Hill |
| Ottawa | Wyle Laboratories Duluth | TEL: (410) 312-4844 | TEL: (609) 424-0110 |
| TEL: (613) 226-1700 | TEL: (404) 441-9045 | Zeus, An Arrow Company | $\begin{aligned} & \text { Parsippany } \\ & \text { TEL: (201) 515-1641 } \end{aligned}$ |
| Vancouver, B.C. <br> TEL: (604) 420-4101 | Zeus, An Arrow Company <br> TEL: (407) 333-3055 | TEL: (800) 52-HI-REL | Wyle Laboratories Mt. Laurel |
| Toronto | TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ | MASSACHUSETTS | TEL: (609) 439-9110 |
|  | ILLINOIS Alliance Electronics, Inc. | Alliance Electronics, Inc. Winchester | Pine Brook <br> TEL: (201) 882-8358 |
| COLORADO <br> Arrow/Schweber Englewood TEL: (303) 799-0258 |  | TEL: (617) 756-1910 | Zeus, An Arrow Company |
|  | TEL: (708) 949-9890 | Arrow/Schweber Wilmington | TEL: (914) 937-7400 |
|  | Arrow/Schweber | TEL: (508) 658-0900 | TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ |
| Hamilton Hallmark Denver TEL: (303) 790-1662 | Itasca <br> TEL: (708) 250-0500 <br> Hamilton Hallmark | Gerber <br> Norwood <br> TEL: (617) 769-6000 | NEW MEXICO Hamilton Hallmark Albuquerque |
| Colorado Springs TEL: (719) 637-0055 | Chicago <br> TEL: (708) 860-7780 | Hamilton Halimark Peabody | TEL: (505) 828-1058 |
|  | Newark Electronics, Inc. |  | Zeus, An Arrow Company <br> TEL: (408) 629-4789 |
| Thornton | Chicago (312) 907-5436 | Wyle Laboratories Burlington (617) 272-7300 | TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ |

[^28]| NEW YORK |
| :--- |
| Alliance Electronics，Inc． |
| Binghamton |
| TEL：（607）648－8833 |
| Huntington |
| TEL：（516）673－1930 |
| Arrow／Schweber |
| Farmingdale |
| TEL：（516）293－6363 |
| Hauppauge |
| TEL：（516）231－1000 |
| Melville |
| TEL：（516）391－1276 |
| TEL：（516）391－1300 |
| TEL：（516）391－1633 |
| Rochester |
| TEL：（716）427－0300 |
| Hamilton Hallmark |
| Long Island |
| TEL：（516）434－7400 |
| Rochester |
| TEL：（716）475－9130 |
| Ronkonkoma |
| TEL：（516）737－0600 |
| Zeus，An Arrow Company |
| Pt．Chester |
| TEL：（914）937－7400 |
| TEL：（800）52－HI－REL |
| NORTH CAROLINA |
| Arrow／Schweber |
| Raleigh |
| TEL：（919）876－3132 |
| EMC |
| Charlotte |
| TEL：（704）394－6195 |
| Hamilton Hallmark |
| Raleigh |
| TEL：（919）872－0712 |
| Zeus，An Arrow Company |
| TEL：（407）333－3055 |
| TEL：（800）52－HI－REL |
| Cente |
| Alliance Electronics，Inc． |
| Dayton |
| TEL：（513）433－7700 |
| Arrow／Schweber |
| Solon |
| TEL： 216 ）248－3990 |

EMC
Columbus
TEL：（614）299－4161
Hamilton Hallmark
Cleveland
TEL：（216）498－1100
Columbus
TEL：（614）888－3313
Dayton
TEL：（513）439－6735
Toledo
TEL：（419）242－6610
Zeus，An Arrow Company
TEL：（708）595－9730
TEL：（800）52－HI－REL
Arrow／Schweber
Austin
TEL：（512）835－4180
Dallas
TEL：（214）380－6464
Houston
TEL：（713）647－6868
Hamilton Hallmark
Austin
TEL：（512）258－8848
Dallas
TEL：（214）553－4300
Houston
TEL：（713）781－6100
Wyle Laboratories

Austin
TEL：（512）345－8853
Houston
TEL：（713）879－9953
Richardson
TEL：（214）235－9953
Zeus，An Arrow Company
Carrollton
TEL：（214）380－4330
TEL：（800）52－HI－REL

## UTAH

Salt Lake City
TEL：（801）973－6913
Hamilton Hallmark
Salt Lake City
TEL：（801）266－2022
Wyle Laboratories
West Valley City
TEL：（801）974－9953
Zeus，An Arrow Company
TEL：（408）629－4789
TEL：（800）52－HI－REL
WASHINGTON
Almac／Arrow
Bellevue
TEL：（206）643－9992
Hamilton Hallmark
Seattle
TEL：（206）881－6697
Wyle Laboratories
Redmond
TEL：（206）881－1150
Zeus，An Arrow Company
TEL：（408）629－4789
TEL：（800）52－HI－REL

| WISCONSIN |
| :--- |
| Arrow／Schweber |
| Brookfield |
| TEL：（414）792－0150 |
| Hamilton Halimark |
| Mikwaukee |
| TEL：（414）780－7200 |
| Wyle Laboratories |
| Waukesha |
| TEL：（414）521－9333 |
| Zeus，An Arrow Company |
| TEL：（708）250－0500 |
| TEL：（800）52－HI－REL |

## Harris Semiconductor

 Chip DistributorsChip Supply，Inc．
7725 N．Orange Blossom Trail Orlando，FL 32810－2696
TEL：（407）298－7100
FAX：（407）290－0164
Elmo Semiconductor Corp．
7590 North Glenoaks Blvd．
Burbank，CA 91504－1052
TEL：（818）768－7400
FAX：（818）767－7038
Minco Technology Labs，Inc． 1805 Rutherford Lane
Austin，TX 78754
TEL：（512）834－2022
FAX：（512）837－6285

## Puerto Rican

Authorized Distributor Hamilton Hallmark
TEL：（809）731－1110

## South American

## Authorized Distributor

Graftec Electronic Sales Inc． One Boca Place，Suite 305 East 2255 Glades Road Boca Raton，Florida 33431
TEL．：（407）994－0933
FAX： 407 994－5518

## BRASIL

Graftec Electronics
Av．Moema 538
04077－022 Sao Paulo－SP
Brasil
TEL： 01155115722727
FAX： 01155115757519

## European Sales Offices and Representatives

European Sales Headquarters

Harris S．A．
Mercure Center
Rue de la Fusee 100
B－1130 Brussels，Belgium
TEL： 3227242111
FAX： 322724 2205／．．． 09
AUSTRIA
Eurodis Electronics GmbH
Lamezanstrasse 10
A－ 1232 Vienna
TEL： $43161062-0$
FAX： 431610625

| DENMARK |
| :--- |
| Delco AS |
| Titangade 15 |
| DK－ 2200 Copenhagen $N$ |
| TEL： 4535821200 |
| FAX： 4535821205 |

FINLAND
J．Havulinna \＆Son
Reinikkalan Kartano
SF－ 51200 Kangasniemi
TEL： 35859432031
FAX： 35859432367

[^29]

[^30]| GERMANY <br> Avnet/E2000 <br> Stahlgruberring, 12 <br> D - 81829 München <br> TEL: 49894511001 <br> FAX: 498945110129 <br> EBV Elektronik GmbH <br> * Hans-Pinsel-Strasse 4 D - 85540 Haar-bei-München TEL: 4989 45610-0 <br> FAX: 4989464488 | Lasi Elettronica Viale Fulvio Testi 280 I - 20126 Milano TEL: 39266101370 FAX: 39266101385 Silverstar Viale Fulvio Testi 280 I - 20126 Milano TEL: 392661251 FAX: 39266101359 | Bexab Sweden AB P.O. Box 523 Kemistvagen, 10A S - 18325 Taby TEL: 4686308800 FAX: 4687327058 <br> SWITZERLAND <br> Avnet E2000 AG Boehirainstrasse 11 CH - 8801 Thalwil TEL: 4117221330 | Micromark Electronics <br> Boyn Valley Road <br> Maidenhead <br> Berkshire SL6 4DT <br> TEL: 4462876176 <br> FAX: 44628783799 <br> Thame Components <br> Thame Park Rd. <br> Thame, Oxfordshire OX9 3UQ <br> TEL: 44844261188 <br> FAX: 44844261681 |
| :---: | :---: | :---: | :---: |
| Eurodis Enatechnik <br> Electronics GmbH <br> Pascalkehre, 1 <br> D - 25451 Quickborn <br> P.B. 1240 <br> D - 25443 Quickborn <br> TEL: 494106 701-0 <br> FAX: 494106701268 | NETHERLANDS <br> * Auriema Nederland BV Beatrix de Rijkweg 8 NL - 5657 EG Eindhoven TEL: 3140502602 FAX: 3140510255 | FAX: 4117221340 |  |
|  |  | Basix Fur Elektronik Hardturmstrasse 181 CH - 8010 Zürich <br> TEL: 4112761111 FAX: 4112761234 EBV Elektronik | Harris Semiconductor Chip Distributors Die Technology Ltd. Corbrook Rd., Chadderton Lancashire OL9 9SD TEL: 44616263827 |
| Indeg Industrie Elektronik Emil Kommerling Strasse 5 <br> D - 66954 Pirmasens Postfach 1563 D - 66924 Pirmasens TEL: 49633194065 FAX: 49633194064 | Coltbaan 17 <br> NL - 3439 NG Nieuwegein TEL: 31340291234 <br> FAX: 31340235924 | $\begin{aligned} & \text { Vordstadtstrasse } 37 \\ & \text { CH-8953 Dietikon } \\ & \text { TEL: } 4117401090 \\ & \text { FAX: } 4117415110 \end{aligned}$ | FAX: 44616274321 <br> TWX: 668570 <br> Rood Technology |
|  | $\begin{aligned} & \text { Postbus } 7139 \\ & \text { NL }-5605 \mathrm{JC} \text { Eindhoven } \\ & \text { TEL: } 3140545430 \\ & \text { FAX: } 3140535540 \end{aligned}$ | Eurodis Electronic AG Bahnstrasse 58/60 CH-8105 Regensdorf TEL: 4118433111 FAX: 4118433910 | Hampshire GU34 2QG <br> TEL: 4442088022 <br> FAX: 4442087259 <br> TWX: 21137 |
| Sasco Semiconductor GmbH <br> Hermann-Oberth Strasse 16 D - 85640 Putzbrunn-beiMünchen <br> TEL: 498946 11-0 <br> FAX: 498946 11-270 | EBV Elektronik <br> * Planetenbaan, 2 NL - 3606 AK Maarssenbroek TEL: 31346562353 FAX: 31346564277 | Fabrimex Spoerle Kirchenweg 5 <br> CH - 8032 Zürich <br> TEL: 4113868686 <br> FAX: 4113832379 | South African <br> Authorized Distributor <br> transvail <br> Allied Electronic Components |
| Spoerle Electronic <br> Max-Planck Strasse 1-3 <br> D - 63303 Dreieich-bei- <br> Frankfurt <br> TEL: 4961033 04-0 <br> FAX: 4961063 04-201 | NORWAY <br> Avnet Nortec <br> Smedsvingen 4B Box 123 N - 1364 Hvalstad TEL: 4766846210 FAX: 4766846545 | ```TURKEY Besyol Londra Asfalti TK - 34630 Sefakoy/ Istanbul TEL: 9015993050 FAX: 9015993059``` | 10, Skietlood Street Isando, Ext. 3, 1600 P.O. Box 69 Isando, 1600 TEL: 2711392 3804/. . . 19 FAX: 27119749625 FAX: 27119749683 |
| GREECE Semicon Co. 104 Aeolou Street GR - 10564 Athens TEL: 3013253626 FAX: 3013216063 | PORTUGAL <br> Amitron-Arrow <br> Quinta Grande, Lote 20 <br> Alfragide <br> P - 2700 Amadora <br> TEL: 351.1.471 4806 <br> FAX: 351.1.471 0802 | UNITED KINGDOM Arrow-Jermyn Electronic Vestry Industrial Estate Sevenoaks Kent TN14 5EU TEL: 44732743743 FAX: 44732451251 | Asian Pacific <br> Sales Offices and <br> Representatives <br> NORTH ASIA <br> Sales Headquarters |
| ISRAEL <br> Aviv Electronics Hayetzira Street 4, Ind. Zone IS - 43651 Ra'anana PO Box 2433 IS - 43100 Ra'anana TEL: 9729983232 FAX: 9729916510 | SPAIN <br> Amitron-Arrow S.A. Albasanz, 75 SP - 28037 Madrid TEL: 3413043040 FAX: 3413272472 EBV Elektronik <br> * Calle Maria Tubau, 6 SP - 28049 Madrid TEL: 3413588608 FAX: 3413588560 | Avnet Emg <br> Jubilee House, Jubilee Road Letchworth Hertfordshire SG6 1QH TEL: 44462488500 FAX: 44462488567 <br> Farnell Electronic | JAPAN <br> Harris K.K. <br> Kojimachi-Nakata Bldg. 4F 5-3-5 Kojimachi Chiyoda-ku, Tokyo, 102 Japan TEL: (81) 3-3265-7571 TEL: (81) 3-3265-7572 (Sales) FAX: (81) 3-3265-7575 |
| ITALY <br> EBV Elektronik <br> - Via C. Frova, 34 I - 20092 Cinisello Balsamo (MI) TEL: 39266017111 <br> FAX: 39266017020 |  | Armley Road, Leeds <br> West Yorkshire LS 12 2QQ <br> TEL: 44532790101 <br> FAX: 44532633404 | SOUTH ASIA <br> Sales Headquarters <br> HONG KONG <br> Harris Semiconductor H.K. Ltd. <br> 13/F Fourseas Building |
|  |  | Farnell Electronic Services | 208-212 Nathan Road Tsimshatsui, Kowloon |
| Eurelettronica Via Enrico Fermi, 8 I-20090 Assago (MI) TEL: 392457841 | Avnet Nortec Englundavagen 7 P.O. Box 1830 S-171 27 Solna | Edinburgh Way. Harlow <br> Essex CM20 2DE <br> TEL: 44279626777 | TEL: (852) 723-6339 FAX: (852) 739-8946 TLX: 78043645 |
| FAX: 3924880275 | FAX: $468 \mathbf{8 2 7} 0280$ | FAX: 44279441687 | AUSTRALIA <br> VSI Electronics Pty, Ltd. <br> Unit C 6-8 Lyon Park Road North Ryde NSW 2113 TEL: (612) 878-1299 FAX: (612) 878-1266 |



* Field Application Assistance Available


## We're Backing You Up with Products, Support, and Solutions!

## Signal Processing

- Linear
- Custom Linear
- Data Conversion
- Interface
- Analog Switches
- Multiplexers
- Filters
- DSP
- Telecom


## Digital

- CMOS Microprocessors and Peripherals
- CMOS Microcontrollers
- CMOS Logic


## ASICs

- Full-Custom
- Analog Semicustom
- Mixed-Signal
- ASIC Design Software


## Power Products

- Power MOSFETS
- IGBTS
- Bipolar Discretes
- Transient Voltage

Suppressors

- Power Rectitiers

Intelligent Power

- Power ICs
- Power ASICs
- Hybrid Programmable Switches
- Full-Custom High Voltage ICs


## Microwave

- GaAs FETS
- GaAs MMICs
- Foundry Services


## Military/Aerospace Products

- Microprocessors and Peripherals
- Memories
- Analog ICs
- Digital ICs
- Discrete Power

Bipolar
MOSFET

- Rad-Hard ICS

Military/Aerospace Programs

- COMSEC Programs
- Strategic and Space


## Programs

- Military ASIC Programs


[^0]:    Harris Semiconductor products are sold by description only. All specifications in this product guide are applicable only to packaged products; specifications for die are available upon request. 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 information in this publication is current before placing orders. Reference to products of other manufacturers are solely for convenience of comparison and do not imply total equivalency of design, performance, or otherwise.

[^1]:    ${ }^{-}$Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$.

[^2]:    Shaded areas indicate instructions not available in 80C86/88 microsystems

[^3]:    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 $T_{2}$ state (8ns into $T_{3}$ )

[^4]:    - Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal voltages.
    +Maximum limits of minimum characteristics are the values above which all devices function.

[^5]:    * output enabled when en = high INTERNAL SIGNAL SHOWN FOR REFERENCE ONLY (SEE FIG I) 92cs-29024

[^6]:    *Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nomınal $V_{D D}$

[^7]:    *Timekeeping function only, no READ/WRITE accesses, $32-\mathrm{kHz}$ external frequency source only no crystal operation.
    †See Standby (Timekeeping) Voltage Operation, Page 11.

[^8]:    *CDP1879C-1 only.

[^9]:    92CM-37295

[^10]:    "A" Parts Screened to <5 $\mu \mathrm{A}$ ISTBY @ 32 KHz

[^11]:    *For 16 -bit mode, 82 C 237 only In 8-bit mode this signal is always high impedance tri-stated Waveform shown is for an 8 -bit transfer with the 82 C 237 programmed in 16-bit mode For a 16 -bit transfer, DWLE will go low at least TASS before the falling edge of ADSTB in S2, and remain low for the entire transfer

[^12]:    *IF TSFPC is not met on one edge of PLCK. SLO/FST will be recognized on the next edge of PLCK.

[^13]:    X = Not Defined, May Be 0 or 1

[^14]:    * LSB, Data Bit 0 is the first bit transmitted or received.

[^15]:    
    *Maxımum limits of minimum characteristics are the values above which all devices function.
    

[^16]:    ${ }^{\dagger}$ Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal voltages.
    *Maximum limits of minimum characteristics are the values above which all devices function.

[^17]:    *See Table I (Control Word Function)

[^18]:    ${ }^{\dagger}$ Time required by a limit device to allow for indicated function

    - Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$

[^19]:    ${ }^{+}$Time required by a limit device to allow for indicated function
    ${ }^{*}$ Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$

[^20]:    $\dagger$ Time required by a limit device to allow for the indicated function
    -Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal $V_{D D}$

[^21]:    1. Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal $\mathrm{V}_{\mathrm{DD}}$.
[^22]:    * Access Time/Data Retention Supply Current
    ** Respective $/ 883$ specifications are included at the end of this data sheet.

[^23]:    CAUTION: These devices are sensitive to electronic discharge. Proper IC handling procedures shoula be followed.

[^24]:    * Respective $/ 883$ specifications are included at the end of this datasheet.

[^25]:    * P should be hardwired to GND except during programming.

[^26]:    - $\overline{\text { P }}$ Should be Hardwired to VCC Except During Programming.

[^27]:    ＊Field Application Assistance Available

[^28]:    * Field Application Assistance Available

[^29]:    ＊Field Application Assistance Available

[^30]:    * Field Application Assistance Available

