$\stackrel{E}{\bar{W}^{+}}$

# Embedded Microcontrollers and Processors Vol.II 



intel

## LITERATURE

To order Intel literature or obtain literature pricing information in the U.S. and Canada call or write Intel Literature Sales. In Europe and other international locations, please contact your local sales office or distributor.

INTEL LITERATURE SALES
P.O. Box 7641

Mt. Prospect, IL 60056-7641

## In the U.S. and Canada

call toll free
(800) 548-4725

This 800 number is for external customers only.

## CURRENT HANDBOOKS

Product line handbooks contain data sheets, application notes, article reprints and other design information. All handbooks can be ordered individually, and most are available in a pre-packaged set in the U.S. and Canada.

Title

SET OF TWELVE HANDBOOKS
(Available in U.S. and Canada)
CONTENTS LISTED BELOW FOR INDIVIDUAL ORDERING:

| CONNECTIVITY | 231658 | 1-55512-174-8 |
| :---: | :---: | :---: |
| EMBEDDED APPLICATIONS (1993/94) | 270648 | 1-55512-179-9 |
| EMBEDDED MICROCONTROLLERS \& PROCESSORS <br> (2 volume set) | 270645 | 1-55512-176-4 |
| MEMORY PRODUCTS | 210830 | 1-55512-172-1 |
| MICROCOMPUTER PRODUCTS | 280407 | 1-55512-173-X |
| MICROPROCESSORS (2 volume set) | 230843 | 1-55512-169-1 |
| MOBILE COMPUTER PRODUCTS | 241420 | 1-55512-186-1 |
| i750 ${ }^{\text {® }}$, $\mathbf{1 8 6 0}{ }^{\text {™ }}$, $\mathbf{1 9 6 0 ®}{ }^{\text {® }}$ PROCESSORS AND RELATED PRODUCTS | 272084 | 1-55512-185-3 |
| PACKAGING | 240800 | 1-55512-182-9 |
| PERIPHERAL COMPONENTS | 296467 | 1-55512-181-0 |
| PRODUCT OVERVIEW <br> (A guide to Intel Architectures and Applications) | 210846 | N/A |
| PROGRAMMABLE LOGIC | 296083 | 1-55512-180-2 |

## ADDITIONAL LITERATURE:

(Not included in handbook set)

| AUTOMOTIVE | 231792 | 1-55512-125-X |
| :---: | :---: | :---: |
| COMPONENTS QUALITY/RELIABILITY | 210997 | 1-55512-132-2 |
| CUSTOMER LITERATURE GUIDE | 210620 | N/A |
| INTERNATIONAL LITERATURE GUIDE <br> (Available in Europe only) | E00029 | N/A |
| MILITARY AND SPECIAL PRODUCTS (2 volume set) | 210461 | 1-55512-189-6 |
| SYSTEMS QUALITY/RELIABILITY | 231762 | 1-55512-046-6 |
| HANDBOOK DIRECTORY <br> (Index of all data sheets contained in the handbooks) | 241197 | N/A |



Founded in 1968 to pursue the integration of large numbers of transistors onto tiny silicon chips, Intel's history has been marked by a remarkable number of scientific breakthroughs and innovations. In 1971, Intel introduced the 4004, the first microprocessor. Containing 2300 transistors, this first commercially-available computer on a chip is considered primitive compared with today's million-plus transistor products.

Innovations such as the microprocessor, the erasable programmable read-only memory (EPROM) and the dynamic random access memory (DRAM) revolutionized electronics by making integrated circuits the mainstay of both consumer and business computing products.

Over the last two and a half decades, Intel's business has evolved and today the company's focus is on delivering an extensive line of component, module and system-level building block products to the computer industry. The company's product line covers a broad spectrum, and includes microprocessors, flash memory, microcontrollers, a broad line of PC enhancement and local area network products, multimedia technology products, and massively parallel supercomputers. Intel's 32-bit X86 architecture, represented by the Intel $386^{\mathrm{TM}}$ and Intel $486^{\mathrm{TM}}$ microprocessor families, are the de facto standard of modern business computing and installed in millions of PCs worldwide.

Intel has over 25,000 employees located in offices and manufacturing facilities around the world. Today, Intel is the largest semiconductor company in the United States and the second largest in the world.

## U.S. and CANADA LITERATURE ORDER FORM

NAME: $\qquad$
COMPANY: $\qquad$
ADDRESS: $\qquad$
CITY: $\qquad$ STATE:
ZIP: $\qquad$
COUNTRY:
PHONE NO.: ( )

Include postage:
Must add $15 \%$ of Subtotal to cover U.S.
and Canada postage. ( $20 \%$ all other.)
$\qquad$
$\qquad$
Total
Pay by check, money order, or include company purchase order with this form (\$200 minimum). We also accept VISA, MasterCard or American Express. Make payment to Intel Literature Sales. Allow 2-3 weeks for delivery.MasterCard $\qquad$ American Express Expiration Date $\qquad$
Account No. $\qquad$
Signature $\qquad$

Mail To: Intel Literature Sales P.O. Box 7641

Mt. Prospect, IL 60056-7641

International Customers outside the U.S. and Canada should use the International order form on the next page or contact their local Sales Office or Distributor.

## For phone orders in the U.S. and Canada

Call Toll Free: (800) 548-4725

INTERNATIONAL LITERATURE ORDER FORM
NAME: $\qquad$
COMPANY: $\qquad$
ADDRESS: $\qquad$
CITY: $\qquad$ STATE: $\qquad$ ZIP: $\qquad$
COUNTRY:
PHONE NO.: $(\quad)$
ORDER NO. TITLE QTY. PRICE TOTAL

Subtotal
Must Add Your
Local Sales Tax
Total

## PAYMENT

Cheques should be made payable to your local Intel Sales Office (see inside back cover).
Other forms of payment may be available in your country. Please contact the Literature Coordinator at your local Intel Sales Office for details.

The completed form should be marked to the attention of the LITERATURE COORDINATOR and returned to your local Intel Sales Office.

## EMBEDDED MICROCONTROLLERS and PROCESSORS <br> VOLUME II

Intel Corporation makes no warranty for the use of its products and assumes no responsibility for any errors which may appear in this document nor does it make a commitment to update the information contained herein.

Intel retains the right to make changes to these specifications at any time, without notice.
Contact your local sales office to obtain the latest specifications before placing your order.
The following are trademarks of Intel Corporation and may only be used to identify Intel products:

| $376{ }^{\text {™ }}$ | 1750® | MAPNET ${ }^{\text {m }}$ |
| :---: | :---: | :---: |
| Above ${ }^{\text {TM }}$ | 1860 ${ }^{\text {™ }}$ | Matched ${ }^{\text {TM }}$ |
| ActionMedia ${ }^{\text {® }}$ | 1960® | MCS® |
| BITBUS ${ }^{\text {TM }}$ | Intel $287{ }^{\text {™ }}$ | Media Mail ${ }^{\text {™ }}$ |
| Code Builder ${ }^{\text {TM }}$ | Intel386 ${ }^{\text {TM }}$ | NetPort ${ }^{\text {™ }}$ |
| DeskWare ${ }^{\text {TM }}$ | Intel $387^{\text {m }}$ | NetSentry ${ }^{\text {™ }}$ |
| Digital Studio ${ }^{\text {™ }}$ | Intel486 ${ }^{\text {M }}$ | OpenNET ${ }^{\text {TM }}$ |
| DV1® | Intel $487^{\text {TM }}$ | OverDrive ${ }^{\text {TM }}$ |
| EtherExpress ${ }^{\text {™ }}$ | Intel ${ }^{\text {® }}$ | Paragon ${ }^{\text {™ }}$ |
| ETOX ${ }^{\text {™ }}$ | intel inside. ${ }^{\text {TM }}$ | ProSolver ${ }^{\text {TM }}$ |
| ExCA ${ }^{\text {™ }}$ | Intellec® | RapidCAD ${ }^{\text {™ }}$ |
| Exchange and Go ${ }^{\text {™ }}$ | iPSC® | READY-LAN ${ }^{\text {TM }}$ |
| FaxBACK ${ }^{\text {™ }}$ | iRMX ${ }^{\text {® }}$ | Reference Point ${ }^{(1)}$ |
| FlashFile ${ }^{\text {™ }}$ | iSBC® | RMX/80 ${ }^{\text {™ }}$ |
| Grand Challenge ${ }^{\text {TM }}$ | iSBX ${ }^{\text {TM }}$ | RxServer ${ }^{\text {™ }}$ |
| - | - WARP ${ }^{\text {™ }}$ | SatisFAXtion ${ }^{(1)}$ |
| ICE ${ }^{\text {TM }}$ | LANDesk ${ }^{\text {™ }}$ | Snapln $386^{\text {™ }}$ |
| iLBX ${ }^{\text {M }}$ | LANPrint ${ }^{\text {® }}$ | Storage Broker ${ }^{\text {TM }}$ |
| Inboard ${ }^{\text {M }}$ | LANProtect ${ }^{\text {TM }}$ | SugarCube ${ }^{\text {TM }}$ |
| 1287 ${ }^{\text {™ }}$ | LANSelect® | The Computer Inside. ${ }^{\text {TM }}$ |
| -386 ${ }^{\text {™ }}$ | LANShell ${ }^{\text {® }}$ | TokenExpress ${ }^{\text {TM }}$ |
| i387 ${ }^{\text {m }}$ | LANSight ${ }^{\text {TM }}$ | Visual Edge ${ }^{\text {TM }}$ |
| 1486 ${ }^{\text {™ }}$ | LANSpace ${ }^{\text {® }}$ | WYPIWYF® |
| 1487 ${ }^{\text {™ }}$ | LANSpool ${ }^{(1)}$ |  |

MDS is an ordering code only and is not used as a product name or trademark. MDS is a registered trademark of Mohawk Data Sciences Corporation.

CHMOS and HMOS are patented processes of Intel Corp.
Intel Corporation and Intel's FASTPATH are not affiliated with Kinetics, a division of Excelan, Inc. or its FASTPATH trademark or products.

Additional copies of this manual or other Intel literature may be obtained from:
Intel Corporation
Literature Sales
P.O. Box 7641

Mt. Prospect, IL 60056-7641

## DATA SHEET DESIGNATIONS

Intel uses various data sheet markings to designate each phase of the document as it relates to the product. The marking appears in the upper, right-hand corner of the data sheet. The following is the definition of these markings:

Advanced Information Contains information on products being sampled or in

## Data Sheet Marking

Product Preview

Preliminary

No Marking

## Description

Contains information on products in the design phase of development. Do not finalize a design with this information. Revised information will be published when the product becomes available. the initial production phase of development.*
Contains preliminary information on new products in production.*

Contains information on products in full production.*

[^0]MCS ${ }^{\circledR}$-48 Single Component System
MCS ${ }^{\circledR}$-48 Expanded System2
MCS®. 48 Instruction Set
MCS ${ }^{\circledR}$-48 Data Sheets
MCS® ${ }^{\text {- }} 51$ ArchitecturalOverview3
MCS ${ }^{\circledR}$-5 1 Programmer's Guide and Instruction Set
MCS ${ }^{\circledR}$ - 51 Hardware
Descriptions and Data Sheets ..... 7
8XC51FX Hardware
Description and Data Sheets ..... 8
8XC51GB HardwareDescription and Data Sheets9

## inted.

83C152 Hardware
Description and Data Sheet

MCS ${ }^{\circledR}$-51 Development Support Tools

RUPI-44 Family<br>MCS ${ }^{\circledR}$-80/85 Data Sheets<br>MCS® ${ }^{\circledR} 96$ Architectural<br>Overview and Quick References

12

14

8X9X Data Sheets

8XC196KB Data Sheets

8XC196KC Data Sheet
17

8XC196KD Data Sheets
18

## inte.

8XC196KR Data Sheet8XC196NT/8XC196NQ and8XC196KT Data Sheets20
8XC196MC Data Sheet
MCS ${ }^{\circledR}$-96 Development Support Tools22
MCS®. 51 and MCS-96 Packaging Information ..... 23
80186/188/C186/C188 Data Sheets ..... 24
80186/80188 DevelopmentSupport Tools25
i376 ${ }^{\text {TM }}$ Processor and Peripherals Data Sheets ..... 26
i376 ${ }^{\text {TM }}$ Processor
Development Tools 27

## inted.

## CAN 82527 Data Sheet

CAN 82527 Development Tool

## Table of Contents

Alphanumeric Index ..... xxi
MCS®-48 FAMILY
Chapter 1
MCS®-48 Single Component System ..... 1-1
Chapter 2
MCS®-48 Expanded System ..... 2-1
Chapter 3
MCS®-48 Instruction Set ..... 3-1
Chapter 4MCS®-48 DATA SHEETS
8243 MCS-48 Input/Output Expander ..... 4-1
P8748H/P8749H/8048AH/8035AHL/8049AH/8039AHL/8050AH/8040AHL HMOS Single Component 8-Bit Microcontroller ..... 4-8
D8748H/D8749H HMOS-E Single-Component 8-Bit Microcontroller ..... 4-21
P8049KB HMOS Single-Component 8-Bit Microcontroller ..... 4-33
MCS-48 Express ..... 4-45
MCS®-51 FAMILY
Chapter 5
MCS-51 Family of Microcontrollers Architectural Overview ..... 5-1
Chapter 6
MCS-51 Programmer's Guide and Instruction Set ..... 6-1
Chapter 7
8051, 8052 and 80C51 Hardware Description ..... 7-1
8XC52/54/58 Hardware Description ..... 7-37
8X5X DATA SHEETS
MCS-51 8-Bit Control-Oriented Microcontrollers 8031AH/8051AH/8032AH/ 8052AH/8751H/8751H-8 ..... 7-48
8051AHP MCS-51 Family 8-Bit Control-Oriented Microcontroller with Protected ROM ..... 7-63
8751BH Single-Chip 8-Bit Microcontroller with 4 Kbytes of EPROM Program Memory ..... 7-73
8751BH Express ..... 7-85
8752BH Single-Chip 8-Bit Microcontroller with 8 Kbytes of EPROM Program Memory ..... 7-87
8752BH Express ..... 7-99
8XC5X DATA SHEETS
80C31BH/80C51BH Express ..... 7-101
80C51BHP CHMOS Single-Chip 8-Bit Microcontroller with Protected ROM ..... 7-103
87C51/80C51BH/80C31BH CHMOS Single-Chip 8-Bit Microcontroller with 4 Kbytes Internal Program Memory ..... 7-117
87C51 Express ..... 7-136
87C51-20/-3 Commercial/Express 20 MHz CHMOS Microcontroller ..... 7-139
8XC51SL/Low Voltage 8XC51SL Keyboard Controller ..... 7-153
87C52/80C52/80C32 CHMOS Single-Chip 8-Bit Microcontroller with 8 Kbytes Internal Program Memory ..... 7-154
87C52/80C52/80C32 Express ..... 7-170
87C52-20/80C52-20/80C32-20 Commercial/Express 20 MHz Microcontroller ..... 7-172
87C54/80C54 CHMOS Single-Chip 8-Bit Microcontroller with 16 Kbytes Internal Program Memory ..... 7-188
87C54/80C54 Express ..... 7-204
87C54-20/-3 80C54-20/-3 Commercial/Express 20 MHz Microcontroller ..... 7-206

## Table of Contents (Continued)

87C58/80C58 CHMOS Single-Chip 8-Bit Microcontroller with 32 Kbytes Internal Program Memory ..... 7-222
87C58/80C58 Express ..... 7-239
87C58-20/-3 80C58-20/-3 Commercial/Express 20 MHz Microcontroller ..... 7-241
Chapter 8
8XC51FX Hardware Description ..... 8-1
8XC51FX DATA SHEETS
83C51FA/80C51FA Express ..... 8-44
87C51FA/83C51FA/80C51FA CHMOS Single-Chip 8-Bit Microcontroller with 8 Kbytes Internal Program Memory ..... 8-46
87C51FA Express ..... 8-65
87C51FA-20/-3 Commercial/Express 20 MHz CHMOS Microcontroller ..... 8-68
87C51FB/83C51FB CHMOS Single-Chip 8-Bit Microcontroller with 16 Kbytes Internal Program Memory ..... 8-83
87C51FB-20/-3 83C51FB-20/-3 Commercial/Express 20 MHz Microcontroller ..... 8-100
87C51FC/83C51FC CHMOS Single-Chip 8-Bit Microcontroller with 32 Kbytes Internal Program Memory ..... 8-115
87C51FC/83C51FC Express ..... 8-132
87C51FC-20/-3 83C51FC-20/-3 Commercial/Express 20 MHz Microcontroller ..... 8-134
Chapter 9
87C51GB Hardware Description ..... 9-1
8XC51GB DATA SHEETS
87C51GB/83C51GB/80C51GB CHMOS Single-Chip 8-Bit Microcontroller ..... 9-56
87C51GB/80C51GB CHMOS Single-Chip 8-Bit Microcontroller Express ..... 9-78
Chapter 10
83C152 Hardware Description ..... 10-1
8XC152JX DATA SHEET
8XC152JA/JB/JC/JD Universal Communication Controller 8-Bit Microcontroller ..... 10-71
Chapter 11
MCS®-51 DEVELOPMENT SUPPORT TOOLS
Development Tools for the MCS-51 Family of Microcontrollers ..... 11-1
ACE51FX Software ..... 11-7
EV80C51FX Evaluation Board ..... 11-8
EV80C51GX Evaluation Board ..... 11-11
THE RUPI FAMILY
Chapter 12
The RUPI-44 Family: Microcontroller with On-Chip Communication Controller ..... 12-1
8044 Architecture ..... 12-9
The RUPI-44 Serial Interface Unit ..... 12-19
8044 Application Examples ..... 12-57
8044 DATA SHEET
8044AH/8344AH/8744AH High Performance 8-Bit Microcontroller with On-Chip Serial Communication Controller ..... 12-131
MCS ${ }^{\circledR}$-80/85 FAMILY
Chapter 13
MCS®-80/85 DATA SHEETS
8080A/8080A-1/8080A-2 8-Bit N-Channel Microprocessor ..... 13-1
8085AH/8085AH-2/8085AH-1 8-Bit HMOS Microprocessors ..... 13-11
8155H/8156H/8155H-2/8156H-2 2048-Bit Static HMOS RAM with I/O Ports and Timer ..... 13-31
8185/8185-2 $1024 \times 8$-Bit Static RAM for MCS®-85 ..... 13-45
8224 Clock Generator and Driver for 8080A CPU ..... 13-50

## Table of Contents (Continued)

8228 System Controller and Bus Driver for 8080A CPU ..... 13-55
8755A 16,384-Bit EPROM with I/O ..... 13-59
MCS ${ }^{\circledR}$-96 FAMILY
Chapter 14
MCS-96 Architectural Overview ..... 14-1
8X9X Quick Reference ..... 14-15
8XC196KB Quick Reference ..... 14-40
8XC196KC Quick Reference ..... 14-73
8XC196KD Quick Reference ..... 14-104
8XC196KR Quick Reference ..... 14-134
8XC196KT Quick Reference ..... 14-161
8XC196MC Quick Reference ..... 14-190
8XC196NT/NQ Quick Reference ..... 14-224
MCS-96 A/D Converter Quick Reference ..... 14-253
Chapter 15
8X9X DATA SHEETS
809XBH/839XBH/879XBH Commercial/Express HMOS Microcontroller ..... 15-1
8097JF/8397JF/8797JF Commercial/Express HMOS Microcontroller ..... 15-23
8098/8398/8798 Commercial/Express HMOS Microcontroller ..... $15-42$
Chapter 16
8XC196KB DATA SHEETS
80C196KB10/83C196KB10/80C196KB12/83C196KB12 Commercial/ExpressCHMOS Microcontroller16-1
80C198/83C198/80C194/83C194 Commercial/Express CHMOS Microcontroller ..... 16-22
8XC196KB/8XC196KB16 Commercial/Express CHMOS Microcontroller ..... 16-38
8XC198 Commercial CHMOS Microcontroller ..... 16-60
Chapter 17
8XC196KC DATA SHEET
8XC196KC Commercial/Express CHMOS Microcontroller ..... 17-1
Chapter 18
8XC196KD DATA SHEETS
8XC196KD/8XC196KD20 Commercial CHMOS Microcontroller ..... 18-1
8XL196KD Commercial CHMOS Microcontroller ..... 18-26
Chapter 19
8XC196KR DATA SHEET
8XC196KR/KQ/JR/JQ Commercial/Express CHMOS Microcontroller ..... 19-1
Chapter 20
8XC196NT/8XC196NQ AND 8XC196KT DATA SHEETS 8XC196NT/8XC196NQ CHMOS Microcontroller ..... 20-1
8XC196KT Commercial CHMOS Microcontroller ..... 20-33
Chapter 21
8XC196MC DATA SHEET
87C196MC Industrial Motor Control Microcontroller ..... 21-1
Chapter 22
MCS ${ }^{\circledR}-96$ DEVELOPMENT SUPPORT TOOLS ICE-196KD/HX In-Circuit Emulator ..... 22-1
ICE-196 KD/PC In-Circuit Emulator ..... 22-6
MCS-96 Software Development Packages ..... 22-9
ApBuilder Programming Package ..... 22-12
EV80C196KX/EV8097BH/EV80C196KB/EV80C196KC/EV80C196KD Evaluation Boards ..... 22-15
EV80C196KR Evaluation Board ..... 22-22

## Table of Contents (Continued)

EV80C196MC Evaluation Board ..... 22-24
Chapter 23MCS®-51 and MCS-96 PACKAGING INFORMATIONMCS-51 and MCS-96 Packaging Information23-1
80186/80188 FAMILY Chapter 24
80186/188/C186/C188 DATA SHEETS 80186 High Integration 16-Bit Microprocessor ..... 24-1
80C186 CHMOS High Integration 16-Bit Microprocessor ..... 24-59
80C186XL20, 16, 12, 10 16-Bit High Integration Embedded Processor ..... 24-128
80C186EA20, 16, 12 16-Bit High Integration Embedded Processor ..... 24-174
80C186EB-20 ,-16, -13, -8, 16-Bit High-Integration Embedded Processor ..... 24-227
80C186EC-16, -13 16-Bit High-Integration Embedded Processor ..... 24-283
80L186EA8 16-Bit High Integration Embedded Processor ..... 24-338
80L186EB-13, -8; 16-Bit High-Integration Embedded Processor ..... 24-366
80C187 80-Bit Math Coprocessor ..... 24-390
80188 High Integration 8-Bit Microprocessor ..... 24-420
80C188 CHMOS High Integration 16-Bit Microprocessor ..... 24-479
80C188XL20, 16, 12, 10 16-Bit High Integration Embedded Processor ..... 24-551
80C188EA20, 16, 12 16-Bit High Integration Embedded Processor ..... 24-597
80C188EB-20, -16, -13, -8 16-Bit High-Integration Embedded Processor ..... 24-649
80C188EC-16, -13 16-Bit High-Integration Embedded Processor ..... 24-704
80L188EA8 16-Bit High Integration Embedded Processor ..... 24-761
80L188EB-13, -8, 16-Bit High-Integration Embedded Processor ..... 24-788
82188 Integrated Bus Controller for 8086, 8088, 80186, 80188 Processors ..... 24-812
Chapter 25
80186/80188 DEVELOPMENT SUPPORT TOOLS
ICE-186/188 Family In-Circuit Emulator ..... 25-1
8086/80C186 Software Development Tools ..... 25-8
EV80C186EA/XL Evaluation Board ..... 25-13
EV80C186EB Evaluation Board ..... 25-16
EV80C186EC Evaluatión Board ..... 25-19
DB86A Artic Software Debugger ..... 25-21
i376TM EMBEDDED PROCESSOR
Chapter 26
i376TM PROCESSOR AND PERIPHERALS DATA SHEETS
376 High Performance 32-Bit Embedded Processor ..... 26-1
Intel387 SX Math CoProcessor ..... 26-96
82355 Bus Master Interface Controller (BMIC) ..... 26-97
82370 Integrated System Peripheral ..... 26-98
82596DX and 82596SX High-Performance 32-Bit Local Area Network Coprocessor ..... 26-99
Chapter 27
i376TM PROCESSOR DEVELOPMENT TOOLS
Intel386 and Intel486 Family Development Support ..... 27-1
TRANS 186-376 Assembly Code Translator ..... 27-9
CAN 82527 CONTROLLER
Chapter 2882527 DATA SHEETSerial Communications Controller (Controller Area Network Protocol)28-1
Chapter 29
82527 DEVELOPMENT TOOLEV82527 Evaluation Kit29-1

## Alphanumeric Index

376 High Performance 32-Bit Embedded Processor ..... 26-1
80186 High Integration 16-Bit Microprocessor ..... 24-1
80188 High Integration 8-Bit Microprocessor ..... 24-420
8044 Application Examples ..... 12-57
8044 Architecture ..... 12-9
8044AH/8344AH/8744AH High Performance 8-Bit Microcontroller with On-Chip Serial Communication Controller ..... 12-131
8051, 8052 and 80C51 Hardware Description ..... 7-1
8051AHP MCS-51 Family 8-Bit Control-Oriented Microcontroller with Protected ROM ..... 7-63
8080A/8080A-1/8080A-2 8-Bit N-Channel Microprocessor ..... 13-1
8085AH/8085AH-2/8085AH-1 8-Bit HMOS Microprocessors ..... 13-11
8086/80C186 Software Development Tools ..... 25-8
8097JF/8397JF/8797JF Commercial/Express HMOS Microcontroller ..... 15-23
8098/8398/8798 Commercial/Express HMOS Microcontroller ..... 15-42
809XBH/839XBH/879XBH Commercial/Express HMOS Microcontroller ..... 15-1
80C186 CHMOS High Integration 16-Bit Microprocessor ..... 24-59
80C186EA20, 16, 12 16-Bit High Integration Embedded Processor ..... 24-174
80C186EB-20 ,-16, -13, -8, 16-Bit High-Integration Embedded Processor ..... 24-227
80C186EC-16, -13 16-Bit High-Integration Embedded Processor ..... 24-283
80C186XL20, 16, 12, 10 16-Bit High Integration Embedded Processor ..... 24-128
80C187 80-Bit Math Coprocessor ..... 24-390
80C188 CHMOS High Integration 16-Bit Microprocessor ..... 24-479
80C188EA20, 16, 12 16-Bit High Integration Embedded Processor ..... 24-597
80C188EB-20, -16, -13, -8 16-Bit High-Integration Embedded Processor ..... 24-649
80C188EC-16, -13 16-Bit High-Integration Embedded Processor ..... 24-704
80C188XL20, 16, 12, 10 16-Bit High Integration Embedded Processor ..... 24-551
80C196KB10/83C196KB10/80C196KB12/83C196KB12 Commercial/Express CHMOS Microcontroller ..... 16-1
80C198/83C198/80C194/83C194 Commercial/Express CHMOS Microcontroller ..... 16-22
80C31BH/80C51BH Express ..... 7-101
80C51BHP CHMOS Single-Chip 8-Bit Microcontroller with Protected ROM ..... 7-103
80L186EA8 16-Bit High Integration Embedded Processor ..... 24-338
80L186EB-13, -8, 16-Bit High-Integration Embedded Processor ..... 24-366
80L188EA8 16-Bit High Integration Embedded Processor ..... 24-761
80L188EB-13, -8, 16-Bit High-Integration Embedded Processor ..... 24-788
8155H/8156H/8155H-2/8156H-2 2048-Bit Static HMOS RAM with I/O Ports and Timer ..... 13-31
8185/8185-2 $1024 \times 8$-Bit Static RAM for MCS ${ }^{\text {® }}$ - 85 ..... 13-45
82188 Integrated Bus Controller for $8086,8088,80186,80188$ Processors ..... 24-812
8224 Clock Generator and Driver for 8080A CPU ..... 13-50
8228 System Controller and Bus Driver for 8080A CPU ..... 13-55
82355 Bus Master Interface Controller (BMIC) ..... 26-97
82370 Integrated System Peripheral ..... 26-98
8243 MCS-48 Input/Output Expander ..... 4-1
82596DX and 82596SX High-Performance 32-Bit Local Area Network Coprocessor ..... 26-99
83C152 Hardware Description ..... 10-1
83C51FA/80C51FA Express ..... 8-44
8751BH Express ..... 7-85
8751BH Single-Chip 8-Bit Microcontroller with 4 Kbytes of EPROM Program Memory ..... 7-73
8752BH Express ..... 7-99
8752BH Single-Chip 8-Bit Microcontroller with 8 Kbytes of EPROM Program Memory ..... 7-87
8755A 16,384-Bit EPROM with I/O ..... 13-59
87C196MC Industrial Motor Control Microcontroller ..... 21-1
87C51 Express ..... 7-136
87C51-20/-3 Commercial/Express 20 MHz CHMOS Microcontroller ..... 7-139

## Alphanumeric Index (Continued)

87C51/80C51BH/80C31BH CHMOS Single-Chip 8-Bit Microcontroller with 4 Kbytes Internal Program Memory ..... 7-117
87C51FA Express ..... 8-65
87C51FA-20/-3 Commercial/Express 20 MHz CHMOS Microcontroller ..... 8-68
87C51FA/83C51FA/80C51FA CHMOS Single-Chip 8-Bit Microcontroller with 8 Kbytes Internal Program Memory ..... 8-46
87C51FB-20/-3 83C51FB-20/-3 Commercial/Express 20 MHz Microcontroller ..... 8-100
87C51FB/83C51FB CHMOS Single-Chip 8-Bit Microcontroller with 16 Kbytes Internal Program Memory ..... 8-83
87C51FC-20/-3 83C51FC-20/-3 Commercial/Express 20 MHz Microcontroller ..... 8-134
87C51FC/83C51FC CHMOS Single-Chip 8-Bit Microcontroller with 32 Kbytes Internal Program Memory ..... 8-115
87C51FC/83C51FC Express ..... 8-132
87C51GB Hardware Description ..... 9-1
87C51GB/80C51GB CHMOS Single-Chip 8-Bit Microcontroller Express ..... 9-78
87C51GB/83C51GB/80C51GB CHMOS Single-Chip 8-Bit Microcontroller ..... 9-56
87C52-20/80C52-20/80C32-20 Commercial/Express 20 MHz Microcontroller ..... 7-172
87C52/80C52/80C32 CHMOS Single-Chip 8-Bit Microcontroller with 8 Kbytes Internal Program Memory ..... 7-154
87C52/80C52/80C32 Express ..... 7-170
87C54-20/-3 80C54-20/-3 Commercial/Express 20 MHz Microcontroller ..... 7-206
87C54/80C54 CHMOS Single-Chip 8-Bit Microcontroller with 16 Kbytes Internal Program Memory ..... 7-188
87C54/80C54 Express ..... 7-204
87C58-20/-3 80C58-20/-3 Commercial/Express 20 MHz Microcontroller ..... 7-241
87C58/80C58 CHMOS Single-Chip 8-Bit Microcontroller with 32 Kbytes Internal Program Memory ..... 7-222
87C58/80C58 Express ..... 7-239
8X9X Quick Reference ..... 14-15
8XC152JA/JB/JC/JD Universal Communication Controller 8-Bit Microcontroller ..... 10-71
8XC196KB' Quick Reference ..... 14-40
8XC196KB/8XC196KB16 Commercial/Express CHMOS Microcontroller ..... 16-38
8XC196KC Commercial/Express CHMOS Microcontroller ..... 17-1
8XC196KC Quick Reference ..... 14-73
8XC196KD Quick Reference ..... 14-104
8XC196KD/8XC196KD20 Commercial CHMOS Microcontroller ..... 18-1
8XC196KR Quick Reference ..... 14-134
8XC196KR/KQ/JR/JQ Commercial/Express CHMOS Microcontroller ..... 19-1
8XC196KT Commercial CHMOS Microcontroller ..... 20-33
8XC196KT Quick Reference ..... 14-161
8XC196MC Quick Reference ..... 14-190
8XC196NT/8XC196NQ CHMOS Microcontroller ..... 20-1
8XC196NT/NQ Quick Reference ..... 14-224
8XC198 Commercial CHMOS Microcontroller ..... 16-60
8XC51FX Hardware Description ..... 8-1
8XC51SL/Low Voltage 8XC51SL Keyboard Controller ..... 7-153
8XC52/54/58 Hardware Description ..... 7-37
8XL196KD Commercial CHMOS Microcontroller ..... 18-26
ACE51FX Software ..... 11-7
ApBuilder Programming Package ..... 22-12
D8748H/D8749H HMOS-E Single-Component 8-Bit Microcontroller ..... 4-21
DB86A Artic Software Debugger ..... 25-21
Development Tools for the MCS-51 Family of Microcontrollers ..... 11-1
EV80C186EA/XL Evaluation Board ..... 25-13

## Alphanumeric Index (Continued)

EV80C186EB Evaluation Board ..... 25-16
EV80C186EC Evaluation Board ..... 25-19
EV80C196KR Evaluation Board ..... 22-22
EV80C196KX/EV8097BH/EV80C196KB/EV80C196KC/EV80C196KD Evaluation Boards ..... 22-15
EV80C196MC Evaluation Board ..... 22-24
EV80C51FX Evaluation Board ..... 11-8
EV80C51GX Evaluation Board ..... 11-11
EV82527 Evaluation Kit ..... 29-1
ICE-186/188 Family In-Circuit Emulator ..... 25-1
ICE-196 KD/PC In-Circuit Emulator ..... 22-6
ICE-196KD/HX In-Circuit Emulator ..... 22-1
Intei386 and Intel486 Family Development Support ..... 27-1
Intel387 SX Math CoProcessor ..... 26-96
MCS-48 Express ..... 4-45
MCS-51 8-Bit Control-Oriented Microcontrollers 8031AH/8051AH/8032AH/8052AH/ 8751H/8751H-8 ..... 7-48
MCS-51 and MCS-96 Packaging Information ..... 23-1
MCS-51 Family of Microcontrollers Architectural Overview ..... 5-1
MCS-51 Programmer's Guide and Instruction Set ..... 6-1
MCS-96 A/D Converter Quick Reference ..... 14-253
MCS-96 Architectural Overview ..... 14-1
MCS-96 Software Development Packages ..... 22-9
MCS ${ }^{\circledR}$-48 Expanded System ..... 2-1
MCS ${ }^{\circledR}$-48 Instruction Set ..... 3-1
MCS ${ }^{\circledR}$-48 Single Component System ..... 1-1
P8049KB HMOS Single-Component 8-Bit Microcontroller ..... 4-33
P8748H/P8749H/8048AH/8035AHL/8049AH/8039AHL/8050AH/8040AHL. HMOS Single Component 8-Bit Microcontroller ..... 4-8
Serial Communications Controller (Controller Area Network Protocol) ..... 28-1
The RUPI-44 Family: Microcontroller with On-Chip Communication Controller ..... 12-1
The RUPI-44 Serial Interface Unit ..... 12-19
TRANS 186-376 Assembly Code Translator ..... 27-9

## 80186/188/C186/C188 Data Sheets

®
80186
HIGH INTEGRATION 16-BIT MICROPROCESSOR

■ Integrated Feature Set
— Enhanced 8086-2 CPU

- Clock Generator
- 2 Independent DMA Channels
- Programmable Interrupt Controller
- 3 Programmable 16-bit Timers
- Programmable Memory and Peripheral Chip-Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- Available in 10 MHz (80186-10) and 8 MHz (80186) Versions
- High-Performance Processor - 4 MByte/Sec Bus Bandwidth Interface @ 8 MHz
- 5 MByte/Sec Bus Bandwidth Interface @ 10 MHz
■ Direct Addressing Capability to 1 MByte of Memory and 64 KByte I/O
- Completely Object Code Compatible with All Existing 8086, 8088 Software - 10 New Instruction Types
- Complete System Development Support
-Development Software: ASM 86 Assembler, PL/M-86, Pascal-86, Fortran-86, C-86, and System Utilities - In-Circuit-Emulator (I2ICETM-186)
- Numerics Coprocessing Capability Through 8087 Interface
■ Available in 68 Pin:
- Plastic Leaded Chip Carrier (PLCC)
- Ceramic Pin Grid Array (PGA)
- Ceramic Leadless Chip Carrier (LCC)
(See Packaging Outlines and Dimensions, Order \#231369)
- Available in EXPRESS
- Standard Temperature with Burn-In
- Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )


210451-1
Figure 1. 80186 Block Diagram

The Intel 80186 is a highly integrated 16-bit microprocessor. The 80186 effectively combines 15-20 of the most common 8086 system components onto one. The 80186 provides two times greater throughput than the standard 5 MHz 8086 . The 80186 is upward compatible with 8086 and 8088 software and adds 10 new instruction types to the existing set.


Ceramic Pin Grid Array


210451-3
Plastic Leaded Chip Carrier


210451-19
Figure 2. 80186 Pinout Diagrams

Table 1. 80186 Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | $\begin{aligned} & \hline 9 \\ & 43 \end{aligned}$ | 1 | System Power: + 5 volt power supply. |
| $\mathrm{V}_{\text {ss }}$ | $\begin{aligned} & 26 \\ & 60 \end{aligned}$ | 1 | System Ground. |
| RESET | 57 | 0 | Reset Output indicates that the 80186 CPU is being reset, and can be used as a system reset. It is active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods corresponding to the length of the RES signal. |
| $\begin{array}{\|l\|} \hline \times 1 \\ \times 2 \end{array}$ | $\begin{aligned} & 59 \\ & 58 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Crystal Inputs X1 and X2 provide external connections for a fundamental mode parallel resonant crystal for the internal oscillator. Instead of using a crystal, an external clock may be applied to X1 while minimizing stray capacitance on X2. The input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). |
| CLKOUT | 56 | 0 | Clock Output provides the system with a $50 \%$ duty cycle waveform. All device pin timings are specified relative to CLKOUT. |
| $\overline{\text { RES }}$ | 24 | 1 | An active $\overline{\text { RES }}$ causes the 80186 to immediately terminate its present activity, clear the internal logic, and enter a dormant state. This signal may be asynchronous to the 80186 clock. The 80186 begins fetching instructions approximately $61 / 2$ clock cycles after RES is returned HIGH. For proper initialization, $\mathrm{V}_{\mathrm{CC}}$ must be within specifications and the clock signal must be stable for more than 4 clocks with RES held LOW. RES is internally synchronized. This input is provided with a Schmitt-trigger to facilitate power-on RES generation via an RC network. |
| TEST | 47 | 1/0 | TEST is examined by the WAIT instruction. If the TEST input is HIGH when "WAIT" execution begins, instruction execution will suspend. TEST will be resampled until it goes LOW, at which time execution will resume. If interrupts are enabled while the 80186 is waiting for TEST, interrupts will be serviced. During power-up, active RES is required to configure TEST as an input. This pin is synchronized internally. |
| TMR IN 0 TMR IN 1 | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | $1$ | Timer Inputs are used either as clock or control signals, depending upon the programmed timer mode. These inputs are active HIGH (or LOW-to-HIGH transitions are counted) and internally synchronized. |
| TMR OUT 0 TMR OUT 1 | $\begin{aligned} & 22 \\ & 23 \end{aligned}$ | $\begin{aligned} & \mathrm{O} \\ & \mathrm{O} \end{aligned}$ | Timer outputs are used to provide single pulse or continous waveform generation, depending upon the timer mode selected. |
| $\begin{array}{\|l} \hline \text { DRQ0 } \\ \text { DRQ1 } \end{array}$ | $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | $1$ | DMA Request is asserted HIGH by an external device when it is ready for DMA Channel 0 or 1 to perform a transfer. These signals are leveltriggered and internally synchronized. |
| NMI | 46 | 1 | The Non-Maskable Interrupt input causes a Type 2 interrupt. An NMI transition from LOW to HIGH is latched and synchronized internally, and initiates the interrupt at the next instruction boundary. NMI must be asserted for at least one clock. The Non-Maskable Interrupt cannot be avoided by programming. |
|  | $\begin{aligned} & 45 \\ & 44 \\ & 42 \\ & 41 \end{aligned}$ |  | Maskable Interrupt Requests can be requested by activating one of these pins. When configured as inputs, these pins are active HIGH. Interrupt Requests are synchronized internally. INT2 and INT3 may be configured to provide active-LOW interrupt-acknowledge output signals. All interrupt inputs may be configured to be either edge- or level-triggered. To ensure recognition, all interrupt requests must remain active until the interrupt is acknowledged. When Slave Mode is selected, the function of these pins changes (see Interrupt Controller section of this data sheet). |

Table 1.80186 Pin Description (Continued)

| Symbol | Pin No. | Type |  |  | Name and Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A19/S6 A18/S5 A17/S4 A16/S3 | 65 66 67 68 | 0 0 0 0 | Address Bus Outputs (16-19) and Bus Cycle Status (3-6) indicate the four most significant address bits during $\mathrm{T}_{1}$. These signals are active HIGH. During $\mathrm{T}_{2}, \mathrm{~T}_{3}, \mathrm{~T}_{\mathrm{W}}$, and $\mathrm{T}_{4}$, the S 6 pin is LOW to indicate a CPU-initiated bus cycle or HIGH to indicate a DMA-initiated bus cycle. During the same T-states, S3, S4, and S 5 are always LOW. The status pins float during bus HOLD or RESET. |  |  |
| AD15 AD14 AD13 AD12 AD11 AD10 AD9 AD8 AD7 AD6 AD5 AD4 AD3 AD2 AD1 AD0 | 1 3 5 7 10 12 14 16 2 4 6 8 11 13 15 17 | $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ $1 / 0$ | Address/Data Bus ( $0-15$ ) signals constitute the time multiplexed memory or I/O address ( $T_{1}$ ) and data ( $T_{2}, T_{3}, T_{W}$, and $T_{4}$ ) bus. The bus is active HIGH. $A_{0}$ is analogous to $\overline{B H E}$ for the lower byte of the data bus, pins $D_{7}$ through $D_{0}$. It is LOW during $\mathrm{T}_{1}$ when a byte is to be transferred onto the lower portion of the bus in memory or I/O operations. |  |  |
| $\overline{\text { BHE/S7 }}$ | 64 | 0 | During $\mathrm{T}_{1}$ the Bus High Enable signal should be used to determine if data is to be enabled onto the most significant half of the data bus; pins $D_{15}-D_{8}$. BHE is LOW during $\mathrm{T}_{1}$ for read, write, and interrupt acknowledge cycles when a byte is to be transferred on the higher half of the bus. The $\mathrm{S}_{7}$ status information is available during $T_{2}, T_{3}$, and $T_{4}$. $S_{7}$ is logically equivalent to $\overline{B H E}$. $\overline{B H E} / S 7$ floats during HOLD. |  |  |
|  |  |  | $\overline{B H E}$ and AO Encodings |  |  |
|  |  |  | $\overline{\text { BHE }}$ <br> Value | A0 Value | Function |
|  |  |  | 0 0 1 1 | 0 1 0 1 | Word Transfer <br> Byte Transfer on upper half of data bus (D15-D8) Byte Transfer on lower half of data bus ( $\mathrm{D}_{7}-\mathrm{D}_{0}$ ) Reserved |
| ALE/QSO | 61 | 0 | Address Latch Enable/Queue Status 0 is provided by the 80186 to latch the address. ALE is active HIGH. Addresses are guaranteed to be valid on the trailing edge of ALE. The ALE rising edge is generated off the rising edge of the CLKOUT immediately preceding $\mathrm{T}_{1}$ of the associated bus cycle, effectively one-half clock cycle earlier than in the 8086. The trailing edge is generated off the CLKOUT rising edge in $T_{1}$ as in the 8086. Note that ALE is never floated. |  |  |
| $\overline{\text { WR/QS1 }}$ | 63 | 0 | Write Strobe/Queue Status 1 indicates that the data on the bus is to be written into a memory or an I/O device. $\overline{W R}$ is active for $T_{2}, T_{3}$, and $T_{W}$ of any write cycle. It is active LOW, and floats during HOLD. When the 80186 is in queue status mode, the ALE/QS0 and WR/QS1 pins provide information about processor/instruction queue interaction. |  |  |
|  |  |  | QS1 | QSO | Queue Operation |
|  |  |  | 0 0 1 1 | 0 1 1 0 | No queue operation First opcode byte fetched from the queue Subsequent byte fetched from the queue Empty the queue |

Table 1. 80186 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ | 62 | 1/0 | Read Strobe is an active LOW signal which indicates that the 80186 is performing a memory or I/O read cycle. It is guaranteed not to go LOW before the A/D bus is floated. An internal pull-up ensures that $\overline{R D}$ is HIGH during RESET. Following RESET the pin is sampled to determine whether the 80186 is to provide ALE, $\overline{R D}$, and $\overline{W R}$, or queue status information. To enable Queue Status Mode, $\overline{\mathrm{RD}}$ must be connected to GND. $\overline{\text { RD }}$ will float during bus HOLD. |  |  |  |
| ARDY | 55 | 1 | Asynchronous Ready informs the 80186 that the addressed memory space or I/O device will complete a data transfer. The ARDY pin accepts a rising edge that is asynchronous to CLKOUT, and is active HIGH. The falling edge of ARDY must be synchronized to the 80186 clock. Connecting ARDY HIGH will always assert the ready condition to the CPU. If this line is unused, it should be tied LOW to yield control to the SRDY pin. |  |  |  |
| SRDY | 49 | 1 | Synchronous Ready informs the 80186 that the addressed memory space or I/O device will complete a data transfer. The SRDY pin accepts an active-HIGH input synchronized to CLKOUT. The use of SRDY allows a relaxed system timing over ARDY. This is accomplished by elimination of the one-half clock cycle required to internally synchronize the ARDY input signal. Connecting SRDY high will always assert the ready condition to the CPU. If this line is unused, it should be tied LOW to yield control to the ARDY pin. |  |  |  |
| LOCK | 48 | 0 | LOCK output indicates that other system bus masters are not to gain control of the system bus while LOCK is active LOW. The LOCK signal is requested by the LOCK prefix instruction and is activated at the beginning of the first data cycle associated with the instruction following the LOCK prefix. It remains active until the completion of that instruction. No instruction prefetching will occur while $\overline{\text { LOCK }}$ is asserted. When executing more than one LOCK instruction, always make sure there are 6 bytes of code between the end of the first LOCK instruction and the start of the second LOCK instruction. LOCK is driven HIGH for one clock during RESET and then floated. |  |  |  |
| $\overline{\frac{\overline{S 0}}{\frac{S 1}{S 2}}}$ | $\begin{aligned} & 52 \\ & 53 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Bus cycle status $\overline{\mathrm{S} 0}-\overline{\mathrm{S}} 2$ are encoded to provide bus-transaction information: |  |  |  |
|  |  |  | 80186 Bus Cycle Status Information |  |  |  |
|  |  |  | $\overline{\mathbf{S 2}}$ | $\overline{\text { S1 }}$ | $\overline{\mathbf{S o}}$ | Bus Cycle Initiated |
|  |  |  | 0 0 0 0 1 1 1 1 | 0 0 1 1 0 0 1 1 | 0 1 0 1 0 1 0 1 | Interrupt Acknowledge <br> Read I/O <br> Write I/O <br> Halt <br> Instruction Fetch <br> Read Data from Memory <br> Write Data to Memory <br> Passive (no bus cycle) |
|  |  |  | The status pins float during HOLD. $\overline{\mathrm{S} 2}$ may be used as a logical $\mathrm{M} / / \overline{\mathrm{O}}$ indicator, and $\overline{\mathrm{S} 1}$ as a $\mathrm{DT} / \overline{\mathrm{R}}$ indicator. |  |  |  |

Table 1. 80186 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { HOLD } \\ & \text { HLDA } \end{aligned}$ | $\begin{aligned} & 50 \\ & 51 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | HOLD indicates that another bus master is requesting the local bus. The HOLD input is active HIGH. HOLD may be asynchronous with respect to the 80186 clock. The 80186 will issue a HLDA (HIGH) in response to a HOLD request at the end of $\mathrm{T}_{4}$ or $\mathrm{T}_{\mathrm{i}}$. Simultaneous with the issuance of HLDA, the 80186 will float the local bus and control lines. After HOLD is detected as being LOW, the 80186 will lower HLDA. When the 80186 needs to run another bus cycle, it will again drive the local bus and control lines. |
| $\overline{\text { UCS }}$ | 34 | 0 | Upper Memory Chip Select is an active LOW output whenever a memory reference is made to the defined upper portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ block) of memory. This line is not floated during bus HOLD. The address range activating UCS is software programmable. |
| $\overline{\text { LCS }}$ | 33 | 0 | Lower Memory Chip Select is active LOW whenever a memory reference is made to the defined lower portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ ) of memory. This line is not floated during bus HOLD. The address range activating $\overline{\text { LCS }}$ is software programmable. |
| $\begin{array}{\|l\|} \hline \frac{\mathrm{MCSO}}{\mathrm{MCS1}} \\ \hline \frac{\mathrm{MCS2}}{} \\ \hline \mathrm{MCS3} \\ \hline \end{array}$ | $\begin{aligned} & 38 \\ & 37 \\ & 36 \\ & 35 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | Mid-Range Memory Chip Select signals are active LOW when a memory reference is made to the defined mid-range portion of memory ( $8 \mathrm{~K}-512 \mathrm{~K}$ ). These lines are not floated during bus HOLD. The address ranges activating $\overline{\text { MCSO }}-3$ are software programmable. |
| PCS0 <br> PCS1 <br> PCS2 <br> PCS3 <br> PCS4 | $\begin{aligned} & 25 \\ & 27 \\ & 28 \\ & 29 \\ & 30 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Peripheral Chip Select signals $0-4$ are active LOW when a reference is made to the defined peripheral area ( 64 K byte I/O space). These lines are not floated during bus HOLD. The address ranges activating $\overline{\text { PCSO }}-4$ are software programmable. |
| $\overline{\text { PCS5/A1 }}$ | 31 | 0 | Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth peripheral chip select, or to provide an internally latched A1 signal. The address range activating PCS5 is software-programmable. PCS5/A1 does not float during bus HOLD. When programmed to provide latched A1, this pin will retain the previously latched value during HOLD. |
| $\overline{\text { PCS6 } / A 2 ~}$ | 32 | 0 | Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh peripheral chip select, or to provide an internally latched A2 signal. The address range activating PCS6 is software programmable. PCS6/A2 does not float during bus HOLD. When programmed to provide latched A2, this pin will retain the previously latched value during HOLD. |
| DT/ $\bar{R}$ | 40 | 0 | Data Transmit/Receive controls the direction of data flow through an external data bus transceiver. When LOW, data is transferred to the 80186. When HIGH the 80186 places write data on the data bus. |
| $\overline{\text { DEN }}$ | 39 | 0 | Data Enable is provided as a data bus transceiver output enable. $\overline{\mathrm{DEN}}$ is active LOW during each memory and I/O access. DEN is HIGH whenever DT/ $\overline{\mathrm{R}}$ changes state. During RESET, DEN is driven HIGH for one clock, then floated. $\overline{\text { DEN }}$ also floats during HOLD. |

## FUNCTIONAL DESCRIPTION

## Introduction

The following Functional Description describes the base architecture of the 80186. The 80186 is a very high integration 16 -bit microprocessor. It combines 15-20 of the most common microprocessor system components onto one chip while providing twice the performance of the standard 8086. The 80186 is object code compatible with the 8086/8088 microprocessors and adds 10 new instruction types to the 8086/8088 instruction set.

## 80186 BASE ARCHITECTURE

The 8086, 8088, 80186, and 80286 family all contain the same basic set of registers, instructions, and addressing modes.

## Register Set

The 80186 base architecture has fourteen registers as shown in Figures 3 a and 3 b . These registers are grouped into the following categories.

## General Registers

Eight 16 -bit general purpose registers may be used for arithmetic and logical operands. Four of these ( $A X, B X, C X$, and $D X$ ) can be used as 16 -bit registers or split into pairs of separate 8 -bit registers.

## 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.)

## 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 selects the specific registers for operand and address calculations.

## Status and Control Registers

Two 16-bit special purpose registers record or alter certain aspects of the 80186 processor state. These are the Instruction Pointer Register, which contains the offset address of the next sequential instruction to be executed, and the Status Word Register, which contains status and control flag bits (see Figures 3a and 3 b ).

## Status Word Description

The Status Word records specific characteristics of the result of logical and arithmetic instructions (bits $0,2,4,6,7$, and 11) and controls the operation of the 80186 within a given operating mode (bits 8,9 , and 10). The Status Word Register is 16 -bits wide. The function of the Status Word bits is shown in Table 2.


Figure 3a. 80186 Register Set


Figure 3b. Status Word Format

Table 2. Status Word Bit Functions

| Bit <br> Position | Name | Function |
| :---: | :---: | :--- |
| 0 | CF | Carry Flag-Set on high-order <br> bit carry or borrow; cleared <br> otherwise |
| 2 | PF | Parity Flag-Set if low-order 8 <br> bits of result contain an even <br> number of 1-bits; cleared <br> otherwise |
| 4 | AF | Set on carry from or borrow to <br> the low order four bits of AL; <br> cleared otherwise |
| 6 | ZF | Zero Flag-Set if result is zero; <br> cleared otherwise |
| 7 | SF | Sign Flag-Set equal to high- <br> order bit of result (0 if positive, <br> 1 if negative) |
| 8 | TF | Single Step Flag-Once set, a <br> single step interrupt occurs <br> after the next instruction <br> executes. TF is cleared by the <br> single step interrupt. |
| 9 | IF | Interrupt-enable Flag-When <br> set, maskable interrupts will <br> cause the CPU to transfer <br> control to an interrupt vector <br> specified location. |
| 10 | DF | Direction Flag-Causes string <br> instructions to auto decrement <br> the appropriate index register <br> when set. Clearing DF causes <br> auto increment. |
| 11 | OF | Overflow Flag-Set if the <br> signed result cannot be <br> expressed within the number <br> of bits in the destination <br> operand; cleared otherwise |

## Instruction Set

The instruction set is divided into seven categories: data transfer, arithmetic, shift/rotate/logical, string manipulation, control transfer, high-level instructions, and processor control. These categories are summarized in Figure 4.

An 80186 instruction can reference anywhere from zero to several operands. An operand can reside in a register, in the instruction itself, or in memory. Specific operand addressing modes are discussed later in this data sheet.

## Memory Organization

Memory is organized in sets of segments. Each segment is a linear contiguous sequence of up to 64 K (216) 8 -bit bytes. Memory is addressed using a twocomponent address (a pointer) that consists of a 16bit base segment and a 16 -bit offset. The 16 -bit base values are contained in one of four internal segment register (code, data, stack, extra). The physical address is calculated by shifting the base value LEFT by four bits and adding the 16 -bit offset value to yield a 20 -bit physical address (see Figure 5). This allows for a 1 MByte physical address size.

All instructions that address operands in memory must specify the base segment and the 16 -bit offset value. For speed and compact instruction encoding, the segment register used for physical address generation is implied by the addressing mode used (see Table 3). These rules follow the way programs are written (see Figure 6) 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 overridden for special cases. The stack, data, and extra segments may coincide for simple programs.

| GENERAL PURPOSE |  | MOVS |  | Move byte or word string |
| :---: | :---: | :---: | :---: | :---: |
| MOV | Move byte or word | INS |  | Input bytes or word string |
| PUSH | Push word onto stack | OUTS |  | Output bytes or word string |
| POP | Pop word off stack | CMPS |  | Compare byte or word string |
| PUSHA | Push all registers on stack | SCAS |  | Scan byte or word string |
| POPA | Pop all registers from stack | LODS |  | Load byte or word st |
| XCHG | Exchange byte or word |  |  |  |
| XLAT | Translate byte | STOS |  | Store byte or word string • |
| INPUT/OUTPUT |  | REP |  | Repeat |
| IN | Input byte or word | REPE/REPZ |  | Repeat while equal/zero |
| OUT | Output byte or word | REPNE/REPNZ |  | Repeat while not equal/not zero |
| ADDRESS OBJECT |  | LOGICALS |  |  |
| LEA | Load effective address |  | "Not" byte or word |  |
| LDS | Load pointer using DS | AND | "And" byte or word |  |
| LES | Load pointer using ES | OR | "Inclusive or" byte or word |  |
| FLAG TRANSFER |  | XOR | "Exclusive or" byte or word |  |
|  |  | TEST | "Test" byte or word |  |
|  | Load AH register from flags | SHIFTS |  |  |
| SAHF | Store AH register in flags | SHL/SAL | Shift logical/arithmetic left byte or word |  |
| PUSHF | Push flags onto stack | SHR | Shift logical right byte or word |  |
| POPF | Pop flags off stack | SAR $\quad$ Shift arithmetic right byte or word |  |  |
| ADDITION |  | ROTATES |  |  |
| ADD | Add byte or word | ROL | Rotate left byte or word |  |
| ADC | Add byte or word with carry | ROR | Rotate right byte or word |  |
| INC | Increment byte or word by 1 | RCL | Rotate through carry left byte or word |  |
| AAA | ASCII adjust for addition | RCR | Rotate through carry right byte or word |  |
| DAA | Decimal adjust for addition | FLAG OPERATIONS |  |  |
| SUBTRACTION |  | STC | Set carry flag |  |
| SUB | Subtract byte or word | CLC | Clear carry flag |  |
| SBB |  |  | Complement carry flag |  |
| DEC | Decrement byte or word by 1 | STD | Set direction flag |  |
| NEG | Negate byte or word | CLD | Clear direction flag |  |
| CMP | Compare byte or word | STI | Set interrupt enable flag |  |
| AAS | ASCII adjust for subtraction | CLI | Clear interrupt enable flag |  |
| DAS | Decimal adjust for subtraction | EXTERNAL SYNCHRONIZATION |  |  |
| MULTIPLICATION |  | HLT | Halt until interrupt or reset |  |
| MUL | Multiply byte or word unsigned | WAIT | Wait for TEST pin active |  |
| IMUL | Integer multiply byte or word | ESC | Escape to extension processor |  |
| AAM | ASCII adjust for multiply | LOCK Lock bus during next instruction |  |  |
| DIVISION |  | NO OPERATION |  |  |
| DIV | Divide byte or word unsigned | NOP | No operation |  |
| IDIV | Integer divide byte or word | HIGH LEVEL INSTRUCTIONS |  |  |
| AAD | ASCII adjust for division | ENTER | Format stack for procedure entry |  |
| CBW | Convert byte to word | LEAVE | Restore stack for procedure exit |  |
| CWD | Convert word to doubleword | BOUND | Detects values outside prescribed range |  |

Figure 4. 80186 Instruction Set

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

Figure 4. 80186 Instruction Set (Continued)

To access operands that do not reside in one of the four immediately available segments, a full 32-bit pointer can be used to reload both the base (segment) and offset values.


Figure 5. Two Component Address
Table 3. Segment Register Selection Rules

| Memory <br> Reference <br> Needed | Segment <br> Register <br> Used | Implicit Segment <br> Selection Rule |
| :--- | :--- | :--- |
| Instructions | Code (CS) | Instruction prefetch and <br> immediate data. <br> Stack |
| Stack (SS) | All stack pushes and <br> pop; any memory <br> references which use BP <br> Register as a base |  |
| register. |  |  |
| External | Extra (ES) | All string instruction <br> references which use <br> the DI register as an <br> index. <br> Data <br> (Global) |
| Local Data | Data (DS) |  |
| All other data references. |  |  |



Figure 6. Segmented Memory Helps Structure Software

## Addressing Modes

The 80186 provides eight categories of addressing modes to specify operands. Two addressing modes are provided for instructions that operate on register or immediate 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: a segment base and an offset. The segment base is supplied by a 16 -bit segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset, also called the effective address, is calculated by summing any combination of the following three address elements:

- the displacement (an 8- or 16 -bit immediate value contained in the instruction);
- the base (contents of either the BX or BP base registers); and
- the index (contents of either the SI or DI index registers).

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 80186 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 an 8087 Numeric Data Coprocessor with the 80186.
- Ordinal: An unsigned binary numeric value contained in an 8 -bit byte or a 16 -bit word.
- Pointer: A 16 - or 32 -bit quantity, composed of a 16-bit offset component or a 16 -bit segment base component in addition to a 16 -bit offset component.
- String: A contiguous sequence of bytes or words. A string may contain from 1 to 64 K bytes.
- ASCIl: A byte representation of alphanumeric and control characters using the ASCII standard of character representation.
- $B C D$ : A byte (unpacked) representation of the decimal digits 0-9.
- Packed BCD: A byte (packed) representation of two decimal digits $(0-9)$. One digit is stored in each nibble (4-bits) of the byte.
- Floating Point: A signed 32-, 64-, or 80 -bit real number representation. (Floating point operands are supported using an 8087 Numeric Data Coprocessor with the 80186.)

In general, individual data elements must fit within defined segment limits. Figure 7 graphically represents the data types supported by the 80186.

## I/O Space

The I/O space consists of 64 K 8 -bit or 32 K 16 -bit ports. Separate 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 $00 F F(H)$ are reserved.

## Interrupts

An interrupt transfers execution to a new program location. The old program address (CS:IP) and machine state (Status Word) 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.


NOTE:
*Supported by using an 8087 Numeric Data Coprocessor with the 80186.

Figure 7. 80186 Supported Data Types
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. If the exception was caused by executing an ESC instruction with the ESC trap bit set in the relocation register, the return instruction will point to the ESC instruction, or to the segment override prefix immediately preceding the ESC instruction if the prefix was present. In all other cases, the
return address from an exception will point at the instruction immediately following the instruction causing the exception.

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. Table 4 shows the 80186 predefined types and default priority levels. For each interrupt, an 8-bit vector must be supplied to the 80186 which identifies the appropriate table entry. Exceptions supply the interrupt vector internally. In addition, internal peripherals and noncascaded external interrupts will generate their own vectors through the internal interrupt controller. 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. Non-maskable hardware interrupts use a predefined internally supplied vector.

## Interrupt Sources

The 80186 can service interrupts generated by software or hardware. The software interrupts are generated by specific instructions (INT, ESC, unused OP, etc.) or the results of conditions specified by instructions (array bounds check, INTO, DIV, IDIV, etc.). All interrupt sources are serviced by an indirect call through an element of a vector table. This vector table is indexed by using the interrupt vector type (Table 4), multiplied by four. All hardware-generated interrupts are sampled at the end of each instruction. Thus, the software interrupts will begin service first. Once the service routine is entered and interrupts are enabled, any hardware source of sufficient priority can interrupt the service routine in progress.

Those pre-defined 80186 interrupts which cannot be masked by programming are described below.

## DIVIDE ERROR EXCEPTION (TYPE 0)

Generated when a DIV or IDIV instruction quotient cannot be expressed in the number of bits in the destination.

## SINGLE-STEP INTERRUPT (TYPE 1)

Generated after most instructions if the TF flag is set. Interrupts will not be generated after prefix instructions (e.g., REP), instructions which modify segment registers (e.g., POP DS), or the WAIT instruction.

## NON-MASKABLE INTERRUPT-NMI (TYPE 2)

An external interrupt source which cannot be masked.

Table 4. 80186 Interrupt Vectors

| Interrupt <br> Name | Vector <br> Type | Vector <br> Address | Default <br> Priority | Related <br> Instructions | Applicable <br> Notes |
| :--- | :---: | :---: | :---: | :--- | :---: |
| Divide Error Exception | 0 | 00 H | 1 | DIV, IDIV | 1 |
| Single Step Interrupt | 1 | 04 H | 1 A | All | 2 |
| Non-Maskable Interrupt (NMI) | 2 | 08 H | 1 | All |  |
| Breakpoint Interrupt | 3 | 0 CH | 1 | INT | 1 |
| INTO Detected Overflow Exception | 4 | 10 H | 1 | INTO | 1 |
| Array Bounds Exception | 5 | 14 H | 1 | BOUND | 1 |
| Unused Opcode Exception | 6 | 18 H | 1 | Undefined Opcodes | 1 |
| ESC Opcode Exception | 7 | 1 CH | 1 | ESC Opcodes <br> (Coprocessor) | 1,3 |
| Timer 0 Interrupt | 8 | 20 H | 2 A |  | 4,5 |
| Timer 1 Interrupt | 18 | 48 H | 2 B |  | 4,5 |
| Timer 2 Interrupt | 19 | 4 CH | 2 C |  | 4,5 |
| Reserved | 9 | 24 H | 3 |  |  |
| DMA 0 Interrupt | 10 | 28 H | 4 |  | 5 |
| DMA 1 Interrupt | 11 | 2 CH | 5 |  |  |
| INTO Interrupt | 12 | 30 H | 6 |  |  |
| INT1 Interrupt | 13 | 34 H | 7 |  |  |
| INT2 Interrupt | 14 | 38 H | 8 |  |  |
| INT3 Interrupt | 15 | 3 CH | 9 |  |  |
| Reserved | 16,17 | $40 \mathrm{H}, 44 \mathrm{H}$ |  |  |  |
| Reserved | $20-31$ | $50 \mathrm{H}-7 \mathrm{CH}$ |  |  |  |

## NOTES:

Default priorities for the interrupt sources are used only if the user does not program each source to a unique priority level.

1. Generated as a result of an instruction execution.
2. Performed in same manner as 8086.
3. An ESC (coprocessor) opcode will cause a trap only if the proper bit is set in the peripheral control block relocation register.
4. All three timers constitute one source of request to the interrupt controller. As such, they share the same priority level with respect to other interrupt sources. However, the timers have a defined priority order among themselves ( $2 A>2 B>2 \mathrm{C}$ ). 5. The vector type numbers for these sources are programmable in Slave Mode.

## BREAKPOINT INTERRUPT (TYPE 3)

A one-byte version of the INT instruction. It uses 12 as an index into the service routine address table (because it is a type 3 interrupt).

## INTO DETECTED OVERFLOW EXCEPTION (TYPE4)

Generated during an INTO instruction if the OF bit is set.

## ARRAY BOUNDS EXCEPTION (TYPE 5)

Generated during a BOUND instruction if the array index is outside the array bounds. The array bounds are located in memory at a location indicated by one of the instruction operands. The other operand indicates the value of the index to be checked.

## UNUSED OPCODE EXCEPTION (TYPE 6)

Generated if execution is attempted on undefined opcodes.

## ESCAPE OPCODE EXCEPTION (TYPE 7)

Generated if execution is attempted of ESC opcodes (D8H-DFH). This exception will only be generated if a bit in the relocation register is set. The return address of this exception will point to the ESC instruction causing the exception. If a segment override prefix preceded the ESC instruction, the return address will point to the segment override prefix.

Hardware-generated interrupts are divided into two groups: maskable interrupts and non-maskable interrupts. The 80186 provides maskable hardware interrupt request pins INTO-INT3. In addition, maskable interrupts may be generated by the 80186
integrated DMA controller and the integrated timer unit. The vector types for these interrupts is shown in Table 4. Software enables these inputs by setting the interrupt flag bit (IF) in the Status Word. The interrupt controller is discussed in the peripheral section of this data sheet.

Further maskable interrupts are disabled while servicing an interrupt because the IF bit is reset as part of the response to an interrupt or exception. The saved Status Word will reflect the enable status of the processor prior to the interrupt. The interrupt flag will remain zero unless specifically set. The interrupt return instruction restores the Status Word, thereby restoring the original status of IF bit. If the interrupt return re-enables interrupts, and another interrupt is pending, the 80186 will immediately service the highest-priority interrupt pending, i.e., no instructions of the main line program will be executed.

## Non-Maskable Interrupt Request (NMI)

A non-maskable interrupt ( NMI ) is also provided. This interrupt is serviced regardless of the state of the IF bit. 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. The IF bit is cleared at the beginning of an NMI interrupt to prevent maskable interrupts from being serviced.

## Single-Step Interrupt

The 80186 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 Status 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.

## Initialization and Processor Reset

Processor initialization is accomplished by driving the RES input pin LOW. RES must be LOW during power-up to ensure proper device initialization. RES forces the 80186 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as $\overline{\operatorname{RES}}$ is active. After RES becomes inactive and an internal processing interval elapses, the 80186 begins execution with the instruction at physical location FFFFO(H). $\overline{\text { RES }}$ also sets some registers to predefined values as shown in Table 5.

Table 5. 80186 Initial Register State after RESET

| Status Word | FOO2(H) |
| :--- | :--- |
| Instruction Pointer | $0000(\mathrm{H})$ |
| Code Segment | FFFF(H) |
| Data Segment | $0000(\mathrm{H})$ |
| Extra Segment | $0000(\mathrm{H})$ |
| Stack Segment | $0000(\mathrm{H})$ |
| Relocation Register | $20 \mathrm{FF}(\mathrm{H})$ |
| UMCS | FFFB(H) |

## 80186 CLOCK GENERATOR

The 80186 provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, synchronous and asynchronous ready inputs, and reset circuitry.

## Oscillator

The oscillator circuit of the 80186 is designed to be used with a parallel resonant fundamental mode crystal. This is used as the time base for the 80186. The crystal frequency selected will be double the CPU clock frequency. Use of an LC or RC circuit is not recommended with this oscillator. If an external oscillator is used, it can be connected directly to the input pin X1 in lieu of a crystal. The output of the oscillator is not directly available outside the 80186. The recommended crystal configuration is shown in Figure 8.


Figure 8. Recommended 80186 Crystal Configuration

Intel recommends the following values for crystal selection parameters:

[^1]
## Clock Generator

The 80186 clock generator provides the $50 \%$ duty cycle processor clock for the 80186. It does this by dividing the oscillator output by 2 forming the symmetrical clock. If an external oscillator is used, the state of the clock generator will change on the falling edge of the oscillator signal. The CLKOUT pin provides the processor clock signal for use outside the 80186. This may be used to drive other system components. All timings are referenced to the output clock.

## READY Synchronization

The 80186 provides both synchronous and asynchronous ready inputs. Asynchronous ready synchronization is accomplished by circuitry which samples ARDY in the middle of $T_{2}, T_{3}$, and again in the middle of each Tw until ARDY is sampled HIGH. One-half CLKOUT cycle of resolution time is used for full synchronization of a rising ARDY signal. A high-to-low transition on ARDY may be used as an indication of the not ready condition but it must be performed synchronously to CLKOUT either in the middle of $T_{2}, T_{3}$, or $T_{W}$, or at the falling edge of $T_{3}$ or Tw.

A second ready input (SRDY) is provided to interface with externally synchronized ready signals. This input is sampled at the end of $T_{2}, T_{3}$ and again at the end of each $T_{w}$ until it is sampled HIGH. By using this input rather than the asynchronous ready input, the half-clock cycle resolution time penalty is eliminated. This input must satisfy set-up and hold times to guarantee proper operation of the circuit.

In addition, the 80186, as part of the integrated chipselect logic, has the capability to program WAIT states for memory and peripheral blocks. This is discussed in the Chip Select/Ready Logic description.

## RESET Logic

The 80186 provides both a $\overline{\text { RES }}$ input pin and a synchronized RESET output pin for use with other system components. The RES input pin on the 80186 is provided with hysteresis in order to facilitate poweron Reset generation via an RC network. RESET output is guaranteed to remain active for at least five clocks given a RES input of at least six clocks. RESET may be delayed up to approximately two and one-half clocks behind RES.

Multiple 80186 processors may be synchronized through the $\overline{R E S}$ input pin, since this input resets both the processor and divide-by-two internal coun-
ter in the clock generator. In order to ensure that the divide-by-two counters all begin counting at the same time, the active going edge of RES must satisfy a 25 ns setup time before the falling edge of the 80186 clock input. In addition, in order to ensure that all CPUs begin executing in the same clock cycle, the reset must satisfy a 25 ns setup time before the rising edge of the CLKOUT signal of all the processors.

## LOCAL BUS CONTROLLER

The 80186 provides a local bus controller to generate the local bus control signals. In addition, it employs a HOLD/HLDA protocol for relinquishing the local bus to other bus masters. It also provides outputs that can be used to enable external buffers and to direct the flow of data on and off the local bus.

## Memory/Peripheral Control

The 80186 provides ALE, $\overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ bus control signals. The $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ signals are used to strobe data from memory or I/O to the 80186 or to strobe data from the 80186 to memory or I/O. The ALE line provides a strobe to latch the address when it is valid. The 80186 local bus controller does not provide a memory///O signal. If this is required, use the $\overline{\mathrm{S} 2}$ signal (which will require external latching), make the memory and I/O spaces nonoverlapping, or use only the integrated chip-select circuitry.

## Transceiver Control

The 80186 generates two control signals to be connected to transceiver chips. This capability allows the addition of transceivers for extra buffering without adding external logic. These control lines, $D T / \bar{R}$ and $\overline{\text { DEN }}$, are generated to control the flow of data through the transceivers. The operation of these signals is shown in Table 6.

Table 6. Transceiver Control Signals Description

| Pin Name | Function |
| :--- | :--- |
| $\overline{\text { DEN }}$ |  |
| (Data Enable) | Enables the output drivers of the <br> transceivers. It is active LOW <br> during memory, I/O, or INTA <br> cycles. |
| DT// <br> (Data Transmit/ $/$ <br> Retermines the direction of travel <br> Rhrough the transceivers. A HIGH <br> level directs data away from the <br> processor during write <br> operations, while a LOW level <br> directs data toward the processor <br> during a read operation. |  |

## Local Bus Arbitration

The 80186 uses a HOLD/HLDA system of local bus exchange. This provides an asynchronous bus exchange mechanism. This means multiple masters utilizing the same bus can operate at separate clock frequencies. The 80186 provides a single HOLD/ HLDA pair through which all other bus masters may gain control of the local bus. External circuitry must arbitrate which external device will gain control of the bus when there is more than one alternate local bus master. When the 80186 relinquishes control of the local bus, it floats $\overline{D E N}, \overline{R D}, \overline{W R}, \overline{S O}-\overline{S 2}, \overline{L O C K}$, AD0-AD15, A16-A19, BHE, and DT/ $\overline{\mathrm{R}}$ to allow another master to drive these lines directly.

The 80186 HOLD latency time, i.e., the time between HOLD request and HOLD acknowledge, is a function of the activity occurring in the processor when the HOLD request is received. A HOLD request is the highest-priority activity request which the processor may receive: higher than instruction fetching or internal DMA cycles. However, if a DMA cycle is in progress, the 80186 will complete the transfer before relinquishing the bus. This implies that if a HOLD request is received just as a DMA transfer begins, the HOLD latency time can be as great as 4 bus cycles. This will occur if a DMA word transfer operation is taking place from an odd address to an odd address. This is a total of 16 clocks or more, if WAIT states are required. In addition, if locked transfers are performed, the HOLD latency time will be increased by the length of the locked transfer.

## Local Bus Controller and Reset

During RESET the local bus controller will perform the following action:

- Drive $\overline{\mathrm{DEN}}, \overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ HIGH for one clock cycle, then float.


## NOTE:

$\overline{R D}$ is also provided with an internal pull-up device to prevent the processor from inadvertently entering Queue Status Mode during RESET.

- Drive $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ to the inactive state (all HIGH) and then float.
- Drive $\overline{\text { LOCK }}$ HIGH and then float.
- Float ADO-15, A16-19, $\overline{B H E}, D T / \overline{\mathrm{R}}$.
- Drive ALE LOW (ALE is never floated).
- Drive HLDA LOW.


## INTERNAL PERIPHERAL INTERFACE

All the 80186 integrated peripherals are controlled by 16 -bit registers contained within an internal 256byte control block. The control block may be mapped into either memory or I/O space. Internal logic will recognize control block addresses and respond to bus cycles. During bus cycles to internal registers, the bus controller will signal the operation externally (i.e., the $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, status, address, data, etc., lines will be driven as in a normal bus cycle), but $D_{15-0}$, SRDY, and ARDY will be ignored. The base address of the control block must be on an even 256 -byte boundary (i.e., the lower 8 bits of the base address are all zeros). All of the defined registers within this control block may be read or written by the 80186 CPU at any time.

The control block base address is programmed by a 16-bit relocation register contained within the control block at offset FEH from the base address of the control block (see Figure 9). It provides the upper 12 bits of the base address of the control block. The control block is effectively an internal chip select range and must abide by all the rules concerning chip selects (the chip select circuitry is discussed later in this data sheet). Any access to the 256 bytes of the control block activates an internal chip select. Other chip selects may overlap the control block only if they are programmed to zero wait states and ignore external ready. In addition, bit 12 of this register determines whether the control block will be mapped into I/O or memory space. If this bit is 1 , the control block will be located in memory space. If the bit is 0 , the control block will be located in I/O space. If the control register block is mapped into I/O space, the upper 4 bits of the base address must be programmed as 0 (since I/O addresses are only 16 bits wide).

In addition to providing relocation information for the control block, the relocation register contains bits which place the interrupt controller into Slave Mode, and cause the CPU to interrupt upon encountering ESC instructions. At RESET, the relocation register

$$
\begin{aligned}
& \text { ET = ESC Trap / No ESC Trap (1/0) } \\
& \mathrm{M} / \mathrm{IO}=\text { Register block located in Memory / I/O Space (1/0) } \\
& \text { SLAVE/ } \overline{\text { MASTER }}=\text { Configure interrupt controller for Slave/Master Mode (I/O) }
\end{aligned}
$$

Figure 9. Relocation Register
is set to 20FFH, which maps the control block to start at FFOOH in I/O space. An offset map of the 256-byte control register block is shown in Figure 10.

## CHIP-SELECT/READY GENERATION LOGIC

The 80186 contains logic which provides programmable chip-select generation for both memories and peripherals. In addition, it can be programmed to provide READY (or WAIT state) generation. It can also provide latched address bits A1 and A2. The chip-select lines are active for all memory and I/O cycles in their programmed areas, whether they be generated by the CPU or by the integrated DMA unit.


Figure 10. Internal Register Map

## Memory Chip Selects

The 80186 provides 6 memory chip select outputs for 3 address areas; upper memory, lower memory, and midrange memory. One each is provided for upper memory and lower memory, while four are provided for midrange memory.

The range for each chip select is user-programmable and can be set to $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}, 16 \mathrm{~K}, 32 \mathrm{~K}, 64 \mathrm{~K}$, 128 K (plus 1 K and 256 K for upper and lower chip selects). In addition, the beginning or base address of the midrange memory chip select may also be selected. Only one chip select may be programmed to be active for any memory location at a time. All chip select sizes are in bytes, whereas 80186 memory is arranged in words. This means that if, for example, $1664 \mathrm{~K} \times 1$ memories are used, the memory block size will be 128 K , not 64 K .

## Upper Memory $\overline{\text { CS }}$

The 80186 provides a chip select, called UCS, for the top of memory. The top of memory is usually used as the system memory because after reset the 80186 begins executing at memory location FFFFOH.

The upper limit of memory defined by this chip select is always FFFFFH, while the lower limit is programmable. By programming the lower limit, the size of the select block is also defined. Table 7 shows the relationship between the base address selected and the size of the memory block obtained.

Table 7. UMCS Programming Values

| Starting <br> Address <br> (Base <br> Address) | Memory <br> Block <br> Size | UMCs Value <br> (Assuming <br> R0= R1 $=\mathbf{R 2}=\mathbf{0})$ |
| :---: | :---: | :---: |
| FFC00 | 1 K | FFF8H |
| FF800 | 2 K | FFB8H |
| FF000 | 4 K | FF33H |
| FE000 | 8 K | FE38H |
| FC000 | 16 K | FC38H |
| F8000 | 32 K | F838H |
| F0000 | 64 K | F038H |
| E0000 | 128 K | E038H |
| C0000 | 256 K | C038H |

The lower limit of this memory block is defined in the UMCS register (see Figure 11). This register is at offset $A O H$ in the internal control block. The legal values for bits 6-13 and the resulting starting address and memory block sizes are given in Table 7. Any combination of bits 6-13 not shown in Table 7 will result in undefined operation. After reset, the UMCS register is programmed for a 1 K area. It must be reprogrammed if a larger upper memory area is desired.

The internal generation of any 20 -bit address whose upper 16 bits are equal to or greater than the UMCS
value (with bits 0-5 as " 0 ") asserts UCS. UMCS bits R2-R0 specify the ready mode for the area of memory defined by this chip select register, as explained later.

## Lower Memory $\overline{\mathbf{C S}}$

The 80186 provides a chip select for low memory called LCS. The bottom of memory contains the interrupt vector table, starting at location 00000 H .

The lower limit of memory defined by this chip select is always OH , while the upper limit is programmable. By programming the upper limit, the size of the memory block is defined. Table 8 shows the relationship between the upper address selected and the size of the memory block obtained.

Table 8. LMCS Programming Values

| Upper Address | Memory Block Size | $\begin{gathered} \text { LMCS Value } \\ \text { (Assuming } \\ \mathbf{R 0}=\mathbf{R 1}=\mathbf{R 2}=\mathbf{0} \text { ) } \end{gathered}$ |
| :---: | :---: | :---: |
| 003FFH | 1K | 0038H |
| 007FFH | 2K | 0078H |
| 00FFFH | 4K | 00 F 8 H |
| 01FFFH | 8K | 01 F 8 H |
| 03FFFH | 16K | 03F8H |
| 07FFFH | 32K | 07F8H |
| OFFFFH | 64K | 0FF8H |
| 1FFFFH | 128K | 1FF8H |
| 3FFFFH | 256K | 3 FF 8 H |

The upper limit of this memory block is defined in the LMCS register (see Figure 12) at offset A2H in the internal control block. The legal values for bits 6-15 and the resulting upper address and memory block sizes are given in Table 8. Any combination of bits 6-15 not shown in Table 8 will result in undefined operation. After RESET, the LMCS register value is undefined. However, the $\overline{\text { LCS }}$ chip-select line will not become active until the LMCS register is accessed.

Any internally generated 20-bit address whose upper 16 bits are less than or equal to LMCS (with bits $0-5$ " 1 ") will assert LCS. LMCS register bits R2-R0 specify the READY mode for the area of memory defined by this chip-select register.

## Mid-Range Memory $\overline{\mathbf{C S}}$

The 80186 provides four $\overline{M C S}$ lines which are active within a user-locatable memory block. This block can be located within the 801861 M byte memory address space exclusive of the areas defined by $\overline{U C S}$ and LCS. Both the base address and size of this memory block are programmable.

The size of the memory block defined by the midrange select lines, as shown in Table 9, is determined by bits 8-14 of the MPCS register (see Figure 13). This register is at location A8H in the internal control block. One and only one of bits 8-14 must be set at a time. Unpredictable operation of the MCS lines will otherwise occur. Each of the four chip-select lines is active for one of the four equal contiguous divisions of the mid-range block. If the total block size is 32 K , each chip select is active for 8 K of memory with MCSO being active for the first range and MCS3 being active for the last range.

The EX and MS in MPCS relate to peripheral functionality as described in a later section.

Table 9. MPCS Programming Values

| Total Block <br> Size | Individual <br> Select Size | MPCS Bits <br> $\mathbf{1 4 - 8}$ |
| :---: | :---: | :---: |
| 8 K | 2 K | 0000001 B |
| 16 K | 4 K | 0000010 B |
| 32 K | 8 K | 0000100 B |
| 64 K | 16 K | 0001000 B |
| 128 K | 32 K | 0010000 B |
| 256 K | 64 K | 0100000 B |
| 512 K | 128 K | 1000000 B |

The base address of the mid-range memory block is defined by bits $15-9$ of the MMCS register (see Figure 14). This register is at offset A 6 H in the internal


Figure 11. UMCS Register


Figure 12. LMCS Register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OFFSET: A8H | 1 | M6 | M5 | M4 | M3 | M2 | M1 | M0 | EX | MS | 1 | 1 | 1 | R2 | R1 | R0 |

Figure 13. MPCS Register

OFFSET: A6H | 15 |
| :---: |
| U |
| A19 |

Figure 14. MMCS Register
control block. These bits correspond to bits A19-A13 of the 20-bit memory address. Bits A12-A0 of the base address are always 0 . The base address may be set at any integer multiple of the size of the total memory block selected. For example, if the mid-range block size is 32 K (or the size of the block for which each $\overline{M C S}$ line is active is 8 K ), the block could be located at 10000 H or 18000 H , but not at 14000 H , since the first few integer multiples of a 32 K memory block are $0 \mathrm{H}, 8000 \mathrm{H}$, $10000 \mathrm{H}, 18000 \mathrm{H}$, etc. After RESET, the contents of both of these registers are undefined. However, none of the MCS lines will be active until both the MMCS and MPCS registers are accessed.

MMCS bits R2-R0 specify READY mode of operation for all four mid-range chip selects.

The 512K block size for the mid-range memory chip selects is a special case. When using 512 K , the base address would have to be at either locations 00000 H or 80000 H . If it were to be programmed at 00000 H when the $\overline{\mathrm{LCS}}$ line was programmed, there would be an internal conflict between the $\overline{\mathrm{LCS}}$ ready generation logic and the $\overline{M C S}$ ready generation logic. Likewise, if the base address were programmed at 80000 H , there would be a conflict with the UCS ready generation logic. Since the $\overline{\mathrm{LCS}}$ chip-select line does not become active until programmed, while the UCS line is active at reset, the memory base can be set only at 00000 H . If this base address is selected, however, the $\overline{\mathrm{LCS}}$ range must not be programmed.
seven contiguous blocks of 128 bytes above a programmable base address. The base address may be located in either memory or I/O space.

Seven $\overline{\mathrm{CS}}$ lines called $\overline{\text { PCSO }}-6$ are generated by the 80186. The base address is user-programmable; however it can only be a multiple of 1 K bytes, i.e., the least significant 10 bits of the starting address are always 0 .
$\overline{\text { PCS5 }}$ and $\overline{\text { PCS6 }}$ can also be programmed to provide latched address bits A1 and A2. If so programmed, they cannot be used as peripheral selects. These outputs can be connected directly to the A0 and A1 pins used for selecting internal registers of 8-bit peripheral chips. This simplifies the external hardware because the peripheral registers can be located on even boundaries in I/O or memory space.

The starting address of the peripheral chip-select block is defined by the PACS register (see Figure 15). The register is located at offset A 4 H in the internal control block. Bits 15-6 of this register correspond to bits 19-10 of the 20-bit Programmable Base Address (PBA) of the peripheral chip-select block. Bits 9-0 of the PBA of the peripheral chip-select block are all zeros. If the chip-select block is located in I/O space, bits $12-15$ must be programmed zero, since the I/O address is only 16 bits wide. Table 10 shows the address range of each peripheral chip select with respect to the PBA contained in PACS register.

## Peripheral Chip Selects

The 80186 can generate chip selects for up to seven peripheral devices. These chip selects are active for

| 15 | 6 | 5 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OFFSET: | A4H |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| A19 | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | 1 | 1 | 1 | $R 2$ | $R 1$ | $R 0$ |

Figure 15. PACS Register

The user should program bits 15-6 to correspond to the desired peripheral base location. PACS bits 0-2 are used to specify READY mode for $\overline{\text { PCSO }}-\overline{\mathrm{PCS}}$.

Table 10. PCS Address Ranges

| $\overline{\text { PCS Line }}$ | Active between Locations |
| :--- | :--- |
| $\overline{\text { PCS0 }}$ | PBA $-\mathrm{PBA}+127$ |
| $\overline{\text { PCS1 }}$ | PBA $+128-\mathrm{PBA}+255$ |
| $\overline{\text { PCS2 }}$ | PBA $+256-\mathrm{PBA}+383$ |
| $\overline{\text { PCS3 }}$ | PBA $+384-$ PBA +511 |
| $\overline{\text { PCS4 }}$ | PBA $+512-\mathrm{PBA}+639$ |
| $\overline{\text { PCS5 }}$ | PBA $+640-\mathrm{PBA}+767$ |
| $\overline{\text { PCS6 }}$ | PBA $+768-\mathrm{PBA}+895$ |

The mode of operation of the peripheral chip selects is defined by the MPCS register (which is also used to set the size of the mid-range memory chip-select block, see Figure 13). The register is located at offset A8H in the internal control block. Bit 7 is used to select the function of PCS5 and PCS6, while bit 6 is used to select whether the peripheral chip selects are mapped into memory or I/O space. Table 11 describes the programming of these bits. After RESET, the contents of both the MPCS and the PACS registers are undefined, however none of the PCS lines will be active until both of the MPCS and PACS registers are accessed.

Table 11. MS, EX Programming Values

| Bit | Description |
| :--- | :--- |
| MS | $1=$ Peripherals mapped into memory space. |
|  | $0=$ Peripherals mapped into I/O space. |
| EX | $0=5 \overline{\text { PCS }}$ lines. A1, A2 provided. |
|  | $1=7$ PCS lines. A1, A2 are not provided. |

MPCS bits 0-2 specify the READY mode for $\overline{\text { PCS4 }}-$ $\overline{\text { PCS6 }}$ as outlined below.

## READY Generation Logic

The 80186 can generate a READY signal internally for each of the memory or peripheral CS lines. The number of WAIT states to be inserted for each peripheral or memory is programmable to provide 0-3 wait states for all accesses to the area for which the chip select is active. In addition, the 80186 may be programmed to either ignore external READY for each chip-select range individually or to factor external READY with the integrated ready generator.

READY control consists of 3 bits for each $\overline{\mathrm{CS}}$ line or group of lines generated by the 80186. The interpretation of the READY bits is shown in Table 12.

Table 12. READY Bits Programming

| R2 | R1 | R0 | Number of WAIT States Generated |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 wait states, external RDY |
| 0 | 0 | 1 | 1 wait state inserted, external RDY |
| 0 | 1 | 0 | also used. 2 wait states inserted, external RDY |
| 0 | 1 | 1 | also used. |
| 1 | 0 | 0 | also used. <br> 0 wait states, external RDY |
| 1 | 0 | 1 | ignored. 1 wait state inserted, external RDY |
| 1 | 1 | 0 | ignored. 2 wait states inserted, external RDY |
| 1 | 1 | 1 | ignored. <br> 3 wait states inserted, external RDY ignored. |

The internal ready generator operates in parallel with external READY, not in series if the external READY is used ( $\mathrm{R} 2=0$ ). For example, if the internal generator is set to insert two wait states, but activity on the external READY lines will insert four wait states, the processor will only insert four wait states, not six. This is because the two wait states generated by the internal generator overlapped the first two wait states generated by the external ready signal. Note that the external ARDY and SRDY lines are always ignored during cycles accessing internal peripherals.

R2-R0 of each control word specifies the READY mode for the corresponding block, with the exception of the peripheral chip selects: R2-R0 of PACS set the PCSO-3 READY mode, R2-R0 of MPCS set the $\overline{\text { PCS4-6 }} \mathbf{- 6}$ READY mode.

## Chip Select/Ready Logic and Reset

Upon RESET, the Chip-Select/Ready Logic will perform the following actions:

- All chip-select outputs will be driven HIGH.
- Upon leaving RESET, the UCS line will be programmed to provide chip selects to a 1 K block with the accompanying READY control bits set at 011 to insert 3 wait states in conjunction with external READY (i.e., UMCS resets to FFFBH).
- No other chip select or READY control registers have any predefined values after RESET. They will not become active until the CPU accesses their control registers. Both the PACS and MPCS registers must be accessed before the $\overline{\mathrm{PCS}}$ lines will become active.


## DMA CHANNELS

The 80186 DMA controller provides two independent DMA channels. Data transfers can occur between memory and I/O spaces (e.g., Memory to I/O) or within the same space (e.g., Memory to Memory or I/O to I/O). Data can be transferred either in bytes ( 8 bits) or in words ( 16 bits) to or from even or odd addresses. Each DMA channel maintains both a 20-bit source and destination pointer which can be optionally incremented or decremented after each data transfer (by one or two depending on byte or word transfers). Each data transfer consumes 2 bus cycles (a minimum of 8 clocks), one cycle to fetch data and the other to store data. This provides a maximum data transfer rate of $1.25 \mathrm{Mword} / \mathrm{sec}$ or 2.5 MBytes/sec at 10 MHz .

## DMA Operation

Each channel has six registers in the control block which define each channel's operation. The control registers consist of a 20 -bit Source pointer (2 words), a 20 -bit destination pointer ( 2 words), a $16-$ bit Transfer Count Register, and a 16 -bit Control Word. The format of the DMA Control Blocks is shown in Table 13. The Transfer Count Register (TC) specifies the number of DMA transfers to be performed. Up to 64 K byte or word transfers can be performed with automatic termination. The Control Word defines the channel's operation (see Figure 17). All registers may be modified or altered during any DMA activity. Any changes made to these registers will be reflected immediately in DMA operation.

Table 13. DMA Control Block Format

| Register Name | Register Address |  |
| :--- | :---: | :---: |
|  | Ch. 0 | Ch. 1 |
| Control Word | CAH | DAH |
| Transfer Count | $\mathrm{C8H}$ | D8H |
| Destination Pointer (upper 4 | C 6 H | D6H |
| bits) |  |  |
| Destination Pointer | C 4 H | D4H |
| Source Pointer (upper 4 bits) | C 2 H | D2H |
| Source Pointer | COH | D0H |



Figure 16. DMA Unit Block Diagram


Figure 17. DMA Control Register

## DMA Channel Control Word Register

Each DMA Channel Control Word determines the mode of operation for the particular 81086 DMA channel. This register specifies:

- the mode of synchronization;
- whether bytes or words will be transferred;
- whether interrupts will be generated after the last transfer;
- whether DMA activity will cease after a programmed number of DMA cycles;
- the relative priority of the DMA channel with respect to the other DMA channel;
- whether the source pointer will be incremented, decremented, or maintained constant after each transfer;
- whether the source pointer addresses memory or I/O space;
- whether the destination pointer will be incremented, decremented, or maintained constant after each transfer; and
- whether the destination pointer will address memory or I/O space.

The DMA channel control registers may be changed while the channel is operating. However, any changes made during operation will affect the current DMA transfer.

## DMA Control Word Bit Descriptions

DEST:
$\mathrm{M} / \overline{\mathrm{IO}}$ Destination pointer is in memory (1) or I/O (0) space.

DEC Decrement destination pointer by 1 or 2 (depends on $\bar{B} / W$ ) after each transfer.
INC Increment destination pointer by 1 or 2 (depends on $\bar{B} / W$ ) after each transfer.
If both INC and DEC are specified, the pointer will not change after each cycle.

SOURCE: $M / \overline{\mathrm{IO}}$ Source pointer is in memory (1) or I/O (0) space.
DEC Decrement source pointer by 1 or 2 (depends on $\bar{B} / W$ ) after each transfer.
INC Increment source pointer by 1 or 2 (depends on $\bar{B} / W$ ) after each transfer.
If both INC and DEC are specified, the pointer will not change after each cycle.
TC: If set, DMA will terminate when the contents of the transfer count register reach zero. The ST/STOP bit will also be reset at this point. If cleared, the DMA controller will decrement the transfer count register for each DMA cycle, but DMA transfers will not stop when the transfer count register reaches zero.
INT: Enable interrupts to CPU upon transfer count termination.

SYN:
00 No synchronization.
NOTE:
When unsynchronized transfers are specified, the TC bit will be ignored and the ST bit will be cleared upon the transfer count reaching zero, stopping the channel.
01 Source synchronization.
10 Destination synchronization.
11 Unused.
$\mathrm{P}: \quad$ Channel priority relative to other channel during simultaneous requests.
0 Low priority.
1 High priority.
Channels will alternate cycles if both are set at same priority level.
TDRQ: Enable/Disable (1/0) DMA requests from timer 2.

CHG/NOCHG: Change/Do not change (1/0) ST/STOP bit. If this bit is set when writing the control word, the ST/STOP bit will be programmed by the write to the control word. If this bit is cleared when writing the control word, the ST/STOP bit will not be altered. This bit is not stored; it will always be read as 0 .
ST/STOP: $\quad$ Start/Stop (1/0) channel.
$\bar{B} / \mathrm{W}: \quad$ Byte/Word (0/1) transfers.

## DMA Destination and Source Pointer Registers

Each DMA channel maintains a 20 -bit source and a 20 -bit destination pointer. Each of these pointers takes up two full 16-bit registers in the peripheral control block. The lower four bits of the upper register contain the upper four bits of the 20-bit physical address (see Figure 18). These pointers may be individually incremented or decremented after each transfer. If word transfers are performed the pointer is incremented or decremented by two. Each pointer may point into either memory or I/O space. Since the DMA channels can perform transfers to or from odd addresses, there is no restriction on values for the pointer registers. Higher transfer rates can be obtained if all word transfers are performed to even addresses, since this will allow data to be accessed in a single bus cycle.

## DMA Transfer Count Register

Each DMA channel maintains a 16-bit transfer count register (TC). The register is decremented after ev-
ery DMA cycle, regardless of the state of the TC bit in the DMA Control Register. If the TC bit in the DMA control word is set or if unsynchronized transfers are programmed, however, DMA activity will terminate when the transfer count register reaches zero.

## DMA Requests

Data transfers may be either source or destination synchronized, that is either the source of the data or the destination of the data may request the data transfer. In addition, DMA transfers may be unsynchronized; that is, the transfer will take place continually until the correct number of transfers has occurred. When source or unsynchronized transfers are performed, the DMA channel may begin another transfer immediately after the end of a previous DMA transfer. This allows a complete transfer to take place every 2 bus cycles or eight clock cycles (assuming no wait states). When destination synchronized transfers are performed, data will not be fetched from the source address until the destination device signals that it is ready to receive it. Also, the DMA controller will relinquish control of the bus after every transfer. If no other bus activity is initiated, another destination synchronized DMA cycle will begin after two processor clocks. This allows the destination device time to remove its request if another transfer is not desired. Since the DMA controller will relinquish the bus, the CPU can initiate a bus cycle. As a result, a complete bus cycle will often be inserted between destination synchronized transfers. Table 14 shows the maximum DMA transfer rates.

Table 14. Maximum DMA Transfer
Rates @ CLKOUT=10 MHz

| Type of <br> Synchronization <br> Selected | CPU Running | CPU Halted |
| :--- | :---: | :---: |
| Unsynchronized <br> Source Synch. <br> Destination Synch. | $2.5 \mathrm{MBytes} / \mathrm{sec}$ | $2.5 \mathrm{MBytes} / \mathrm{sec}$ |


| HIGHER <br> REGISTER <br> ADDRESS <br> LOWER <br> REGISTER <br> ADDRESS |
| :---: | | A15-A12 | A11-A8 | A7-A4 | A3-A0 |
| :---: | :---: | :---: | :---: |
| 15 | A19-A16 |  |  |

Figure 18. DMA Pointer Register Format

## DMA Acknowledge

No explicit DMA acknowledge pulse is provided. Since both source and destination pointers are maintained, a read from a requesting source, or a write to a requesting destination, should be used as the DMA acknowledge signal. Since the chip-select lines can be programmed to be active for a given block of memory or I/O space, and the DMA pointers can be programmed to point to the same given block, a chip-select line could be used to indicate a DMA acknowledge.

## DMA Priority

The DMA channels may be programmed to give one channel priority over the other, or they may be programmed to alternate cycles when both have DMA requests pending. DMA cycles always have priority over internal CPU cycles except between locked memory accesses or word accesses to odd memory locations; also, an external bus hold takes priority over an internal DMA cycle. Because an interrupt request cannot suspend a DMA operation and the CPU cannot access memory during a DMA cycle, interrupt latency time will suffer during sequences of continuous DMA cycles. An NMI request, however, will cause all internal DMA activity to halt. This allows the CPU to quickly respond to the NMI request.

## DMA Programming

DMA cycles will occur whenever the ST/STOP bit of the Control Register is set. If synchronized transfers
are programmed, a DRQ must also be generated. Therefore the source and destination transfer pointers, and the transfer count register (if used) must be programmed before the ST/STOP bit is set.

Each DMA register may be modified while the channel is operating. If the CHG/NOCHG bit is cleared when the control register is written, the ST/STOP bit of the control register will not be modified by the write. If multiple channel registers are modified, it is recommended that a LOCKED string transfer be used to prevent a DMA transfer from occurring between updates to the channel registers.

## DMA Channels and Reset

Upon RESET, the DMA channels will perform the following actions:

- The Start/Stop bit for each channel will be reset to STOP.
- Any transfer in progress is aborted.


## TIMERS

The 80186 provides three internal 16 -bit programmable timers (see Figure 19). Two of these are highly flexible and are connected to four external pins (2 per timer). They can be used to count external events, time external events, generate nonrepetitive waveforms, etc. The third timer is not connected to any external pins, and is useful for real-time coding and time delay applications. In addition, the third timer can be used as a prescaler to the other two, or as a DMA request source.


Figure 19. Timer Block Diagram

## Timer Operation

The timers are controlled by 1116 -bit registers in the peripheral control block. The configuration of these registers is shown in Table 15. The count register contains the current value of the timer. It can be read or written at any time independent of whether the timer is running or not. The value of this register will be incremented for each timer event. Each of the timers is equipped with a MAX COUNT register, which defines the maximum count the timer will reach. After reaching the MAX COUNT register value, the timer count value will reset to zero during that same clock, i.e., the maximum count value is never stored in the count register itself. Timers 0 and 1 are, in addition, equipped with a second MAX COUNT register, which enables the timers to alternate their count between two different MAX COUNT values. If a single MAX COUNT register is used, the timer output pin will switch LOW for a single clock, 1 clock after the maximum count value has been reached. In the dual MAX COUNT register mode, the output pin will indicate which MAX COUNT register is currently in use, thus allowing nearly complete freedom in selecting waveform duty cycles. For the timers with two MAX COUNT registers, the RIU bit in the control register determines which is used for the comparison.

Each timer gets serviced every fourth CPU-clock cycle, and thus can operate at speeds up to one-quarter the internal clock frequency (one-eighth the crystal rate). External clocking of the timers may be done at up to a rate of one-quarter of the internal CPUclock rate ( 2 MHz for an 8 MHz CPU clock). Due to internal synchronization and pipelining of the timer circuitry, a timer output may take up to 6 clocks to respond to any individual clock or gate input.

Since the count registers and the maximum count registers are all 16 bits wide, 16 bits of resolution are provided. Any Read or Write access to the timers will add one wait state to the minimum four-clock bus cycle, however. This is needed to synchronize and coordinate the internal data flows between the internal timers and the internal bus.

The timers have several programmable options.

- All three timers can be set to halt or continue on a terminal count.
- Timers 0 and 1 can select between internal and external clocks, alternate between MAX COUNT registers and be set to retrigger on external events.
- The timers may be programmed to cause an interrupt on terminal count.

These options are selectable via the timer mode/ control word.

## Timer Mode/Control Register

The mode/control register (see Figure 20) allows the user to program the specific mode of operation or check the current programmed status for any of the three integrated timers.

Table 15. Timer Control Block Format

| Register Name | Register Offset |  |  |
| :--- | :---: | :---: | :---: |
|  | Tmr. 0 | Tmr. 1 | Tmr. 2 |
| Mode/Control Word | 56 H | 5 EH | 66 H |
| Max Count B | 54 H | 5 CH | not present |
| Max Count A | 52 H | 5 AH | 62 H |
| Count Register | 50 H | 58 H | 60 H |


| 15 | 14 | 13 | 12 | 11 |  | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EN | $\overline{\mathrm{NH}}$ | INT | RIU | 0 | . | MC | RTG | P | EXT | ALT | CONT |

Figure 20. Timer Mode/Control Register

## EN:

The enable bit provides programmer control over the timer's RUN/HALT status. When set, the timer is enabled to increment subject to the input pin constraints in the internal clock mode (discussed previously). When cleared, the timer will be inhibited from counting. All input pin transistions during the time EN is zero will be ignored. If CONT is zero, the EN bit is automatically cleared upon maximum count.

## INH:

The inhibit bit allows for selective updating of the enable (EN) bit. If INH is a one during the write to the mode/control word, then the state of the EN bit will be modified by the write. If INH is a zero during the write, the EN bit will be unaffected by the operation. This bit is not stored; it will always be a 0 on a read.

## INT:

When set, the INT bit enables interrupts from the timer, which will be generated on every terminal count. If the timer is configured in dual MAX COUNT register mode, an interrupt will be generated each time the value in MAX COUNT register A is reached, and each time the value in MAX COUNT register $B$ is reached. If this enable bit is cleared after the interrupt request has been generated, but before a pending interrupt is serviced, the interrupt request will still be in force. (The request is latched in the Interrupt Controller).

## RIU:

The Register In Use bit indicates which MAX COUNT register is currently being used for comparison to the timer count value. A zero value indicates register A. The RIU bit cannot be written, i.e., its value is not affected when the control register is written. It is always cleared when the ALT bit is zero.

## MC:

The Maximum Count bit is set whenever the timer reaches its final maximum count value. If the timer is configured in dual MAX COUNT register mode, this bit will be set each time the value in MAX COUNT register A is reached, and each time the value in MAX COUNT register $B$ is reached. This bit is set regardless of the timer's interrupt-enable bit. The MC bit gives the user the ability to monitor timer status through software instead of through interrupts.

Programmer intervention is required to clear this bit.

## RTG:

Retrigger bit is only active for internal clocking (EXT $=0$ ). In this case it determines the control function provided by the input pin.

If RTG $=0$, the input level gates the internal clock on and off. If the input pin is HIGH, the timer will count; if the input pin is LOW, the timer will hold its value. As indicated previously, the input signal may be asynchronous with respect to the 80186 clock.

When RTG = 1, the input pin detects LOW-to-HIGH transitions. The first such transition starts the timer running, clearing the timer value to zero on the first clock, and then incrementing thereafter. Further transitions on the input pin will again reset the timer to zero, from which it will start counting up again. If CONT $=0$, when the timer has reached maximum count, the EN bit will be cleared, inhibiting further timer activity.

## P:

The prescaler bit is ignored unless internal clocking has been selected (EXT $=0$ ). If the $P$ bit is a zero, the timer will count at one-fourth the internal CPU clock rate. If the P bit is a one, the output of timer 2 will be used as a clock for the timer. Note that the user must initialize and start timer 2 to obtain the prescaled clock.

## EXT:

The external bit selects between internal and external clocking for the timer. The external signal may be asynchronous with respect to the 80186 clock. If this bit is set, the timer will count LOW-to-HIGH transitions on the input pin. If cleared, it will count an internal clock while using the input pin for control. In this mode, the function of the external pin is defined by the RTG bit. The maximum input to output transition latency time may be as much as 6 clocks. However, clock inputs may be pipelined as closely together as every 4 clocks without losing clock pulses.

## ALT:

The ALT bit determines which of two MAX COUNT registers is used for count comparison. If ALT $=0$, register A for that timer is always used, while if ALT $=1$, the comparison will alternate between register A and register B when each maximum count is reached. This alternation allows the user to change one MAX COUNT register while the other is being used, and thus provides a method of generating non-repetitive waveforms. Square waves and pulse
outputs of any duty cycle are a subset of available signals obtained by not changing the final count registers. The ALT bit also determines the function of the timer output pin. If ALT is zero, the output pin will go LOW for one clock, the clock after the maximum count is reached. If ALT is one, the output pin will reflect the current MAX COUNT register being used ( $0 / 1$ for $B / A$ ).

CONT:
Setting the CONT bit causes the associated timer to run continuously, while resetting it causes the timer to halt upon maximum count. If CONT $=0$ and ALT $=1$, the timer will count to the MAX COUNT register A value, reset, count to the register B value, reset, and halt.

Not all mode bits are provided for timer 2. Certain bits are hardwired as indicated below:

$$
\text { ALT }=0, \text { EXT }=0, P=0, \text { RTG }=0, \text { RIU }=0
$$

## Count Registers

Each of the three timers has a 16-bit count register. The contents of this register may be read or written by the processor at any time. If the register is written while the timer is counting,the new value will take effect in the current count cycle.

## Max Count Registers

Timers 0 and 1 have two MAX COUNT registers, while timer 2 has a single MAX COUNT register. These contain the number of events the timer will count. In timers 0 and 1, the MAX COUNT register used can alternate between the two max count values whenever the current maximum count is reached. A timer resets when the timer count register equals the max count value being used. If the timer count register or the max count register is changed so that the max count is less than the timer count, the timer does not immediately reset. Instead, the timer counts up to OFFFFH, "wraps around" to zero, counts up to the max count value, and then resets.

## Timers and Reset

Upon RESET, the Timers will perform the following actions:

- All EN (Enable) bits are reset preventing timer counting.
- For Timers 0 and 1 , the RIU bits are reset to zero and the ALT bits are set to one. This results in the Timer Out pins going high.


## INTERRUPT CONTROLLER

The 80186 can receive interrupts from a number of sources, both internal and external. The internal interrupt controller serves to merge these requests on a priority basis, for individual service by the CPU.

Internal interrupt sources (Timers and DMA channels) can be disabled by their own control registers or by mask bits within the interrupt controller. The 80186 interrupt controller has its own control register that sets the mode of operation for the controller.

The interrupt controller will resolve priority among requests that are pending simultaneously. Nesting is provided so interrupt service rountines for lower priority interrupts may be interrupted by higher priority interrupts. A block diagram of the interrupt controller is shown in Figure 21.

The 80186 has a special Slave Mode in which the internal interrupt controller acts as a slave to an external master. The controller is programmed into this mode by setting bit 14 in the peripheral control block relocation register. (See Slave Mode section.)

## MASTER MODE OPERATION

## Interrupt Controller External Interface

Five pins are provided for external interrupt sources. One of these pins is NMI, the non-maskable interrupt. NMI is generally used for unusual events such as power-fail interrupts. The other four pins may be configured in any of the followirig ways:

- As four interrupt input lines with internally generated interrupt vectors.
- As an interrupt line and interrupt acknowledge line pair (Cascade Mode) with externally generated interrupt vectors plus two interrupt input lines with internally generated vectors.
- As two pairs of interrupt/interrupt acknowledge lines (Cascade Mode) with externally generated interrupt vectors.

External sources in the Cascade Mode use externally generated interrupt vectors. When an interrupt is acknowledged, two INTA cycles are initiated and the vector is read into the 80186 on the second cycle. The capability to interface to external 8259A programmable interrupt controllers is provided when the inputs are configured in Cascade Mode.

## Interrupt Controller Modes of Operation

The basic modes of operation of the interrupt controller in Master Mode are similar to the 8259A. The interrupt controller responds identically to internal interrupts in all three modes: the difference is only in the interpretation of function of the four external interrupt pins. The interrupt controller is set into one of these three modes by programming the correct bits in the INT0 and INT1 control registers. The modes of interrupt controller operation are as follows:

## Fully Nested Mode

When in the fully nested mode four pins are used as direct interrupt requests as in Figure 22. The vectors for these four inputs are generated internally. An inservice bit is provided for every interrupt source. If a lower-priority device requests an interrupt while the in service bit (IS) is set, no interrupt will be generated by the interrupt controller. In addition, if another interrupt request occurs from the same interrupt source while the in-service bit is set, no interrupt will be generated by the interrupt controller. This allows interrupt service routines to operate with interrupts enabled, yet be suspended only by interrupts of higher priority than the in-service interrupt.

When a service routine is completed, the proper IS bit must be reset by writing the proper pattern to the EOI register. This is required to allow subsequent interrupts from this interrupt source and to allow servicing of lower-priority interrupts. An EOI command is executed at the end of the service routine
just before the return from interrupt instruction. If the fully nested structure has been upheld, the next highest-priority source with its IS bit set is then serviced.

## Cascade Mode

The 80186 has four interrupt pins and two of them have dual functions. In the fully nested mode the four pins are used as direct interrupt inputs and the corresponding vectors are generated internally. In the Cascade Mode, the four pins are configured into interrupt input-dedicated acknowledge signal pairs. The interconnection is shown in Figure 23. INT0 is an interrupt input interfaced to an 8259A, while INT2/INTAO serves as the dedicated interrupt acknowledge signal to that peripheral. The same is true for INT1 and INT3//्INTA1. Each pair can selectively be placed in the Cascade Mode by programming the proper value into INTO and INT1 control registers. The use of the dedicated acknowledge signals eliminates the need for the use of external logic to generate $\overline{\mathrm{NTA}}$ and device select signals.

The primary Cascade Mode allows the capability to serve up to 128 external interrupt sources through the use of external master and slave 8259As. Three levels of priority are created, requiring priority resolution in the 80186 interrupt controller, the master 8259As, and the slave 8259As. If an external interrupt is serviced, one IS bit is set at each of these levels. When the interrupt service routine is completed, up to three end-of-interrupt commands must be issued by the programmer.


Figure 21. Interrupt Controller Block Diagram


Figure 22. Fully Nested (Direct) Mode Interrupt Controller Connections

## Special Fully Nested Mode

This mode is entered by setting the SFNM bit in INTO or INT1 control register. It enables complete nestability with external 8259A masters. Normally, an interrupt request from an interrupt source will not be recognized unless the in-service bit for that source is reset. If more than one interrupt source is connected to an external interrupt controller, all of the interrupts will be funneled through the same 80186 interrupt request pin. As a result, if the external interrupt controller receives a higher-priority interrupt, its interrupt will not be recognized by the 80186 controller until the 80186 in-service bit is reset. In Special Fully Nested Mode, the 80186 interrupt controller will allow interrupts from an external pin regardless of the state of the in-service bit for an interrupt source in order to allow multiple interrupts from a single pin. An in-service bit will continue to be set, however, to inhibit interrupts from other lowerpriority 80186 interrupt sources.

Special procedures should be followed when resetting is bits at the end of interrupt service routines. Software polling of the IS register in the external master 8259 A is required to determine if there is more than one bit set. If so, the IS bit in the 80186 remains active and the next interrupt service routine is entered.

## Operation in a Polled Environment

The controller may be used in a polled mode if interrupts are undesirable. When polling, the processor disables interrupts and then polls the interrupt controller whenever it is convenient. Polling the interrupt controller is accomplished by reading the Poll Word (Figure 32). Bit 15 in the poll word indicates to the processor that an interrupt of high enough priority is requesting service. Bits $0-4$ indicate to the processor the type vector of the highest-priority source re-
questing service. Reading the Poll Word causes the In-Service bit of the highest priority source to be set.

It is desirable to be able to read the Poll Word information without guaranteeing service of any pending interrupt, i.e., not set the indicated in-service bit. The 80186 provides a Poll Status Word in addition to the conventional Poll Word to allow this to be done. Poll Word information is duplicated in the Poll Status Word, but reading the Poll Status Word does not set the associated in-service bit. These words are located in two adjacent memory locations in the register file.

## Master Mode Features

## Programmable Priority

The user can program the interrupt sources into any of eight different priority levels. The programming is done by placing a 3 -bit priority level $(0-7)$ in the control register of each interrupt source. (A source with a priority level of 4 has higher priority over all priority levels from 5 to 7 . Priority registers containing values lower than 4 have greater priority). All interrupt sources have preprogrammed default priority levels (see Table 4).

If two requests with the same programmed priority level are pending at once, the priority ordering scheme shown in Table 4 is used. If the serviced interrupt routine reenables interrupts, other interrupt requests can be serviced.

## End-of-Interrupt Command

The end-of-interrupt (EOI) command is used by the programmer to reset the In -Service (IS) bit when an interrupt service routine is completed. The EOI command is issued by writing the proper pattern to the EOI register. There are two types of EOI commands, specific and nonspecific. The nonspecific command does not specify which IS bit is reset. When issued, the interrupt controller automatically resets the IS bit of the highest priority source with an active service routine. A specific EOI command requires that the programmer send the interrupt vector type to the interrupt controller indicating which source's IS bit is to be reset. This command is used when the fully nested structure has been disturbed or the highest priority IS bit that was set does not belong to the service routine in progress.

## Trigger Mode

The four external interrupt pins can be programmed in either edge- or level-trigger mode. The control register for each external source has a level-trigger
mode (LTM) bit. All interrupt inputs are active HIGH. In the edge sense mode or the level-trigger mode, the interrupt request must remain active (HIGH) until the interrupt request is acknowledged by the 80186 CPU. In the edge-sense mode, if the level remains high after the interrupt is acknowledged, the input is disabled and no further requests will be generated. The input level must go LOW for at least one clock cycle to re-enable the input. In the level-trigger mode, no such provision is made: holding the interrupt input HIGH will cause continuous interrupt requests.

## Interrupt Vectoring

The 80186 Interrupt Controller will generate interrupt vectors for the integrated DMA channels and the integrated Timers. In addition, the Interrupt Controller will generate interrupt vectors for the external interrupt lines if they are not configured in Cascade or Special Fully Nested Mode. The interrupt vectors generated are fixed and cannot be changed (see Table 4).

## Interrupt Controller Registers

The Interrupt Controller register model is shown in Figure 24. It contains 15 registers. All registers can both be read or written unless specified otherwise.

## In-Service Register

This register can be read from or written into. The format is shown in Figure 25. It contains the In-Service bit for each of the interrupt sources. The In-Service bit is set to indicate that a source's service routine is in progress. When an In -Service bit is set, the interrupt controller will not generate interrupts to the

CPU when it receives interrupt requests from devices with a lower programmed priority level. The TMR bit is the In-Service bit for all three timers; the D0 and D1 bits are the In-Service bits for the two DMA channels; the $10-13$ are the In -Service bits for the external interrupt pins. The IS bit is set when the processor acknowledges an interrupt request either by an interrupt acknowledge or by reading the poll register. The IS bit is reset at the end of the interrupt service routine by an end-of-interrupt command.

## Interrupt Request Register

The internal interrupt sources have interrupt request bits inside the interrupt controller. The format of this register is shown in Figure 25. A read from this register yields the status of these bits. The TMR bit is the logical OR of all timer interrupt requests. D0 and D1 are the interrupt request bits for the DMA channels.

The state of the external interrupt input pins is also indicated. The state of the external interrupt pins is not a stored condition inside the interrupt controller, therefore the external interrupt bits cannot be written. The external interrupt request bits are set when an interrupt request is given to the interrupt controller, so if edge-triggered mode is selected, the bit in the register will be HIGH only after an inactive-to-active transition. For internal interrupt sources, the register bits are set when a request arrives and are reset when the processor acknowledges the requests.

Writes to the interrupt request register will affect the D0 and D1 interrupt request bits. Setting either bit will cause the corresponding interrupt request while clearing either bit will remove the corresponding interrupt request. All other bits in the register are readonly.


$$
210451-12
$$

Figure 23. Cascade and Special Fully Nested Mode Interrupt Controller Connections

## Mask Register

This is a 16-bit register that contains a mask bit for each interrupt source. The format for this register is shown in Figure 25. A one in a bit position corresponding to a particular source masks the source from generating interrupts. These mask bits are the exact same bits which are used in the individual control registers; programming a mask bit using the mask register will also change this bit in the individual control registers, and vice versa.


## Priority Mask Register

This register masks all interrupts below a particular interrupt priority level. The format of this register is shown in Figure 26. The code in the lower three bits of this register inhibits interrupts of priority lower (a higher priority number) than the code specified. For example, 100 written into this register masks interrupts of level five (101), six (110), and seven (111). The register is reset to seven (111) upon RESET so no interrupts are masked due to priority number.

## Interrupt Status Register

This register contains general interrupt controller status information. The format of this register is shown in Figure 27. The bits in the status register have the following functions:
DHLT: DMA Halt Transfer; setting this bit halts all DMA transfers. It is automatically set whenever a non-maskable interrupt occurs, and it is reset when an IRET instruction is executed. This bit allows prompt service of all nonmaskable interrupts. This bit may also be set by the programmer.
IRTx: These three bits represent the individual timer interrupt request bits. These bits differentiate between timer interrupts, since the timer IR bit in the interrupt request register is the "OR" function of all timer interrupt request. Note that setting any one of these three bits initiates an interrupt request to the interrupt controller.

Figure 24. Interrupt Controller Registers (Master Mode)

| 15 | 14 |  |  |  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | - | - | - | 0 | 0 | 0 | 13 | 12 | 11 | 10 | D1 | D | 0 | TMR |

Figure 25. In-Service, Interrupt Request, and Mask Register Formats


Figure 26. Priority Mask Register Format


Figure 27. Interrupt Status Register Format (Master Mode)

## Timer, DMA 0, 1; Control Register

These registers are the control words for all the internal interrupt sources. The format for these registers is shown in Figure 28. The three bit positions PRO, PR1, and PR2 represent the programmable priority level of the interrupt source. The MSK bit inhibits interrupt requests from the interrupt source. The MSK bits in the individual control registers are the exact same bits as are in the Mask Register; modifying them in the individual control registers will also modify them in the Mask Register, and vice versa.

## INTO-INT3 Control Registers

These registers are the control words for the four external input pins. Figure 29 shows the format of the INT0 and INT1 Control registers; Figure 30 shows the format of the INT2 and INT3 Control registers. In Cascade Mode or Special Fully Nested Mode, the control words for INT2 and INT3 are not used.

The bits in the various control registers are encoded as follows:
PRO-2: Priority programming information. Highest Priority $=000$, Lowest Priority $=111$
LTM: $\quad$ Level-trigger mode bit. $1=$ level-triggered; $0=$ edge-triggered. Interrupt Input levels are active high. In level-triggered mode, an interrupt is generated whenever the external line is high. In edge-triggered mode, an interrupt will be generated only when this
level is preceded by an inactive-to-active transition on the line. In both cases, the level must remain active until the interrupt is acknowledged.
MSK: $\quad$ Mask bit, $1=$ mask; $0=$ non-mask.
C: $\quad$ Cascade mode bit, $1=$ cascade; $0=$ direct
SFNM: Special Fully Nested Mode bit, $1=$ SFNM

## EOI Register

The end of the interrupt register is a command register which can only be written into. The format of this register is shown in Figure 31. It initiates an EOI command when written to by the 80186 CPU.

The bits in the EOI register are encoded as follows:
$S_{x}$ : Encoded information that specifies an interrupt source vector type as shown in Ta ble 4. For example, to reset the In-Service bit for DMA channel 0 , these bits should be set to 01010, since the vector type for DMA channel 0 is 10 .

## NOTE:

To reset the single in-Service bit for any of the three timers, the vector type for timer 0 (8) should be written in this register.

Figure 28. Timer/DMA Control Registers Formats


Figure 29. INTO/INT1 Control Register Formats


Figure 30. INT2/INT3 Control Register Formats

NSPEC/: A bit that determines the type of EOI comSPEC $\quad$ mand. Nonspecific $=1$, Specific $=0$.

## Poll and Poll Status Registers

These registers contain polling information. The format of these registers is shown in Figure 32. They can only be read. Reading the Poll register constitutes a software poll. This will set the IS bit of the highest priority pending interrupt. Reading the poll status register will not set the IS bit of the highest priority pending interrupt; only the status of pending interrupts will be provided.

Encoding of the Poll and Poll Status register bits are as follows:
$S_{x}$ : Encoded information that indicates the vector type of the highest priority interrupting source. Valid only when INTREQ $=1$.
INTREQ: This bit determines if an interrupt request is present. Interrupt Request $=1$; no $\ln$ terrupt Request $=0$.

## SLAVE MODE OPERATION

When Slave Mode is used, the internal 80186 interrupt controller will be used as a slave controller to an external master interrupt controller. The internal 80186 resources will be monitored by the internal interrupt controller, while the external controller
functions as the system master interrupt controller. Upon reset, the 80186 will be in Master Mode. To provide for slave mode operation bit 14 of the relocation register should be set.

Because of pin limitations caused by the need to interface to an external 8259A master, the internal interrupt controller will no longer accept external inputs. There are however, enough 80186 interrupt controller inputs (internally) to dedicate one to each timer. In this mode, each timer interrupt source has its own mask bit, IS bit, and control word.

In Slave Mode each peripheral must be assigned a unique priority to ensure proper interrupt controller operation. Therefore, it is the programmer's responsibility to assign correct priorities and initialize interrupt control registers before enabling interrupts.

These level assignments must remain fixed in the Slave Mode of operation.

## Slave Mode External Interface

The configuration of the 80186 with respect to an external 8259A master is shown in Figure 33. The INT0 (pin 45) input is used as the 80186 CPU interrupt input. IRQ (pin 41) functions as an output to send the 80186 slave-interrupt-request to one of the 8 master-PIC-inputs.


Figure 31. EOI Register Format


Figure 32. Poll and Poll Status Register Format


Figure 33. Slave Mode Interrupt Controller Connections

Correct master-slave interface requires decoding of the slave addresses (CASO-2). Slave 8259As do this internally. Because of pin limitations, the 80186 slave address will have to be decoded externally. SELECT (pin 44) is used as a slave-select input. Note that the slave vector address is transferred internally, but the READY input must be supplied externally.
$\overline{\text { INTAO }}$ (pin 42) is used as an acknowledge output, suitable to drive the INTA input of an 8259A.

## Interrupt Nesting

Slave Mode operation allows nesting of interrupt requests. When an interrupt is acknowledged, the priority logic masks off all priority levels except those with equal or higher priority.

## Vector Generation in the Slave Mode

Vector generation in Slave Mode is exactly like that of an 8259A or 82C59A slave. The interrupt controller generates an 8-bit vector type number which the CPU multiplies by four to use as an address into the vector table. The five most significant bits of this type number are user-programmable while the three least significant bits are defined according to Figure 34. The significant five bits of the vector are programmed by writing to the Interrupt Vector register at offset 20 H .

## Specific End-of-Interrupt

In Slave Mode the specific EOI command operates to reset an in-service bit of a specific priority. The user supplies a 3 -bit priority-level value that points to an in-service bit to be reset. The command is executed by writing the correct value in the Specific EOI register at offset 22 H .

## Interrupt Controller Registers in the Slave Mode

All control and command registers are located inside the internal peripheral control block. Figure 34 shows the offsets of these registers.

## End-of-Interrupt Register

The end-of-interrupt register is a command register which can only be written. The format of this register is shown in Figure 35. It initiates an EOI command when written by the 80186 CPU.

The bits in the EOI register are encoded as follows:
$\mathrm{V} \mathrm{T}_{\mathrm{x}}$ : Three least-significant vector type bits corresponding to the source for which the IS bit is to be reset. Figure 34 indicates these bits.

## In-Service Register

This register can be read from or written into. It contains the in-service bit for each of the internal interrupt sources. The format for this register is shown in Figure 36. Bit positions 2 and 3 correspond to the DMA channels; positions 0,4 , and 5 correspond to the integral timers. The source's IS bit is set when the processor acknowledges its interrupt request.

## Interrupt Request Register

This register indicates which internal peripherals have interrupt requests pending. The format of this register is shown in Figure 36. The interrupt request bits are set when a request arrives from an internal source, and are reset when the processor acknowledges the request. As in Master Mode, D0 and D1 are read/write; all other bits are read only.

## Mask Register

This register contains a mask bit for each interrupt source. The format for this register is shown in Figure 36. If the bit in this register corresponding to a particular interrupt source is set, any interrupts from that source will be masked. These mask bits are exactly the same bits which are used in the individual control registers, i.e., changing the state of a mask bit in this register will also change the state of the mask bit in the individual interrupt control register corresponding to the bit.

## Control Registers

These registers are the control words for all the internal interrupt sources. The format of these registers is shown in Figure 37. Each of the timers and both of the DMA channels have their own Control Register.

The bits of the Control Registers are encoded as follows:
prx: 3-bit encoded field indicating a priority level for the source.
msk: mask bit for the priority level indicated by $\mathrm{pr}_{\mathrm{x}}$ bits.

| TIMER2 CONTROL REGISTER (VECTOR TYPE $x \times x \times x$ 101) | ЗАН |
| :---: | :---: |
| TIMER1 CONTROL REGISTER (VECTOR TYPE xxxxx100) | 38 |
| DMA1 CONTROL REGISTER (VECTOR TYPE xxxxx011) | 36 H |
| DMAO CONTROL REGISTER (VECTOR TYPE $x x x x x 010$ ) | 34 |
| TIMERO CONTROL REGISTER (VECTOR TYPE xxxxx000) | 32 |
| Interrupt status register | ${ }^{30 H}$ |
| INTERRUPT-REQUEST REGISTER | 2EH |
| in-SERVICE REGISTER | 2 CH |
| PRIORITY-LEVEL MASK REGISTER | 2 A |
| MASK REGISTER | 28 H |
| SPECIFIC EOI REGISTER | 22 H |
| INTERRUPT VECTOR REGISTER | 2 OH |

Figure 34. Interrupt Controller Registers
(Slave Mode)

## Interrupt Vector Register

This register provides the upper five bits of the interrupt vector address. The format of this register is shown in Figure 38. The interrupt controller itself provides the lower three bits of the interrupt vector as determined by the priority level of the interrupt request.

The format of the bits in this register is:
$t_{x}$ : 5 -bit field indicating the upper five bits of the vector address.

## Priority-Level Mask Register

This register indicates the lowest priority-level interrupt which will be serviced.

The encoding of the bits in this register is:
$m_{x}$ : 3-bit encoded field indication priority-level value. All levels of lower priority will be masked.

## Interrupt Controller and Reset

Upon RESET, the interrupt controller will perform the following actions:

- All SFNM bits reset to 0 , implying Fully Nested Mode.
- All PR bits in the various control registers set to 1. This places all sources at lowest priority (level 111).
- All LTM bits reset to 0 , resulting in edge-sense mode.
- All Interrupt Service bits reset to 0 .
- All Interrupt Request bits reset to 0 .
- All MSK (Interrupt Mask) bits set to 1 (mask).
- All C (Cascade) bits reset to 0 (non-Cascade).
- All PRM (Priority Mask) bits set to 1 , implying no levels masked.
- Initialized to Master Mode.


## Interrupt Status Register

This register is defined as in Master Mode except that DHLT is not implemented. (See Figure 27).


Figure 37. Control Word Format

| 15 | 14 | 13 |  |  |  |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $\bullet$ | - | - | $\bullet$ | 0 | $t 4$ | t3 | t2 | $t 1$ | to | 0 | 0 | 0 |

Figure 38. Interrupt Vector Register Format

| 15 | 14 | 13 |  |  |  |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | - | - | - | - | 0 | 0 | 0 | 0 | 0 | 0 | m2 | m1 | m0 |

Figure 39. Priority Level Mask Register


Figure 40. Typical 80186 Computer


Figure 41. Typical $\mathbf{8 0 1 8 6}$ Multi-Master Bus Interface

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias $.0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature

$$
\ldots \ldots \ldots-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}
$$

Voltage on any Pin with
Respect to Ground............... -1.0 V to +7 V
Power Dissipation .3W

NOTICE: This is a production data sheet. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the 'Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.
D.C. CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

Applicable to 80186 ( 8 MHz ), $80186-10(10 \mathrm{MHz}$ ).

| 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 (All except X1 and ( $\overline{\mathrm{RES}}$ ) | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{H} 1}$ | Input High Voltage ( $\overline{\mathrm{RES}}$ ) | 3.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{a}}=2.5 \mathrm{~mA} \text { for } \overline{\mathrm{SO}}-\overline{\mathrm{S2}} \\ & \mathrm{I}_{\mathrm{a}}=2.0 \mathrm{~mA} \text { for all other Outputs } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{oa}}=-400 \mu \mathrm{~A}$ |
| ICC | Power Supply Current |  | 600* | mA | $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ |
|  |  |  | 550 | mA | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
|  |  |  | 415 | mA | $\mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C}$ |
| lıI | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {CC }}$ |
| LLO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V}<\mathrm{V}_{\text {OUT }}<\mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\text {CLO }}$ | Clock Output Low |  | 0.6 | V | $\mathrm{l}_{\mathrm{a}}=4.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{CHO}}$ | Clock Output High | 4.0 |  | V | $\mathrm{l}_{\mathrm{oa}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {CLI }}$ | Clock Input Low Voltage | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{\mathrm{CHI}}$ | Clock Input High Voltage | 3.9 | $\mathrm{V}_{\mathrm{CC}}+1.0$ | V |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 10 | pF |  |
| $\mathrm{ClO}_{10}$ | I/O Capacitance |  | 20 | pF |  |

[^2]
## PIN TIMINGS

A.C. CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

80186 Timing Requirements All Timings Measured At 1.5V Unless Otherwise Noted.

| Symbol | Parameter | $80186$ <br> ( 8 MHz ) |  | $\begin{aligned} & \mathbf{8 0 1 8 6 - 1 0} \\ & (10 \mathrm{MHz}) \end{aligned}$ |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| T DVCL | Data in Setup (A/D) | 20 |  | 15 |  | ns |  |
| TCLDX | Data in Hold (A/D) | 10 |  | 8 |  | ns |  |
| $\mathrm{T}_{\text {ARYHCH }}$ | Asynchronous Ready (ARDY) Active Setup Time (1) | 20 |  | 15 |  | ns |  |
| TARYLCL | ARDY Inactive Setup Time | 35 |  | 25 |  | ns |  |
| TCLARX | ARDY Hold Time | 15 |  | 15 |  | ns |  |
| T ARYCHL | Asynchronous Ready Inactive Hold Time | 15 |  | 15 |  | ns |  |
| TSRYCL | Synchronous Ready (SRDY) Transition Setup Time (2) | 20 |  | 20 |  | ns |  |
| TCLSRY | SRDY Transition Hold Time (2) | 15 |  | 15 |  | ns |  |
| THVCL | HOLD Setup (1) | 25 |  | 20 |  | ns |  |
| TINVCH | INTR, NMI, TEST, TIM IN, Setup (1) | 25 |  | 25 |  | ns |  |
| TinVCL | DRQ0, DRQ1, Setup (1) | 25 |  | 20 |  | ns |  |

80186 Master Interface Timing Responses
$\left.\begin{array}{|l|l|c|c|c|c|c|c|}\hline T_{C L A V} & \text { Address Valid Delay } & 5 & 55 & 5 & 44 & \mathrm{~ns} & \begin{array}{c}C_{L}=20-200 \mathrm{pF} \\ \text { all Outputs } \\ \text { (Except } \mathrm{T}_{\mathrm{CLMM}} \\ \text { @ 8 \& 10 MHz }\end{array} \\ \hline \mathrm{T}_{\mathrm{CLAX}} & \text { Address Hold } & 10 & & 10 & & \mathrm{~ns}\end{array}\right)$

1. To guarantee recognition at next clock.
2. To guarantee proper operation.

80186

PIN TIMINGS (Continued)
A.C. CHARACTERISTICS $\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ ) (Continued)

80186 Master Interface Timing Responses (Continued)

| Symbol | Parameter | $\begin{gathered} 80186 \\ (8 \mathrm{MHz}) \end{gathered}$ |  | $\begin{aligned} & 80186-10 \\ & (10 \mathrm{MHz}) \end{aligned}$ |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| $\mathrm{T}_{\text {AZRL }}$ | Address Float to RD Active | 0 |  | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 70 | 10 | 56 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 55 | 10 | 44 | ns |  |
| TrHAV | $\overline{\mathrm{RD}}$ Inactive to Address Active | TCLCL-40 |  | TCLCL-40 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 5 | 50 | 5 | 40 | ns |  |
| TRLRH | $\overline{\text { RD Width }}$ | $2 T_{\text {CLCL }}-50$ |  | $2 \mathrm{~T}_{\text {CLCL }}-46$ |  | ns |  |
| TWLWH | WR Width | $2 \mathrm{~T}_{\text {CLCL }}-40$ |  | $2 \mathrm{~T}_{\text {CLCL }}-34$ |  | ns |  |
| TAVLL | Address Valid to ALE Low | $\mathrm{TCLCH}^{-25}$ |  | $\mathrm{T}_{\mathrm{CLCH}}{ }^{-19}$ |  | ns |  |
| TCHSV | Status Active Delay | 10 | 55 | 10 | 45 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 65 | 10 | 50 | ns |  |
| TCLTMV | Timer Output Delay |  | 60 |  | 48 | ns | $\begin{aligned} & 100 \mathrm{pF} \max \\ & @ 8 \& 10 \mathrm{MHz} \end{aligned}$ |
| TCLRO | Reset Delay |  | 60 |  | 48 | ns |  |
| TCHQSV | Queue Status Delay |  | 35 |  | 28 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 10 |  | 10 |  | ns |  |
| TCLLV | $\overline{\text { LOCK Valid/Invalid }}$ Delay | 5 | 65 | 5 | 60 | ns |  |

80186 Chip-Select Timing Responses

| $T_{\text {CLCSV }}$ | Chip-Select <br> Active Delay |  | 66 | 45 | ns |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\text {CXCSX }}$ | Chip-Select Hold from <br> Command Inactive | 35 |  | 35 |  | ns |  |
| $\mathrm{~T}_{\text {CHCSX }}$ | Chip-Select <br> Inactive Delay | 5 | 35 | 5 | 32 | ns |  |

80186 CLKIN Requirements

| $T_{\text {CKIN }}$ | CLKIN Period | 62.5 | 250 | 50 | 250 | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {CKHL }}$ | CLKIN Fall Time |  | 10 |  | 10 | ns | 3.5 to 1.0 V |
| $T_{\text {CKLH }}$ | CLKIN Rise Time |  | 10 |  | 10 | ns | 1.0 to 3.5V |
| $T_{\text {CLCK }}$ | CLKIN Low Time | 25 |  | 20 |  | ns | 1.5 V |
| $T_{\text {CHCK }}$ | CLKIN High Time | 25 |  | 20 |  | ns | 1.5 V |

80186 CLKOUT Timing ( 200 pF load)

| $T_{\text {CICO }}$ | CLKIN to <br> CLKOUT Skew | 50 |  | 25 | ns |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\mathrm{CLCL}}$ | CLKOUT Period | 125 | 500 | 100 | 500 | ns |  |
| $\mathrm{~T}_{\mathrm{CLCH}}$ | CLKOUT Low Time | $1 / 2 \mathrm{~T}_{\mathrm{CLCL}}-7.5$ |  | $1 / 2 T_{\mathrm{CLCL}}-6.0$ |  | ns | 1.5 V |
| $\mathrm{~T}_{\mathrm{CHCL}}$ | CLKOUT High Time | $1 / 2 \mathrm{~T}_{\mathrm{CLCL}}-7.5$ |  | $1 / 2 T_{\mathrm{CLCL}}-6.0$ |  | ns | 1.5 V |
| $\mathrm{~T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLKOUT Rise Time |  | 15 |  | 12 | ns | 1.0 to 3.5V |
| $\mathrm{T}_{\mathrm{CL} 2 \mathrm{CL} 1}$ | CLKOUT Fall Time |  | 15 |  | 12 | ns | 3.5 to 1.0 V |

## EXPLANATION OF THE AC SYMBOLS

Each timing symbol has from 5 to 7 characters. The first character is always a "T" (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.
A: Address
ARY: Asynchronous Ready Input
C: Clock Output
CK: Clock Input
CS: Chip Select
CT: Control (DT/ $\overline{\mathrm{R}}, \overline{\mathrm{DEN}}, \ldots$ )
D: Data Input
DE: DEN
H: Logic Level High

IN: Input (DRQO, TIMO, ...)
L: Logic Level Low or ALE
O: Output
QS: Queue Status (QS1, QS2)
R: $\overline{R D}$ signal, RESET signal
$\mathrm{S}: \quad \mathrm{Status}(\overline{\mathrm{SO}}, \overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2})$
SRY: Synchronous Ready Input
V: Valid
W: WR Signal
X: No Longer a Valid Logic Level
Z: Float
Examples:
Tclav - Time from Clock low to Address valid
TCHLH - Time from Clock high to ALE high
Tclcsv - Time from Clock low to Chip Select valid

## WAVEFORMS



WAVEFORMS (Continued)
MAJOR CYCLE TIMING (Continued)


## NOTES:

1. INTA occurs one clock later in slave mode.
2. Status inactive just prior to $T_{4}$.
3. If latched A1 and A2 are selected instead of $\overline{\mathrm{PCS5}}$ and $\overline{\mathrm{PCS} 6}$, only $\mathrm{T}_{\text {CLCSV }}$ is applicable.

WAVEFORMS (Continued)


WAVEFORMS (Continued)


WAVEFORMS (Continued)


## WAVEFORMS (Continued)

## HOLD/HLDA TIMING (Entering Hold)



## HOLD/HLDA TIMING (Leaving Hold)



WAVEFORMS (Continued)
TIMER ON 80186


210451-27

## 80186 EXPRESS

The Intel EXPRESS system offers enhancements to the operational specifications of the 80186 microprocessor. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

The EXPRESS program includes the commercial standard temperature range with burn-in and an extended temperature range without burn-in.

With the commercial standard temperature range operational characteristics are guaranteed over the temperature range of $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$. With the extended temperature range option, operational characteristics are guaranteed over the range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

The optional burn-in is dynamic, for a minimum time of 160 hours at $+125^{\circ} \mathrm{C}$ with $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 0.25 \mathrm{~V}$, following guidelines in MIL-STD-883, Method 1015.

Package types and EXPRESS versions are identified by a one- or two-letter prefix to the part number. The prefixes are listed in Table 16. All A.C. and D.C. specifications not mentioned in this section are the same for both commercial and EXPRESS parts.

Table 16. Prefix Identification

| Prefix | Package <br> Type | Temperature <br> Range | Burn-In |
| :---: | :---: | :---: | :---: |
| A | PGA | Commercial | No |
| N | PLCC | Commercial | No |
| R | LCC | Commercial | No |
| TA | PGA | Extended | No |
| QA | PGA | Commercial | Yes |
| QR | LCC | Commercial | Yes |

## NOTE:

Not all package/temperature range/speed combinations are available.

## 80186 EXECUTION TIMINGS

A determination of 80186 program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDS occur.
- All word-data is located on even-address boundaries.

All instructions which involve memory accesses can also require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

With a 16 -bit BIU, the 80186 has sufficient bus performance to ensure that an adequate number of prefetched bytes will reside in the queue most of the time. Therefore, actual program execution time will not be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY

| Function |  |  | Cormat |
| :--- | :--- | :--- | :--- |

Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format | Clock <br> Cycles |
| :--- | :--- | :---: | :---: |
| Comments |  |  |  |

Shaded areas indicate instructions not available in 8086, 8088 microsystems.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if $\mathrm{mod}=11$ then $\mathrm{r} / \mathrm{m}$ is treated as 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 $\mathrm{EA}=(\mathrm{BX})+(\mathrm{SI})+\mathrm{DISP}$
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)+(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=011$ then $\mathrm{EA}=(\mathrm{BP})+(\mathrm{DI})+\mathrm{DISP}$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then $\mathrm{EA}=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+D I S P^{*}$
if $\mathrm{r} / \mathrm{m}=111$ then $E A=(B X)+D I S P$
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

## Segment Override Prefix

| 0 | 0 | 1 | reg | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

reg is assigned according to the following:

| reg | Segment <br> Register |
| :---: | :---: |
| 00 | ES |
| 01 | CS |
| 10 | SS |
| 11 | DS |

REG is assigned according to the following table:

| $\mathbf{1 6 - B i t}(\mathbf{w}=\mathbf{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.

## REVISION HISTORY

The sections significantly revised since version -010 are:
Pin Description Table Added note to TEST pin requiring proper RESET at power-up to configure pin as input.
Renamed pin 44 to INT1/SELECT and pin 41 to INT3/INTA $1 /$ IRQ to better describe their functions in Slave Mode.
Initialization and Processor Reset
Major Cycle Timing Waveform
HOLD/HLDA Timing Waveforms
Slave Mode Operation

Clarified applicability of TCLCSV to latched A1 and A2 in footnote.

Redrawn to indicate correct relationship of HOLD inactive to HLDA inactive.

The three low order bits associated with vector generation and performing EOI are not alterable; however, the priority levels are programmable. This information is a clarification only.

The sections significantly revised since version -009 are:
Pin Description Table Various descriptions rewritten for clarity.
Interrupt Vector Table
A.C. Characteristics

Redrawn for clarity.
Added reminder that $\mathrm{T}_{\text {SRYCL }}$ and $\mathrm{T}_{\text {CLSRY }}$ must be met.
Explanation of the
New section.
A.C. Symbols

Major Cycle Timing Waveforms

TCLRO indicated.

The sections significantly revised since version -008 are:
Pin Description Table Noted $\overline{R E S}$ to be low more than 4 clocks. Connections to X 1 and X2 clarified.
DMA Control Bit Descriptions Moved and clarified note concerning TC condition for ST/ $\overline{\text { STOP }}$ clearing during unsynchronized transfers.
Interrupt Controller, etc. Renamed iRMX Mode to Slave Mode.
Interrupt Request Register
Execution Timings
Noted that D0 and D1 are read/write, others read-only.
Effect of bus width clarified.
The sections significantly revised since the October, 1986 version -007 are:
A.C. Characteristics Deleted column for 12.5 MHz devices. Intel never marketed a 12.5 MHz 80186.

The sections significantly revised since the February, 1986 version $\mathbf{- 0 0 7}$ are:
A.C. Characteristics Several timings changed in anticipation of test change (all listed in ns): TCLAV (min.) at 10 MHz from 50 to 44 ; TCVCTV (min.) at 8 MHz from 10 to 5; TCVCTV (max.) from 70 to 50 at 8 MHz and 56 to 40 at 10 MHz .

PREELOOONANY

## 80C186 <br> CHMOS HIGH INTEGRATION 16-BIT MICROPROCESSOR

Operation Modes Include:

- Enhanced Mode Which Has
-DRAM Refresh Control Unit
- Power-Save Mode
- Direct Interface to New Numerics Coprocessor
- Compatible Mode
— NMOS 80186 Pin-for-Pin
Replacement for Non-Numerics Applications
Integrated Feature Set
— Enhanced 80C86/C88 CPU
- Clock Generator
- 2 Independent DMA Channels
- Programmable Interrupt Controller
- 3 Programmable 16-Bit Timers
- Dynamic RAM Refresh Control Unit
- Programmable Memory and Peripheral Chip Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- Power Save Mode
- System-Level Testing Support (High Impedance Test Mode)
Available in 16 MHz (80C186-16), 12.5 MHz (80C186-12) and 10 MHz (80C186) Versions
- Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Completely Object Code Compatible with All Existing 8086/8088 Software and Also Has 10 Additional Instructions Over 8086/8088
- Complete System Development Support
- All 8086 and NMOS 80186 Software Development Tools Can Be Used for 80C186 System Development
- ASM 86 Assembler, PL/M-86, Pascal-86, FORTRAN-86, C-86 and System Utilities
- In-Circuit-Emulator (ICETM-186)

■ High Performance Numeric Coprocessing Capability through 80C187 Interface
■ Available in 68-Pin:

- Plastic Leaded Chip Carrier (PLCC)
- Ceramic Pin Grid Array (PGA)
- Ceramic Leadless Chip Carrier (JEDEC A Package)
(See Packaging Outlines and Dimensions, Order Number 231369)
- Available in EXPRESS Extended Temperature Range $\left(-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}$ )
- Available in Military:
- Different Specifications
- 10 MHz (M80C186-10) and 12.5 MHz (M80C186-12) Versions
(See M80C186 data sheet, Order Number 270500 for specifications)

The Intel 80C186 is a CHMOS high integration microprocessor. In has features which are new to the 80186 family which include a DRAM refresh control unit, power-save mode and a direct numerics interface. When used in "compatible" mode, the 80C186 is $100 \%$ pin-for-pin compatible with the NMOS 80186 (except for 8087 applications). The "enhanced" mode of operation allows the full feature set of the 80C186 to be used. The 80 C 186 is upward compatible with 8086 and 8088 software and fully compatible with 80186 and 80188 software.

270354-1
PRERLOMONARY


Figure 2. 80C186 Pinout Diagrams

Table 1. 80C186 Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\begin{gathered} 9 \\ 43 \end{gathered}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | System Power: + 5 volt power supply. |
| $\mathrm{V}_{S S}$ | $\begin{aligned} & 26 \\ & 60 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | System Ground. |
| RESET | 57 | 0 | RESET Output indicates that the 80 C 186 CPU is being reset, and can be used as a system reset. It is active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods corresponding to the length of the RES signal. Reset goes inactive 2 clockout periods after RES goes inactive. When tied to the TEST/BUSY pin, RESET forces the 80C186 into enhanced mode. RESET is not floated during bus hold. |
| $\begin{aligned} & \mathrm{X} 1 \\ & \mathrm{X} 2 \end{aligned}$ | $\begin{aligned} & 59 \\ & 58 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Crystal Inputs X1 and X2 provide external connections for a fundamental mode or third overtone parallel resonant crystal for the internal oscillator. X1 can connect to an external clock instead of a crystal. In this case, minimize the capacitance on X 2 . The input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). |
| CLKOUT | 56 | 0 | Clock Output provides the system with a $50 \%$ duty cycle waveform. All device pin timings are specified relative to CLKOUT. CLKOUT is active during reset and bus hold. |
| $\overline{\text { RES }}$ | 24 | 1 | An active $\overline{\mathrm{RES}}$ causes the 80 C 186 to immediately terminate its present activity, clear the internal logic, and enter a dormant state. This signal may be asynchronous to the 80 C 186 clock. The 80 C 186 begins fetching instructions approximately $61 / 2$ clock cycles after $\overline{\text { RES }}$ is returned HIGH. For proper initialization, $\mathrm{V}_{\mathrm{CC}}$ must be within specifications and the clock signal must be stable for more than 4 clocks with RES held LOW. $\overline{\text { RES }}$ is internally synchronized. This input is provided with a Schmitt-trigger to facilitate power-on RES generation via an RC network. |
| TEST/BUSY | 47 | I/O | The TEST pin is sampled during and after reset to determine whether the 80C186 is to enter Compatible or Enhanced Mode. Enhanced Mode requires TEST to be HIGH on the rising edge of RES and LOW four CLKOUT cycles later. Any other combination will place the 80C186 in Compatible Mode. During power-up, active $\overline{R E S}$ is required to configure TEST/BUSY as an input. A weak internal pullup ensures a HIGH state when the input is not externally driven. <br> TEST-In Compatible Mode this pin is configured to operate as TEST. This pin is examined by the WAIT instruction. If the TEST input is HIGH when WAIT execution begins, instruction execution will suspend. TEST will be resampled every five clocks until it goes LOW, at which time execution will resume. If interrupts are enabled while the 80C186 is waiting for TEST, interrupts will be serviced. <br> BUSY-In Enhanced Mode, this pin is configured to operate as BUSY. The BUSY input is used to notify the 80C186 of Numerics Processor Extension activity. Floating point instructions executing in the 80C186 sample the BUSY pin to determine when the Numerics Processor is ready to accept a new command. BUSY is active HIGH. |
| TMR IN 0 TMR IN 1 | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | $1$ | Timer Inputs are used either as clock or control signals, depending upon the programmed timer mode. These inputs are active HIGH (or LOW-toHIGH transitions are counted) and internally synchronized. Timer Inputs must be tied HIGH when not being used as clock or retrigger inputs. |
| TMR OUT 0 TMR OUT 1 | $\begin{aligned} & 22 \\ & 23 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Timer outputs are used to provide single pulse or continous waveform generation, depending upon the timer mode selected. These outputs are not floated during a bus hold. |

Table 1. 80C186 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |  |
| :--- | :---: | :---: | :--- | :--- |
| DRQ0 | 18 | I | DMA Request is asserted HIGH by an external device when it is ready <br> for DMA Channel 0 or 1 to perform a transfer. These signals are level- <br> DRQ1 | 19 |
| triggered and internally synchronized. |  |  |  |  |

Table 1. 80C186 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { BHE }}$ | 64 | O | The $\overline{B H E}$ (Bus High Enable) signal is analogous to $A 0$ in that it is used to enable data on to the most significant half of the data bus, pins D15-D8. BHE will be LOW during $T_{1}$ when the upper byte is transferred and will remain LOW through $T_{3}$ AND $T_{W}$. $\overline{\text { BHE does not need to be latched. } \overline{B H E}}$ will float during HOLD or RESET. <br> In Enhanced Mode, $\overline{B H E}$ will also be used to signify DRAM refresh cycles. A refresh cycle is indicated by both BHE and AO being HIGH. |  |  |
|  |  |  | $\overline{\text { BHE and AO Encodings }}$ |  |  |
|  |  |  | BHE Value | AO Value | Function |
|  |  |  | 0 0 1 1 | 0 1 0 1 | Word Transfer <br> Byte Transfer on upper half of data bus (D15-D8) Byte Transfer on lower half of data bus ( $\left(D_{7}-D_{0}\right)$ Refresh |
| ALE/QSO | 61 | 0 | Address Latch Enable/Queue Status 0 is provided by the 80 C 186 to latch the address. ALE is active HIGH, with addresses guaranteed valid on the trailing edge. |  |  |
| WR/QS1 | 63 | 0 | Write Strobe/Queue Status 1 indicates that the data on the bus is to be written into a memory or an I/O device. It is active LOW, and floats during bus hold or reset. When the 80C186 is in queue status mode, the ALE/QS0 and WR/QS1 pins provide information about processor/instruction queue interaction. |  |  |
|  |  |  | QS1 | Qso | Queue Operation |
|  |  |  | 0 0 1 1 | 0 1 1 0 | No queue operation <br> First opcode byte fetched from the queue Subsequent byte fetched from the queue Empty the queue |
| $\overline{\text { RD/ }} \overline{\text { QSMD }}$ | 62 | O/I | Read Strobe is an active LOW signal which indicates that the 80 C 186 is performing a memory or I/O read cycle. It is guaranteed not to go LOW before the A/D bus is floated. An internal pull-up ensures that $\overline{R D} / \overline{Q_{S M D}}$ is HIGH during RESET. Following RESET the pin is sampled to determine whether the $80 C 186$ is to provide ALE, $\overline{\text { RD }}$, and $\overline{W R}$, or queue status information. To enable Queue Status Mode, $\overline{\mathrm{RD}}$ must be connected to GND. $\overline{R D}$ will float during bus HOLD. |  |  |
| ARDY | 55 | 1 | Asynchronous Ready informs the 80C186 that the addressed memory space or I/O device will complete a data transfer. The ARDY pin accepts a rising edge that is asynchronous to CLKOUT and is active HIGH. The falling edge of ARDY must be synchronized to the 80C186 clock. Connecting ARDY HIGH will always assert the ready condition to the CPU. If this line is unused, it should be tied LOW to yield control to the SRDY pin. |  |  |
| SRDY | 49 | 1 | Synchronous Ready informs the 80C186 that the addressed memory space or I/O device will complete a data transfer. The SRDY pin accepts an activeHIGH input synchronized to CLKOUT. The use of SRDY allows a relaxed system timing over ARDY. This is accomplished by elimination of the onehalf clock cycle required to internally synchonize the ARDY input signal. Connecting SRDY high will always assert the ready condition to the CPU. If this line is unused, it should be tied LOW to yield control to the ARDY pin. |  |  |

Table 1. 80C186 Pin Description (Continued)


Table 1. 80C186 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{\text { LCS }}$ | 33 | O/I | Lower Memory Chip Select is active LOW whenever a memory reference is made to the defined lower portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ ) of memory. $\overline{\text { LCS }}$ does not float during bus HOLD. The address range activating $\overline{L C S}$ is software programmable. <br> $\overline{U C S}$ and $\overline{\mathrm{LCS}}$ are sampled upon the rising edge of $\overline{\mathrm{RES}}$. If both pins are held low, the 80C186 will enter ONCE Mode. In ONCE Mode all pins assume a high impedance state and remain so until a subsequent RESET. LCS has a weak internal pullup that is active only during RESET to ensure that the 80C186 does not enter ONCE mode inadvertently. |
| $\overline{M C S O} /$ PEREQ <br> $\overline{\text { MCS1/ERROR }}$ $\overline{\mathrm{MCS}} 2$ $\overline{\mathrm{MCS}} / \overline{\mathrm{NPS}}$ | $\begin{aligned} & 38 \\ & 37 \\ & 36 \\ & 35 \end{aligned}$ | $\begin{aligned} & 0 / 1 \\ & 0 / 1 \\ & 0 \\ & 0 \end{aligned}$ | Mid-Range Memory Chip Select signals are active LOW when a memory reference is made to the defined mid-range portion of memory ( $8 \mathrm{~K}-512 \mathrm{~K}$ ). These lines do not float during bus HOLD. The address ranges activating $\overline{\mathrm{MCSO}}-3$ are software programmable. <br> In Enhanced Mode, $\overline{M C S O}$ becomes a PEREQ input (Processor Extension Request). When connected to the Numerics Processor Extension, this input is used to signal the 80 C 186 when to make numeric data transfers to and from the NPX. MCS3 becomes NPS (Numeric Processor Select) which may only be activated by communication to the Numerics Processor Extension. MCS1 becomes ERROR in enhanced mode and is used to signal numerics coprocessor errors. <br> $\overline{M C S O} / P E R E Q$ and $\overline{M C S 1 / E R R O R}$ have weak internal pullups which are active during reset. |
| $\begin{aligned} & \overline{\mathrm{PCSO}} \\ & \overline{\mathrm{PCS} 1} \\ & \overline{\mathrm{PCS} 2} \\ & \overline{\mathrm{PCS} 3} \\ & \hline \mathrm{PCS} 4 \end{aligned}$ | $\begin{aligned} & 25 \\ & 27 \\ & 28 \\ & 29 \\ & 30 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Peripheral Chip Select signals 0-4 are active LOW when a reference is made to the defined peripheral area ( 64 K byte I/O or 1 MByte memory space). These lines do not float during bus HOLD. The address ranges activating $\overline{\text { PCSO }}-4$ are software programmable. |
| $\overline{\text { PCS5/A1 }}$ | 31 | 0 | Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth peripheral chip select, or to provide an internally latched A1 signal. The address range activating $\overline{\text { PCS5 }}$ is software-programmable. $\overline{\text { PCS5 }} / \mathrm{A} 1$ does not float during bus HOLD. When programmed to provide latched A1, this pin will retain the previously latched value during HOLD. |
| $\overline{\text { PCS6/A2 }}$ | 32 | 0 | Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh peripheral chip select, or to provide an internally latched A2 signal. The address range activating $\overline{\mathrm{PCS}} \mathrm{is}$ is software-programmable. PCS6/A2 does not float during bus HOLD. When programmed to provide latched A2, this pin will retain the previously latched value during HOLD. |
| DT/ $\bar{R}$ | 40 | 0 | Data Transmit/Receive controls the direction of data flow through an external data bus transceiver. When LOW, data is transferred to the 80C186. When HIGH the 80C186 places write data on the data bus. DT/ $\overline{\mathrm{R}}$ floats during a bus hold or reset. |
| $\overline{\text { DEN }}$ | 39 | 0 | Data Enable is provided as a data bus transceiver output enable. $\overline{\text { DEN }}$ is active LOW during each memory and I/O access (including 80C187 access). $\overline{\text { DEN }}$ is HIGH whenever DT/ $\bar{R}$ changes state. During RESET, $\overline{\mathrm{DEN}}$ is driven HIGH for one clock, then floated. $\overline{\mathrm{DEN}}$ also floats during HOLD. |

## FUNCTIONAL DESCRIPTION

## Introduction

The following Functional Description describes the base architecture of the 80 C 186 . The 80 C 186 is a very high integration 16 -bit microprocessor. It combines 15-20 of the most common microprocessor system components onto one chip. The 80C186 is object code compatible with the $8086 / 8088$ microprocessors and adds 10 new instruction types to the 8086/8088 instruction set.

The 80C186 has two major modes of operation, Compatible and Enhanced. In Compatible Mode the 80C186 is completely compatible with NMOS 80186, with the exception of 8087 support. The Enhanced mode adds three new features to the system design. These are Power-Save control, Dynamic RAM refresh, and an asynchronous Numerics Coprocessor interface.

## 80C186 BASE ARCHITECTURE

The 8086, 8088, 80186, and 80188 family all contain the same basic set of registers, instructions, and addressing modes. The 80C186 processor is upward compatible with the 8086 and 8088 CPUs.

## Register Set

The 80 C 186 base architecture has fourteen registers as shown in Figures 3a and 3b. These registers are grouped into the following categories.

## General Registers

Eight 16-bit general purpose registers may be used for arithmetic and logical operands. Four of these (AX, BX, CX, and DX) can be used as 16-bit registers or split into pairs of separate 8 -bit registers.


Figure 3a. 80C186 Register Set


Figure 3b. Status Word Format

## 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.)

## 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 selects the specific registers for operand and address calculations.

## Status and Control Registers

Two 16-bit special purpose registers record or alter certain aspects of the 80 C 186 processor state. These are the Instruction Pointer Register, which contains the offset address of the next sequential instruction to be executed, and the Status Word Register, which contains status and control flag bits (see Figures 3a and 3b).

## Status Word Description

The Status Word records specific characteristics of the result of logical and arithmetic instructions (bits $0,2,4,6,7$, and 11) and controls the operation of the 80C186 within a given operating mode (bits 8, 9 , and 10). The Status Word Register is 16 -bits wide. The function of the Status Word bits is shown in Table 2.

## Instruction Set

The instruction set is divided into seven categories: data transfer, arithmetic, shift/rotate/logical, string manipulation, control transfer, high-level instructions, and processor control. These categories are summarized in Figure 4.

An 80C186 instruction can reference anywhere from zero to several operands. An operand can reside in a register, in the instruction itself, or in memory. Specific operand addressing modes are discussed later in this data sheet.

## Memory Organization

Memory is organized in sets of segments. Each segment is a linear contiguous sequence of up to 64 K (216) 8 -bit bytes. Memory is addressed using a twocomponent address (a pointer) that consists of a 16bit base segment and a 16 -bit offset. The 16 -bit base values are contained in one of four internal segment register (code, data, stack, extra). The

Table 2. Status Word Bit Functions

| Bit <br> Position | Name | Function |
| :---: | :---: | :--- |
| 0 | CF | Carry Flag-Set on high-order <br> bit carry or borrow; cleared <br> otherwise |
| 2 | PF | Parity Flag-Set if low-order 8 <br> bits of result contain an even <br> number of 1-bits; cleared <br> otherwise |
| 4 | AF | Set on carry from or borrow to <br> the low order four bits of AL; <br> cleared otherwise |
| 6 | ZF | Zero Flag-Set if result is zero; <br> cleared otherwise |
| 7 | SF | Sign Flag-Set equal to high- <br> order bit of result (0 if positive, <br> 1 if negative) |
| 9 | TF | Single Step Flag-Once set, a <br> single step interrupt occurs <br> after the next instruction <br> executes. TF is cleared by the <br> single step interrupt. |
| 10 | IF | Interrupt-enable Flag-When <br> set, maskable interrupts will <br> cause the CPU to transfer <br> control to an interrupt vector <br> specified location. |
| 11 | OF | Direction Flag-Causes string <br> instructions to auto decrement <br> the appropriate index register <br> when set. Clearing DF causes <br> auto increment. |
| Overflow Flag-Set if the <br> signed result cannot be <br> expressed within the number <br> of bits in the destination <br> operand; cleared otherwise |  |  |

physical address is calculated by shifting the base value LEFT by four bits and adding the 16 -bit offset value to yield a 20 -bit physical address (see Figure 5). This allows for a 1 MByte physical address size.

All instructions that address operands in memory must specify the base segment and the 16 -bit offset value. For speed and compact instruction encoding, the segment register used for physical address generation is implied by the addressing mode used (see Table 3). These rules follow the way programs are written (see Figure 6) 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 overridden for special cases. The stack, data, and extra segments may coincide for simple programs.

| MOVS | Move byte or word string |
| :--- | :--- |
| INS | Input bytes or word string |
| OUTS | Output bytes or word string |
| CMPS | Compare byte or word string |
| SCAS | Scan byte or word string |
| LODS | Load byte or word string |
| STOS | Store byte or word string |
| REP | Repeat |
| REPE/REPZ | Repeat while equal/zero |
| REPNE/REPNZ | Repeat while not equal/not zero |
| 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 logical/arithmetic left byte or word |
| SHR | Shift logical right byte or word |
| SAR | Shift arithmetic right byte or word |
| ROTATES |  |


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


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


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

Figure 4. 80C186 Instruction Set

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

Figure 4. 80C186 Instruction Set (Continued)

To access operands that do not reside in one of the four immediately available segments, a full 32 -bit pointer can be used to reload both the base (segment) and offset values.


Figure 5. Two Component Address
Table 3. Segment Register Selection Rules

| Memory <br> Reference <br> Needed | Segment <br> Register <br> Used | Implicit Segment <br> Selection Rule |
| :--- | :--- | :--- |
| Instructions | Code (CS) | Instruction prefetch and <br> immediate data. <br> Stack |
| Stack (SS) | All stack pushes and <br> pops; any memory <br> references which use BP <br> Register as a base <br> register. |  |
| External | Extra (ES) | All string instruction <br> references which use <br> the DI register as an <br> index. <br> Data <br> (Global) |
| Local Data | Data (DS) | All other data references. |



Figure 6. Segmented Memory Helps Structure Software

## Addressing Modes

The 80C186 provides eight categories of addressing modes to specify operands. Two addressing modes are provided for instructions that operate on register or immediate 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: a segment base and an offset. The segment base is supplied by a 16 -bit segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset, also called the effective address, is calculated by summing any combination of the following three address elements:

- the displacement (an 8 - or 16 -bit immediate value contained in the instruction);
- the base (contents of either the BX or BP base registers); and
- the index (contents of either the SI or DI index registers).

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 ( $B X$ or $B P$ ).
- 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 80 C 186 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 a Numeric Data Coprocessor with the 80C186.
- Ordinal: An unsigned binary numeric value contained in an 8 -bit byte or a 16 -bit word.
- Pointer: A $16-$ or 32 -bit quantity, composed of a 16 -bit offset component or a 16 -bit segment base component in addition to a 16 -bit offset component.
- String: A contiguous sequence of bytes or words. A string may contain from 1 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 BCD: A byte (packed) representation of two decimal digits $(0-9)$. One digit is stored in each nibble (4-bits) of the byte.
- Floating Point: A signed 32-, 64-, or 80-bit real number representation. (Floating point operands are supported using a Numeric Data Coprocessor with the 80C186.)

In general, individual data elements must fit within defined segment limits. Figure 7 graphically represents the data types supported by the 80C186.

## I/O Space

The I/O space consists of 64 K 8 -bit or 32 K 16 -bit ports. Separate 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 $00 F F(\mathrm{H})$ are reserved.

## Interrupts

An interrupt transfers execution to a new program location. The old program address (CS:IP) and machine state (Status Word) 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.


NOTE:
*Supported by using a Numeric Data Coprocessor with the 80C186.

Figure 7. 80C186 Supported Data Types
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. If the exception was caused by executing an ESC instruction with the ESC trap bit set in the relocation register, the return instruction will point to the ESC instruction, or to the segment override prefix immediately preceding the ESC instruc-
tion if the prefix was present. In all other cases, the return address from an exception will point at the instruction immediately following the instruction causing the exception.

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. Table 4 shows the 80C186 predefined types and default priority levels. For each interrupt, an 8 -bit vector must be supplied to the 80C186 which identifies the appropriate table entry. Exceptions supply the interrupt vector internally. In addition, internal peripherals and noncascaded external interrupts will generate their own vectors through the internal interrupt controller. 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. Non-maskable hardware interrupts use a predefined internally supplied vector.

## Interrupt Sources

The 80C186 can service interrupts generated by software or hardware. The software interrupts are generated by specific instructions (INT, ESC, unused OP, etc.) or the results of conditions specified by instructions (array bounds check, INTO, DIV, IDIV, etc.). All interrupt sources are serviced by an indirect call through an element of a vector table. This vector table is indexed by using the interrupt vector type (Table 4), multiplied by four. All hardware-generated interrupts are sampled at the end of each instruction. Thus, the software interrupts will begin service first. Once the service routine is entered and interrupts are enabled, any hardware source of sufficient priority can interrupt the service routine in progress.

Those pre-defined 80C186 interrupts which cannot be masked by programming are described below.

## DIVIDE ERROR EXCEPTION (TYPE 0)

Generated when a DIV or IDIV instruction quotient cannot be expressed in the number of bits in the destination.

## SINGLE-STEP INTERRUPT (TYPE 1)

Generated after most instructions if the TF flag in the status word is set. This interrupt allows programs to execute one instruction at a time. Interrupts will not be generated after prefix instructions (e.g., REP), instructions which modify segment registers (e.g., POP DS), or the WAIT instruction. Vectoring to the single-step interrupt service routine clears the TF bit. An IRET instruction in the interrupt service routine

Table 4. 80C186 Interrupt Vectors

| Interrupt Name | Vector Type | Vector Address | Default Priority | Related Instructions | Applicable Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Divide Error Exception | 0 | 00H | 1 | DIV, IDIV | 1 |
| Single Step Interrupt | 1 | 04H | 1A | All | 2 |
| Non-Maskable Interrupt (NMI) | 2 | 08H | 1 | All |  |
| Breakpoint Interrupt | 3 | OCH | 1 | INT | 1 |
| INTO Detected Overflow Exception | 4 | 10 H | 1 | INTO | 1 |
| Array Bounds Exception | 5 | 14 H | 1 | BOUND | 1 |
| Unused Opcode Exception | 6 | 18 H | 1 | Undefined Opcodes | 1 |
| ESC Opcode Exception | 7 | 1 CH | 1 | ESC Opcodes (Coprocessor) | 1, 3 |
| Timer 0 Interrupt | 8 | 20 H | 2A |  | 4 |
| Timer 1 Interrupt | 18 | 48 H | 2B | 1 | 4, 6 |
| Timer 2 Interrupt | 19 | 4 CH | 2 C |  | 4, 6 |
| Reserved | 9 | 24 H | 3 |  |  |
| DMA 0 Interrupt | 10 | 28 H | 4 |  | 6 |
| DMA 1 Interrupt | 11 | 2 CH | 5 |  | 6 |
| INTO Interrupt | 12 | 30 H | 6 |  |  |
| INT1 Interrupt | 13 | 34 H | 7 |  |  |
| INT2 Interrupt | 14 | 38 H | 8 |  |  |
| INT3 Interrupt | 15 | 3 CH | 9 |  |  |
| Numerics Coprocessor Exception | 16 | 40 H | 1 | ESC Opcodes (Numerics Coprocessor) | 1,5 |
| Reserved | 17 | 44H |  |  |  |
| Reserved | 20-31 | $50 \mathrm{H} \ldots 7 \mathrm{CH}$ |  |  |  |

## NOTES:

Default priorities for the interrupt sources are used only if the user does not program each source to a unique priority level.

1. Generated as a result of an instruction execution.
2. Performed in the same manner as 8086.
3. An ESC (coprocessor) opcode will cause a trap if the 80C186 is in compatible mode or if the processor is in Enhanced Mode with the proper bit set in the peripheral control block relocation register. The 80C186 is not directly compatible with the $\mathbf{8 0 1 8 6}$ in this respect.
4. All three timers constitute one source of request to the interrupt controller. As such, they share the same priority level with respect to other interrupt sources. However, the timers have a defined priority order among themselves ( $2 \mathrm{~A}>2 \mathrm{~B}>2 \mathrm{C}$ ).
5. Numerics coprocessor exceptions are detected by the 80 C 186 upon execution of a subsequent numerics instruction.
6. The vector type numbers for these sources are programmable in Slave Mode.
restores the TF bit to logic "1" and transfers control to the next instruction to be single-stepped.

## NON-MASKABLE INTERRUPT—NMI (TYPE 2)

An external interrupt source which is serviced regardless of the state of the IF bit. No external interrupt acknowledge sequence is performed. The IF bit is cleared at the beginning of an NMI interrupt to prevent maskable interrupts from being serviced. A typical use of NMI would be to activate a power failure routine.

## BREAKPOINT INTERRUPT (TYPE 3)

A one-byte version of the INT instruction. It uses 12 as an index into the service routine address table (because it is a type 3 interrupt).

## INTO DETECTED OVERFLOW EXCEPTION (TYPE4)

Generated during an INTO instruction if the OF bit is set.

## ARRAY BOUNDS EXCEPTION (TYPE 5)

Generated during a BOUND instruction if the array index is outside the array bounds. The array bounds are located in memory at a location indicated by one of the instruction operands. The other operand indicates the value of the index to be checked.

## UNUSED OPCODE EXCEPTION (TYPE 6)

Generated if execution is attempted on undefined opcodes.

## ESCAPE OPCODE EXCEPTION (TYPE 7)

Generated if execution is attempted of ESC opcodes (D8H-DFH). In compatible mode operation, ESC opcodes will always generate this exception. In enhanced mode operation, the exception will be generated only if a bit in the relocation register is set. The return address of this exception will point to the ESC instruction causing the exception. If a segment override prefix preceded the ESC instruction, the return address will point to the segment override prefix.

## NOTE:

80 C 186 processing of ESC (numerics coprocessor) opcodes differs substantially from the 80186.

## NUMERICS COPROCESSOR EXCEPTION (TYPE 16)

An interrupt generated in response to an unmasked error in the 80C187 Numerics Coprocessor Extension. In general, the 80C187 does not detect an error until the instruction after the error occurred. A numerics coprocessor error is signalled to the 80C187 on its ERROR input pin.

Hardware-generated interrupts are divided into two groups: maskable interrupts and non-maskable interrupts. The 80 C 186 provides maskable hardware interrupt request pins INTO-INT3. In addition, maskable interrupts may be generated by the 80 C 186 integrated DMA controller and the integrated timer unit. The vector types for these interrupts is shown in Table 4. Software enables these inputs by setting the interrupt flag bit (IF) in the Status Word. The interrupt controller is discussed in the peripheral section of this data sheet.

Further maskable interrupts are disabled while servicing an interrupt because the IF bit is reset as part of the response to an interrupt or exception. The saved Status Word will reflect the enable status of the processor prior to the interrupt. The interrupt flag will remain zero unless specifically set. The interrupt return instruction restores the Status Word, thereby
restoring the original status of IF bit. If the interrupt return re-enables interrupts, and another interrupt is pending, the 80 C 186 will immediately service the highest-priority interrupt pending, i.e., no instructions of the main line program will be executed.

## Initialization and Processor Reset

Processor initialization is accomplished by driving the $\overline{\text { RES }}$ input pin LOW. $\overline{\text { RES }}$ must be LOW during power-up to ensure proper device initialization. $\overline{\text { RES }}$ forces the 80C186 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as $\overline{\text { RES }}$ is active. After RES becomes inactive and an internal processing interval elapses, the 80C186 begins execution with the instruction at physical location $\operatorname{FFFFO}(\mathrm{H})$. $\overline{\text { RES }}$ also sets some registers to predefined values as shown in Table 5.

Table 5. 80C186 Initial Register State after RESET

| Status Word | FOO2(H) |
| :--- | :--- |
| Instruction Pointer | $0000(\mathrm{H})$ |
| Code Segment | FFFF(H) |
| Data Segment | $0000(\mathrm{H})$ |
| Extra Segment | $0000(\mathrm{H})$ |
| Stack Segment | $0000(\mathrm{H})$ |
| Relocation Register | $20 \mathrm{FF}(\mathrm{H})$ |
| UMCS | FFFB(H) |

## 80C186 CLOCK GENERATOR

The 80C186 provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, synchronous and asynchronous ready inputs, and reset circuitry.

## Oscillator

The 80C186 oscillator circuit is designed to be used either with a parallel resonant fundamental or thirdovertone mode crystal, depending upon the frequency range of the application as shown in Figure 8c. This is used as the time base for the 80C186. The crystal frequency chosen should be twice the required processor frequency. Use of an LC or RC circuit is not recommended.

The output of the oscillator is not directly available outside the 80 C 186 . The two recommended crystal configurations are shown in Figures 8a and 8b. When used in third-overtone mode the tank circuit shown in Figure 8b is recommended for stable operation. The sum of the stray capacitances and load-


Figure 8. 80C186 Oscillator Configurations (see text)
ing capacitors should equal the values shown. It is advisable to limit stray capacitance between the X1 and X2 pins to less than 10 pF . While a fundamen-tal-mode circuit will require approximately 1 ms for start-up, the third-overtone arrangement may require 1 ms to 3 ms to stabilize.

Alternately, the oscillator may be driven from an external source as shown in Figure 8d. The configuration shown in Figure 8e is not recommended.

Intel recommends the following values for crystal selection parameters.
Temperature Range:
ESR (Equivalent Series Resistance):
0 to $70^{\circ} \mathrm{C}$
$40 \Omega$ max $\mathrm{C}_{0}$ (Shunt Capacitance of Crystal):
$\mathrm{C}_{1}$ (Load Capacitance):
Drive Level:
$20 \mathrm{pF} \pm 2 \mathrm{pF}$
1 mW max

## Clock Generator

The 80C186 clock generator provides the $50 \%$ duty cycle processor clock for the 80C186. It does this by dividing the oscillator output by 2 forming the symmetrical clock. If an external oscillator is used, the state of the clock generator will change on the falling edge of the oscillator signal. The CLKOUT pin provides the processor clock signal for use outside the 80 C 186 . This may be used to drive other system components. All timings are referenced to the output clock.

## READY Synchronization

The 80C186 provides both synchronous and asynchronous ready inputs. Asynchronous ready synchronization is accomplished by circuitry which samples ARDY in the middle of $T_{2}, T_{3}$, and again in the middle of each $T_{W}$ until ARDY is sampled ${ }^{3}$ IGH. One-half CLKOUT cycle of resolution time is used for full synchronization of a rising ARDY signal. A high-to-low transition on ARDY may be used as an indication of the not ready condition but it must be performed synchronously to CLKOUT either in the middle of $T_{2}, T_{3}$, or $T_{W}$, or at the falling edge of $T_{3}$ or $\mathrm{T}_{\mathrm{w}}$.

A second ready input (SRDY) is provided to interface with externally synchronized ready signals. This input is sampled at the end of $T_{2}, T_{3}$ and again at the end of each $\mathrm{T}_{w}$ until it is sampled HIGH. By using this input rather than the asynchronous ready input, the half-clock cycle resolution time penalty is eliminated. This input must satisfy set-up and hold times to guarantee proper operation of the circuit.

In addition, the 80 C 186 , as part of the integrated chip-select logic, has the capability to program WAIT states for memory and peripheral blocks. This is discussed in the Chip Select/Ready Logic description.

## RESET Logic

The 80 C 186 provides both a $\overline{\text { RES }}$ input pin and a synchronized RESET output pin for use with other system components. The RES input pin on the 80 C 186 is provided with hysteresis in order to facilitate power-on Reset generation via an RC network. RESET output is guaranteed to remain active for at least five clocks given a $\overline{\text { RES }}$ input of at least six clocks. RESET may be delayed up to approximately two and one-half clocks behind RES.

## LOCAL BUS CONTROLLER

The 80C186 provides a local bus controller to generate the local bus control signals. In addition, it employs a HOLD/HLDA protocol for relinquishing the local bus to other bus masters. It also provides outputs that can be used to enable external buffers and to direct the flow of data on and off the local bus.

## Memory/Peripheral Control

The 80C186 provides ALE, $\overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ bus control signals. The RD and WR signals are used to strobe data from memory or I/O to the 80C186 or to strobe data from the 80C186 to memory or I/O. The ALE line provides a strobe to latch the address when it is valid. The 80C186 local bus controller does not pro-
vide a memory/ $\overline{10}$ signal. If this is required, use the $\overline{\mathrm{S} 2}$ signal (which will require external latching), make the memory and I/O spaces nonoverlapping, or use only the integrated chip-select circuitry.

## Transceiver Control

The 80C186 generates two control signals for external transceiver chips. This capability allows the addition of transceivers for extra buffering without adding external logic. These control lines, DT/ $\bar{R}$ and $\overline{D E N}$, are generated to control the flow of data through the transceivers. The operation of these signals is shown in Table 6.

Table 6. Transceiver Control Signals Description

| Pin Name | Function |
| :--- | :--- |
| $\overline{\text { DEN }}$ |  |
| (Data Enable) | Enables the output drivers of the <br> transceivers. It is active LOW <br> during memory, I/O, numeric <br> processor extension, or INTA |
| cycles. |  |
| DT//̄ |  |
| Determines the direction of travel |  |
| through the transceivers. A HIGH |  |
| level directs data away from the |  |
| leceive) |  |
| processor during write |  |
| operations, while a LOW level |  |
| directs data toward the processor |  |
| during a read operation. |  |

## Local Bus Arbitration

The 80C186 uses a HOLD/HLDA system of local bus exchange. This provides an asynchronous bus exchange mechanism. This means multiple masters utilizing the same bus can operate at separate clock frequencies. The 80C186 provides a single HOLD/ HLDA pair through which all other bus masters may gain control of the local bus. External circuitry must arbitrate which external device will gain control of the bus when there is more than one alternate local bus master. When the 80 C 186 relinquishes control of the local bus, it floats $\overline{\mathrm{DEN}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$, LOCK, AD0-AD15, A16-A19, BHE, and DT/信 to allow another master to drive these lines directly.

The 80C186 HOLD latency time, i.e., the time between HOLD request and HOLD acknowledge, is a function of the activity occurring in the processor when the HOLD request is received. A HOLD request is second only to DRAM refresh requests in priority of activity requests the processor may receive. Any bus cycle in progress will be completed before the 80 C 186 relinquishes the bus. This implies that if a HOLD request is received just as a DMA transfer begins, the HOLD latency can be as great as 4 bus cycles. This will occur if a DMA word trans-
fer operation is taking place from an odd address to an odd address. This is a total of 16 clock cycles or more if WAIT states are required. In addition, if locked transfers are performed, the HOLD latency time will be increased by the length of the locked transfer.

If the 80 C 186 has relinquished the bus and a refresh request is pending, HLDA is removed (driven low) to signal the remote processor that the 80C186 wishes to regain control of the bus. The 80C186 will wait until HOLD is removed before taking control of the bus to run the refresh cycle.

## Local Bus Controller and Reset

During RESET the local bus controller will perform the following action:

- Drive $\overline{\mathrm{DEN}}, \overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ HIGH for one clock cycle, then float them.
- Drive $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ to the inactive state (all HIGH) and then float.
- Drive $\overline{\text { LOCK }} \mathrm{HIGH}$ and then float.
- Float ADO-15, A16-19, $\overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$.
- Drive ALE LOW
- Drive HLDA LOW.
$\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{\mathrm{MCSO}} / P E R E Q, \overline{\mathrm{MCS}} /$ ERROR, and TEST/BUSY pins have internal pullup devices which are active while $\overline{R E S}$ is applied. Excessive loading or grounding certain of these pins causes the 80 C 186 to enter an alternative mode of operation:
- $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ low results in Queue Status Mode.
- $\overline{U C S}$ and $\overline{L C S}$ low results in ONCETM Mode.
- TEST/BUSY low (and high later) results in Enhanced Mode.


## INTERNAL PERIPHERAL INTERFACE

All the 80 C 186 integrated peripherals are controlled by 16-bit registers contained within an internal 256byte control block. The control block may be mapped into either memory or I/O space. Internal logic will recognize control block addresses and respond to bus cycles. During bus cycles to internal registers, the bus controller will signal the operation externally (i.e., the $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, status, address, data, etc., lines will be driven as in a normal bus cycle), but $D_{15-0}$, SRDY, and ARDY will be ignored. The base address of the control block must be on an even 256-byte boundary (i.e., the lower 8 bits of the base address are all zeros). All of the defined registers within this control block may be read or written by the 80C186 CPU at any time.

The control block base address is programmed by a 16-bit relocation register contained within the control block at offset FEH from the base address of the control block (see Figure 9). It provides the upper 12 bits of the base address of the control block. The control block is effectively an internal chip select range and must abide by all the rules concerning chip selects (the chip select circuitry is discussed later in this data sheet). Any access to the 256 bytes of the control block activates an internal chip select.

Other chip selects may overlap the control block only if they are programmed to zero wait states and ignore external ready. In addition, bit 12 of this register determines whether the control block will be mapped into I/O or memory space. If this bit is 1 , the control block will be located in memory space. If the bit is 0 , the control block will be located in I/O space. If the control register block is mapped into I/O space, the upper 4 bits of the base address must be programmed as 0 (since I/O addresses are only 16 bits wide).

In addition to providing relocation information for the control block, the relocation register contains bits which place the interrupt controller into Slave Mode, and cause the CPU to interrupt upon encountering ESC instructions. At RESET, the relocation register is set to 20FFH, which maps the control block to start at FFOOH in I/O space. An offset map of the 256-byte control register block is shown in Figure 10.

## CHIP-SELECT/READY GENERATION LOGIC

The 80C186 contains logic which provides programmable chip-select generation for both memories and peripherals. In addition, it can be programmed to provide READY (or WAIT state) generation. It can also provide latched address bits A1 and A2. The chip-select lines are active for all memory and I/O cycles in their programmed areas, whether they be generated by the CPU or by the integrated DMA unit.

## Memory Chip Selects

The 80C186 provides 6 memory chip select outputs for 3 address areas; upper memory, lower memory, and midrange memory. One each is provided for upper memory and lower memory, while four are provided for midrange memory.

The range for each chip select is user-programmable and can be set to $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}, 16 \mathrm{~K}, 32 \mathrm{~K}, 64 \mathrm{~K}$, 128 K (plus 1 K and 256 K for upper and lower chip selects). In addition, the beginning or base address

OFFSET: 15 14
ET = ESC Trap / No ESC Trap (1/0)
M/IO = Register block located in Memory / I/O Space (1/0)
SLAVE/MASTER = Configures interrupt controller for Slave/Master Mode (1/0)

Figure 9. Relocation Register


Figure 10. Internal Register Map
of the midrange memory chip select may also be selected. Only one chip select may be programmed to be active for any memory location at a time. All chip select sizes are in bytes, whereas 80C186 memory is arranged in words. This means that if, for example, $1664 \mathrm{~K} \times 1$ memories are used, the memory block size will be 128 K , not 64 K .

## Upper Memory CS

The 80C186 provides a chip select, called $\overline{U C S}$, for the top of memory. The top of memory is usually used as the system memory because after reset the 80C186 begins executing at memory location FFFFOH.

The upper limit of memory defined by this chip select is always FFFFFH, while the lower limit is programmable. By programming the lower limit, the size of the select block is also defined. Table 7 shows the relationship between the base address selected and the size of the memory block obtained.

Table 7: UMCS Programming Values

| Starting <br> Address <br> (Base <br> Address) | Memory <br> Block <br> Size | UMCS Value <br> (Assuming <br> R0= R1 = R2 = 0) |
| :---: | :---: | :---: |
| FFC00 | 1 K | FFF8H |
| FF800 | 2 K | FFB8H |
| FF000 | 4 K | FF38H |
| FE000 | 8 K | FE38H |
| FC000 | 16 K | FC38H |
| F8000 | 32 K | F838H |
| F0000 | 64 K | F038H |
| E0000 | 128 K | E038H |
| C0000 | 256 K | C038H |

The lower limit of this memory block is defined in the UMCS register (see Figure 11). This register is at offset $A O H$ in the internal control block. The legal values for bits 6-13 and the resulting starting address and memory block sizes are given in Table 7. Any combination of bits 6-13 not shown in Table 7 will result in undefined operation. After reset, the UMCS register is programmed for a 1 K area. It must be reprogrammed if a larger upper memory area is desired.

The internal generation of any 20-bit address whose upper 16 bits are equal to or greater than the UMCS value (with bits $0-5$ as " 0 ") asserts UCS. UMCS bits R2-R0 specify the ready mode for the area of memory defined by the chip select register, as explained later.

## Lower Memory $\overline{\mathbf{C S}}$

The 80 C 186 provides a chip select for low memory called LCS. The bottom of memory contains the interrupt vector table, starting at location 00000 H .

The lower limit of memory defined by this chip select is always OH , while the upper limit is programmable. By programming the upper limit, the size of the memory block is defined. Table 8 shows the relationship between the upper address selected and the size of the memory block obtained.

Table 8. LMCS Programming Values

| Upper Address | Memory Block Size | $\begin{gathered} \text { LMCS Value } \\ \text { (Assuming } \\ \mathbf{R 0}=\mathbf{R 1}=\mathbf{R 2}=\mathbf{0} \text { ) } \end{gathered}$ |
| :---: | :---: | :---: |
| 003FFH | 1K | 0038H |
| 007FFH | 2K | 0078H |
| 00FFFH | 4K | $00 \mathrm{F8H}$ |
| 01FFFH | 8K | $01 \mathrm{F8H}$ |
| 03FFFF | 16K | 03 F 8 H |
| 07FFFH | 32 K | 07F8H |
| OFFFFFH | 64K | OFF8H |
| 1FFFFH | 128K | $1 \mathrm{FF8H}$ |
| 3FFFFH | 256K | 3 FF 8 H |

The upper limit of this memory block is defined in the LMCS register (see Figure 12) at offset A2H in the internal control block. The legal values for bits 6-15 and the resulting upper address and memory block sizes are given in Table 8. Any combination of bits 6-15 not shown in Table 8 will result in undefined operation. After RESET, the LMCS register value is undefined. However, the $\overline{\mathrm{LCS}}$ chip-select line will not become active until the LMCS register is accessed.

Any internally generated 20-bit address whose upper 16 bits are less than or equal to LMCS (with bits 0-5 "1") will assert $\overline{L C S}$. LMCS register bits R2-R0 specify the READY mode for the area of memory defined by this chip-select register.

## Mid-Range Memory $\overline{\mathbf{C S}}$

The 80 C 186 provides four $\overline{\mathrm{MCS}}$ lines which are active within a user-locatable memory block. This block can be located within the 80C186 1M byte memory address space exclusive of the areas defined by UCS and ECS. Both the base ad-
dress and size of this memory block are programmable.

The size of the memory block defined by the midrange select lines, as shown in Table 9, is determined by bits 8-14 of the MPCS register (see Figure 13). This register is at location A 8 H in the internal control block. One and only one of bits 8-14 must be set at a time. Unpredictable operation of the $\overline{M C S}$ lines will otherwise occur. Each of the four chip-select lines is active for one of the four equal contiguous divisions of the mid-range block. If the total block size is 32 K , each chip select is active for 8 K of memory with $\overline{\mathrm{MCSO}}$ being active for the first range and MCS3 being active for the last range.

The EX and MS in MPCS relate to peripheral functionality as described in a later section.

Table 9. MPCS Programming Values

| Total Block <br> Size | Individual <br> Select Size | MPCS Bits <br> $\mathbf{1 4 - 8}$ |
| :---: | :---: | :---: |
| 8 K | 2 K | 0000001 B |
| 16 K | 4 K | 0000010 B |
| 32 K | 8 K | 0000100 B |
| 64 K | 16 K | 0001000 B |
| 128 K | 32 K | 0010000 B |
| 256 K | 64 K | 0100000 B |
| 512 K | 128 K | 1000000 B |

The base address of the mid-range memory block is defined by bits 15-9 of the MMCS register (see Figure 14). This register is at offset A6H in the internal control block. These bits correspond to bits A19-A13 of the 20-bit memory address. Bits A12-A0 of the base address are always 0 . The base address may be set at any integer multiple of the size of the total memory block selected. For example, if the mid-range block size is 32 K (or the size of the block for which each $\overline{M C S}$ line is active is 8 K ), the block could be located at 10000 H or 18000 H , but not at 14000 H , since the first few integer multiples of a 32 K memory block are $0 \mathrm{H}, 8000 \mathrm{H}$, $10000 \mathrm{H}, 18000 \mathrm{H}$, etc. After RESET, the contents of both registers are undefined. However, none of the $\overline{\text { MCS }}$ lines will be active until both the MMCS and MPCS registers are accessed.

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OFFSET: AOH | 1 | 1 | U | U | U | U | U | U | U | U | 1 | 1 | 1 | R2 | R1 | RO |
|  | A19 A10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 11. UMCS Register


Figure 12. LMCS Register


Figure 13. MPCS Register

OFFSET: A6H | 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A19 | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | 1 | 1 | 1 | 1 | 1 | 1 | $R 2$ | $R 1$ | $R 0$ |

Figure 14. MMCS Register

MMCS bits R2-R0 specify READY mode of operation for all four mid-range chip selects.

The 512K block size for the mid-range memory chip selects is a special case. When using 512 K , the base address would have to be at either locations 00000 H or 80000 H . If it were to be programmed at 00000 H when the LCS line was programmed, there would be an internal conflict between the LCS ready generation logic and the MCS ready generation logic. Likewise, if the base address were programmed at 80000 H , there would be a conflict with the UCS ready generation logic. Since the LCS chip-select line does not become active until programmed, while the UCS line is active at reset, the memory base can be set only at 00000 H . If this base address is selected, however, the LCS range must not be programmed.

In Enhanced Mode, three of the four $\overline{\mathrm{MCS}}$ pins become handshaking pins for the 80C187 Numerics Processor Extension. MCS2 is still available as a chip select covering one-fourth the mid-range address block, subject to the usual programming of the MPCS and MMCS registers.

## Peripheral Chip Selects

The 80C186 can generate chip selects for up to seven peripheral devices. These chip selects are active for seven contiguous blocks of 128 bytes above a
programmable base address. The base address may be located in either memory or I/O space.

Seven $\overline{\mathrm{CS}}$ lines called $\overline{\mathrm{PCSO}}-6$ are generated by the 80C186. The base address is user-programmable; however it can only be a multiple of 1 K bytes, i.e., the least significant 10 bits of the starting address are always 0 .
$\overline{\text { PCS5 }}$ and $\overline{\text { PCS6 }}$ can also be programmed to provide latched address bits A1 and A2. If so programmed, they cannot be used as peripheral selects. These outputs can be connected directly to the A0 and A1 pins used for selecting internal registers of external 8 -bit peripheral chips. This scheme simplifies the external hardware because the peripheral registers can be located on even boundaries in I/O or memory space.

The starting address of the peripheral chip-select block is defined by the PACS register (see Figure 15). The register is located at offset A 4 H in the internal control block. Bits 15-6 of this register correspond to bits $19-10$ of the 20 -bit Programmable Base Address (PBA) of the peripheral chip-select block. Bits 9-0 of the PBA of the peripheral chip-select block are all zeros. If the chip-select block is located in I/O space, bits 12-15 must be programmed zero, since the I/O address is only 16 bits wide. Table 10 shows the address range of each peripheral chip select with respect to the PBA contained in PACS register.


Figure 15. PACS Register

The user should program bits 15-6 to correspond to the desired peripheral base location. PACS bits 0-2 are used to specify READY mode for $\overline{\mathrm{PCSO}}-\overline{\mathrm{PCS3}}$.

Table 10. PCS Address Ranges

| $\overline{\mathrm{PCS}}$ Line | Active between Locations |
| :--- | :--- |
| $\overline{\mathrm{PCS} 0}$ | $\mathrm{PBA} \quad-\mathrm{PBA}+127$ |
| $\overline{\mathrm{PCS} 1}$ | $\mathrm{PBA}+128-\mathrm{PBA}+255$ |
| $\overline{\mathrm{PCS} 2}$ | $\mathrm{PBA}+256-\mathrm{PBA}+383$ |
| $\overline{\mathrm{PCS}}$ | $\mathrm{PBA}+384-\mathrm{PBA}+511$ |
| $\overline{\mathrm{PCS}}$ | $\mathrm{PBA}+512-\mathrm{PBA}+639$ |
| $\overline{\mathrm{PCS} 5}$ | $\mathrm{PBA}+640-\mathrm{PBA}+767$ |
| $\overline{\mathrm{PCS}}$ | $\mathrm{PBA}+768-\mathrm{PBA}+895$ |

The mode of operation of the peripheral chip selects is defined by the MPCS register (which is also used to set the size of the mid-range memory chip-select block, see Figure 13). The register is located at offset A 8 H in the internal control block. Bit 7 is used to select the function of $\overline{\text { PCS5 }}$ and PCS6, while bit 6 is used to select whether the peripheral chip selects are mapped into memory or I/O space. Table 11 describes the programming of these bits. After RESET, the contents of both the MPCS and the PACS registers are undefined, however none of the PCS lines will be active until both of the MPCS and PACS registers are accessed.

Table 11. MS, EX Programming Values

| Bit | Description |
| :--- | :--- |
| MS | $1=$ Peripherals mapped into memory space. |
|  | $0=$ Peripherals mapped into I/O space. |
| EX | $0=5 \overline{\text { PCS }}$ lines. A1, A2 provided. |
|  | $1=7 \overline{\text { PCS }}$ lines. A1, A2 are not provided. |

MPCS bits 0-2 specify the READY mode for $\overline{\text { PCS4 }}-$ $\overline{\mathrm{PCS} 6}$ as outlined below.

## READY Generation Logic

The 80C186 can generate a READY signal internally for each of the memory or peripheral CS lines. The number of WAIT states to be inserted for each peripheral or memory is programmable to provide $0-3$ wait states for all accesses to the area for which the chip select is active. In addition, the 80C186 may be programmed to either ignore external READY for each chip-select range individually or to factor external READY with the integrated ready generator.

READY control consists of 3 bits for each $\overline{\mathrm{CS}}$ line or group of lines generated by the 80C186. The interpretation of the READY bits is shown in Table 12.

Table 12. READY Bits Programming

| R2 | R1 | R0 | Number of WAIT States Generated |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 wait states, external RDY <br> also used. <br> 1 wait state inserted, external RDY <br> also used. <br> 2 wait states inserted, external RDY <br> also used. <br> 3 wait states inserted, external RDY <br> also used. |
| 0 | 0 | 1 | 1 |
| 1 | 0 | 0 | in wait states, external RDY <br> ignored. |
| 1 | 0 | 1 | 1 wait state inserted, external RDY <br> ignored. <br> 2 wait states inserted, external RDY <br> ignored. |
| 1 | 1 | 0 | 1 |

The internal ready generator operates in parallel with external READY, not in series if the external READY is used $(R 2=0)$. For example, if the internal generator is set to insert two wait states, but activity on the external READY lines will insert four wait states, the processor will only insert four wait states, not six. This is because the two wait states generated by the internal generator overlapped the first two wait states generated by the external ready signal. Note that the external ARDY and SRDY lines are always ignored during cycles accessing internal peripherals.

R2-R0 of each control word specifies the READY mode for the corresponding block, with the exception of the peripheral chip selects: R2-R0 of PACS set the $\overline{\mathrm{PCSO}}-3$ READY mode, R2-R0 of MPCS set the $\overline{\mathrm{PCS}} 4-6$ READY mode.

## Chip Select/Ready Logic and Reset

Upon RESET, the Chip-Select/Ready Logic will perform the following actions:

- All chip-select outputs will be driven HIGH.
- Upon leaving RESET, the UCS line will be programmed to provide chip selects to a 1 K block with the accompanying READY control bits set at 011 to insert 3 wait states in conjunction with external READY (i.e., UMCS resets to FFFBH).
- No other chip select or READY control registers have any predefined values after RESET. They will not become active until the CPU accesses their control registers. Both the PACS and MPCS registers must be accessed before the $\overline{\mathrm{PCS}}$ lines will become active.


## DMA CHANNELS

The 80C186 DMA controller provides two independent high-speed DMA channels. Data transfers can occur between memory and I/O spaces (e.g., Memory to I/O) or within the same space (e.g., Memory to Memory or I/O to I/O). Data can be transferred either in bytes ( 8 bits) or in words ( 16 bits) to or from even or odd addresses. Each DMA channel maintains both a 20-bit source and destination pointer which can be optionally incremented or decremented after each data transfer (by one or two depending on byte or word transfers). Each data transfer consumes 2 bus cycles (a minimum of 8 clocks), one cycle to fetch data and the other to store data.

## DMA Operation

Each channel has six registers in the control block which define each channel's operation. The control registers consist of a 20-bit Source pointer (2 words), a 20 -bit destination pointer ( 2 words), a

16-bit Transfer Count Register, and a 16-bit Control Word. The format of the DMA Control Blocks is shown in Table 13. The Transfer Count Register (TC) specifies the number of DMA transfers to be performed. Up to 64 K byte or word transfers can be performed with automatic termination. The Control Word defines the channel's operation (see Figure 17). All registers may be modified or altered during any DMA activity. Any changes made to these registers will be reflected immediately in DMA operation.

Table 13. DMA Control Block Format

| Register Name | Register Address |  |
| :--- | :---: | :---: |
|  | Ch. 0 | Ch. 1 |
| Control Word | CAH | DAH |
| Transfer Count | C 8 H | D 8 H |
| Destination Pointer (upper 4 | C 6 H | D 6 H |
| $\quad$ bits) |  |  |
| Destination Pointer | C 4 H | D 4 H |
| Source Pointer (upper 4 bits) | C 2 H | D 2 H |
| Source Pointer | COH | DOH |



270354-9

Figure 16. DMA Unit Block Diagram


Figure 17. DMA Control Register

## DMA Channel Control Word Register

Each DMA Channel Control Word determines the mode of operation for the particular 80C186 DMA channel. This register specifies:

- the mode of synchronization;
- whether bytes or words will be transferred;
- whether interrupts will be generated after the last transfer;
- whether DMA activity will cease after a programmed number of DMA cycles;
- the relative priority of the DMA channel with respect to the other DMA channel;
- whether the source pointer will be incremented, decremented, or maintained constant after each transfer;
- whether the source pointer addresses memory or I/O space;
- whether the destination pointer will be incremented, decremented, or maintained constant after each transfer; and
- whether the destination pointer will address memory or I/O space.

The DMA channel control registers may be changed while the channel is operating. However, any changes made during operation will affect the current DMA transfer.

## DMA Control Word Bit Descriptions

DEST: $\quad \mathrm{M} / \overline{\mathrm{O}}$ Destination pointer is in memory (1) or I/O (0) space.
DEC Decrement destination pointer by 1 or 2 (depends on $\overline{\mathrm{B}} / \mathrm{W}$ ) after each transfer.
INC Increment destination pointer by 1 or 2 (depends on $\bar{B} / W$ ) after each transfer.
If both INC and DEC are specified, the pointer will remain constant after each cycle.
SOURCE: $M / \overline{\mathrm{O}}$ Source pointer is in memory (1) or I/O (0) space.
DEC Decrement source pointer by 1 or 2 (depends on $\overline{\mathrm{B}} / \mathrm{W}$ ) after each transfer.

INC Increment source pointer by 1 or 2 (depends on $\bar{B} / W$ ) after each transfer.
If both INC and DEC are specified, the pointer will remain constant after each cycle.
TC: If set, DMA will terminate when the contents of the transfer count register reach zero. The ST/STOP bit will also be reset at this point. If cleared, the DMA controller will decrement the transfer count register for each DMA cycle, but DMA transfers will not stop when the transfer count register reaches zero.
INT: Enable interrupts to CPU upon transfer count termination.
00 No synchronization.

## NOTE:

When unsynchronized transfers are specified, the TC bit will be ignored and the ST/STOP bit will be cleared upon the transfer count reaching zero, stopping the channel.
01 Source synchronization.
10 Destination synchronization.
11 Unused.
$\mathrm{P}: \quad$ Channel priority relative to other channel during simultaneous requests.
0 Low priority.
1 High priority.
Channels will alternate cycles if both are set at same priority level.
TDRQ: Enable/Disable (1/0) DMA requests from timer 2.
CHG/NOCHG: Change/Do not change (1/0) ST/STOP bit. If this bit is set when writing to the control word, the ST/STOP bit will be programmed by the write to the control word. If this bit is cleared when writing the control word, the ST/STOP bit will not be altered. This bit is not stored; it will always be read as 0 .
ST/STOP: Start/Stop (1/0) channel.
$\bar{B} / \mathrm{W}: \quad$ Byte/Word (0/1) transfers.

## DMA Destination and Source Pointer Registers

Each DMA channel maintains a 20 -bit source and a 20-bit destination pointer. Each of these pointers takes up two full 16 -bit registers in the peripheral control block. For each DMA channel to be used, all four pointer registers must be initialized. The lower four bits of the upper register contain the upper four bits of the 20-bit physical address (see Figure 18). These pointers may be individually incremented or decremented after each transfer. If word transfers are performed the pointer is incremented or decremented by two.

Each pointer may point into either memory or I/O space. Since the upper four bits of the address are not automatically programmed to zero, the user must program them in order to address the normal 64 K I/O space. Since the DMA channels can perform transfers to or from odd addresses, there is no restriction on values for the pointer registers. Higher transfer rates can be achieved if all word transfers are performed to or from even addresses so that accesses will occur in single bus cycles.

## DMA Transfer Count Register

Each DMA channel maintains a 16 -bit transfer count register (TC). The register is decremented after every DMA cycle, regardless of the state of the TC bit in the DMA Control Register. If the TC bit in the DMA control word is set or if unsynchronized transfers are programmed, however, DMA activity will terminate when the transfer count register reaches zero.

## DMA Requests

Data transfers may be either source or destination synchronized, that is either the source of the data or the destination of the data may request the data transfer. In addition, DMA transfers may be unsynchronized; that is, the transfer will take place continually until the correct number of transfers has occurred. When source or unsynchronized transfers are performed, the DMA channel may begin another transfer immediately after the end of a previous DMA transfer. This allows a complete transfer to take place every 2 bus cycles or eight clock cycles (assuming no wait states). When destination synchronization is performed, data will not be fetched from the source address until the destination device signals that it is ready to receive it. When destination synchronized transfers are requested, the DMA controller will relinquish control of the bus after every transfer. If no other bus activity is initiated, another DMA cycle will begin after two processor clocks. This allows the destination device time to remove its request if another transfer is not desired. Since the DMA controller will relinquish the bus, the CPU can initiate a bus cycle. As a result, a complete bus cycle will often be inserted between destination synchronized transfers. Table 14 shows the maximum DMA transfer rates.

Table 14. Maximum DMA Transfer Rates at CLKOUT $=16 \mathrm{MHz}$

| Type of <br> Synchronization <br> Selected | CPU Running | CPU Halted |
| :--- | :---: | :---: |
| Unsynchronized <br> Source Synch <br> Destination Synch | $4.0 \mathrm{MBytes} / \mathrm{sec}$ <br> $4.0 \mathrm{MBytes} / \mathrm{sec}$ <br> $2.7 \mathrm{MBytes} / \mathrm{sec}$ | $4.0 \mathrm{MBytes} / \mathrm{sec}$ <br> $4.0 \mathrm{MByy} / \mathrm{sec}$ <br> $3 . \mathrm{sec}$ |



Figure 18. DMA Pointer Register Format

## DMA Acknowledge

No explicit DMA acknowledge pulse is provided. Since both source and destination pointers are maintained, a read from a requesting source, or a write to a requesting destination, should be used as the DMA acknowledge signal. Since the chip-select lines can be programmed to be active for a given block of memory or I/O space, and the DMA pointers can be programmed to point to the same given block, a chip-select line could be used to indicate a DMA acknowledge.

## DMA Priority

The DMA channels may be programmed to give one channel priority over the other, or they may be programmed to alternate cycles when both have DMA requests pending. DMA cycles always have priority over internal CPU cycles except between locked memory accesses or word accesses to odd memory locations; also an external bus hold takes priority over an internal DMA cycle. Because an interrupt request cannot suspend a DMA operation and the CPU cannot access memory during a DMA cycle, interrupt latency time will suffer during sequences of continuous DMA cycles. An NMI request, however, will cause all internal DMA activity to halt. This allows the CPU to quickly respond to the NMI request.

## DMA Programming

DMA cycles will occur whenever the ST/ $\overline{\mathrm{STOP}}$ bit of the Control Register is set. If synchronized transfers are programmed, a DRQ must also be generated.

Therefore the source and destination transfer pointers, and the transfer count register (if used) must be programmed before the ST/STOP bit is set.

Each DMA register may be modified while the channel is operating. If the CHG/NOCHG bit is cleared when the control register is written, the ST/STOP bit of the control register will not be modified by the write. If multiple channel registers are modified, it is recommended that a LOCKED string transfer be used to prevent a DMA transfer from occurring between updates to the channel registers.

## DMA Channels and Reset

Upon RESET, the state of the DMA channels will be as follows:

- The $\mathrm{ST} / \overline{\mathrm{STOP}}$ bit for each channel will be reset to STOP.
- Any transfer in progress is aborted.
- The values of the transfer count registers, source pointers, and destination pointers are indeterminate.


## TIMERS

The 80C186 provides three internal 16-bit programmable timers (see Figure 19). Two of these are highly flexible and are connected to four external pins (2 per timer). They can be used to count external events, time external events, generate nonrepetitive waveforms, etc. The third timer is not connected to any external pins, and is useful for real-time coding and time delay applications. In addition, the third timer can be used as a prescaler to the other two, or as a DMA request source.


Figure 19. Timer Block Diagram

## Timer Operation

The timers are controlled by 1116 -bit registers in the peripheral control block. The configuration of these registers is shown in Table 15. The count register contains the current value of the timer. It can be read or written at any time independent of whether the timer is running or not. The value of this register will be incremented for each timer event. Each of the timers is equipped with a MAX COUNT register, which defines the maximum count the timer will reach. After reaching the MAX COUNT register value, the timer count value will reset to zero during that same clock, i.e., the maximum count value is never stored in the count register itself. Timers 0 and 1 are, in addition, equipped with a second MAX COUNT register, which enables the timers to alternate their count between two different MAX COUNT values. If a single MAX COUNT register is used, the timer output pin will switch LOW for a single clock, 1 clock after the maximum count value has been reached. In the dual MAX COUNT register mode, the output pin will indicate which MAX COUNT register is currently in use, thus allowing nearly complete freedom in selecting waveform duty cycles. For the timers with two MAX COUNT registers, the RIU bit in the control register determines which is used for the comparison.

Each timer gets serviced every fourth CPU-clock cycle, and thus can operate at speeds up to one-quarter the internal clock frequency (one-eighth the crystal rate). External clocking of the timers may be done at up to a rate of one-quarter of the internal CPUclock rate. Due to internal synchronization and pipelining of the timer circuitry, a timer output may take up to 6 clocks to respond to any individual clock or gate input.

Since the count registers and the maximum count registers are all 16 bits wide, 16 bits of resolution are provided. Any Read or Write access to the timers will add one wait state to the minimum four-clock bus cycle, however. This is needed to synchronize and coordinate the internal data flows between the internal timers and the internal bus.

The timers have several programmable options.

- All three timers can be set to halt or continue on a terminal count.
- Timers 0 and 1 can select between internal and external clocks, alternate between MAX COUNT registers and be set to retrigger on external events.
- The timers may be programmed to cause an interrupt on terminal count.

These options are selectable via the timer mode/ control word.

## Timer Mode/Control Register

The mode/control register (see Figure 20) allows the user to program the specific mode of operation or check the current programmed status for any of the three integrated timers.

Table 15. Timer Control Block Format

| Register Name | Register Offset |  |  |
| :--- | :---: | :---: | :---: |
|  | Tmr. 0 | Tmr. 1 | Tmr. 2 |
| Mode/Control Word | 56 H | 5 EH | 66 H |
| Max Count B | 54 H | 5 CH | not present |
| Max Count A | 52 H | 5 AH | 62 H |
| Count Register | 50 H | 58 H | 60 H |

## EN:

The enable bit provides programmer control over the timer's RUN/HALT status. When set, the timer is enabled to increment subject to the input pin constraints in the internal clock mode (discussed previously). When cleared, the timer will be inhibited from counting. All input pin transistions during the time EN is zero will be ignored. If CONT is zero, the EN bit is automatically cleared upon maximum count.

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

The inhibit bit allows for selective updating of the enable (EN) bit. If INH is a one during the write to the mode/control word, then the state of the EN bit will be modified by the write. If INH is a zero during the write, the EN bit will be unaffected by the operation. This bit is not stored; it will always be a 0 on a read.

## INT:

When set, the INT bit enables interrupts from the timer, which will be generated on every terminal


Figure 20. Timer Mode/Control Register
count. If the timer is configured in dual MAX COUNT register mode, an interrupt will be generated each time the value in MAX COUNT register $A$ is reached, and each time the value in MAX COUNT register $B$ is reached. If this enable bit is cleared after the interrupt request has been generated, but before a pending interrupt is serviced, the interrupt request will still be in force. (The request is latched in the Interrupt Controller).

## RIU:

The Register In Use bit indicates which MAX COUNT register is currently being used for comparison to the timer count value. A zero value indicates register $A$. The RIU bit cannot be written, i.e., its value is not affected when the control register is written. It is always cleared when the ALT bit is zero.

## MC:

The Maximum Count bit is set whenever the timer reaches its final maximum count value. If the timer is configured in dual MAX COUNT register mode, this bit will be set each time the value in MAX COUNT register $A$ is reached, and each time the value in MAX COUNT register B is reached. This bit is set regardless of the timer's interrupt-enable bit. The MC bit gives the user the ability to monitor timer status through software instead of through interrupts.

Programmer intervention is required to clear this bit.

## RTG:

Retrigger bit is only active for internal clocking (EXT $=0$ ). In this case it determines the control function provided by the input pin.

If RTG $=0$, the input level gates the internal clock on and off. If the input pin is HIGH, the timer will count; if the input pin is LOW, the timer will hold its value. As indicated previously, the input signal may be asynchronous with respect to the 80 C 186 clock.

When RTG $=1$, the input pin detects LOW-to-HIGH transitions. The first such transition starts the timer running, clearing the timer value to zero on the first clock, and then incrementing thereafter. Further transitions on the input pin will again reset the timer to zero, from which it will start counting up again. If CONT $=0$, when the timer has reached maximum count, the EN bit will be cleared, inhibiting further timer activity.

## P:

The prescaler bit is ignored unless internal clocking has been selected (EXT $=0$ ). If the $P$ bit is a zero, the timer will count at one-fourth the internal CPU clock rate. If the $P$ bit is a one, the output of timer 2 will be used as a clock for the timer. Note that the user must initialize and start timer 2 to obtain the prescaled clock.

## EXT:

The external bit selects between internal and external clocking for the timer. The external signal may be asynchronous with respect to the 80 C 186 clock.

If this bit is set, the timer will count LOW-to-HIGH transitions on the input pin. If cleared, it will count an internal clock while using the input pin for control. In this mode, the function of the external pin is defined by the RTG bit. The maximum input to output transition latency time may be as much as 6 clocks. However, clock inputs may be pipelined as closely together as every 4 clocks without losing clock pulses.

## ALT:

The ALT bit determines which of two MAX COUNT registers is used for count comparison. If ALT $=0$, register A for that timer is always used, while if ALT $=1$, the comparison will alternate between register A and register $B$ when each maximum count is reached. This alternation allows the user to change one MAX COUNT register while the other is being used, and thus provides a method of generating non-repetitive waveforms. Square waves and pulse outputs of any duty cycle are a subset of available signals obtained by not changing the final count registers. The ALT bit also determines the function of the timer output pin. If ALT is zero, the output pin will go LOW for one clock, the clock after the maximum count is reached. If ALT is one, the output pin will reflect the current MAX COUNT register being used ( $0 / 1$ for $B / A$ ).

## CONT:

Setting the CONT bit causes the associated timer to run continuously, while resetting it causes the timer to halt upon maximum count. If CONT $=0$ and ALT $=1$, the timer will count to the MAX COUNT register A value, reset, count to the register B value, reset, and halt.

Not all mode bits are provided for timer 2. Certain bits are hardwired as indicated below:

$$
A L T=0, E X T=0, P=0, R T G=0, R I U=0
$$

## Count Registers

Each of the three timers has a 16-bit count register. The contents of this register may be read or written by the processor at any time. If the register is written while the timer is counting, the new value will take effect in the current count cycle.

The count registers should be programmed before attempting to use the timers since they are not automatically initialized to zero.

## Max Count Registers

Timers 0 and 1 have two MAX COUNT registers, while timer 2 has a single MAX COUNT register. These contain the number of events the timer will count. In timers 0 and 1, the MAX COUNT register used can alternate between the two max count values whenever the current maximum count is reached. A timer resets when the timer count register equals the max count value being used. If the timer count register or the max count register is changed so that the max count is less than the timer count, the timer does not immediately reset. Instead, the timer counts up to OFFFFH, "wraps around" to zero, counts up to the max count value, and then resets.

## Timers and Reset

Upon RESET, the state of the timers will be as follows:

- All EN (Enable) bits are reset preventing timer counting.
- For Timers 0 and 1, the RIU bits are rese to zero and the ALT bits are set to one. This results in the Timer Out pins going HIGH.
- The contents of the count registers are indeterminate.


## INTERRUPT CONTROLLER

The 80 C 186 can receive interrupts from a number of sources, both internal and external. The internal interrupt controller serves to merge these requests on a priority basis, for individual service by the CPU.

Internal interrupt sources (Timers and DMA channels) can be disabled by their own control registers or by mask bits within the interrupt controller. The 80C186 interrupt controller has its own control register that sets the mode of operation for the controller.

The interrupt controller will resolve priority among requests that are pending simultaneously. Nesting is provided so interrupt service routines for lower priority interrupts may be interrupted by higher priority interrupts. A block diagram of the interrupt controller is shown in Figure 21.

The 80C186 has a special Slave Mode in which the internal interrupt controller acts as a slave to an external master. The controller is programmed into this mode by setting bit 14 in the peripheral control block relocation register. (See Slave Mode section.)

## MASTER MODE OPERATION

## Interrupt Controller External Interface

Five pins are provided for external interrupt sources. One of these pins is NMI, the non-maskable interrupt. NMI is generally used for unusual events such as power-fail interrupts. The other four pins may be configured in any of the following ways:

- As four interrupt lines with internally generated interrupt vectors.
- As an interrupt line and interrupt acknowledge line pair (Cascade Mode) with externally generated interrupt vectors plus two interrupt input lines with internally generated vectors.
- As two pairs of interrupt/interrupt acknowledge lines (Cascade Mode) with externally generated interrupt vectors.

External sources in the Cascade Mode use externally generated interrupt vectors. When an interrupt is acknowledged, two INTA cycles are initiated and the vector is read into the 80C186 on the second cycle. The capability to interface to external 82C59A programmable interrupt controllers is provided when the inputs are configured in Cascade Mode.

## Interrupt Controller Modes of Operation

The basic modes of operation of the interrupt controller in Master Mde are similar to the 82C59A. The interrupt controller responds identically to internal interrupts in all three modes: the difference is only in the interpretation of function of the four external interrupt pins. The interrupt controller is set into one of these three modes by programming the correct bits in the INTO and INT1 control registers. The modes of interrupt controller operation are as follows:

## Fully Nested Mode

When in the fully nested mode four pins are used as direct interrupt requests as in Figure 22. The vectors for these four inputs are generated internally. An inservice bit is provided for every interrupt source. If a lower-priority device requests an interrupt while the in service bit (IS) is set, no interrupt will be generated by the interrupt controller. In addition, if another interrupt request occurs from the same interrupt source while the in-service bit is set, no interrupt will be generated by the interrupt controller. This allows interrupt service routines to operate with interrupts enabled, yet be suspended only by interrupts of higher priority than the in-service interrupt.

When a service routine is completed, the proper IS bit must be reset by writing the proper pattern to the EOI register. This is required to allow subsequent interrupts from this interrupt source and to allow servicing of lower-priority interrupts. An EOI com-
mand is executed at the end of the service routine just before the return from interrupt instruction. If the fully nested structure has been upheld, the next highest-priority source with its IS bit set is then serviced.

## Cascade Mode

The 80C186 has four interrupt pins and two of them have dual functions. In the fully nested mode the four pins are used as direct interrupt inputs and the corresponding vectors are generated internally. In the Cascade Mode, the four pins are configured into interrupt input-dedicated acknowledge signal pairs. The interconnection is shown in Figure 23. INT0 is an interrupt input interfaced to an 82C59A, while INT2/INTAO serves as the dedicated interrupt acknowledge signal to that peripheral. The same is true for INT1 and INT3/INTA1. Each pair can selectively be placed in the Cascade Mode by programming the proper value into INT0 and INT1 control registers. The use of the dedicated acknowledge signals eliminates the need for the use of external logic to generate INTA and device select signals.

The primary Cascade Mode allows the capability to serve up to 128 external interrupt sources through the use of external master and slave 82C59As. Three levels of priority are created, requiring priority resolution in the 80C186 interrupt controller, the master 82C59As, and the slave 82C59As. If an external interrupt is serviced, one IS bit is set at each of these levels. When the interrupt service routine is completed, up to three end-of-interrupt commands must be issued by the programmer.


Figure 21. Interrupt Controller Block Diagram


Figure 22. Fully Nested (Direct) Mode Interrupt Controller Connections

## Special Fully Nested Mode

This mode is entered by setting the SFNM bit in INT0 or INT1 control register. It enables complete nestability with external 82C59A masters. Normally, an interrupt request from an interrupt source will not be recognized unless the in-service bit for that source is reset. If more than one interrupt source is connected to an external interrupt controller, all of the interrupts will be funneled through the same 80C186 interrupt request pin. As a result, if the external interrupt controller receives a higher-priority interrupt, its interrupt will not be recognized by the 80C186 controller until the 80C186 in-service bit is reset. In Special Fully Nested Mode, the 80C186 interrupt controller will allow interrupts from an external pin regardless of the state of the in-service bit for an interrupt source in order to allow multiple interrupts from a single pin. An in-service bit will continue to be set, however, to inhibit interrupts from other lower-priority 80C186 interrupt sources.

Special procedures should be followed when resetting IS bits at the end of interrupt service routines. Software polling of the IS register in the external master 82C59A is required to determine if there is more than one bit set. If so, the IS bit in the 80C186 remains active and the next interrupt service routine is entered.

## Operation in a Polled Environment

The controller may be used in a polled mode if interrupts are undesirable. When polling, the processor disables interrupts and then polls the interrupt controller whenever it is convenient. Polling the interrupt controller is accomplished by reading the Poll Word (Figure 32). Bit 15 in the poll word indicates to the processor that an interrupt of high enough priority is requesting service. Bits $0-4$ indicate to the processor the type vector of the highest-priority source requesting service. Reading the Poll Word causes the In-Service bit of the highest priority source to be set.

It is desirable to be able to read the Poll Word information without guaranteeing service of any pending
interrupt, i.e., not set the indicated in-service bit. The 80C186 provides a Poll Status Word in addition to the conventional Poll Word to allow this to be done. Poll Word information is duplicated in the Poll Status Word, but reading the Poll Status Word does not set the associated in-service bit. These words are located in two adjacent memory locations in the register file.

## Master Mode Features

## Programmable Priority

The user can program the interrupt sources into any of eight different priority levels. The programming is done by placing a 3 -bit priority level $(0-7)$ in the control register of each interrupt source. (A source with a priority level of 4 has higher priority over all priority levels from 5 to 7 . Priority registers containing values lower than 4 have greater priority). All interrupt sources have preprogrammed default priority levels (see Table 4).

If two requests with the same programmed priority level are pending at once, the priority ordering scheme shown in Table 4 is used. If the serviced interrupt routine reenables interrupts, other interrupt requests can be serviced.

## End-of-Interrupt Command

The end-of-interrupt (EOI) command is used by the programmer to reset the In-Service (IS) bit when an interrupt service routine is completed. The EOI command is issued by writing the proper pattern to the EOI register. There are two types of EOI commands, specific and nonspecific. The nonspecific command does not specify which IS bit is reset. When issued, the interrupt controller automatically resets the IS bit of the highest priority source with an active service routine. A specific EOI command requires that the programmer send the interrupt vector type to the interrupt controller indicating which source's is bit is to be reset. This command is used when the fully nested structure has been disturbed or the highest priority IS bit that was set does not belong to the service routine in progress.

## Trigger Mode

The four external interrupt pins can be programmed in either edge- or level-trigger mode. The control register for each external source has a level-trigger mode (LTM) bit. All interrupt inputs are active HIGH. In the edge sense mode or the level-trigger mode, the interrupt request must remain active (HIGH) until the interrupt request is acknowledged by the

80 C 186 CPU . In the edge-sense mode, if the level remains high after the interrupt is acknowledged, the input is disabled and no further requests will be generated. The input level must go LOW for at least one clock cycle to re-enable the input. In the level-trigger mode, no such provision is made: holding the interrupt input HIGH will cause continuous interrupt requests.

## Interrupt Vectoring

The 80C186 Interrupt Controller will generate interrupt vectors for the integrated DMA channels and the integrated Timers. In addition, the Interrupt Controller will generate interrupt vectors for the external interrupt lines if they are not configured in Cascade or Special Fully Nested Modes. The interrupt vectors generated are fixed and cannot be changed (see Table 4).

## Interrupt Controller Registers

The Interrupt Controller register model is shown in Figure 24. It contains 15 registers. All registers can both be read or written unless specified otherwise.

## In-Service Register

This register can be read from or written into. The format is shown in Figure 25. It contains the In-Service bit for each of the interrupt sources. The In-Service bit is set to indicate that a source's service routine is in progress. When an In-Service bit is set, the interrupt controller will not generate interrupts to the CPU when it receives interrupt requests from devices with a lower programmed priority level. The TMR bit is the In-Service bit for all three timers; the DO and D1 bits are the In-Service bits for the two DMA channels; the $10-13$ are the In -Service bits for the external interrupt pins. The IS bit is set when the
processor acknowledges an interrupt request either by an interrupt acknowledge or by reading the poll register. The IS bit is reset at the end of the interrupt service routine by an end-of-interrupt command.

## Interrupt Request Register

The internal interrupt sources have interrupt request bits inside the interrupt controller. The format of this register is shown in Figure 25. A read from this register yields the status of these bits. The TMR bit is the logical OR of all timer interrupt requests. D0 and D1 are the interrupt request bits for the DMA channels.

The state of the external interrupt input pins is also indicated. The state of the external interrupt pins is not a stored condition inside the interrupt controller, therefore the external interrupt bits cannot be written. The external interrupt request bits are set when an interrupt request is given to the interrupt controller, so if edge-triggered mode is selected, the bit in the register will be HIGH only after an inactive-to-active transition. For internal interrupt sources, the register bits are set when a request arrives and are reset when the processor acknowledges the requests.

Writes to the interrupt request register will affect the D0 and D1 interrupt request bits. Setting either bit will cause the corresponding interrupt request while clearing either bit will remove the corresponding interrupt request. All other bits in the register are readonly.

## Mask Register

This is a 16 -bit register that contains a mask bit for each interrupt source. The format for this register is shown in Figure 25. A one in a bit position corre-


270354-12
Figure 23. Cascade and Special Fully Nested Mode Interrupt Controller Connections
sponding to a particular source masks the source from generating interrupts. These mask bits are the exact same bits which are used in the individual control registers; programming a mask bit using the mask register will also change this bit in the individual control registers, and vice versa.

|  | OFFSET <br> 3EH |
| :---: | :---: |
| INT3 CONTROL REGISTER |  |
| INT2 CONTROL REGISTER | 3 CH |
| INT1 CONTROL REGISTER | 3AH |
| INTO CONTROL REGISTER | 38H |
| DMA 1 CONTROL REGISTER | 36H |
| DMA O CONTROL REGISTER | 34H |
| TIMER CONTROL REGISTER | 32H |
| INTERRUPT STATUS REGISTER | 3 H |
| INTERRUPT REQUEST REGISTER | 2EH |
| IN-SERVICE REGISTER | 2 CH |
| PRIORITY MASK REGISTER | 2AH |
| MASK REGISTER | 28H |
| POLL StATUS REGISTER | 26H |
| POLL REGISTER | 24H |
| EOI REGISTER | 22H |

Figure 24. Interrupt Controller Registers (Master Mode)

## Priority Mask Register

This register masks all interrupts below a particular interrupt priority level. The format of this register is shown in Figure 26. The code in the lower three bits of this register inhibits interrupts of priority lower (a higher priority number) than the code specified. For example, 100 written into this register masks interrupts of level five (101), six (110), and seven (111). The register is reset to seven (111) upon RESET so no interrupts are masked due to priority number.

## Interrupt Status Register

This register contains general interrupt controller status information. The format of this register is shown in Figure 27. The bits in the status register have the following functions:
DHLT: DMA Halt Transfer; setting this bit halts all DMA transfers. It is automatically set whenever a non-maskable interrupt occurs, and it is reset when an IRET instruction is executed. This bit allows prompt service of all nonmaskable interrupts. This bit may also be set by the programmer.
IRTx: These three bits represent the individual timer interrupt request bits. These bits differentiate between timer interrupts, since the timer IR bit in the interrupt request register is the "OR" function of all timer interrupt request. Note that setting any one of these three bits initiates an interrupt request to the interrupt controller.

| 15 | 14 |  |  | 10 |  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | - | $\bullet$ | $\bullet$ | 0 | 0 | 0 | 13 | 12 | 11 | 10 | D1 | D0 | 0 | TMR |

Figure 25. In-Service, Interrupt Request, and Mask Register Formats


Figure 26. Priority Mask Register Format


Figure 27. Interrupt Status Register Format (Master Mode)

## Timer, DMA 0, 1; Control Register

These registers are the control words for all the internal interrupt sources. The format for these registers is shown in Figure 28. The three bit positions PR0, PR1, and PR2 represent the programmable priority level of the interrupt source. The MSK bit inhibits interrupt requests from the interrupt source. The MSK bits in the individual control registers are the exact same bits as are in the Mask Register; modifying them in the individual control registers will also modify them in the Mask Register, and vice versa.

## INTO-INT3 Control Registers

These registers are the control words for the four external input pins. Figure 29 shows the format of the INTO and INT1 Control registers; Figure 30 shows the format of the INT2 and INT3 Control registers. In Cascade Mode or Special Fully Nested Mode, the control words for INT2 and INT3 are not used.

The bits in the various control registers are encoded as follows:
PRO-2: Priority programming information. Highest Priority $=000$, Lowest Priority $=111$
LTM: $\quad$ Level-trigger mode bit. $1=$ level-triggered; $0=$ edge-triggered. Interrupt Input levels are active high. In level-triggered mode, an interrupt is generated whenever the external line is high. In edge-triggered mode, an interrupt will be generated only when this
level is preceded by an inactive-to-active transition on the line. In both cases, the level must remain active until the interrupt is acknowledged.
MSK: $\quad$ Mask bit, $1=$ mask; $0=$ non-mask.
C: $\quad$ Cascade mode bit, $1=$ cascade; $0=$ direct
SFNM: Special Fully Nested Mode bit, $1=$ SFNM

## EOI Register

The end of the interrupt register is a command register which can only be written into. The format of this register is shown in Figure 31. It initiates an EOI command when written to by the 80C186 CPU.

The bits in the EOI register are encoded as follows:
$S_{x}$ : Encoded information that specifies an interrupt source vector type as shown in Table 4. For example, to reset the In-Service bit for DMA channel 0 , these bits should be set to 01010, since the vector type for DMA channel 0 is 10 .

NOTE:
To reset the single In-Service bit for any of the three timers, the vector type for timer 0 (8) should be written in this register.

NSPEC/: A bit that determines the type of EOI comSPEC mand. Nonspecific $=1$, Specific $=0$.

Figure 28. Timer/DMA Control Registers Formats


Figure 29. INTO/INT1 Control Register Formats

| 15 | 14 |  |  |  |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | - | $\bullet$ | - | - | - | - | - | 0 | LTM | MSK | PR2 | PR1 | PR0 |

Figure 30. INT2/INT3 Control Register Formats

## Poll and Poll Status Registers

These registers contain polling information. The format of these registers is shown in Figure 32. They can only be read. Reading the Poll register constitutes a software poll. This will set the IS bit of the highest priority pending interrupt. Reading the poll status register will not set the IS bit of the highest priority pending interrupt; only the status of pending interrupts will be provided.

Encoding of the Poll and Poll Status register bits are as follows:
Sx: Encoded information that indicates the vector type of the highest priority interrupting source. Valid only when INTREQ $=1$.
INTREQ: This bit determines if an interrupt request is present. Interrupt Request =1; no Interrupt Request $=0$.

## SLAVE MODE OPERATION

When Slave Mode is used, the internal 80 C 186 interrupt controller will be used as a slave controller to an external master interrupt controller. The internal 80C186 resources will be monitored by the internal interrupt controller, while the external controller functions as the system master interrupt controller.

Upon reset, the 80 C 186 will be in master mode. To provide for slave mode operation bit 14 of the relocation register should be set.

Because of pin limitations caused by the need to interface to an external 82C59A master, the internal interrupt controller will no longer accept external inputs. There are however, enough 80 C 186 interrupt controller inputs (internally) to dedicate one to each timer. In this mode, each timer interrupt source has its own mask bit, is bit, and control word.

In Slave Mode each peripheral must be assigned a unique priority to ensure proper interrupt controller operation. Therefore, it is the programmer's responsibility to assign correct priorities and initialize interrupt control registers before enabling interrupts.

## Slave Mode External Interface

The configuration of the 80C186 with respect to an external 82C59A master is shown in Figure 33. The INTO (Pin 45) input is used as the 80C186 CPU interrupt input. IRQ (Pin 41) functions as an output to send the 80C186 slave-interrupt-request to one of the 8 master-PIC-inputs.


Figure 31. EOI Register Format

| 15 | 14 | 13 |  |  |  |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INT REQ | 0 | 0 | - | - | - | - | - | - | - | 0 | S4 | S3 | S2 | S1 | So |

Figure 32. Poll and Poll Status Register Format


270354-13
Figure 33. Slave Mode Interrupt Controller Connections

Correct master-slave interface requires decoding of the slave addresses (CAS0-2). Slave 82C59As do this internally. Because of pin limitations, the 80 C 186 slave address will have to be decoded externally. SELECT (Pin 44) is used as a slave-select input. Note that the slave vector address is transferred internally, but the READY input must be supplied externally.
$\overline{\mathbb{N T A O}}$ (Pin 42) is used as an acknowledge output, suitable to drive the INTA input of an 82C59A.

## Interrupt Nesting

Slave Mode operation allows nesting of interrupt requests. When an interrupt is acknowledged, the priority logic masks off all priority levels except those with equal or higher priority.

## Vector Generation in the Slave Mode

Vector generation in Slave Mode is exactly like that of an 8259A or 82C59A slave. The interrupt controller generates an 8-bit vector type number which the CPU multiplies by four to use as an address into the vector table. The five most significant bits of this type number are user-programmable while the three least significant bits are defined according to Figure 34. The significant five bits of the vector are programmed by writing to the Interrupt Vector register at offset 20 H .

## Specific End-of-Interrupt

In Slave Mode the specific EOI command operates to reset an in-service bit of a specific priority. The user supplies a 3-bit priority-level value that points to an in-service bit to be reset. The command is executed by writing the correct value in the Specific EOI register at offset 22 H .

## Interrupt Controller Registers in the Slave Mode

All control and command registers are located inside the internal peripheral control block. Figure 34 shows the offsets of these registers.

## End-of-Interrupt Register

The end-of-interrupt register is a command register which can only be written. The format of this register is shown in Figure 35. It initiates an EOI command when written by the 80C186 CPU.

The bits in the EOI register are encoded as follows:
$\mathrm{V} \mathrm{T}_{\mathrm{x}}$ : Three least-significant vector type bits corresponding to the source for which the IS bit is to be reset. Figure 34 indicates these bits.

## In-Service Register

This register can be read from or written into. It contains the in-service bit for each of the internal interrupt sources. The format for this register is shown in Figure 36. Bit positions 2 and 3 correspond to the DMA channels; positions 0,4 , and 5 correspond to the integral timers. The source's IS bit is set when the processor acknowledges its interrupt request.

## Interrupt Request Register

This register indicates which internal peripherals have interrupt requests pending. The format of this register is shown in Figure 36. The interrupt request bits are set when a request arrives from an internal source, and are reset when the processor acknowledges the request. As in Master Mode, D0 and D1 are read/write; all other bits are read only.

## Mask Register

This register contains a mask bit for each interrupt source. The format for this register is shown in Figure 36. If the bit in this register corresponding to a particular interrupt source is set, any interrupts from that source will be masked. These mask bits are exactly the same bits which are used in the individual control registers, i.e., changing the state of a mask bit in this register will also change the state of the mask bit in the individual interrupt control register corresponding to the bit.

## Control Registers

These registers are the control words for all the internal interrupt sources. The format of these registers is shown in Figure 37. Each of the timers and both of the DMA channels have their own Control Register.

The bits of the Control Registers are encoded as follows:
$\mathrm{pr}_{\mathrm{x}}$ : 3-bit encoded field indicating a priority level for the source.
msk: mask bit for the priority level indicated by $\mathrm{pr}_{\mathrm{x}}$ bits.


Figure 34. Interrupt Controller Registers (Slave Mode)

| 15 | 14 | 13 |  |  |  |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | - | $\bullet$ | $\bullet$ | $\bullet$ | 0 | 0 | 0 | 0 | 0 | 0 | VT2 | VT1 | VTO |

Figure 35. Specific EOI Register Format


Figure 36. In-Service, Interrupt Request, and Mask Register Format

## Interrupt Vector Register

This register provides the upper five bits of the interrupt vector address. The format of this register is shown in Figure 38. The interrupt controller itself provides the lower three bits of the interrupt vector as determined by the priority level of the interrupt request.

The format of the bits in this register is:
$\mathrm{t}_{\mathrm{x}}$ : 5 -bit field indicating the upper five bits of the vector address.

## Priority-Level Mask Register

This register indicates the lowest priority-level interrupt which will be serviced.

The encoding of the bits in this register is:
$\mathrm{m}_{\mathrm{x}}$ : 3-bit encoded field indication priority-level value. All levels of lower priority will be masked.

## Interrupt Controller and Reset

Upon RESET, the interrupt controller will perform the following actions:

- All SFNM bits reset to 0 , implying Fully Nested Mode.
- All PR bits in the various control registers set to 1 . This places all sources at lowest priority (level 111).
- All LTM bits reset to 0 , resulting in edge-sense mode.
- All Interrupt Service bits reset to 0 .
- All Interrupt Request bits reset to 0 .
- All MSK (Interrupt Mask) bits set to 1 (mask).
- All C (Cascade) bits reset to 0 (non-Cascade).
- All PRM (Priority Mask) bits set to 1 , implying no levels masked.
- Initialized to Master Mode.


## Interrupt Status Register

This register is defined as in Master Mode except that DHLT is not implemented (see Figure 27).

## Enhanced Mode Operation

In Compatible Mode the 80C186 operates with all the features of the NMOS 80186, with the exception of 8087 support (i.e. no numeric coprocessing is possible in Compatible Mode). Queue-Status information is still available for design purposes other than 8087 support.

All the Enhanced Mode features are completely masked when in Compatible Mode. A write to any of the Enhanced Mode registers will have no effect, while a read will not return any valid data.

In Enhanced Mode, the 80C186 will operate with Power-Save, DRAM refresh, and numerics coprocessor support in addition to all the Compatible Mode features.

## Entering Enhanced Mode

If connected to a numerics coprocessor, this mode will be invoked automatically. Without an NPX, this mode can be entered by tying the RESET output signal from the 80C186 to the TEST/BUSY input:

## Queue-Status Mode

The queue-status mode is entered by strapping the $\overline{R D}$ pin low. $\overline{R D}$ is sampled at RESET and if LOW, the 80C186 will reconfigure the ALE and WR pins to be QS0 and QS1 respectively. This mode is available on the 80C186 in both Compatible and Enhanced Modes.

## DRAM Refresh Control Unit Description

The Refresh Control Unit (RCU) automatically generates DRAM refresh bus cycles. The RCU operates only in Enhanced Mode. After a programmable period of time, the RCU generates a memory read request to the BIU. If the address generated during a refresh bus cycle is within the range of a properly programmed chip select, that chip select will be activated when the BIU executes the refresh bus cycle. The ready logic and wait states programmed for that region will also be in force. If no chip select is activated, then external ready is automatically required to terminate the refresh bus cycle.

If the HLDA pin is active when a DRAM refresh request is generated (indicating a bus hold condition), then the 80C186 will deactivate the HLDA pin in order to perform a refresh cycle. The circuit external to the 80C186 must remove the HOLD signal for at least one clock in order to execute the refresh cycle. The sequence of HLDA going inactive while HOLD is being held active can be used to signal a pending refresh request.

All registers controlling DRAM refresh may be read and written in Enhanced Mode. When the processor is operating in Compatible Mode, they are deselected and are therefore inaccessible. Some fields of these registers cannot be written and are always read as zeros.

## DRAM Refresh Addresses

The address generated during a refresh cycle is determined by the contents of the MDRAM register (see Figure 40) and the contents of a 9-bit counter. Figure 41 illustrates the origin of each bit.

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MDRAM: <br> Offset EOH | M6 | M5 | M4 | M3 | M2 | M1 | M0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Bits 0-8: Reserved, read back as 0 .
Bits 9-15: M0-M6, are address bits A13-A19 of the 20-bit memory refresh address. These bits should correspond to any chip select address to be activated for the DRAM partition. These bits are cleared to 0 on RESET.

Figure 40. Memory Partition Register


Figure 41. Addresses Generated by RCU

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CDRAM: Offset E2H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C8 | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 |

Bits 0-8: $\quad$ C0-C8, clock divisor register, holds the number of CLKOUT cycles between each refresh request.
Bits 9-15: Reserved, read back as 0 .
Figure 42. Clock Pre-Scaler Register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EDRAM: <br> Offset E4H | E | 0 | 0 | 0 | 0 | 0 | 0 | T8 | T7 | T6 | T5 | T4 | T3 | T2 | T1 | T0 |

Bits 0-8: T0-T8, refresh clock counter outputs. Read only.
Bits 9-14: Reserved, read back as 0 .
Bit 15: Enable RCU, set to 0 on RESET.
Figure 43. Enable RCU Register

## Refresh Control Unit Programming and Operation

After programming the MDRAM and the CDRAM registers (Figures 40 and 42), the RCU is enabled by setting the " $E$ " bit in the EDRAM register (Figure 43). The clock counter (T0-T8 of EDRAM) will be loaded from $\mathrm{C} 0-\mathrm{C} 8$ of CDRAM during $\mathrm{T}_{3}$ of instruction cycle that sets the " E " bit. The clock counter is then decremented at each subsequent CLKOUT.

A refresh is requested when the value of the counter has reached 1 and the counter is reloaded from CDRAM. In order to avoid missing refresh requests, the value in the CDRAM register should always be at least 18 (12H). Clearing the " E " bit at anytime will clear the counter and stop refresh requests, but will not reset the refresh address counter.

## POWER-SAVE CONTROL

## Power Save Operation

The 80C186, when in Enhanced Mode, can enter a power saving state by internally dividing the processor clock frequency by a programmable factor. This divided frequency is also available at the CLKOUT
pin. The PDCON register contains the two-bit fields for selecting the clock division factor and the enable bit.

All internal logic, including the Refresh Control Unit and the timers, will have their clocks slowed down by the division factor. To maintain a real time count or a fixed DRAM refresh rate, these peripherals must be re-programmed when entering and leaving the power-save mode.

The power-save mode is exited whenever an interrupt is processed by automatically resetting the enable bit. If the power-save mode is to be re-entered after serving the interrupt, the enable bit will need to be set in software before returning from the interrupt routine.

The internal clocks of the 80C186 will begin to be divided during the $T_{3}$ state of the instruction cycle that sets the enable bit. Clearing the enable bit will restore full speed in the $T_{3}$ state of that instruction.

At no time should the internal clock frequency be allowed to fall below 0.5 MHz . This is the minimum operational frequency of the 80 C 186 . For example, an 80 C 186 running with a 12 MHz crystal ( 6 MHz CLOCKOUT) should never have a clock divisor greater than eight.

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PDCON: <br> Offset FOH | E | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | F1 | F0 |

Bits 0-1: Clock Divisor Select

| F1 | F0 | Division Factor |
| :---: | :---: | :--- |
| 0 | 0 | divide by 1 |
| 0 | 1 | divide by 4 |
| 1 | 0 | divide by 8 |
| 1 | 1 | divide by 16 |

Bits 2-14: Reserved, read back as zero.
Bit 15: Enable Power Save Mode. Set to zero on RESET.
Figure 44. Power-Save Control Register

## Interface for 80C187 Numeric Processor Extension

In Enhanced Mode, three of the mid-range memory chip selects are redefined according to Table 16 for use with the 80C187. The fourth chip select, MCS2 functions as in compatible mode, and may be programmed for activity with ready logic and wait states accordingly. As in compatible mode, MCS2 will function for one-fourth a programmed block size.

Table 16. $\overline{\text { MCS }}$ Assignments

| Compatible <br> Mode | Enhanced Mode |
| :--- | :--- |
| $\overline{\text { MCS0 }}$ | PEREQ |
| $\overline{\text { PCSOcessor Extension Request }}$ |  |
| $\overline{\text { ERROR }}$ | NPX Error |
| $\overline{\text { MCS2 }}$ | $\overline{\text { MCS2 }}$ |
| $\overline{\text { MCS3 }}$ | Mid-Range Chip Select <br> NPS |
| Numeric Processor Select |  |

Four port addresses are assigned to the 80C186/ 80C187 interface for 16-bit reads and writes. Table 17 shows the port definitions. These ports are not accessible by using the 80C186 I/O instructions. However, numerics operations will cause a $\overline{\text { PCS }}$ line to be activated if it is properly programmed for this I/O range.

Table 17. Numerics Coprocessor I/O Port
Assignments

| I/O Address | Read Definition | Write Definition |
| :---: | :---: | :---: |
| OOF8H | Status/Control | Opcode |
| OOFAH | Data | Data |
| OOFCH | reserved | CS:IP, DS:EA |
| 00FEH | Opcode Status | reserved |

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80C186 has a test mode available which allows all pins to be placed in a high-impedance state. ONCE stands for "ON Circuit Emulation". When placed in this mode, the 80C186 will put all pins in the high-impedance state until RESET.

The ONCE mode is selected by tying the $\overline{U C S}$ and the LCS LOW during RESET. These pins are sampled on the low-to-high transition of the RES pin. The $\overline{U C S}$ and the $\overline{L C S}$ pins have weak internal pullup resistors similar to the $\overline{\text { RD }}$ and TEST/BUSY pins to guarantee normal operation.


270354-14
Figure 45. Typical 80C186 Computer

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias $\ldots .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature $\ldots \ldots . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground ............. - 1.0 V to +7.0 V
Package Power Dissipation ....................... 1W
Not to exceed the maximum allowable die temperature based on thermal resistance of the package.


#### Abstract

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


NOTICE: This data sheet is only valid for devices indicated in the Specification Level Markings section. Specifications contained in the following tables are subject to change.

## D.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| V $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (Except X1) | -0.5 | $0.2 \mathrm{~V}_{\text {CC }}-0.3$ | V |  |
| $\mathrm{V}_{\text {IL1 }}$ | Clock Input Low Voltage (X1) | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (All except X1, $\overline{\text { RES }}$, ARDY, and SRDY) | $0.2 \mathrm{~V}_{\mathrm{CC}}+0.9$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{H} 1}$ | Input High Voltage ( $\overline{\mathrm{RES}}$ ) | 3.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{H} 2}$ | Input High Voltage (SRDY, ARDY) | $0.2 \mathrm{~V}_{\mathrm{CC}}+1.1$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{IH3}}$ | Clock Input High Voltage (X1) | 3.9 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\begin{aligned} & \mathrm{loL}=2.5 \mathrm{~mA}(\mathrm{SO}, 1,2) \\ & \mathrm{loL}=2.0 \mathrm{~mA} \text { (others) } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | $V_{C C}$ | V | $\mathrm{IOH}^{\prime}=-2.4 \mathrm{~mA} @ 2.4 \mathrm{~V}(4)$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}-0.5$ | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{l}_{\mathrm{OH}}=-200 \mu \mathrm{~A} @ \mathrm{~V}_{\mathrm{CC}}-0.5(4)$ |
| Icc | Power Supply Current |  | 150 | mA | $\begin{aligned} & \hline @ 16 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}(3) \\ & \hline \end{aligned}$ |
|  |  |  | 120 | mA | $\begin{aligned} & @ 12.5 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3) \\ & \hline \end{aligned}$ |
|  |  |  | 100 | mA | $\begin{aligned} & @ 10 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3) \end{aligned}$ |
| LI | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & @ 0.5 \mathrm{MHz}, \\ & 0.45 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| Lo | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & @ 0.5 \mathrm{MHz}, \\ & 0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}}{ }^{(1)} \end{aligned}$ |
| $\mathrm{V}_{\text {CLO }}$ | Clock Output Low |  | 0.45 | V | $\mathrm{I}_{\mathrm{CLO}}=4.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{CHO}}$ | Clock Output High | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{I}_{\mathrm{CHO}}=-500 \mu \mathrm{~A}$ |
| $\mathrm{Cl}_{\text {IN }}$ | Input Capacitance |  | 10 | pF | @ 1 MHz ${ }^{(2)}$ |
| $\mathrm{Cl}_{10}$ | Output or I/O Capacitance |  | 20 | pF | @ 1 MHz ${ }^{(2)}$ |

## NOTES:

1. Pins being floated during HOLD or by invoking the ONCE Mode.
2. Characterization conditions are a) Frequency $=1 \mathrm{MHz}$; b) Unmeasured pins at GND ; c) $\mathrm{V}_{\mathrm{IN}}$ at +5.0 V or 0.45 V . This parameter is not tested.
3. Current is measured with the device in RESET with X 1 and X 2 driven and all other non-power pins open.
4. $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \mathrm{UCS}, \mathrm{LCS}, \overline{M C S O} / P E R E Q, \overline{M C S 1 / E R R O R}$, and TEST/BUSY pins have internal pullup devices. Loading some of these pins above $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ can cause the 80 C 186 to go into alternative modes of operation. See the section on Local Bus Controller and Reset for details.

## POWER SUPPLY CURRENT

Current is linearly proportional to clock frequency and is measured with the device in RESET with X1 and X 2 driven and all other non-power pins open.

Maximum current is given by $\mathrm{I}_{\mathrm{CC}}=8.4 \mathrm{~mA} \times$ freq. $(\mathrm{MHz})+15 \mathrm{~mA}$.

Typical current is given by $l_{\mathrm{CC}}$ (typical) $=6.4 \mathrm{~mA} \times$ freq. (MHz) +4.0 mA . "Typicals" are based on a limited number of samples taken from early manufacturing lots measured at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and room temperature. "Typicals" are not guaranteed.


Figure 46. Icc vs Frequency

## A. C. CHARACTERISTICS

## MAJOR CYCLE TIMINGS (READ CYCLE)

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | 80 C 186 |  | 80C186-12 |  | 80C186-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 80C186 GENERAL TIMING REQUIREMENTS (Listed More Than Once) |  |  |  |  |  |  |  |  |  |
| T ${ }_{\text {DVCL }}$ | Data in Setup (A/D) | 15 |  | 15 |  | 15 |  | ns |  |
| TCLDX | Data in Hold (A/D) | 3 |  | 3 |  | 3 |  | ns |  |
| 80C186 GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}^{\text {CHSVV }}$ | Status Active Delay | 5 | 45 | 5 | 35 | 5 | 31 | ns |  |
| TCLSH | Status Inactive Delay | 5 | 46 | 5 | 35 | 5 | 30 | ns |  |
| T CLAV | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| ${ }^{T}$ CLAX | Address Hold | 0 |  | 0 |  | 0 |  | ns |  |
| T CLDV | Data Valid Delay | 5 | 40 | 5 | 36 | 5 | 33 | ns |  |
| T CHDX | Status Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 30 |  | 25 |  | 20 | ns |  |
| TLHLL | ALE Width | $\mathrm{T}_{\text {CLCL }}-15$ |  | $\mathrm{T}_{\text {CLCL - }} 15$ |  | $\mathrm{T}_{\text {CLCL }-15}$ |  | ns |  |
| $\mathrm{T}_{\text {CHLL }}$ | ALE Inactive Delay |  | 30 |  | 25 |  | 20 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH-18 |  | TCLCH - 15 |  | T $\mathrm{CLCH}^{\text {- }} 15$ |  | ns | $\begin{gathered} \text { Equal } \\ \text { Loading } \\ \hline \end{gathered}$ |
| TLLAX | Address Hold from ALE Inactive | T ${ }_{\text {CHCL }}$ - 15 |  | TCHCL - 15 |  | T ${ }_{\text {CHCL }}-15$ |  | ns | Equal Loading |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | 0 |  | ns |  |
| TCLAZ | Address Float Delay | $\mathrm{T}_{\text {CLAX }}$ | 30 | $\mathrm{T}_{\text {CLAX }}$ | 25 | TCLAX | 20 | ns |  |
| $\mathrm{T}_{\text {CLCSV }}$ | Chip-Select Active Delay | 3 | 42 | 3 | 33 | 3 | 30 | ns |  |
| $T_{\text {cxcsx }}$ | Chip-Select Hold from Command Inactive | TCLCH - 10 |  | TCLCH - 10 |  | TCLCH-10 |  | ns | Equal Loading |
| $\mathrm{T}_{\text {CHCSX }}$ | Chip-Select Inactive Delay | 5 | 35 | 5 | 30 | 5 | 25 | ns |  |
| $\mathrm{T}_{\mathrm{DXDL}}$ | $\overline{\mathrm{DEN}}$ Inactive to DT/R Low | 0 |  | 0 |  | 0 |  | ns | Equal Loading |
| ${ }^{\text {chevat }}$ | Control Active Delay 1 | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| ${ }^{\text {T CVDEX }}$ | $\overline{\mathrm{DEN}}$ Inctive Delay | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| ${ }^{\text {T CHCTV }}$ | Control Active Delay 2 | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| TCLLV | $\overline{\text { LOCK }}$ Valid/Invalid Delay | 3 | 40 | 3 | 37 | 3 | 35 | ns |  |
| 80C186 TIMING RESPONSES (Read Cycie) |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {AZRL }}$ | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {CLRL }}$ | $\overline{\mathrm{RD}}$ Active Delay | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Pulse Width | ${ }^{2} \mathrm{~T}_{\text {CLCL }}-30$ |  | ${ }^{2} \mathrm{C}_{\text {CLCL }}-25$ |  | ${ }^{2 T}$ CLCL - 25 |  | ns |  |
| $\mathrm{T}_{\text {CLRH }}$ | $\overline{\mathrm{RD}}$ Inactive Delay | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| TRHLH | $\overline{\mathrm{RD}}$ Inactive to ALE High | $\mathrm{T}_{\text {CLCH }}$ - 14 |  | T CLCH -14 |  | TCLCH - 14 |  | ns | $\begin{gathered} \text { Equal } \\ \text { Loading } \end{gathered}$ |
| TrHAV | $\overline{\mathrm{RD}}$ Inactive to Address Active | TCLCL - 15 |  | TCLCL - 15 |  | TCLCL - 15 |  | ns | Equal Loading |

## A. C. CHARACTERISTICS

## READ CYCLE WAVEFORMS



## A. C. CHARACTERISTICS

## MAJOR CYCLE TIMINGS (WRITE CYCLE)

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | 80 C 186 |  | 80C186-12 |  | 80C186-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 80C186 GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {CHSV }}$ | Status Active Delay | 5 | 45 | 5 | 35 | 5 | 31 | ns |  |
| $\mathrm{T}_{\text {CLSH }}$ | Status Inactive Delay | 5 | 46 | 5 | 35 | 5 | 30 | ns |  |
| TCLAV | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| $\mathrm{T}_{\text {Clax }}$ | Address Hold | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {CLDV }}$ | Data Valid Delay | 5 | 40 | 5 | 36 | 5 | 33 | ns |  |
| $\mathrm{T}_{\text {CHDX }}$ | Status Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 30 |  | 25 |  | 20 | ns |  |
| TLHLL | ALE Width | $\mathrm{T}_{\text {CLCL }}-15$ |  | $\mathrm{T}_{\text {CLCL - }} 15$ |  | $\mathrm{T}_{\text {CLCL - }} 15$ |  | ns |  |
| ${ }^{\text {T CHLL }}$ | ALE Inactive Delay |  | 30 |  | 25 |  | 20 | ns |  |
| $T_{\text {AVLL }}$ | Address Valid to ALE Low | $\mathrm{T}_{\text {CLCH }}-18$ |  | $\mathrm{T}_{\text {CLCH }} \mathbf{1 5}$ |  | TCLCH - 15 |  | ns | $\begin{aligned} & \text { Equal } \\ & \text { Loading } \end{aligned}$ |
| Tllax | Address Hold from ALE Inactive | $\mathrm{T}_{\text {CHCL }}-15$ |  | $\mathrm{T}_{\text {CHCL }}$ - 15 |  | $\mathrm{T}_{\text {CHCL }}-15$ |  | ns | Equal Loading |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {CLDOX }}$ | Data Hold Time | 3 |  | 3 |  | 3 |  | ns |  |
| T ${ }^{\text {CVCTV }}$ ( | Control Active Delay 1 | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| $\mathrm{T}_{\text {cVatix }}$ | Control Inactive Delay | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| TClcsv | Chip-Select Active Delay | 3 | 42 | 3 | 33 | 3 | 30 | ns |  |
| $\mathrm{T}_{\text {cxcsx }}$ | Chip-Select Hold from Command Inactive | $\mathrm{T}_{\text {CLCH }}-10$ |  | TCLCH - 10 |  | $\mathrm{T}_{\text {CLCH }}-10$ |  | ns | Equal Loading |
| $\mathrm{T}_{\text {CHCSX }}$ | Chip-Select Inactive Delay | 5 | 35 | 5 | 30 | 5 | 25 | ns |  |
| TDXDL | $\overline{\text { DEN }}$ Inactive to DT/R ${ }^{\text {L }}$ Low | 0 |  | 0 |  | 0 |  | ns | Equal Loading |
| $\mathrm{T}_{\text {CLLV }}$ | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | 3 | 35 | ns |  |

80C186 TIMING RESPONSES (Write Cycle)

| TWLWH | WR Pulse Width | ${ }^{2} \mathrm{CLCLL}^{-30}$ | $2 \mathrm{C}_{\text {CLCL }}-25$ | $2{ }^{\text {CLCL }}$ - 25 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TWHLH | WR Inactive to ALE High | $\mathrm{T}_{\text {CLCH - }} 14$ | T ${ }_{\text {CLCH }}$ - 14 | T ${ }_{\text {CLCH }}$-14 | ns | Equal Loading |
| T WHDX | Data Hold After WR | TCLCL - 34 | TCLCL - 20 | TCLCL - 20 | ns | Equal Loading |
| T WHDEX | $\overline{\text { WR }}$ Inactive to $\overline{\text { DEN }}$ Inactive | TCLCH - 10 | TCLCH - 10 | TCLCH - 10 | ns | Equal Loading |

## A. C. CHARACTERISTICS

## WRITE CYCLE WAVEFORMS



## A. C. CHARACTERISTICS

## MAJOR CYCLE TIMINGS (INTERRUPT ACKNOWLEDGE CYCLE)

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{C C}=5 \mathrm{~V}_{ \pm} 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | 80 C 186 |  | $80 \mathrm{C} 186-12$ |  | $80 \mathrm{C} 186-16$ |  | Unit <br> Test <br> Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |

80C186 GENERAL TIMING REQUIREMENTS (Listed More Than Once)

| $T_{\text {DVCL }}$ | Data in Setup (AD) | 15 |  | 15 |  | 15 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLDX | Data in Hold (ADD) | 3 |  | 3 |  | 3 |  | ns |  |

80C186 GENERAL TIMING RESPONSES (Listed More Than Once)

| ${ }^{\text {T }}$ CHSV | Status Active Delay | 5 | 45 | 5 | 35 | 5 | 31 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 5 | 46 | 5 | 35 | 5 | 30 | ns |  |
| T CLAV | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | 0 |  | ns |  |
| T CLAX | Address Hold | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {CLDV }}$ | Data Valid Delay | 5 | 40 | 5 | 36 | 5 | 33 | ns |  |
| $\mathrm{T}_{\text {CHDX }}$ | Status Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay | . | 30 |  | 25 |  | 20 | ns |  |
| TLHLL | ALE Width | $\mathrm{T}_{\text {CLCL }}-15$ |  | $\mathrm{T}_{\text {CLCL }} 15$ |  | $\mathrm{T}_{\text {CLCL }}-15$ |  | ns |  |
| $\mathrm{T}_{\text {CHLL }}$ | ALE Inactive Delay |  | 30 |  | 25 |  | 20 | ns |  |
| TAVLL | Address Valid to ALE Low | $\mathrm{T}_{\text {CLCH }}-18$ |  | TCLCH-15 |  | $\mathrm{T}_{\text {CLCH }}-15$ |  | ns | Equal Loading |
| TLLAX | Address Hold to ALE Inactive | $\mathrm{T}_{\text {CHCL }}-15$ |  | TCHCL - 15 |  | $\mathrm{T}_{\text {CHCL }}-15$ |  | ns | Equal Loading |
| TCLAZ | Address Float Delay | $\mathrm{T}_{\text {CLAX }}$ | 30 | TCLAX | 25 | $\mathrm{T}_{\text {CLAX }}$ | 20 | ns |  |
| T ${ }_{\text {cVetv }}$ | Control Active Delay 1 | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| $\mathrm{T}_{\text {cvetx }}$ | Control Inactive Delay | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| $T_{\text {DXDL }}$ | DEN Inactive to DT//R Low | 0 |  | 0 |  | 0 |  | ns | Equal Loading |
| $\mathrm{T}_{\text {CHCTV }}$ | Control Active Delay 2 | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| T Cvdex | $\overline{\mathrm{DEN}}$ Inctive Delay (Non-Write Cycles) | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| TCllv | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | 3 | 35 | ns |  |

## A. C. CHARACTERISTICS

INTERRUPT ACKNOWLEDGE CYCLE WAVEFORMS


NOTES:

1. Status inactive in state preceding $T_{4}$.
2. The data hold time lasts only until $\overline{\mathbb{N T A}}$ goes inactive, even if the $\overline{\operatorname{INTA}}$ transition occurs prior to $\mathrm{T}_{\mathrm{CLDX}}(\mathrm{min})$.
3. INTA occurs one clock later in Slave Mode.
4. For write cycle followed by interrupt acknowledge cycle.
5. $\overline{\text { LOCK }}$ is active upon $T_{1}$ of the first interrupt acknowledge cycle and inactive upon $T_{2}$ of the second interrupt acknowledge cycle.

## A. C. CHARACTERISTICS

## SOFTWARE HALT CYCLE TIMINGS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{G}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | 80 C 186 |  | 80C186-12 |  | 80C186-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 80C186 GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {CHSV }}$ | Status Active Delay | 5 | 45 | 5 | 35 | 5 | 31 | ns |  |
| TCLSH | Status Inactive Delay | 5 | 46 | 5 | 35 | 5 | 30 | ns |  |
| TCLAV | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 30 |  | 25 |  | 20 | ns |  |
| TLHLL | ALE Width | $\mathrm{T}_{\text {CLCL }-15}$ |  | ${ }^{\text {CLCLL }} 15$ |  | $\mathrm{T}_{\text {CLCL }}$ - 15 |  | ns |  |
| $\mathrm{T}_{\text {CHLL }}$ | ALE Inactive Delay |  | 30 |  | 25 |  | 20 | ns |  |
| TDXDL | $\overline{\text { DEN }}$ Inactive to DT/R Low |  | 0 |  | 0 |  | 0 | ns | Equal Loading |
| $\mathrm{T}^{\text {chicti }}$ | Control Active Delay 2 | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |

## SOFTWARE HALT CYCLE WAVEFORMS



## A. C. CHARACTERISTICS

## CLOCK TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | 80 C 186 |  | 80C186-12 |  | 80C186-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min | Max | Min | Max | Min | Max |  |  |

80C186 CLKIN REQUIREMENTS Measurements taken with following conditions: External clock input to X1 and X2 not connected (float)

| $T_{\text {CKIN }}$ | CLKIN Period | 50 | 1000 | 40 | 1000 | 31.25 | 1000 | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\text {CLCK }}$ | CLKIN Low Time | 20 |  | 16 |  | 13 |  | ns | $1.5 \mathrm{~V}^{(2)}$ |
| $\mathrm{T}_{\text {CHCK }}$ | CLKIN High Time | 20 |  | 16 |  | 13 |  | ns | $1.5 \mathrm{~V}^{(2)}$ |
| $\mathrm{T}_{\text {CKHL }}$ | CLKIN Fall Time |  | 5 |  | 5 |  | 5 | ns | 3.5 to 1.0 V |
| $\mathrm{~T}_{\text {CKLH }}$ | CLKIN Rise Time |  | 5 |  | 5 |  | 5 | ns | 1.0 to 3.5 V |

## 80C186 CLKOUT TIMING

| T CICO | CLKIN to CLKOUT Skew |  | 25 |  | 21 |  | 17 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\text {CLCL }}$ | CLKOUT Period | 100 | 2000 | 80 | 2000 | 62.5 | 2000 | ns |  |
| $\mathrm{T}_{\mathrm{CLCH}}$ | CLKOUT Low Time | 0.5 TCLCL $^{-8}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-7}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-7}$ |  | ns | $\mathrm{C}_{\underline{E}}=100 \mathrm{pF}(2)$ |
|  |  | 0.5 TCLCL ${ }^{-6}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-5}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-5}$ |  | ns | $\mathrm{C}_{L}=50 \mathrm{pF}{ }^{(3)}$ |
| $\mathrm{T}_{\mathrm{CHCL}}$ | CLKOUT High Time | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-8}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-7}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-7}$ |  | ns | $\mathrm{C}_{\text {E }} 100 \mathrm{pF}$ (4) |
|  |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-6}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-5}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-5}$ |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (3) |
| $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLKOUT Rise Time |  | 10 |  | 10 |  | 10 | ns | 1.0 to 3.5 V |
| $\mathrm{T}_{\text {CL2CL1 }}$ | CLKOUT Fall Time |  | 10 |  | 10 |  | 10 | ns | 3.5 to 1.0 V |

## NOTES:

1. $T_{\text {CLCK }}$ and $T_{\text {CHCK }}$ (CLKIN Low and High times) should not have a duration less than $40 \%$ of $T_{\text {CKIN }}$
2. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}(5.25 \mathrm{~V} @ 16 \mathrm{MHz}) . \mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$.
3. Not Tested.
4. Tested under worst case conditions: $V_{C C}=4.5 \mathrm{~V}(4.75 \mathrm{~V} @ 16 \mathrm{MHz}) . \mathrm{T}_{\mathrm{A}}=\delta^{\circ} \mathrm{C}$.

## CLOCK WAVEFORMS



80C186

## A. C. CHARACTERISTICS

## READY, PERIPHERAL, AND QUEUE STATUS TIMINGS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $C_{L}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}{ }^{-0.5 \mathrm{~V}}$.

| Symbol | Parameter | 80 C 186 |  | 80C186-12 |  | 80C186-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 80C186 READY AND PERIPHERAL TIMING REQUIREMENTS |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {SRYCL }}$ | Synchronous Ready(SRDY) <br> Transition Setup Time (1) | 15 |  | 15 |  | 15 |  | ns |  |
| T CLSRY | SRDY Transition Hold Time (1) | 15 |  | 15 |  | 15 |  | ns |  |
| $\mathrm{T}_{\text {ARYCH }}$ | ARDY Resolution Transition Setup Time (2) | 15 |  | 15 |  | 15 |  | ns |  |
| TCLARX | ARDY Active Hold Time ${ }^{(1)}$ | 15 |  | 15 |  | 15 |  | ns |  |
| TARYCHL | ARDY Inactive Holding Time | 15 |  | 15 |  | 15 |  | ns |  |
| TARYLCL | Asynchronous Ready (ARDY) Setup Time (1) | 25 |  | 25 |  | 25 |  | ns |  |
| TINVCH | INTX, NMI, TEST/BUSY, TMR IN Setup Time (2) | 15 |  | 15 |  | 15 |  | ns |  |
| $\mathrm{T}_{\mathrm{INVCL}}$ | DRQ0, DRQ1 Setup Time (2) | 15 |  | 15 |  | 15 |  | ns | ' |
| 80C186 PERIPHERAL AND QUEUE STATUS TIMING RESPONSES |  |  |  |  |  |  |  |  |  |
| TCLTMV | Timer Output Delay |  | 40 |  | 33 |  | 27 | ns |  |
| $\mathrm{T}_{\text {CHOSV }}$ | Queue Status Delay |  | 37 |  | 32 |  | 30 | ns |  |

## NOTES:

1. To guarantee proper operation.
2. To guarantee recognition at clock edge.

## SYNCHRONOUS READY (SRDY) WAVEFORMS



## A. C. CHARACTERISTICS

 ASYNCHRONOUS READY (ARDY) WAVEFORMS

PERIPHERAL AND QUEUE STATUS WAVEFORMS


## A. C. CHARACTERISTICS

## RESET AND HOLD/HLDA TIMINGS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}$ ( 10 MHz ) and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz}$ ).
For A.C. tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathbb{I H}}=\mathrm{V}_{\mathrm{CC}}{ }^{-0.5 \mathrm{~V}}$.

| Symbol | Parameter | 80 C 186 |  | 80C186-12 |  | 80C186-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 80C186 RESET AND HOLD/HLDA TIMING REQUIREMENTS |  |  |  |  |  |  |  |  |  |
| Tresin | FES Setup | 15 |  | 15 |  | 15 |  | ns |  |
| $\mathrm{T}_{\mathrm{HVCL}}$ | HOLD Setup (1) | 15 |  | 15 |  | 15 |  | ns |  |
| 80C186 GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |  |  |
| TCLAZ | Address Float Delay | T CLAX | 30 | TCLAX | 25 | T CLAX | 20 | ns |  |
| TCLAV | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| 80C186 RESET AND HOLDHLDA TIMING RESPONSES |  |  |  |  |  |  |  |  |  |
| TCLRO | Reset Delay |  | 40 |  | 33 |  | 27 | ns |  |
| T CLHAV | HLDA Valid Delay | 3 | 40 | 3 | 33 | 3 | 25 | ns |  |
| $\mathrm{T}_{\mathrm{CHCZ}}$ | Command Lines Float Delay |  | 40 |  | 33 |  | 28 | ns |  |
| $\mathrm{T}_{\mathrm{CHCV}}$ | Command Lines Valid Delay (after Float) |  | 44 |  | 36 |  | 32 | ns |  |

## NOTE:

1. To guarantee recognition at next clock.

## RESET WAVEFORMS


A. C. CHARACTERISTICS

HOLD/HLDA WAVEFORMS (Entering Hold)


HOLD/HLDA WAVEFORMS (Leaving Hold)


## EXPLANATION OF THE AC SYMBOLS

Each timing symbol has from 5 to 7 characters. The first character is always a ' $T$ ' (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.
A: Address
ARY: Asynchronous Ready Input
C: Clock Output
CK: Clock Input
CS: Chip Select
CT: Control (DT/信, $\overline{\mathrm{DEN}}, \ldots$ )
D: Data Input
DE: $\overline{\mathrm{DEN}}$
H: Logic Level High
IN: Input (DRQ0, TIM0, ... )
L: Logic Level Low or ALE
O: Output
QS: Queue Status (QS1, QS2)
R: $\overline{R D}$ Signal, RESET Signal
S : $\quad$ Status $(\overline{\mathrm{S} 0}, \overline{\mathbf{S} 1}, \overline{\mathrm{~S} 2})$
SRY: Synchronous Ready Input
V: Valid
W: WR Signal
X: $\quad$ No Longer a Valid Logic Level
Z: Float
Examples:
TCLAV - Time from Clock low to Address valid
$T_{\text {CHLH }}$ - Time from Clock high to ALE high
TCLCSV - Time from Clock low to Chip Select valid

WAVEFORMS

## Typical Output Delay Capacitive Derating



Figure 47. Capacitive Derating Curve


Figure 48. TTL Level Rise and Fall Times for Output Buffers

Typical Rise and Fall Times for CMOS Voltage Levels


Figure 49. CMOS Level Rise and Fall Times for Output Buffers

## 80C186 EXPRESS

The Intel EXPRESS system offers enhancements to the operational specifications of the 80 C 186 microprocessor. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

The 80C186 EXPRESS program includes an extended temperature range. With the commercial standard temperature range, operational characteristics are guaranteed over the temperature range of $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$. With the extended temperature range option, operational characteristics are guaranteed over the range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

Package types and EXPRESS versions are identified by a one or two-letter prefix to the part number. The prefixes are listed in Table 18. All AC and DC specifications not mentioned in this section are the same for both commercial and EXPRESS parts.

Table 18. Prefix Identification

| Prefix | Package <br> Type | Temperature <br> Range |
| :---: | :---: | :---: |
| A | PGA | Commercial |
| N | PLCC | Commercial |
| R | LCC | Commercial |
| TA | PGA | Extended |
| TN | PLCC | Extended |
| TR | LCC | Extended |

## NOTE:

Extended temperature versions of the 80 C 186 are not available at 16 MHz .

## 80C186 EXECUTION TIMINGS

A determination of 80 C 186 program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.
- All word-data is located on even-address boundaries.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

With a 16 -bit BIU, the 80 C 186 has sufficient bus performance to ensure that an adequate number of prefetched bytes will reside in the queue most of the time. Therefore, actual program execution time will not be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY

| Function | Format |  |  |  | Clock <br> Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER MOV = Move: |  |  |  |  |  |  |
| Register to Register/Memory | 1000100 w | mod reg r/m |  |  | 2/12 |  |
| Register/memory to register | 1000101 w | mod reg r/m |  |  | 2/9 |  |
| Immediate to register/memory | 1100011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 12-13 | 8/16-bit |
| Immediate to register | 1011 w reg | data | data if $w=1$ |  | 3-4 | 8/16-bit |
| Memory to accumulator | 1010000 w | addr-low | addr-high |  | 8 |  |
| Accumulator to memory | 1010001 w | addr-low | addr-high |  | 9 |  |
| Register/memory to segment register | 10001110 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2/9 |  |
| Segment register to register/memory | 10001100 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2/11 |  |
| PUSH = Push: |  |  |  |  |  |  |
| Memory | 11111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  | 16 |  |
| Register | 01010 reg |  |  |  | 10 |  |
| Segment register | 000 reg 110 |  |  |  | 9 |  |
| Immediate........... | 011010 s 0 | data | data $1 \mathrm{l} \mathrm{s}=0$ |  | 10 |  |
| Plishi = Pumh Al | 01100000 |  |  |  | 36 |  |
| $\mathbf{P O P}=\mathbf{P o p}:$ |  |  |  |  |  |  |
| Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 20 |  |
| Register | 01011 reg |  |  |  | 10 |  |
| Segment register | 000 reg 111 | $(r e g \neq 01)$ |  |  | 8 |  |
| POPA = Fop All | 01100001 |  |  |  | 51 |  |
| XCHG = Exchange: |  |  |  |  |  |  |
| Register/memory with register | 1000011 w | mod reg r/m |  |  | 4/17 |  |
| Register with accumulator | 10010 reg |  |  |  | 3 |  |
| $\mathbf{I N}=$ Input from: |  |  |  |  |  |  |
| Fixed port | 1110010 w | port |  |  | 10 |  |
| Variable port | 1110110 w |  |  |  | 8 |  |
| OUT = Output to: |  |  |  |  |  |  |
| Fixed port | 1110011 w | port |  |  | 9 |  |
| Variable port | 1110111 w |  |  |  | 7 |  |
| XLAT $=$ Translate byte to AL | 11010111 |  |  |  | 11 |  |
| LEA = Load EA to register | 10001101 | mod reg r/m |  |  | 6 |  |
| LDS = Load pointer to DS | 11000101 | mod reg r/m | $(\bmod =11)$ |  | 18 |  |
| LES = Load pointer to ES | 11000100 | mod reg r/m | $(\bmod =11)$ |  | 18 |  |
| LAHF = Load AH with flags | 10011111 |  |  |  | 2 |  |
| SAHF = Store AH into flags | 10011110 |  |  |  | 3 |  |
| PUSHF = Push flags | 10011100 |  |  | ! | 9 |  |
| POPF $=$ Pop flags | 10011101 |  |  |  | 8 |  |

Shaded areas indicate instructions not available in 8086, 8088 microsystems.

## INSTRUCTION SET SUMMARY (Continued)



Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086,8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PROCESSOR CONTROL |  |  |  |  |
| CLC = Clear carry | 11111000 |  | 2 |  |
| CMC = Complement carry | 11110101 |  | 2 |  |
| STC = Set carry | 11111001 |  | 2 |  |
| CLD = Clear direction | 11111100 |  | 2 |  |
| STD $=$ Set direction | 11111101 |  | 2 |  |
| CLI = Clear interrupt | 11111010 |  | 2 |  |
| STI $=$ Set interrupt | 11111011 |  | 2 |  |
| HLT = Halt | 11110100 |  | 2 |  |
| WAIT = Wait | 10011011 |  | 6 | if $\overline{\mathrm{TEST}}=0$ |
| LOCK = Bus lock prefix | 11110000 |  | 2 |  |
| NOP $=$ No Operation | 10010000 |  | 3 |  |
| (TTT LLL are opcode to processor extension) |  |  |  |  |

Shaded areas indicate instructions not available in 8086, 8088 microsystems.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields: if mod $=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field if mod $=00$ then DISP $=0^{*}$, disp-low and disphigh 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)+D I S P$
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)+D I S P$
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then EA $=(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then EA $=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=(\mathrm{BP})+\mathrm{DISP} *$
if $\mathrm{r} / \mathrm{m}=111$ then $\mathrm{EA}=(B X)+$ DISP
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

## Segment Override Prefix

$$
\begin{array}{|lllllll|}
\hline 0 & 0 & 1 & \text { reg } & 1 & 1 & 0 \\
\hline
\end{array}
$$

reg is assigned according to the following:

| reg | Segment <br> Register |
| :---: | :---: |
| 00 | ES |
| 01 | CS |
| 10 | SS |
| 11 | DS |

REG is assigned according to the following table:

| 16-Bit $(w=1)$ | $8-$ Bit $(w=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.

## REVISION HISTORY

The sections significantly revised since version -004 are:

| Pin Description Table | Added note to TEST/BUSY pin requiring proper RESET at power-up to <br> configure pin as input. <br> Renamed pin 44 to INT1/ $\overline{\text { SELECT and pin } 41 \text { to INT3/INTA1/IRQ to better }}$ <br> describe their functions in Slave Mode. |
| :--- | :--- |
| Initialization and Processor Reset |  |
| Added reminder to drive $\overline{\text { RES }}$ pin LOW during power-up. |  |
| Read and Write Cycle Waveforms Clarified applicability of TCLCSv to latched A1 and A2 in footnotes. |  |
| Slave Mode Operation | The three low order bits associated with vector generation and performing <br> EOI are not alterable; however, the priority levels are programmable. This <br> information is a clarification only. |

## The sections significantly revised since version -003 are:

Front Page Deleted references to burn-in devices.
Local Bus Controller and Reset Clarified effects of excessive loading on pins with internal pullup devices. Equivalent resistance no longer shown.
D.C. Characteristics Renamed $\mathrm{V}_{\mathrm{CLI}}$ to $\mathrm{V}_{\mathrm{IL} 1}$. Renamed $\mathrm{V}_{\mathrm{CHI}}$ to $\mathrm{V}_{\mathrm{IH} 3}$. Changed $\mathrm{V}_{\mathrm{OH}}$ (min.) from $0.8 \mathrm{~V}_{\mathrm{CC}}$ to $\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$. Changed ICC (max.) from 180 mA to 150 mA at $16 \mathrm{MHz}, 150 \mathrm{~mA}$ to 120 mA at 12.5 mA , and 100 mA to 120 mA at 10 MHz . Changed $\mathrm{V}_{\mathrm{CLO}}$ (max.) from 0.5 V to 0.45 V . Changed $\mathrm{V}_{\mathrm{CHO}}$ (min.) from $0.8 \mathrm{~V}_{\mathrm{CC}}$ to $\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$. Clarified effect of excessive loading on pins with internal pullup devices.
Power Supply Current
A.C. Characteristics

[^3]
## The sections significantly revised since version -002 are:

Block Diagram
Pin Description Table Interrupt Vector Table ESC Opcode Exception Description
Oscillator Configurations
RESET Logic
Local Bus Arbitration
Local Bus Controller and Reset
DMA Controller
Timers
DRAM Refresh Addresses
D.C. Characteristics

Power Supply Current
A.C. Characteristics

Redrawn to illustrate numerics coprocessor interface.
Various descriptions rewritten for clarity.
Redrawn for clarity. Interrupt Type 16 listed.
Note added concerning ESC trap.
Deleted drive of X2 with inverted X1.
Deleted paragraph concerning setup times for synchronization of multiple processors.
Added description of HLDA when a refresh cycle is pending.
Added description of pullup devices for appropriate pins.
Added reminder to initialize transfer count registers and pointer registers.
Added reminder to intialize count registers.
Refresh address counter described in figure.
$\mathrm{V}_{\mathrm{IH} 2}$ indicated for SRDY, ARDY. ICC (max.) now indicated for all devices.
Typical ICC indicated.
Input $V_{I H}$ test condition at X1 added. TCLDOX, TCVCTV, TCVCTX, TCLHAV, and
$T_{C L L V}$ minimums reduced from 5 ns to 3 ns . $\mathrm{T}_{\mathrm{CLCH}}$ (min.) and $\mathrm{T}_{\mathrm{CHCL}}$ (min.) relaxed by 2 ns . Added reminder that $\mathrm{T}_{\text {SRYCL }}$ and TCLSRY must be met.
Explanation of the A.C. Symbols New Section.
Major Cycle Timing Waveforms TDXDL indicated in Read Cycle. TCLRO indicated.
Rise/Fall and Capacitive Derating Curves
Instruction Set Summary

New Figures added.
ESC instruction clock count deleted.

## The sections significantly revised since version -001 are:

Pin Description Table
Oscillator Configurations
DMA Transfer Rate Table
DMA Control Bit Descriptions

Interrupt Controller, etc. Interrupt Request Register
DRAM Refresh Addresses
A.C. Characteristics

Noted $\overline{\text { RES }}$ to be low more than 4 clocks.
Added reminder not to drive X2.
Corrected to reflect 16 MHz capability.
Moved and clarified note concerning TC condition for ST/STOP clearing during unsynchronized transfers.
Renamed iRMX Mode to Slave Mode.
Noted that D0 and D1 are read/write, others read-only.
Added figure to explain refresh address bits.
Many timings changed (all listed in ns): TCLDX (min.) from 8 to 5; TSRYCL (min.) from 20 to 15; $T_{H V C L}$ (min.) from 20 to $15 ; T_{I N V C H}(m i n$.$) from 25$ to 15; $T_{\text {INVCL }}$ (min.) from 20 to 15; $\mathrm{T}_{\text {CLAV }}$ at 12.5 MHz from 4-33 to 5-36; TCLAV at 16 MHz from 4-30 to $5-33$; TCLAX (min.) to 0 ; TCLDV (min.) at 10 MHz from 10 to 5; TCLDV (min.) at 12.5 MHz from $10-33$ to $5-36$; TCLDV (min.) at 16 MHz from $10-30$ to $5-33$; $\mathrm{T}_{\text {CLDOX ( }} \mathbf{m i n}$.) from 10 at 10 MHz and 8 at 12.5 MHz to 5 at both frequencies; TCVCTV (max.) and TCHCTV (max.) at 16 MHz from 25 to 31; TCHCTV (min.) and TCVDEX (min.) both from 10 at 10 MHz and 8 at 12.5 MHz to 5 at both frequencies; TCVCTX (max.) at 16 MHz from 25 to 33 ; TCLRL at 10 MHz from $10-56$ to $5-44$; TCLRL at 12.5 MHz from 8-47 to 5-35; TCLRL (max.) at 16 MHz from 25 to 31 ; $\mathrm{T}_{\mathrm{CLRH}}$ (min.) at 10 MHz from 10 to 5 and at 12.5 MHz from 8 to 5 ; $\mathrm{T}_{\mathrm{CHSV}}$ (min.) at 10 MHz from 10 to 5 and at 12.5 MHz from 8 to 5 ; $\mathrm{T}_{\mathrm{CHSV}}$ (max.) at 16 MHz from 25 to $31 ; \mathrm{T}_{\text {CLSH }}$ (min.) at 10 MHz from 10 to 5 and at 12.5 MHz from 8 to 5 ; $\mathrm{T}_{\mathrm{CHQSV}}$ (max.) at 12.5 MHz from 23 to 28 and at 16 MHz from 23 to 25 ; $\mathrm{T}_{\mathrm{CHDX}}$ (min.) at 10 MHz from 10 to 5 and at 12.5 MHz from 8 to 5 ; $\mathrm{T}_{\text {AVCH (min.) to } 0 ; ~ T C L L V ~}^{\text {(m }}$ (max.) at 10 MHz from 60 to 45 and at 12.5 MHz from 55 to 40 and at 16 MHz from 40 to 35 ; $T_{D X D L}(\min$.$) to 0 ; T_{\text {CXCSX }}$ (min.) from 35 at 10 MHz and 29 at 12.5 MHz and 25 at 16 MHz to $\mathrm{T}_{\mathrm{CLCH}}-10$ at all frequencies; $\mathrm{T}_{\mathrm{CHCSX}}$ (min.) at 12.5 MHz and 16 MHz from $4-23$ to $5-28$ and 5-23 respectively.
Clarified effect of bus width.

## SPECIFICATION LEVEL MARKINGS

Current 80C186 devices bear backside lot code information consisting of seven digits followed by letters. The second, third, and fourth digits comprise a manufacturing date code. This preliminary data sheet applies only to 80 C 186 devices with a date code corresponding to week 25 of 1989 (backside markings x925xxx XXX) or later.

## 80C186XL20, 16, 12, 10 16-BIT HIGH INTEGRATION EMBEDDED PROCESSOR

- Low Power, Full Static Version of 80C186
- Operation Modes:
- Enhanced Mode
- DRAM Refresh Control Unit
- Power-Save Mode
-Direct Interface to 80C187
- Compatible Mode
— NMOS 80186 Pin-for-Pin
Replacement for Non-Numerics Applications
- Integrated Feature Set
- Static, Modular CPU
- Clock Generator
- 2 Independent DMA Channels
- Programmable Interrupt Controller
- 3 Programmable 16-Bit Timers
- Dynamic RAM Refresh Control Unit
- Programmable Memory and

Peripheral Chip Select Logic

- Programmable Wait State Generator
- Local Bus Controller
- Power-Save Mode
- System-Level Testing Support (High

Impedance Test Mode)
Completely Object Code Compatible with Existing 8086/8088 Software and Has 10 Additional Instructions over 8086/8088

- : Speed Versions Available
- 20 MHz (80C186XL20)
- 16 MHz (80C186XL16)
- 12.5 MHz (80C186XL12)
- 10 MHz (80C186XL)
- Direct Addressing Capability to 1 MByte Memory and 64 Kbyte I/O
- Complete System Development Support
- All 8086 and 80C186 Software Development Tools Can Be Used for 80C186XL System Development - ASM 86 Assembler, PL/M-86, Pascal-86, Fortran-86, iC-86 and System Utilities - In-Circuit-Emulator (ICETM-186)
- Available in 68-Pin:
— Plastic Leaded Chip Carrier (PLCC)
- Ceramic Pin Grid Array (PGA)
- Ceramic Leadless Chip Carrier (JEDEC A Package)
- Available in 80-Pin Quad Flat Pack (EIAJ)
- Available in EXPRESS Extended Temperature Range
$\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

The Intel 80C186XL is a Modular Core re-implementation of the 80C186 Microprocessor. It offers higher speed and lower power consumption than the standard 80 C 186 but maintains $100 \%$ clock-for-clock functional compatibility. Packaging and pinout are also identical.

80C186XL20, 16, 12, 1016-BIT HIGH INTEGRATION EMBEDDED PROCESSOR
CONTENTS
INTRODUCTION ..... 24-138
80C186XL BASE ARCHITECTURE ..... 24-138
80C186XL Clock Generator ..... 24-138
Bus Interface Unit ..... 24-139
80C186XL PERIPHERAL ARCHITECTURE ..... 24-139
Chip-Select/Ready Generation Logic ..... 24-139
DMA Unit ..... 24-140
Timer/Counter Unit ..... 24-140
Interrupt Control Unit ..... 24-140
Enhanced Mode Operation ..... 24-140
Queue-Status Mode ..... 24-140
DRAM Refresh Control Unit ..... 24-141
Power-Save Control ..... 24-141
Interface for 80C187 Math Coprocessor ..... 24-141
ONCETM Test Mode ..... 24-141
ABSOLUTE MAXIMUM RATINGS ..... 24-142
DC CHARACTERISTICS ..... 24-142
POWER SUPPLY CURRENT ..... 24-143
page CONTENTS PAGE
AC CHARACTERISTICS ..... 24-144
Major Cycle Timings (Read Cycle) ..... 24-144
Major Cycle Timings (Write Cycle) ..... 24-146
Major Cycle Timings (Interrupt Acknowledge Cycle) ..... 24-148
Software Halt Cycle Timings ..... 24-150
Clock Timings ..... 24-151
Ready, Peripheral and Queue Status Timings ..... 24-153
Reset and Hold/HLDA Timings ..... 24-155
AC TIMING WAVEFORMS ..... 24-157
EXPLANATION OF THE AC SYMBOLS ..... 24-164
DERATING CURVES ..... 24-165
80C186XL EXPRESS ..... 24-166
80C186XL EXECUTION TIMINGS ..... 24-166
INSTRUCTION SET SUMMARY ..... 24-167
FOOTNOTES ..... 24-172
REVISION HISTORY ..... 24-173
ERRATA ..... 24-173
PRODUCT IDENTIFICATION ..... 24-173



Ceramic Pin Grid Array

Pins Facing Up

| (35) (37) (39) (41) (4) (45) (47) (49) (51) |  |
| :---: | :---: |
| (34) (36) (38) (40) (12) (4) (46) (48) (50) (53) (52) |  |
| (32) (3) ${ }^{3}$ (55) (44) | (5i) (55) |
| (30) (31) $\square$ (57) (56) | (56) |
| (28) (29) (59) (58) |  |
| (26) (27) (61) (6) | (60) (6) (6) $_{\text {(6) }}$ |
| (24) (25) ${ }^{(36)}$ (22) | (62) 6 6) (See Note) |
| (22) (23) (6) (64) | (69) (65) - |
| (20) (21) |  |
| (18) (1) (16) (14) (12) (10) (8) (6) (4) (2) (8) |  |
| (17) (15) (13) (11) (9) (7) (5) (3) (1) | (is) (iv) |

272032-3

NOTE:
XXXXXXXXA indicates the Intel FPO number.
Figure 2. 80C186XL Pinout Diagrams


Figure 2. 80C186XL Pinout Diagrams (Continued)

Table 1. 80C186XL Pin Description

| Symbol | $\begin{array}{\|c\|} \hline \text { LCC } \\ \text { PGA } \\ \text { PLCC } \\ \text { Pin No. } \\ \hline \end{array}$ | QFP Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ | $\begin{gathered} 9 \\ 43 \end{gathered}$ | $\begin{aligned} & 33,34, \\ & 72,73 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | System Power: +5 volt power supply. |
| $\mathrm{V}_{\mathrm{SS}}$ | $\begin{aligned} & 26 \\ & 60 \end{aligned}$ | $\begin{array}{\|c} 12,13, \\ 53 \end{array}$ | $1$ | System Ground. |
| RESET | 57 | 18 | 0 | RESET Output indicates that the 80C186XL CPU is being reset, and can be used as a system reset. It is active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods corresponding to the length of the RES signal. Reset goes inactive 2 clockout periods after RES goes inactive. When tied to the TEST/BUSY pin, RESET forces the 80C186XL into enhanced mode. RESET is not floated during bus hold. |
| $\begin{aligned} & \mathrm{X} 1 \\ & \mathrm{X} 2 \end{aligned}$ | $59$ | $\begin{aligned} & 16 \\ & 17 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Crystal Inputs X1 and X2 provide external connections for a fundamental mode or third overtone parallel resonant crystal for the internal oscillator. X1 can connect to an external clock instead of a crystal. In this case, minimize the capacitance on X2. The input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). |
| CLKOUT | 56 | 19 | 0 | Clock Output provides the system with a $50 \%$ duty cycle waveform. All device pin timings are specified relative to CLKOUT. CLKOUT is active during reset and bus hold. |
| $\overline{\text { RES }}$ | 24 | 55 | 1 | An active $\overline{\text { RES }}$ causes the 80C186XL to immediately terminate its present activity, clear the internal logic, and enter a dormant state. This signal may be asynchronous to the 80C186XL clock. The 80C186XL begins fetching instructions approximately $61 / 2$ clock cycles after RES is returned HIGH. For proper initialization, $V_{C C}$ must be within specifications and the clock signal must be stable for more than 4 clocks with $\overline{\text { RES }}$ held LOW. $\overline{\text { RES }}$ is internally synchronized. This input is provided with a Schmitt-trigger to facilitate power-on $\overline{\text { RES }}$ generation via an RC network. |
| TEST/BUSY | 47 | 29 | 1/O | The TEST pin is sampled during and after reset to determine whether the 80C186XL is to enter Compatible or Enhanced Mode. Enhanced Mode requires TEST to be HIGH on the rising edge of $\overline{\text { RES }}$ and LOW four CLKOUT cycles later. Any other combination will place the 80C186XL in Compatible Mode. During power-up, active $\overline{\operatorname{RES}}$ is required to configure $\overline{T E S T} / B U S Y$ as an input. A weak internal pullup ensures a HIGH state when the input is not externally driven. <br> TEST- In Compatible Mode this pin is configured to operate as TEST. This pin is examined by the WAIT instruction. If the TEST input is HIGH when WAIT execution begins, instruction execution will suspend. TEST will be resampled every five clocks until it goes LOW, at which time execution will resume. If interrupts are enabled while the 80C186XL is waiting for TEST, interrupts will be serviced. <br> BUSY-In Enhanced Mode, this pin is configured to operate as BUSY. The BUSY input is used to notify the 80 C 186 XL of Math Coprocessor activity. Floating point instructions executing in the 80C186XL sample the BUSY pin to determine when the Math Coprocessor is ready to accept a new command. BUSY is active HIGH. |

Table 1. 80C186XL Pin Description (Continued)

| Symbol | LCC PGA PLCC Pin No. | QFP <br> Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| TMR IN 0 TMR $\operatorname{IN} 1$ | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | $\begin{aligned} & 59 \\ & 58 \end{aligned}$ | $1$ | Timer Inputs are used either as clock or control signals, depending upon the programmed timer mode. These inputs are active HIGH (or LOW-to-HIGH transitions are counted) and internally synchronized. Timer Inputs must be tied HIGH when not being used as clock or retrigger inputs. |
| TMR OUT 0 TMR OUT 1 | $\begin{aligned} & 22 \\ & 23 \end{aligned}$ | $\begin{aligned} & 57 \\ & 56 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Timer outputs are used to provide single pulse or continous waveform generation, depending upon the timer mode selected. These outputs are not floated during a bus hold. |
| DRQ0 DRQ1 | $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | $\begin{aligned} & 61 \\ & 60 \end{aligned}$ | $1$ | DMA Request is asserted HIGH by an external device when it is ready for DMA Channel 0 or 1 to perform a transfer. These signals are level-triggered and internally synchronized. |
| NMI | 46 | 30 | 1 | The Non-Maskable Interrupt input causes a Type 2 interrupt. An NMI transition from LOW to HIGH is latched and synchronized internally, and initiates the interrupt at the next instruction boundary. NMI must be asserted for at least one CLKOUT period. The Non-Maskable Interrupt cannot be avoided by programming. |
| INTO <br> INT1/SELECT <br> INT2/INTAO <br> INT3/INTA1/IRQ | $\begin{aligned} & 45 \\ & 44 \\ & 42 \\ & 41 \end{aligned}$ | $\begin{aligned} & 31 \\ & 32 \\ & 35 \\ & 36 \end{aligned}$ | $\begin{gathered} 1 \\ 1 \\ 1 / 0 \\ 1 / 0 \end{gathered}$ | Maskable Interrupt Requests can be requested by activating one of these pins. When configured as inputs, these pins are active HIGH. Interrupt Requests are synchronized internally. INT2 and INT3 may be configured to provide active-LOW interrupt-acknowledge output signals. All interrupt inputs may be configured to be either edge- or level-triggered. To ensure recognition, all interrupt requests must remain active until the interrupt is acknowledged. When Slave Mode is selected, the function of these pins changes (see Interrupt Controller section of this data sheet). |
| A19/S6 <br> A18/S5 <br> A17/S4 <br> A16/S3 | $\begin{aligned} & 65 \\ & 66 \\ & 67 \\ & 68 \end{aligned}$ | $\begin{aligned} & 6 \\ & 5 \\ & 4 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Address Bus Outputs (16-19) and Bus Cycle Status (3-6) indicate the four most significant address bits during $\mathrm{T}_{1}$. These signals are active HIGH. <br> During $T_{2}, T_{3}, T_{W}$ and $T_{4}$, the S 6 pin is LOW to indicate a CPUinitiated bus cycle or HIGH to indicate a DMA-initiated or refresh bus cycle. During the same T-states, S3, S4 and S5 are always LOW. These outputs are floated during bus hold or reset. |
| AD15 | 1 | 1 | $1 / 0$ | Address/Data Bus (0-15) signals constitute the time multiplexed |
| AD14 | 3 | 79 | $1 / 0$ | memory or I/O address ( $T_{1}$ ) and data ( $T_{2}, T_{3}, T_{W}$ and $T_{4}$ ) bus. The |
| AD13 | 5 | 77 | $1 / 0$ | bus is active HIGH. $A_{0}$ is analogous to $\overline{\mathrm{BHE}}$ for the lower byte of the |
| AD12 | 7 | 75 | $1 / 0$ | data bus, pins $D_{7}$ through $D_{0}$. It is LOW during $T_{1}$ when a byte is to |
| AD11 | 10 | 71 | $1 / 0$ | be transferred onto the lower portion of the bus in memory or 1/O |
| AD10 | 12 | 69 | $1 / 0$ | operations. These pins are floated during a bus hold or reset. |
| AD9 | 14 | 67 | 1/0 |  |
| AD8 | 16 | 65 | 1/0 |  |
| AD7 | 2 | 80 | 1/0 |  |
| AD6 | 4 | 78 | $1 / 0$ |  |
| AD5 | 6 | 76 | 1/0 |  |
| AD4 | 8 | 74 | 1/0 |  |
| AD3 | 11 | 70 | 1/0 |  |
| AD2 | 13 | 68 | 1/0 |  |
| AD1 | 15 | 66 | $1 / 0$ |  |
| ADO | 17 | 64 | 1/0 |  |

Table 1. 80C186XL Pin Description (Continued)

| Symbol | LCC <br> PGA <br> PLCC <br> Pin No. | $\begin{array}{\|c\|} \hline \text { QFP } \\ \text { Pin No. } \end{array}$ | Type | Name and Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { BHE }}$ | 64 | 7 | 0 | The $\overline{B H E}$ (Bus High Enable) signal is analogous to $A O$ in that it is used to enable data on to the most significant half of the data bus, pins D15-D8. $\overline{B H E}$ will be LOW during $T_{1}$ when the upper byte is transferred and will remain LOW through $T_{3}$ AND $T_{W}$. $\overline{\text { BHE }}$ does not need to be latched. $\overline{\text { BHE }}$ will float during HOLD or RESET. <br> In Enhanced Mode, $\overline{B H E}$ will also be used to signify DRAM refresh cycles. A refresh cycle is indicated by both $\overline{B H E}$ and AO being HIGH. |  |  |
|  |  |  |  | $\overline{\text { BHE }}$ and AO Encodings |  |  |
|  |  |  |  | $\overline{\text { BHE }}$ <br> Value | $\begin{array}{c\|} \hline \text { AO } \\ \text { Value } \end{array}$ | Function |
|  |  |  |  | 0 0 1 1 | 0 1 0 1 | Word Transfer <br> Byte Transfer on upper half of data bus (D15-D8) Byte Transfer on lower half of data bus ( $\mathrm{D}_{7}-\mathrm{D}_{0}$ ) Refresh |
| ALE/QSO | 61 | 10 | 0 | Address Latch Enable/Queue Status 0 is provided by the 80C186XL to latch the address. ALE is active HIGH, with addresses guaranteed valid on the trailing edge. |  |  |
| $\overline{\text { WR/ } / \mathrm{SS} 1}$ | 63 | 8 | 0 | Write Strobe/Queue Status 1 indicates that the data on the bus is to be written into a memory or an I/O device. It is active LOW, and floats during bus hold or reset. When the 80C186XL is in Queue Status Mode, the ALE/ QSO and $\overline{\text { WR} / Q S 1 ~ p i n s ~ p r o v i d e ~ i n f o r m a t i o n ~ a b o u t ~ p r o c e s s o r / i n s t r u c t i o n ~}$ queue interaction. |  |  |
|  |  |  |  | QS1 | aso | Queue Operation |
|  |  |  |  | 0 0 1 1 | 0 1 1 0 | No queue operation First opcode byte fetched from the queue Subsequent byte fetched from the queue Empty the queue |
| $\overline{\text { RD/ }} \overline{\text { QSMD }}$ | 62 | 9 | O/I | Read S <br> perform <br> before <br> HIGH d <br> whethe <br> informa <br> GND. | trobe is <br> ing a me <br> the A/D <br> uring RE <br> $r$ the 80 C <br> tion. To <br> $\overline{\mathrm{RD}}$ will flo | an active LOW signal which indicates that the 80C186XL is emory or I/O read cycle. It is guaranteed not to go LOW bus is floated. An internal pull-up ensures that $\overline{R D} / \overline{Q_{S M D}}$ is ESET. Following RESET the pin is sampled to determine C186XL is to provide ALE, $\overline{R D}$, and $\overline{W R}$, or queue status enable Queue Status Mode, $\overline{R D}$ must be connected to oat during bus HOLD. |
| ARDY | 55 | 20 | 1 | Asynch <br> space o <br> rising e <br> edge of <br> ARDY <br> unused | ronous P <br> I/O de <br> dge that <br> ARDY <br> HIGH will <br> it should | Ready informs the 80C186XL that the addressed memory vice will complete a data transfer. The ARDY pin accepts a is asynchronous to CLKOUT and is active HIGH. The falling must be synchronized to the 80C186XL clock. Connecting ill always assert the ready condition to the CPU. If this line is Ild be tied LOW to yield control to the SRDY pin. |
| SRDY | 49 | 27 | 1 | Synch space active- relaxed the one signal. CPU. If ARDY | onous R HIGH inp system -half clo Connect this line pin. | Ready informs the 80C186XL that the addressed memory evice will complete a data transfer. The SRDY pin accepts an put synchronized to CLKOUT. The use of SRDY allows a timing over ARDY. This is accomplished by elimination of ck cycle required to internally synchonize the ARDY input ing SRDY high will always assert the ready condition to the is unused, it should be tied LOW to yield control to the |

Table 1. 80C186XL Pin Description (Continued)


Table 1. 80C186XL Pin Description (Continued)

| Symbol | $\begin{array}{\|c\|} \hline \text { CLCC } \\ \text { PGA } \\ \text { PLCC } \\ \text { Pin No. } \end{array}$ | $\begin{gathered} \text { QFP } \\ \text { Pin No. } \end{gathered}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { LCS }}$ <br> (Continued) |  |  |  | $\overline{U C S}$ and $\overline{\text { LCS }}$ are sampled upon the rising edge of $\overline{\text { RES. }}$. If both pins are held low, the 80C186XL will enter ONCE Mode. In ONCE Mode all pins assume a high impedance state and remain so until a subsequent RESET. LCS has a weak internal pullup that is active only during RESET to ensure that the 80C186XL does not enter ONCE mode inadvertently. |
| $\overline{\text { MCSO }} / \mathrm{PEREQ}$ <br> $\overline{\mathrm{MCS1}} / \overline{\mathrm{ERROR}}$ <br> $\overline{\mathrm{MCS2}}$ <br> $\overline{\mathrm{MCS3}} / \overline{\mathrm{NPS}}$ | $\begin{aligned} & 38 \\ & 37 \\ & 36 \\ & 35 \end{aligned}$ | $\begin{aligned} & 39 \\ & 40 \\ & 41 \\ & 42 \end{aligned}$ | $\begin{gathered} \hline 0 / 1 \\ 0 / 1 \\ 0 \\ 0 \end{gathered}$ | Mid-Range Memory Chip Select signals are active LOW when a memory reference is made to the defined mid-range portion of memory ( $8 \mathrm{~K}-512 \mathrm{~K}$ ). These lines do not float during bus HOLD. The address ranges activating $\overline{\mathrm{MCSO}} \mathbf{- 3}$ are software programmable. <br> In Enhanced Mode, MCSO becomes a PEREQ input (Processor Extension Request). When connected to the Math Coprocessor, this input is used to signal the 80C186XL when to make numeric data transfers to and from the coprocessor. MCS3 becomes $\overline{\text { NPS }}$ (Numeric Processor Select) which may only be activated by communication to the 80C187. MCS1 becomes ERROR in Enhanced Mode and is used to signal numerics coprocessor errors. $\overline{M C S 0} / P E R E Q$ and $\overline{M C S 1} / \overline{E R R O R}$ have weak internal pullups which are active during reset. |
| $\overline{\text { PCS0 }}$ <br> $\overline{\text { PCS1 }}$ <br> $\overline{\text { PCS2 }}$ <br> $\overline{\text { PCS } 3}$ <br> PCS4 | $\begin{aligned} & 25 \\ & 27 \\ & 28 \\ & 29 \\ & 30 \end{aligned}$ | $\begin{aligned} & 54 \\ & 52 \\ & 51 \\ & 50 \\ & 49 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Peripheral Chip Select signals 0-4 are active LOW when a reference is made to the defined peripheral area ( 64 K byte I/O or 1 MByte memory space). These lines do not float during bus HOLD. The address ranges activating $\overline{\mathrm{PCSO}-4}$ are software programmable. |
| $\overline{\mathrm{PCS5}} / \mathrm{A} 1$ | 31 | 48 | 0 | Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth peripheral chip select, or to provide an internally latched A1 signal. The address range activating $\overline{\mathrm{PCS5}}$ is softwareprogrammable. $\overline{\text { PCS5 }} / \mathrm{A} 1$ does not float during bus HOLD. When programmed to provide latched A1, this pin will retain the previously latched value during HOLD. |
| $\overline{\text { PCS6/A2 }}$ | 32 | 47 | 0 | Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh peripheral chip select, or to provide an internally latched A2 signal. The address range activating $\overline{\mathrm{CCS}} 6$ is softwareprogrammable. $\overline{\text { PCS6 }} /$ A2 does not float during bus HOLD. When programmed to provide latched A2, this pin will retain the previously latched value during HOLD. |
| DT/ $/ \bar{R}$ | 40 | 37 | 0 | Data Transmit/Receive controls the direction of data flow through an external data bus transceiver. When LOW, data is transferred to the 80C186XL. When HIGH the 80C186XL places write data on the data bus. $\mathrm{DT} / \overline{\mathrm{R}}$ floats during a bus hold or reset. |
| $\overline{\text { DEN }}$ | 39 | 38 | 0 | Data Enable is provided as a data bus transceiver output enable. $\overline{D E N}$ is active LOW during each memory and I/O access (including 80 C 187 access). $\overline{D E N}$ is HIGH whenever DT/ $\overline{\mathrm{R}}$ changes state. During RESET, $\overline{\text { DEN }}$ is driven HIGH for one clock, then floated. $\overline{\text { DEN }}$ also floats during HOLD. |
| N.C. | - | $\begin{array}{\|c} \hline 2,11,14 \\ 15,24,43, \\ 44,62,63 \end{array}$ | - | Not connected. To maintain compatibility with future products, do not connect to these pins. |




Note 1:

| XTAL Frequency | L1 Value |
| :---: | :---: |
| 20 MHz | $12.0 \mu \mathrm{H} \pm 20 \%$ |
| 25 MHz | $8.2 \mu \mathrm{H} \pm 20 \%$ |
| 32 MHz | $4.7 \mu \mathrm{H} \pm 20 \%$ |
| 40 MHz | $3.0 \mu \mathrm{H} \pm 20 \%$ |

LC network is only required when using a third overtone crystal.

Figure 3. 80C186XL Oscillator Configurations (see text)

## INTRODUCTION

The following Functional Description describes the base architecture of the 80C186XL. The 80C186XL is a very high integration 16-bit microprocessor. It combines 15-20 of the most common microprocessor system components onto one chip. The 80C186XL is object code compatible with the 8086/8088 microprocessors and adds 10 new instruction types to the 8086/8088 instruction set.

The 80C186XL has two major modes of operation, Compatible and Enhanced. In Compatible Mode the 80C186XL is completely compatible with NMOS 80186, with the exception of 8087 support. The Enhanced mode adds three new features to the system design. These are Power-Save control, Dynamic RAM refresh, and an asynchronous Numerics Coprocessor interface.

## 80C186XL BASE ARCHITECTURE

## 80C186XL Clock Generator

The 80C186XL provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, synchronous and asynchronous ready inputs, and reset circuitry.

The 80C186XL oscillator circuit is designed to be used either with a parallel resonant fundamental or
third-overtone mode crystal, depending upon the frequency range of the application. This is used as the time base for the 80C186XL.

The output of the oscillator is not directly available outside the 80 C 186 XL . The recommended crystal configuration is shown in Figure 3b. When used in third-overtone mode, the tank circuit is recommended for stable operation. Alternately, the oscillator may be driven from an external source as shown in Figure 3 a .

The crystal or clock frequency chosen must be twice the required processor operating frequency due to the internal divide by two counter. This counter is used to drive all internal phase clocks and the external CLKOUT signal. CLKOUT is a $50 \%$ duty cycle processor clock and can be used to drive other system components. All AC Timings are referenced to CLKOUT.

Intel recommends the following values for crystal selection parameters.

| Temperature Range: | Application Specific |
| :--- | ---: |
| ESR (Equivalent Series Resistance): | $60 \Omega$ max |
| C $_{0}$ (Shunt Capacitance of Crystal): | 7.0 pF max |
| $\mathrm{C}_{1}$ (Load Capacitance): | $20 \mathrm{pF} \pm 5 \mathrm{pF}$ |
| Drive Level: | 2 mW max |

## Bus Interface Unit

The 80C186XL provides a local bus controller to generate the local bus control signals. In addition, it employs a HOLD/HLDA protocol for relinquishing the local bus to other bus masters. It also provides outputs that can be used to enable external buffers and to direct the flow of data on and off the local bus.

The bus controller is responsible for generating 20 bits of address, read and write strobes, bus cycle status information and data (for write operations) information. It is also responsible for reading data from the local bus during a read operation. Synchronous and asynchronous ready input pins are provided to extend a bus cycle beyond the minimum four states (clocks).

The 80C186XL bus controller also generates two control signals ( $\overline{\mathrm{DEN}}$ and DT/ $\overline{\mathrm{R}}$ ) when interfacing to external transceiver chips. This capability allows the addition of transceivers for simple buffering of the multiplexed address/data bus.

During RESET the local bus controller will perform the following action:

- Drive $\overline{\mathrm{DEN}}, \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ HIGH for one clock cycle, then float them.
- Drive $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ to the inactive state (all HIGH) and then float.
- Drive $\overline{\text { LOCK }}$ HIGH and then float.
- Float ADO-15, A16-19, $\overline{B H E}, \mathrm{DT} / \overline{\mathrm{R}}$.
- Drive ALE LOW
- Drive HLDA LOW.
$\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{\mathrm{MCSO}} / \mathrm{PEREQ}, \overline{\mathrm{MCS}} /$ ERROR and TEST/BUSY pins have internal pullup devices which are active while $\overline{\text { RES }}$ is applied. Excessive loading or grounding certain of these pins causes the 80C186XL to enter an alternative mode of operation:
- $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ low results in Queue Status Mode.
- $\overline{U C S}$ and $\overline{L C S}$ low results in ONCETM Mode.
- TEST/BUSY low (and high later) results in Enhanced Mode.


## 80C186XL PERIPHERAL ARCHITECTURE

All the 80 C 186 XL integrated peripherals are controlled by 16 -bit registers contained within an internal 256 -byte control block. The control block may be mapped into either memory or I/O space. Internal logic will recognize control block addresses and respond to bus cycles. An offset map of the 256 -byte control register block is shown in Figure 4.

## Chip-Select/Ready Generation Logic

The 80C186XL contains logic which provides programmable chip-select generation for both memories and peripherals. In addition, it can be programmed to provide READY (or WAIT state) generation. It can also provide latched address bits A1 and A2. The chip-select lines are active for all memory and I/O cycles in their programmed areas, whether they be generated by the CPU or by the integrated DMA unit.

The 80C186XL provides 6 memory chip select outputs for 3 address areas; upper memory, lower memory, and midrange memory. One each is provided for upper memory and lower memory, while four are provided for midrange memory.


Figure 4. Internal Register Map
The 80C186XL provides a chip select, called UCS, for the top of memory. The top of memory is usually used as the system memory because after reset the 80C186XL begins executing at memory location FFFFOH.

The 80C186XL provides a chip select for low memory called LCS. The bottom of memory contains the interrupt vector table, starting at location 00000 H .

The 80C186XL provides four MCS lines which are active within a user-locatable memory block. This block can be located within the 80C186XL 1 Mbyte memory address space exclusive of the areas defined by UCS and LCS. Both the base address and size of this memory block are programmable.

The 80C186XL can generate chip selects for up to seven peripheral devices. These chip selects are active for seven contiguous blocks of 128 bytes above a programmable base address. The base address may be located in either memory or I/O space.

The 80C186XL can generate a READY signal internally for each of the memory or peripheral $\overline{C S}$ lines. The number of WAIT states to be inserted for each peripheral or memory is programmable to provide $0-3$ wait states for all accesses to the area for which the chip select is active. In addition, the 80C186XL may be programmed to either ignore external READY for each chip-select range individually or to factor external READY with the integrated ready generator.

Upon RESET, the Chip-Select/Ready Logic will perform the following actions:

- All chip-select outputs will be driven HIGH.
- Upon leaving RESET, the UCS line will be programmed to provide chip selects to a 1 K block with the accompanying READY control bits set at 011 to insert 3 wait states in conjunction with external READY (i.e., UMCS resets to FFFBH).
- No other chip select or READY control registers have any predefined values after RESET. They will not become active until the CPU accesses their control registers.


## DMA Unit

The 80C186XL DMA controller provides two independent high-speed DMA channels. Data transfers can occur between memory and I/O spaces (e.g., Memory to $1 / 0$ ) or within the same space (e.g., Memory to Memory or I/O to I/O). Data can be transferred either in bytes ( 8 bits) or in words ( 16 bits) to or from even or odd addresses. Each DMA channel maintains both a 20 -bit source and destination pointer which can be optionally incremented or decremented after each data transfer (by one or two depending on byte or word transfers). Each data transfer consumes 2 bus cycles (a minimum of 8 clocks), one cycle to fetch data and the other to store data.

## Timer/Counter Unit

The 80C186XL provides three internal 16-bit programmable timers. Two of these are highly flexible and are connected to four external pins (2 per timer). They can be used to count external events, time external events, generate nonrepetitive waveforms, etc. The third timer is not connected to any external pins, and is useful for real-time coding and time delay applications. In addition, the third timer can be used as a prescaler to the other two, or as a DMA request source.

## Interrupt Control Unit

The 80C186XL can receive interrupts from a number of sources, both internal and external. The 80C186XL has 5 external and 2 internal interrupt sources (Timer/Couners and DMA). The internal interrupt controller serves to merge these requests on a priority basis, for individual service by the CPU.

## Enhanced Mode Operation

In Compatible Mode the 80C186XL operates with all the features of the NMOS 80186, with the exception of 8087 support (i.e. no math coprocessing is possible in Compatible Mode). Queue-Status information is still available for design purposes other than 8087 support.

All the Enhanced Mode features are completely masked when in Compatible Mode. A write to any of the Enhanced Mode registers will have no effect, while a read will not return any valid data.

In Enhanced Mode, the 80C186XL will operate with Power-Save, DRAM refresh, and numerics coprocessor support in addition to all the Compatible Mode features.

If connected to a math coprocessor, this mode will be invoked automatically. Without an NPX, this mode can be entered by tying the RESET output signal from the 80C186XL to the TEST/BUSY input.

## Queue-Status Mode

The queue-status mode is entered by strapping the $\overline{R D}$ pin low. $\overline{R D}$ is sampled at RESET and if LOW, the 80C186XL will reconfigure the ALE and WR pins to be QS0 and QS1 respectively. This mode is available on the 80C186XL in both Compatible and Enhanced Modes.

## DRAM Refresh Control Unit

The Refresh Control Unit (RCU) automatically generates DRAM refresh bus cycles. The RCU operates only in Enhanced Mode. After a programmable period of time, the RCU generates a memory read request to the BIU. If the address generated during a refresh bus cycle is within the range of a properly programmed chip select, that chip select will be activated when the BIU executes the refresh bus cycle.

## Power-Save Control

The 80C186XL, when in Enhanced Mode, can enter a power saving state by internally dividing the processor clock frequency by a programmable factor. This divided frequency is also available at the CLKOUT pin.

All internal logic, including the Refresh Control Unit and the timers, have their clocks slowed down by the division factor. To maintain a real time count or a fixed DRAM refresh rate, these peripherals must be re-programmed when entering and leaving the pow-er-save mode.

## Interface for 80C187 Math Coprocessor

In Enhanced Mode, three of the mid-range memory chip selects are redefined according to Table 2 for
use with the 80C187. The fourth chip select, MCS2 functions as in compatible mode, and may be programmed for activity with ready logic and wait states accordingly. As in Compatible Mode, MCS2 will function for one-fourth a programmed block size.

Table 2. $\overline{\text { MCS }}$ Assignments

| Compatible Mode |  | Enhanced Mode |
| :---: | :---: | :---: |
| MCSO | PEREQ | Processor Extension Request |
| MCS1 | ERROR | NPX Error |
| $\overline{\mathrm{MCS2}}$ | $\overline{\mathrm{MCS}} 2$ | Mid-Range Chip Select |
| $\overline{\text { MCS }}$ | $\overline{\mathrm{NPS}}$ | Numeric Processor Select |

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80C186XL has a test mode available which allows all pins to be placed in a high-impedance state. ONCE stands for "ON Circuit Emulation". When placed in this mode, the 80C186XL will put all pins in the high-impedance state until RESET.

The ONCE mode is selected by tying the UCS and the LCS LOW during RESET. These pins are sampled on the low-to-high transition of the RES pin. The $\overline{U C S}$ and the $\overline{L C S}$ pins have weak internal pullup resistors similar to the $\overline{\operatorname{RD}}$ and TEST/BUSY pins to guarantee ONCE Mode is not entered inadvertently during normal operation. $\overline{\mathrm{LCS}}$ and $\overline{\mathrm{UCS}}$ must be held low at least one clock after RES goes high to guarantee entrance into ONCE Mode.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias $\ldots . .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground . . . . . . . . . . . . 1.0 V to +7.0 V
/Package Power Dissipation ......................1W
Not to exceed the maximum allowable die temperature based on thermal resistance of the package.

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

NOTICE: The specifications are subject to change without notice.

DC CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (Except X1) | -0.5 | $0.2 \mathrm{~V}_{C C}-0.3$ | V |  |
| $\mathrm{V}_{\mathrm{IL} 1}$ | Clock Input Low Voltage (X1) | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage (All except X1 and $\overline{\text { RES }}$ ) | $0.2 \mathrm{~V}_{\mathrm{CC}}+0.9$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{1+1}$ | Input High Voltage ( $\overline{\mathrm{RES}}$ ) | 3.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{IH} 2}$ | Clock Input High Voltage (X1) | 3.9 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\begin{aligned} & \mathrm{lOL}=2.5 \mathrm{~mA}(\mathrm{SO}, 1,2) \\ & \mathrm{loL}=2.0 \mathrm{~mA} \text { (others) } \end{aligned}$ |
| VOH | Output High Voltage | 2.4 | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{IOH}=-2.4 \mathrm{~mA} @ 2.4 \mathrm{~V}(4)$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}-0.5$ | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A} @ \mathrm{~V}_{\mathrm{CC}}-0.5(4)$ |
| ICC | Power Supply Current |  | 100 | mA | @ $20 \mathrm{MHz}, 0^{\circ} \mathrm{C}$ $V_{C C}=5.5 \mathrm{~V}(3)$ |
|  |  |  | 80 | mA | $\begin{aligned} & @ 16 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3) \\ & \hline \end{aligned}$ |
|  |  | : | 65 | mA | $\begin{aligned} & @ 12.5 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3) \end{aligned}$ |
|  |  |  | 50 | mA | $\begin{aligned} & @ 10 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3) \end{aligned}$ |
|  |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & @ \mathrm{DC} 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ |
| LI | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & @ 0.5 \mathrm{MHz}, \\ & 0.45 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| Lo | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & @ 0.5 \mathrm{MHz}, \\ & 0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}}{ }^{(1)} \end{aligned}$ |
| $\mathrm{V}_{\text {ClO }}$ | Clock Output Low |  | 0.45 | V | $\mathrm{ICLO}=4.0 \mathrm{~mA}$ |

DC CHARACTERISTICS (Continued) $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{CHO}}$ | Clock Output High | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{I}_{\mathrm{CHO}}=-500 \mu \mathrm{~A}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $@ 1 \mathrm{MHz}^{(2)}$ |
| $\mathrm{C}_{\mathrm{IO}}$ | Output or I/O Capacitance |  | 20 | pF | $@ 1 \mathrm{MHz}^{(2)}$ |

## NOTES:

1. Pins being floated during HOLD or by invoking the ONCE Mode.
2. Characterization conditions are a) Frequency $=1 \mathrm{MHz}$; b) Unmeasured pins at GND; c) $\mathrm{V}_{\mathrm{IN}}$ at +5.0 V or 0.45 V . This parameter is not tested.
3. Current is measured with the device in RESET with X1 and X2 driven and all other non-power pins open.
4. $\overline{\operatorname{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{M C S O} / P E R E Q, \overline{M C S 1} / \overline{E R R O R}$ and $\overline{T E S T} / B U S Y$ pins have internal pullup devices. Loading some of these pins above $\mathrm{l}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ can cause the 80 C 186 XL to go into alternative modes of operation. See the section on Local Bus Controller and Reset for details.

## POWER SUPPLY CURRENT

Current is linearly proportional to clock frequency and is measured with the device in RESET with X1 and X2 driven and all other non-power pins open.

Maximum current is given by $\mathrm{I}_{\mathrm{CC}}=5 \mathrm{~mA} \times$ freq. $(M H z)+I_{Q L}$.
$l_{Q L}$ is the quiescent leakage current when the clock is static. $l_{Q L}$ is typically less than $100 \mu \mathrm{~A}$.


Figure 5. Icc vs Frequency

80C186XL

## AC CHARACTERISTICS

## MAJOR CYCLE TIMINGS (READ CYCLE)

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL |  | 80C186XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL GENERAL TIMING REQUIREMENTS (Listed More Than Once) |  |  |  |  |  |  |  |
| T DVCL | Data in Setup (A/D) | 15 |  | 15 |  | ns |  |
| TCLDX | Data in Hold (A/D) | 3 |  | 3 |  | ns |  |
| 80C186XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| T CHSV | Status Active Delay | 3 | 45 | 3 | 35 | ns |  |
| TCLSH | Status Inactive Delay | 3 | 46 | 3 | 35 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 40 | 3 | 36 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TCHLH | ALE Active Delay |  | 30 |  | 25 | ns |  |
| TLHLL | ALE Width | $\mathrm{T}_{\text {CLCL }}-15$ |  | $\mathrm{T}_{\text {CLCL }}-15$ |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 30 |  | 25 | ns |  |
| TAVLL | Address Valid to ALE Low | TCLCH - 18 |  | T $\mathrm{CLCH}^{-15}$ |  | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | TCHCL - 15 |  | $\mathrm{T}_{\mathrm{CHCL}}-15$ |  | ns | Equal Loading |
| T ${ }_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 30 | TCLAX | 25 | ns |  |
| TCLCSV | Chip-Select Active Delay | 3 | 42 | 3 | 33 | ns |  |
| TCXCsX | Chip-Select Hold from Command Inactive | $\mathrm{T}_{\mathrm{CLCH}}-10$ |  | $\mathrm{T}_{\mathrm{CLCH}}-10$ |  | ns | Equal Loading |
| TCHCSX | Chip-Select Inactive Delay | 3 | 35 | 3 | 30 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 | . | ns | Equal Loading |
| TCVCTV | Control Active Delay 1 | 3 | 44 | 3 | 37 | ns |  |
| TCVDEX | $\overline{\text { DEN }}$ Inactive Delay | 3 | 44 | 3 | 37 | ns |  |
| TCHCTV | Control Active Delay 2 | 3 | 44 | 3 | 37 | ns |  |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | ns |  |
| 80C186XL TIMING RESPONSES (Read Cycle) |  |  |  |  |  |  |  |
| TAZRL | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 3 | 44 | 3 | 37 | ns |  |
| TrLRH | $\overline{R D}$ Pulse Width | $2 T_{\text {CLCL }}-30$ |  | 2 CLCL $^{-25}$ |  | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 3 | 44 | 3 | 37 | ns |  |
| TRHLH | $\overline{\mathrm{RD}}$ Inactive to ALE High | TCLCH -14 |  | TCLCH -14 |  | ns | Equal Loading |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Address Active | TCLCL -15 |  | TCLCL -15 |  | ns | Equal Loading |

80C186XL

## AC CHARACTERISTICS

## MAJOR CYCLE TIMINGS (READ CYCLE)

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $C_{L}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL16 |  | 80C186XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL GENERAL TIMING REQUIREMENTS (Listed More Than Once) |  |  |  |  |  |  |  |
| TDVCL | Data in Setup (A/D) | 15 |  | 10 |  | ns |  |
| TCLDX | Data in Hold (A/D) | 3 |  | 3 |  | ns |  |
| 80C186XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| T CHSV | Status Active Delay | 3 | 31 | 3 | 25 | ns |  |
| TCLSH | Status Inactive Delay | 3 | 30 | 3 | 25 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| T CHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| T ${ }_{\text {CHLH }}$ | ALE Active Delay |  | 20 |  | 20 | ns |  |
| TLHLL | ALE Width | TCLCL -15 |  | $\mathrm{T}_{\text {CLCL }}-15$ |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 20 |  | 20 | ns |  |
| TAVLL | Address Valid to ALE Low | $\mathrm{T}_{\mathrm{CLCH}}-15$ |  | $\mathrm{T}_{\text {CLCH }}-10$ |  | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | $\mathrm{T}_{\mathrm{CHCL}}-15$ |  | $\mathrm{T}_{\mathrm{CHCL}}-10$ |  | ns | Equal Loading |
| T ${ }_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 20 | TCLAX | 20 | ns |  |
| TCLCSV | Chip-Select Active Delay | 3 | 30 | 3 | 25 | ns |  |
| T CxCsx | Chip-Select Hold from Command Inactive | $t_{\text {CLCH }}-10$ |  | TCLCH -10 |  | ns | Equal Loading |
| TCHCSX | Chip-Select Inactive Delay | 3 | 25 | 3 | 20 | ns |  |
| TDXDL | $\overline{\text { DEN }}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 |  | ns | Equal Loading |
| TCVCTV | Control Active Delay 1 | 3 | 31 | 3 | 22 | ns |  |
| TCVDEX | $\overline{\text { DEN }}$ Inactive Delay | 3 | 31 | 3 | 22 | ns |  |
| TCHCTV | Control Active Delay 2 | 3 | 31 | 3 | 22 | ns |  |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 35 | 3 | 22 | ns |  |

80C186XL TIMING RESPONSES (Read Cycle)

| $T_{\text {AZRL }}$ | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | 0 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {CLRL }}$ | $\overline{\mathrm{RD}}$ Active Delay | 3 | 31 | 3 | 27 | ns |  |
| $T_{\text {RLRH }}$ | $\overline{\mathrm{RD}}$ Pulse Width | $2 \mathrm{~T}_{\mathrm{CLCL}}-25$ |  | $2 \mathrm{~T}_{\mathrm{CLCL}}-20$ |  | ns |  |
| $\mathrm{~T}_{\mathrm{CLRH}}$ | $\overline{\mathrm{RD}}$ Inactive Delay | 3 | 31 | 3 | 27 | ns |  |
| $\mathrm{~T}_{\text {RHLH }}$ | $\overline{\mathrm{RD}}$ Inactive to ALE High | $\mathrm{T}_{\mathrm{CLCH}}-14$ |  | $\mathrm{~T}_{\mathrm{CLCH}}-14$ |  | ns | Equal <br> Loading |
| $\mathrm{T}_{\text {RHAV }}$ | $\overline{\mathrm{RD}}$ Inactive to Address <br> Active | $\mathrm{T}_{\mathrm{CLCL}}-15$ |  | $\mathrm{~T}_{\mathrm{CLCL}}-15$ |  | ns | Equal <br> Loading |

## AC CHARACTERISTICS

## MAJOR CYCLE TIMINGS (WRITE CYCLE)

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{I H}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL |  | 80C186XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C186XL GENERAL TIMING RESPONSES (Listed More Than Once)

| TCHSV | Status Active Delay | 3 | 45 | 3 | 35 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 3 | 46 | 3 | 35 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 40 | 3 | 36 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TCHLH | ALE Active Delay |  | 30 |  | 25 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL-15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 30 |  | 25 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 18 |  | TCLCH - 15 |  | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | TCHCL - 15 |  | TCHCL - 15 |  | ns | Equal Loading |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLDOX | Data Hold Time | 3 |  | 3 |  | ns |  |
| Tcvetv | Control Active Delay 1 | 3 | 44 | 3 | 37 | ns |  |
| T ${ }_{\text {cvetx }}$ | Control Inactive Delay | 3 | 44 | 3 | 37 | ns |  |
| TCLCsV | Chip-Select Active Delay | 3 | 42 | 3 | 33 | ns |  |
| TCXCSX | Chip-Select Hold from Command Inactive | TCLCH - 10 |  | TCLCH - 10 |  | ns | Equal Loading |
| TCHCSX | Chip-Select Inactive Delay | 3 | 35 | 3 | 30 | ns |  |
| T DXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 |  | ns | Equal Loading |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | ns |  |

80C186XL TIMING RESPONSES (Write Cycle)

| T WLWH | $\overline{\text { WR Pulse Width }}$ | $2 \mathrm{~T}_{\text {CLCL }}-30$ | $2 \mathrm{~T}_{\text {CLCL }}-25$ | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\text {WHLH }}$ | $\overline{\text { WR }}$ Inactive to ALE High | TCLCH -14 | TCLCH - 14 | ns | Equal Loading |
| TwHDX | Data Hold after $\overline{\text { WR }}$ | TCLCL - 34 | TCLCL - 20 | ns | Equal Loading |
| Twhdex | $\overline{\text { WR }}$ Inactive to $\overline{\mathrm{DEN}}$ Inactive | TCLCH - 10 | TCLCH - 10 | ns | Equal Loading |

80C186XL

## AC CHARACTERISTICS

MAJOR CYCLE TIMINGS (WRITE CYCLE)
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For AC tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL16 |  | 80C186XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| T ${ }^{\text {CHSV }}$ | Status Active Delay | 3 | 31 | 3 | 25 | ns |  |
| TCLSH | Status Inactive Delay | 3 | 30 | 3 | 25 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 20 |  | 20 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL - 15 |  | ns |  |
| $\mathrm{T}_{\text {CHLL }}$ | ALE Inactive Delay |  | 20 |  | 20 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | $\mathrm{T}_{\text {CLCH }}-15$ |  | TCLCH - 10 |  | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | TCHCL - 15 |  | TCHCL - 10 |  | ns | Equal Loading |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLDOX | Data Hold Time | 3 |  | 3 |  | ns |  |
| T CVCTV | Control Active Delay 1 | 3 | 31 | 3 | 25 | ns |  |
| T CVCtx | Control Inactive Delay | 3 | 31 | 3 | 25 | ns |  |
| TCLCSV | Chip-Select Active Delay | 3 | 30 | 3 | 25 | ns |  |
| TCXCSX | Chip-Select Hold from Command Inactive | TCLCH - 10 |  | TCLCH - 10 |  | ns | Equal Loading |
| T ${ }_{\text {CHCSX }}$ | Chip-Select Inactive Delay | 3 | 25 | 3 | 20 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/R Low | 0 |  | 0 |  | ns | Equal Loading |
| TCLLV | $\overline{\text { LOCK Valid/Invalid Delay }}$ | 3 | 35 | 3 | 22 | ns |  |

80C 186XL TIMING RESPONSES (Write Cycle)

| $T_{\text {WLWH }}$ | $\overline{\text { WR Pulse Width }}$ | $2 \mathrm{~T}_{\text {CLCL }}-25$ |  | $2 \mathrm{~T}_{\text {CLCL }}-20$ |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {WHLH }}$ | $\overline{\text { WR }}$ Inactive to ALE High | $\mathrm{T}_{\text {CLCH }}-14$ |  | $\mathrm{~T}_{\text {CLCH }}-14$ |  | ns | Equal <br> Loading |
| $T_{\text {WHDX }}$ | Data Hold after $\overline{\text { WR }}$ | $\mathrm{T}_{\text {CLCL }}-20$ |  | $\mathrm{~T}_{\text {CLCL }}-15$ |  | ns | Equal <br> Loading |
| $T_{\text {WHDEX }}$ | $\overline{\text { WR }}$ Inactive to $\overline{\text { DEN }}$ Inactive | $\mathrm{T}_{\text {CLCH }}-10$ |  | $\mathrm{~T}_{\text {CLCH }}-10$ |  | ns | Equal <br> Loading |

## AC CHARACTERISTICS

MAJOR CYCLE TIMINGS (INTERRUPT ACKNOWLEDGE CYCLE)
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For AC tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL |  | 80C186XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL GENERAL TIMING REQUIREMENTS (Listed More Than Once) |  |  |  |  |  |  |  |
| TDVCL | Data in Setup (A/D) | 15 |  | 15 |  | ns |  |
| TCLDX | Data in Hold (A/D) | 3 |  | 3 |  | ns |  |

80C186XL GENERAL TIMING RESPONSES (Listed More Than Once)

| TCHSV | Status Active Delay | 3 | 45 | 3 | 35 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 3 | 46 | 3 | 35 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| T AVCH | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| T CLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 40 | 3 | 36 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TCHLH | ALE Active Delay |  | 30 |  | 25 | ns |  |
| TLHLL | ALE Width | $\mathrm{T}_{\text {CLCL }}-15$ |  | $\mathrm{T}_{\mathrm{CLCL}}-15$ |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 30 | - | 25 | ns |  |
| TAVLL | Address Valid to ALE Low | $\mathrm{T}_{\mathrm{CLCH}}-18$ |  | TCLCH -15 |  | ns | Equal Loading |
| TLLAX | Address Hold to ALE Inactive | TCHCL - 15 |  | TCHCL -15 |  | ns | Equal Loading |
| TCLAZ | Address Float Delay | TCLAX | 30 | TCLAX | 25 | ns |  |
| TCVCTV | Control Active Delay 1 | 3 | 44 | 3 | 37 | ns |  |
| TCVCTX | Control Inactive Delay | 3 | 44 | 3 | 37 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 |  | ns | Equal Loading |
| TCHCTV | Control Active Delay 2 | 3 | 44 | 3 | 37 | ns |  |
| TCVDEX | $\overline{\mathrm{DEN}}$ Inactive Delay (Non-Write Cycles) | 3 | 44 | 3 | 37 | ns |  |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | ns |  |

## AC CHARACTERISTICS

## MAJOR CYCLE TIMINGS (INTERRUPT ACKNOWLEDGE CYCLE)

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL16 |  | 80C186XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C186XL GENERAL TIMING REQUIREMENTS (Listed More Than Once)

| $T_{\text {DVCL }}$ | Data in Setup (A/D) | 15 |  | 10 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {CLDX }}$ | Data in Hold (A/D) | 3 |  | 3 |  | ns |  |

80C186XL GENERAL TIMING RESPONSES (Listed More Than Once)

| TCHSV | Status Active Delay | 3 | 31 | 3 | 25 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 3 | 30 | 3 | 25 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| $\mathrm{T}_{\text {CHDX }}$ | Status Hold Time | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 20 |  | 20 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL - 15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 20 |  | 20 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 15 |  | TCLCH - 10 |  | ns | Equal Loading |
| TLLAX | Address Hold to ALE Inactive | TCHCL - 15 |  | TCHCL - 10 |  | ns | Equal Loading |
| TCLAZ | Address Float Delay | TCLAX | 20 | TCLAX | 20 | ns |  |
| Tcvctv | Control Active Delay 1 | 3 | 31 | 3 | 25 | ns |  |
| T ${ }_{\text {CVCTX }}$ | Control Inactive Delay | 3 | 31 | 3 | 25 | ns |  |
| T DXDL | $\overline{\mathrm{DEN}}$ Inactive to DT//ᄌ) Low | 0 |  | 0 |  | ns | Equal Loading |
| TCHCTV | Control Active Delay 2 | 3 | 31 | 3 | 22 | ns |  |
| T ${ }_{\text {cVdex }}$ | $\overline{\mathrm{DEN}}$ Inactive Delay (Non-Write Cycles) | 3 | 31 | 3 | 22 | ns |  |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 35 | 3 | 22 | ns |  |

## AC CHARACTERISTICS

## SOFTWARE HALT CYCLE TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{I H}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL |  | 80C186XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL GENERAL TIMING REQUIREMENTS (Listed More Than Once) |  |  |  |  |  |  |  |
| TCHSV | Status Active Delay | 3 | 45 | 3 | 35 | ns |  |
| TCLSH | Status Inactive Delay | 3 | 46 | 3 | 35 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| TCHLH | ALE Active Delay |  | 30 |  | 25 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL - 15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 30 |  | 25 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/R Low |  | 0 |  | 0 | ns | Equal Loading |
| TCHCTV | Control Active Delay 2 | 3 | 44 | 3 | 37 | ns |  |


| Symbol | ParameterTarget | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL16 |  | 80C186XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| TCHSV | Status Active Delay | 3 | 31 | 3 | 25 | ns |  |
| TCLSH | Status Inactive Delay | 3 | 30 | 3 | 25 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCHLH | ALE Active Delay |  | 20 |  | 20 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL - 15 |  | ns |  |
| $\mathrm{T}_{\text {CHLL }}$ | ALE Inactive Delay |  | 20 |  | 20 | ns |  |
| TXXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/可 Low |  | 0 |  | 0 | ns | Equal Loading |
| T CHCTV | Control Active Delay 2 | 3 | 31 | 3 | 22 | ns |  |

## AC CHARACTERISTICS

## CLOCK TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathbb{I}}=2.4 \mathrm{~V}$ except at $\mathrm{X1}$ where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL |  | 80C186XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C186XL CLKIN REQUIREMENTS(1)

| $T_{\text {CKIN }}$ | CLKIN Period | 50 | $\infty$ | 40 | $\infty$ | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- | :--- |
| $T_{\text {CLCK }}$ | CLKIN Low Time | 20 | $\infty$ | 16 | $\infty$ | ns | $1.5 \mathrm{~V}(2)$ |
| $T_{\text {CHCK }}$ | CLKIN High Time | 20 | $\infty$ | 16 | $\infty$ | ns | $1.5 \mathrm{~V}(2)$ |
| $\mathrm{T}_{\text {CKHL }}$ | CLKIN Fall Time |  | 5 |  | 5 | ns | 3.5 to 1.0 V |
| $T_{\text {CKLH }}$ | CLKIN Rise Time |  | 5 |  | 5 | ns | 1.0 to 3.5 V |

80C186XL CLKOUT TIMING

| TCICO | CLKIN to CLKOUT Skew |  | 25 |  | 21 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL | CLKOUT Period | 100 | $\infty$ | 80 | $\infty$ | ns |  |
| TCLCH | CLKOUT Low Time | 0.5 TCLCL - 6 |  | 0.5 T ${ }_{\text {CLCL }}-5$ |  | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}(3)$ |
| TCHCL | CLKOUT High Time | 0.5 TCLCL - 6 |  | 0.5 TCLCL - 5 |  | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}{ }^{(4)}$ |
| $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLKOUT Rise Time |  | 10 |  | 10 | ns | 1.0 to 3.5 V |
| TCL2CL1 | CLKOUT Fall Time |  | 10 |  | 10 | ns | 3.5 to 1.0 V |

## NOTES:

1. External clock applied to $X 1$ and $X 2$ not connected.
2. TCLCK and TCHCK (CLKIN Low and High times) should not have a duration less than $40 \%$ of TCKIN.
3. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$.
4. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$.

## AC CHARACTERISTICS

## CLOCK TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL16 |  | 80C186XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C 186XL CLKIN REQUIREMENTS(1) |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {CKIN }}$ | CLKIN Period | 31.25 | $\infty$ | 25 | $\infty$ | ns |  |
| TCLCK | CLKIN Low Time | 13 | $\infty$ | 10 | $\infty$ | ns | 1.5 V (2) |
| T ${ }_{\text {CHCK }}$ | CLKIN High Time | 13 | $\infty$ | 10 | $\infty$ | ns | 1.5 V (2) |
| TCKHL | CLKIN Fall Time |  | 5 |  | 5 | ns | 3.5 to 1.0 V |
| TCKLH | CLKIN Rise Time |  | 5 |  | 5 | ns | 1.0 to 3.5 V |
| 80C186XL CLKOUT TIMING |  |  |  |  |  |  |  |
| T CICO | CLKIN to CLKOUT Skew |  | 17 |  | 17 | ns |  |
| TCLCL | CLKOUT Period | 62.5 |  | 50 |  | ns |  |
| TCLCH | CLKOUT Low Time | $0.5 \mathrm{~T}_{\text {CLCL }}-5$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}-5$ |  | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}(3)$ |
| $\mathrm{T}_{\text {CHCL }}$ | CLKOUT High Time | $0.5 \mathrm{~T}_{\text {CLCL }}-5$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}-5$ |  | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}(4)$ |
| $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLKOUT Rise Time |  | 10 |  | 8 | ns | 1.0 to 3.5 V |
| TCL2CL1 | CLKOUT Fall Time |  | 10 |  | 8 | ns | 3.5 to 1.0 V |

## NOTES:

1. External clock applied to $X 1$ and $X 2$ not connected.
2. TCLCK and TCHCK (CLKIN Low and High times) should not have a duration less than $40 \%$ of $T_{\text {CKIN }}$.
3. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$. $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$.
4. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} . \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$.

## AC CHARACTERISTICS

## READY, PERIPHERAL AND QUEUE STATUS TIMINGS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL |  | 80C186XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL READY AND PERIPHERAL TIMING REQUIREMENTS (Listed More Than Once) |  |  |  |  |  |  |  |
| TSRYCL | Synchronous Ready (SRDY) Transition Setup Time(1) | 15 |  | 15 |  | ns |  |
| TCLSRY | SRDY Transition Hold Time(1) | 15 |  | 15 |  | ns |  |
| TARYCH | ARDY Resolution Transition Setup Time ${ }^{(2)}$ | 15 |  | 15 |  | ns |  |
| TCLARX | ARDY Active Hold Time(1) | 15 |  | 15 |  | ns |  |
| TARYCHL | ARDY Inactive Holding Time | 15 |  | 15 |  | ns |  |
| TARYLCL | Asynchronous Ready (ARDY) Setup Time(1) | 25 |  | 25 |  | ns |  |
| TINVCH | INTx, NMI, TEST/BUSY, TMR IN Setup Time (2) | 15 |  | 15 |  | ns |  |
| TINVCL | DRQ0, DRQ1 Setup Time ${ }^{(2)}$ | 15 |  | 15 |  | ns |  |
| 80C186XL PERIPHERAL AND QUEUE STATUS TIMING RESPONSES |  |  |  |  |  |  |  |
| TCLTMV | Timer Output Delay |  | 40 |  | 33 | ns |  |
| TCHQSV | Queue Status Delay |  | 37 |  | 32 | ns |  |

## NOTES:

1. To guarantee proper operation.
2. To guarantee recognition at clock edge.

## AC CHARACTERISTICS

READY, PERIPHERAL, AND QUEUE STATUS TIMINGS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL16 |  | 80C186XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C186XL READY AND PERIPHERAL TIMING REQUIREMENTS

| $\mathrm{T}_{\text {SRYCL }}$ | Synchronous Ready (SRDY) <br> Transition Setup Time(1) | 15 |  | 10 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\text {CLSRY }}$ | SRDY Transition Hold Time(1) | 15 |  | 10 |  | ns |  |
| $\mathrm{~T}_{\text {ARYCH }}$ | ARDY Resolution Transition <br> Setup Time(2) | 15 |  | 10 |  | ns |  |
| $\mathrm{~T}_{\text {CLARX }}$ | ARDY Active Hold Time(1) | 15 |  | 10 |  | ns |  |
| $\mathrm{~T}_{\text {ARYCHL }}$ | ARDY Inactive Holding Time | 15 |  | 10 |  | ns |  |
| $\mathrm{~T}_{\text {ARYLCL }}$ | Asynchronous Ready <br> (ARDY) Setup Time(1) | 25 |  | 15 |  | ns |  |
| $\mathrm{~T}_{\text {INVCH }}$ | INTx, NMI, TEST/BUSY, <br> TMR IN Setup Time(2) | 15 |  | 10 |  | ns |  |
| $\mathrm{~T}_{\text {INVCL }}$ | DRQ0, DRQ1 Setup Time(2) | 15 |  | 10 |  | ns |  |

80C186XL PERIPHERAL AND QUEUE STATUS TIMING RESPONSES

| $T_{\text {CLTMV }}$ | Timer Output Delay |  | 27 |  | 22 | ns |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathrm{~T}_{\text {CHOSV }}$ | Queue Status Delay |  | 30 |  | 27 | ns |  |

## NOTES:

1. To guarantee proper operation.
2. To guarantee recognition at clock edge.

## AC CHARACTERISTICS

## RESET AND HOLD/HLDA TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL |  | 80C186XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL RESET AND HOLD/HLDA TIMING REQUIREMENTS |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {RESIN }}$ | $\overline{\text { RES Setup }}$ | 15 |  | 15 |  | ns |  |
| THVCL | HOLD Setup ${ }^{(1)}$ | 15 |  | 15 |  | ns |  |
| 80C186XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| TCLAZ | Address Float Delay | TCLAX | 30 | TCLAX | 25 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| 80C186XL RESET AND HOLD/HLDA TIMING RESPONSES |  |  |  |  |  |  |  |
| TCLRO | Reset Delay |  | 40 |  | 33 | ns |  |
| TCLHAV | HLDA Valid Delay | 3 | 40 | 3 | 33 | ns |  |
| TCHCZ | Command Lines Float Delay |  | 40 |  | 33 | ns |  |
| TCHCV | Command Lines Valid Delay (after Float) |  | 44 |  | 36 | ns |  |

## NOTE:

1. To guarantee recognition at next clock.

## AC CHARACTERISTICS

## RESET AND HOLD/HLDA TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C186XL16 |  | 80C186XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C186XL RESET AND HOLD/HLDA TIMING REQUIREMENTS |  |  |  |  |  |  |  |
| Tresin | RES Setup | 15 |  | 15 |  | ns |  |
| THVCL | HOLD Setup(1) | 15 |  | 10 |  | ns |  |
| 80C186XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| TCLAZ | Address Float Delay | TCLAX | 20 | TCLAX | 20 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 22 | ns |  |
| 80C186XL RESET AND HOLD/HLDA TIMING RESPONSES |  |  |  |  |  |  |  |
| TCLRO | Reset Delay |  | 27 |  | 22 | ns |  |
| TCLHAV | HLDA Valid Delay | 3 | 25 | 3 | 22 | ns |  |
| TCHCZ | Command Lines Float Delay |  | 28 |  | 25 | ns |  |
| TCHCV | Command Lines Valid Delay (after Float) |  | 32 |  | 26 | ns |  |

## NOTE:

1. To guarantee recognition at next clock.

## AC CHARACTERISTICS

## READ CYCLE WAVEFORMS



## NOTES:

1. Status inactive in state preceding $T_{4}$.
2. If latched $A_{1}$ and $A_{2}$ are selected instead of $\overline{\mathrm{PCS5}}$ and $\overline{\mathrm{PCS6}}$, only $\mathrm{T}_{\text {CLCSV }}$ is applicable.
3. For write cycle followed by read cycle.
4. $\mathrm{T}_{1}$ of next bus cycle.
5. Changes in T-state preceding next bus cycle if followed by write.

Figure 6

## AC CHARACTERISTICS

## WRITE CYCLE WAVEFORMS



## NOTES:

1. Status inactive in state preceding $\mathrm{T}_{4}$.
2. If latched $A_{1}$ and $A_{2}$ are selected instead of $\overline{P C S 5}$ and $\overline{P C S 6}$, only TCLCSV is applicable.
3. For write cycle followed by read cycle.
4. $T_{1}$ of next bus cycle.
5. Changes in T-state preceding next bus cycle if followed by read, INTA, or halt.

Figure 7

## AC CHARACTERISTICS

INTERRUPT ACKNOWLEDGE CYCLE WAVEFORMS


NOTES:

1. Status inactive in state preceding $T_{4}$.
2. The data hold time lasts only until $\frac{1 N T A}{}$ goes inactive, even if the INTA transition occurs prior to $\mathrm{T}_{\mathrm{CLDX}}$ (min).
3. INTA occurs one clock later in Slave Mode.
4. For write cycle followed by interrupt acknowledge cycle.
5. $\overline{\text { LOCK }}$ is active upon $T_{1}$ of the first interrupt acknowledge cycle and inactive upon $T_{2}$ of the second interrupt acknowledge cycle.
6. Changes in T-state preceding next bus cycle if followed by write.

Figure 8

## AC CHARACTERISTICS

## SOFTWARE HALT CYCLE WAVEFORMS



Figure 9

## WAVEFORMS

## CLOCK WAVEFORMS



Figure 10

RESET WAVEFORMS


Figure 11

SYNCHRONOUS READY (SRDY) WAVEFORMS


Figure 12

## AC CHARACTERISTICS

ASYNCHRONOUS READY (ARDY) WAVEFORMS


Figure 13
PERIPHERAL AND QUEUE STATUS WAVEFORMS


Figure 14

## AC CHARACTERISTICS

HOLD/HLDA WAVEFORMS (Entering Hold)


Figure 15
HOLD/HLDA WAVEFORMS (Leaving Hold)


Figure 16

## EXPLANATION OF THE AC SYMBOLS

Each timing symbol has from 5 to 7 characters. The first character is always a ' $T$ ' (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.
A: Address
ARY: Asynchronous Ready Input
C: Clock Output
CK: Clock Input
CS: Chip Select
CT: Control (DT/信, $\overline{\mathrm{DEN}}, \ldots$ )
D: Data Input
DE: $\overline{\mathrm{DEN}}$
H: Logic Level High
OUT: Input (DRQ0, TIMO, ... )
L: Logic Level Low or ALE
O: Output
QS: Queue Status (QS1, QS2)
R: $\overline{R D}$ Signal, RESET Signal
$\mathrm{S}: \quad$ Status $(\overline{\mathrm{S} 0}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 2})$
SRY: Synchronous Ready Input
V: Valid
W: WR Signal
X: $\quad$ No Longer a Valid Logic Level
Z: Float

## Examples:

TCLAV - Time from Clock low to Address valid
TCHLH - Time from Clock high to ALE high
TCLCSV - Time from Clock low to Chip Select valid

DERATING CURVES


Figure 17. Capacitive Derating Curve

## Typical Rise and Fall Times for TTL Voltage Levels



Figure 18. TTL Level Rise and Fall Times for Output Buffers

Typical Rise and Fall Times for CMOS Voltage Levels


Figure 19. CMOS Level Rise and Fall Times for Output Buffers

## 80C186XL EXPRESS

The Intel EXPRESS system offers enhancements to the operational specifications of the 80C186XL microprocessor. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

The 80C186XL EXPRESS program includes an extended temperature range. With the commercial standard temperature range, operational characteristics are guaranteed over the temperature range of $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$. With the extended temperature range option, operational characteristics are guaranteed over the range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

Package types and EXPRESS versions are identified by a one or two-letter prefix to the part number. The prefixes are listed in Table 3. All AC and DC specifications not mentioned in this section are the same for both commercial and EXPRESS parts.

Table 3. Prefix Identification

| Prefix | Package <br> Type | Temperature <br> Range |
| :---: | :---: | :---: |
| A | PGA | Commercial |
| N | PLCC | Commercial |
| R | LCC | Commercial |
| S | QFP | Commercial |
| TA | PGA | Extended |
| TN | PLCC | Extended |
| TR | LCC | Extended |
| TS | QFP | Extended |

## 80C186XL EXECUTION TIMINGS

A determination of 80C186XL program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.
- All word-data is located on even-address boundaries.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

With a 16 -bit BIU, the 80C186XL has sufficient bus performance to ensure that an adequate number of prefetched bytes will reside in the queue most of the time. Therefore, actual program execution time will not be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY


Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER (Continued) SEGMENT = Segment Override: |  |  |  |  |  |  |
| CS | 00101110 |  |  |  | 2 |  |
| SS | 00110110 |  |  |  | 2 |  |
| DS | 00111110 |  |  |  | 2 |  |
| ES | 00100110 |  |  |  | 2 |  |
| ARITHMETIC ADD = Add: |  |  |  |  |  |  |
| Reg/memory with register to either | 000000dw | mod reg r/m |  |  | 3/10 |  |
| Immediate to register/memory | 100000sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if s w $=01$ | 4/16 |  |
| Immediate to accumulator | 0000010 w | data | data if $w=1$ |  | $3 / 4$ | 8/16-bit |
| ADC = Add with carry: |  |  |  |  |  |  |
| Reg/memory with register to either | 000100 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate to register/memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $s$ w $=01$ | 4/16 |  |
| Immediate to accumulator | 0001010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| INC = Increment: |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 3/15 |  |
| Register | 01000 reg |  |  |  | 3 |  |
| SUB = Subtract: |  |  |  |  |  |  |
| Reg/memory and register to either | 001010 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate from register/memory | 100000sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s} \mathbf{w}=01$ | 4/16 |  |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| SBB = Subtract with borrow: |  |  |  |  |  |  |
| Reg/memory and register to either | 000110 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate from register/memory | 100000sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} w=01$ | 4/16 |  |
| Immediate from accumulator | 0.001110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| DEC = Decrement |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 3/15 |  |
| Register | 01001 reg |  |  |  | 3 |  |
| CMP = Compare: |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | modreg r/m |  |  | 3/10 |  |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 3/10 |  |
| Immediate with register/memory | 100000 sw | $\bmod 111 \mathrm{r} / \mathrm{m}$ | data | data if $s \mathbf{w}=01$ | 3/10 |  |
| Immediate with accumulator | 0011110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NEG = Change sign register/memory | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ | , |  | 3/10 |  |
| AAA $=$ ASCII adjust for add | 00110111 |  |  |  | 8 |  |
| DAA $=$ Decimal adjust for add | 00100111 | , |  |  | 4 |  |
| AAS = ASCII adjust for subtract | 00111111 |  |  |  | 7 |  |
| DAS = Decimal adjust for subtract | 00101111 |  |  |  | 4 | - |
| MUL = Multiply (unsigned): | 1111011 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Register-Byte |  |  |  |  | 26-28 |  |
| Register-Word |  |  |  |  | 35-37 |  |
| Memory-Byte |  |  |  |  | 32-34 |  |
| Memory-Word |  |  |  |  | 41-43 |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


[^4]80C186XL
ADVANCE ONPORMATRON

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format | Clock <br> Cycles |
| :--- | :--- | :---: | :---: |
| Comments |  |  |  |
| PROCESSOR CONTROL |  |  |  |
| CMC $=$ Clear carry |  |  |  |
| Complement carry | 11111000 |  |  |
| STC $=$ Set carry | 11110101 |  |  |
| CLD $=$ Clear direction | 11111001 |  |  |
| STD $=$ Set direction | 11111100 |  |  |
| CLI $=$ Clear interrupt | 11111101 |  |  |
| STI $=$ Set interrupt | 11111010 |  |  |
| HLT $=$ Halt | 11111011 |  |  |
| WAIT $=$ Wait | 11110100 |  |  |
| LOCK $=$ Bus lock prefix | 10011011 |  |  |
| NOP $=$ No Operation | 11110000 |  |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if mod $=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field if mod $=00$ then DISP $=0^{*}$, disp-low and disphigh 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 $\mathrm{EA}=(\mathrm{BX})+(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=001$ then EA $=(B X)+(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=010$ then $E A=(B P)+(S I)+D I S P$
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+$ DISP
if $\mathrm{r} / \mathrm{m}=100$ then $\mathrm{EA}=(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then EA $=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+$ DISP*
if $\mathrm{r} / \mathrm{m}=111$ then EA $=(B X)+$ DISP
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.
reg is assigned according to the following:

| reg | Segment <br> Register |
| :---: | :---: |
| 00 | ES |
| 01 | CS |
| 10 | SS |
| 11 | DS |

REG is assigned according to the following table:

| 16-Bit $(w=1)$ | 8 -Bit $(w=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.

## Segment Override Prefix

| 0 | 0 | 1 | reg | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## REVISION HISTORY

The following changes were made between the -001 and -002 versions of the 80C186XL data sheets. The -002 data sheet applies to any 80C188XL with a "B" alpha character after the FPO number. The FPO number location is show in Figure 2.

1. Much of the information provided in the -001 version of the data sheet has been removed. Detail descriptions of part functionality may be found in the 80C186XL User's Manual.
2. All AC Timing waveforms were combined at the end of the AC Characteristics section.
3. TWHLH for the 80 C 186 XL 12 was changed from $\mathrm{T}_{\mathrm{CLCH}}-10$ to $\mathrm{T}_{\mathrm{CLCH}}-14$ due to a previous typographical error.
4. TRESIN for the 80C186XL20 was change from 10 ns to 15 ns .
5. Output test conditions were changed from $\mathrm{C}_{\mathrm{L}}=$ $50-200 \mathrm{pF}$ to $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ to reflect newer test equipment. Note: this has no effect on AC Timing specifications.

## ERRATA

An A or B step 80C186XL has the following errata. The A or B step 80C186XL can be identified by the presence of an " $A$ " or " $B$ " alpha character, respectively, next to the FPO number. The FPO number location is shown in Figure 2.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistently, it is dependent on interrupt timing.

## PRODUCT IDENTIFICATION

Intel 80C186XL devices are marked with a 9-character alphanumeric Intel FPO number underneath the product number. This data sheet (272032-002) is valid for 80C186XL devices with an " $A$ " or " $B$ " as the ninth character in the FPO number, as illustrated in Figure 2.

## 80C186EA20, 16, 12 <br> 16-BIT HIGH INTEGRATION EMBEDDED PROCESSOR

## - 80C186 Upgrade for Power Critical Applications

- Full Static Operation
- True CMOS Inputs and Outputs
- Integrated Feature Set
- Static 186 CPU Core
- Power Save, Idle and Powerdown Modes
- Clock Generator
- 2 Independent DMA Channels
- 3 Programmable 16-Bit Timers
- Dynamic RAM Refresh Control Unit
- Programmable Memory and Peripheral Chip Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- System-Level Testing Support (High Impedance Test Mode)
Speed Versions Available:
- 20 MHz (80C186EA20)
- 16 MHz (80C186EA16)
- 12.5 MHz (80C186EA12)
- Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Complete System Development Support
- All 8086/8088 and 80C186 Family Software Development Tools Can Be Used for 80C186EA System Development
- ASM86 Assembler, iC-86, Pascal-86, Fortran-86, PL/M-86 and System Utilities
- In-Circuit-Emulator (ICETM-186)
- Operation Includes Numerics Mode for Direct Interface to 80C187 Numerics Coprocessor
- Available in the Following Packages: -68-Pin Plastic Leaded Chip Carrier (PLCC) - 80-Pin EIAJ Quad Flat Pack (QFP)

The 80C186EA is a CHMOS high integration embedded microprocessor. The 80C186EA includes all of the features of an "Enhanced Mode" 80C186 while adding the additional capabilities of Idle and Powerdown Modes. In Numerics Mode, the 80C186EA interfaces directly with an 80C187 Numerics Coprocessor.

80C186EA20, 16, 1216-Bit High Integration Embedded Processor
CONTENTS page CONTENTS PAGE
INTRODUCTION ..... 24-177
OVERVIEW ..... 24-177
80C186EA CORE ARCHITECTURE ..... 24-177
Bus Interface Unit ..... 24-177
Clock Generator ..... 24-177
80C186EA PERIPHERAL ARCHITECTURE ..... 24-178
Interrupt Control Unit ..... 24-178
Timer/Counter Unit ..... 24-178
DMA Control Unit ..... 24-180
Chip-Select Unit ..... 24-180
Refresh Control Unit ..... 24-180
Power Management ..... 24-180
80C187 Interface ..... 24-181
ONCETM Test Mode ..... 24-181
DIFFERENCES BETWEEN THE 80C186 AND THE 80C186EA ..... 24-181
Pinout Compatibility ..... 24-181
Operating Modes ..... 24-181
TTL vs CMOS Inputs ..... 24-181
Timing Specifications ..... 24-181
PACKAGE INFORMATION ..... 24-182
Pin Descriptions ..... 24-182
80C186EA Pinout ..... 24-187
PACKAGE THERMAL SPECIFICATIONS ..... 24-191


## INTRODUCTION

The 80C186EA is the second product in a new generation of low-power, high-integration microprocessors. It enhances the existing 80C186 family by offering new features and new operating modes. The 80C186EA is object code compatible with the 80C186/80C188 embedded processor.

The feature set of the 80C186EA meets the needs of low-power, space-critical applications. Low-power applications benefit from the static design of the CPU core and the integrated peripherals. Minimum current consumption is achieved by providing a Powerdown Mode that halts operation of the device, and freezes the clock circuits. Peripheral design enhancements ensure that non-initialized peripherals consume little current.

Space-critical applications benefit from the integration of commonly used system peripherals. Two flexible DMA channels perform CPU-independent data transfers. A flexible chip select unit simplifies memory and peripheral interfacing. The interrupt unit provides sources for up to 128 external interrupts and will prioritize these interrupts with those generated from the on-chip peripherals. Three general purpose timer/counters round out the feature set of the 80C186EA.

## OVERVIEW

Figure 1 shows a block diagram of the 80C186EA. The Execution Unit (EU) is an enhanced 8086 CPU core that includes: dedicated hardware to speed up effective address calculations, enhance execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instructions, and static operation. The Bus Interface Unit (BIU) is the same as that found on the original 80 C 186 family products. An independent internal bus is used to allow communication between the BIU and internal peripherals.

## 80C186EA CORE ARCHITECTURE

## Bus Interface Unit

The 80C186EA core incorporates a bus controller that generates local bus control signals. In addition, it employs a HOLD/HLDA protocol to share the local bus with other bus masters.

The bus controller is responsible for generating 20 bits of address, read and write strobes, bus cycle status information and data (for write operations) information. It is also responsible for reading data off the local bus during a read operation. SRDY and ARDY input pins are provided to extend a bus cycle beyond the minimum four states (clocks).

The 80C186EA local bus controller also generates two control signals ( $\overline{\mathrm{DEN}}$ and DT//̄) when interfacing to external transceiver chips. This capability allows the addition of transceivers for simple buffering of the mulitplexed address/data bus.

## Clock Generator

The 80C186EA provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, and two low-power operating modes.

The oscillator circuit is designed to be used with either a parallel resonant fundamental or third-overtone mode crystal network. Alternatively, the oscillator circuit may be driven from an external clock source. Figure 2 shows the various operating modes of the 80 C 186 EA oscillator circuit.

The crystal or clock frequency chosen must be twice the required processor operating frequency due to the internal divide-by-two counter. This counter is used to drive all internal phase clocks and the external CLKOUT signal. CLKOUT is a $50 \%$ duty cycle processor clock and can be used to drive other system components. All AC timings are referenced to CLKOUT.

The following parameters are recommended when choosing a crystal:

Temperature Range: Application Specific ESR (Equivalent Series Resistance): $\quad 60 \Omega$ max CO (Shunt Capacitance of Crystal): $\quad 7.0 \mathrm{pF}$ max $C_{L}$ (Load Capacitance): $20 \mathrm{pF} \pm 5 \mathrm{pF}$ Drive Level:


The $L_{1} C_{1}$ network is only required when using a third-overtone crystal.
Figure 2. 80C186EA Clock Configurations

## 80C186EA PERIPHERAL ARCHITECTURE

The 80C186EA has integrated several common system peripherals with a CPU core to create a compact, yet powerful system. The integrated peripherals are designed to be flexible and provide logical interconnections between supporting units (e.g., the interrupt control unit supports interrupt requests from the timer/counters or DMA channels).

The list of integrated peripherals include:

- 4-Input Interrupt Control Unit
- 3-Channel Timer/Counter Unit
- 2-Channel DMA Unit
- 13-Output Chip-Select Unit
- Refresh Control Unit
- Power Management logic

The registers associated with each integrated periheral are contained within a $128 \times 16$ register file called the Peripheral Control Block (PCB). The PCB can be located in either memory or 1/O space on any 256 byte address boundary.

Figure 3 provides a list of the registers associated with the PCB when the processor's Interrupt Control Unit is in Master Mode. In Slave Mode, the definitions of some registers change. Figure 4 provides register definitions specific to Slave Mode.

## Interrupt Control Unit

The 80C186EA can receive interrupts from a number of sources, both internal and external. The Interrupt Control Unit (ICU) serves to merge these requests on a priority basis, for individual service by the CPU. Each interrupt source can be independently masked by the Interrupt Control Unit or all interrupts can be globally masked by the CPU.

Internal interrupt sources include the Timers and DMA channels. External interrupt sources come from the four input pins INT3:0. The NMI interrupt pin is not controlled by the ICU and is passed directly to the CPU. Although the timers only have one request input to the ICU, separate vector types are generated to service individual interrupts within the Timer Unit.

## Timer/Counter Unit

The 80C186EA Timer/Counter Unit (TCU) provides three 16-bit programmable timers. Two of these are highly flexible and are connected to external pins for control or clocking. A third timer is not connected to any external pins and can only be clocked internally. However, it can be used to clock the other two timer channels. The TCU can be used to count external events, time external events, generate non-repetitive waveforms, generate timed interrupts, etc.

| $\left\|\begin{array}{c} \text { PCB } \\ \text { Offset } \end{array}\right\|$ | Function |
| :---: | :---: |
| 00H | Reserved |
| 02H | Reserved |
| 04H | Reserved |
| 06H | Reserved |
| 08H | Reserved |
| OAH | Reserved |
| OCH | Reserved |
| OEH | Reserved |
| 10H | Reserved |
| 12 H | Reserved |
| 14H | Reserved |
| 16H | Reserved |
| 18H | Reserved |
| 1AH | Reserved |
| 1CH | Reserved |
| 1EH | Reserved |
| 20H | Reserved |
| 22H | End of Interrupt |
| 24H | Poll |
| 26 H | Poll Status |
| 28 H | Interrupt Mask |
| 2AH | Priority Mask |
| 2 CH | In-Service |
| 2EH | Interrupt Request |
| 30 H | Interrupt Status |
| 32H | Timer Control |
| 34H | DMAO Int. Control |
| 36H | DMA1 Int. Control |
| 38 H | INTO Control |
| 3AH | INT1 Control |
| 3 CH | INT2 Control |
| 3EH | INT3 Control |


| PCB <br> Offset | Function | $\begin{aligned} & \text { PCB } \\ & \text { Offset } \end{aligned}$ | Function |
| :---: | :---: | :---: | :---: |
| 40H | Reserved | 80 H | Reserved |
| 42H | Reserved | 82 H | Reserved |
| 44H | Reserved | 84H | Reserved |
| 46H | Reserved | 86H | Reserved |
| 48 H | Reserved | 88 H | Reserved |
| 4AH | Reserved | 8AH | Reserved |
| 4CH | Reserved | 8 CH | Reserved |
| 4EH | Reserved | 8EH | Reserved |
| 50 H | Timer 0 Count | 90 H | Reserved |
| 52 H | Timer 0 Compare A | 92H | Reserved |
| 54H | Timer 0 Compare B | 94H | Reserved |
| 56 H | Timer 0 Control | 96 H | Reserved |
| 58H | Timer 1 Count | 98H | Reserved |
| 5AH | Timer 1 Compare A | 9AH | Reserved |
| 5 CH | Timer 1 Compare B | 9 CH | Reserved |
| 5EH | Timer 1 Control | 9EH | Reserved |
| 60H | Timer 2 Count | AOH | UMCS |
| 62H | Timer 2 Compare | A 2 H | LMCS |
| 64H | Reserved | A4H | PACS |
| 66H | Timer 2 Control | A6H | MMCS |
| 68H | Reserved | A8H | MPCS |
| 6AH | Reserved | AAH | Reserved |
| 6 CH | Reserved | ACH | Reserved |
| 6EH | Reserved | AEH | Reserved |
| 70 H | Reserved | BOH | Reserved |
| 72H | Reserved | B2H | Reserved |
| 74H | Reserved | B4H | Reserved |
| 76H | Reserved | B6H | Reserved |
| 78H | Reserved | B8H | Reserved |
| 7AH | Reserved | BAH | Reserved |
| 7CH | Reserved | BCH | Reserved |
| 7EH | Reserved | BEH | Reserved |


| PCB Offset | Function |
| :---: | :---: |
| COH | DMAO Src. Lo |
| C 2 H | DMAO Src. Hi |
| C4H | DMAO Dest. Lo |
| C6H | DMAO Dest. Hi |
| $\mathrm{C8H}$ | DMA0 Count |
| CAH | DMAO Control |
| CCH | Reserved |
| CEH | Reserved |
| DOH | DMA1 Src. Lo |
| D2H | DMA1 Src. Hi |
| D4H | DMA1 Dest. Lo |
| D6H | DMA1 Dest. Hi |
| D8H | DMA1 Count |
| DAH | DMA1 Control |
| DCH | Reserved |
| DEH | Reserved |
| EOH | Refresh Base |
| E2H | Refresh Time |
| E4H | Refresh Control |
| E6H | Reserved |
| $\mathrm{E8H}$ | Reserved |
| EAH | Reserved |
| ECH | Reserved |
| EEH | Reserved |
| FOH | Power-Save |
| F2H | Power Control |
| F4H | Reserved |
| F6H | Step ID |
| F8H | Reserved |
| FAH | Reserved |
| FCH | Reserved |
| FEH | Relocation |

Figure 3. 80C186EA Peripheral Control Block Registers

| PCB <br> Offset | Function |
| :---: | :---: |
| 20 H | Interrupt Vector |
| 22 H | Specific EOI |
| 24 H | Reserved |
| 26 H | Reserved |
| 28 H | Interrupt Mask |
| 2 AH | Priority Mask |
| 2 C | In-Service |
| 2 E | Interrupt Request |
| 30 | Interrupt Status |
| 32 | TMR0 Interrupt Control |
| 34 | DMAO Interrupt Control |
| 36 | DMA1 Interrupt Control |
| 38 | TMR1 Interrupt Control |
| 3 A | TMR2 Interrupt Control |
| 3 C | Reserved |
| $3 E$ | Reserved |

Figure 4. 80C186EA Slave Mode Peripheral Control Block Registers

## DMA Control Unit

The 80C186EA DMA Contol Unit provides two independent high-speed DMA channels. Data transfers can occur between memory and 1/O space in any combination: memory to memory, memory to I/O, I/O to I/O or I/O to memory. Data can be transferred either in bytes or words. Transfers may proceed to or from either even or odd addresses, but even-aligned word transfers proceed at a faster rate. Each data transfer consumes two bus cycles (a minimum of eight clocks), one cycle to fetch data and the other to store data. The chip-select/ready logic may be programmed to point to the memory or I/O space subject to DMA transfers in order to provide hardware chip select lines. DMA cycles run at higher priority than general processor execution cycles.

## Chip-Select Unit

The 80C186EA Chip-Select Unit integrates logic which provides up to 13 programmable chip-selects to access both memories and peripherals. In addition, each chip-select can be programmed to automatically terminate a bus cycle independent of the condition of the SRDY and ARDY input pins. The chip-select lines are available for all memory and I/O bus cycles, whether they are generated by the CPU, the DMA unit, or the Refresh Control Unit.

## Refresh Control Unit

The Refresh Control Unit (RCU) automatically generates a periodic memory read bus cycle to keep dynamic or pseudo-static memory refreshed. A 9-bit counter controls the number of clocks between refresh requests.

A 9-bit address generator is maintained by the RCU with the address presented on the A9:1 address lines during the refresh bus cycle. Address bits A19:13 are programmable to allow the refresh address block to be located on any 8 Kbyte boundary.

## Power Management

The 80C186EA has three operational modes to control the power consumption of the device. They are Power Save Mode, Idle Mode, and Powerdown Mode.

Power Save Mode divides the processor clock by a programmable value to take advantage of the fact that current is linearly proportional to frequency. An unmasked interrupt, NMI, or reset will cause the 80C186EA to exit Power Save Mode.

Idle Mode freezes the clocks of the Execution Unit and the Bus Interface Unit at a logic zero state while all peripherals operate normally.

Powerdown Mode freezes all internal clocks at a logic zero level and disables the crystal oscillator. All internal registers hold their values provided $V_{C C}$ is maintained. Current consumption is reduced to transistor leakage only.

## 80C187 Interface

The 80C187 Numerics Coprocessor may be used to extend the 80C186EA instruction set to include floating point and advanced integer instructions. Connecting the 80C186EA RESOUT and TEST/ BUSY pins to the 80C187 enables Numerics Mode operation. In Numerics Mode, three of the four MidRange Chip Select ( $\overline{\mathrm{MCS}}$ ) pins become handshaking pins for the interface. The exchange of data and control information proceeds through four dedicated I/O ports.

If an 80 C 187 is not present, the 80C186EA configures itself for regular operation at reset.

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80C186EA has a test mode available which forces all output and input/ output pins to be placed in the high-impedance state. ONCE stands for "ON Circuit Emulation". The ONCE mode is selected by forcing the UCS and $\overline{L C S}$ pins LOW (0) during a processor reset (these pins are weakly held to a HIGH (1) level) while RESIN is active.

## DIFFERENCES BETWEEN THE 80C186 AND THE 80C186EA

The 80C186EA is intended as a direct functional upgrade for 80C186 designs. In many cases, it will be possible to replace an existing 80C186 with little or no hardware redesign. The following sections describe differences in pinout, operating modes, and AC and DC specifications to keep in mind.

## Pinout Compatibility

The 80C186EA requires a PDTMR pin to time the processor's exit from Powerdown Mode. The original pin arrangement for the 80C186 in the PLCC package did not have any spare leads to use for PDTMR, so the $D T / \bar{R}$ pin was sacrificed. The arrangement of all the other leads in the 68-lead PLCC is identical between the 80C186 and the 80C186EA. DT/ $\overline{\mathrm{R}}$ may be readily synthesized by latching the $\overline{\mathrm{S} 1}$ status output. Therefore, upgrading a PLCC 80C186 to PLCC 80C186EA is particularly straightforward. You must connect a capacitor to the 80C186EA PDTMR pin in order to use Powerdown Mode.

The 80-lead QFP (EIAJ) pinouts are distinctly different between the 80C186 and the 80C186EA. In addition to the PDTMR pin, the 80C186EA has more power and ground pins and the overall arrangement of pins was shifted. A new circuit board layout for the 80C186EA is required.

## Operating Modes

The 80C186 has two operating modes, Compatible and Enhanced. Compatible Mode is a pin-to-pin replacement for the NMOS 80186, except for numerics coprocessing. In Enhanced Mode, the processor has a Refresh Control Unit, the Power-Save feature and an interface to the 80C187 Numerics Coprocessor. The $\overline{\mathrm{MCSO}}, \overline{\mathrm{MCS1}}$, and $\overline{\mathrm{MCS3}}$ pins change their functions to constitute handshaking pins for the 80C187.

The 80C186EA allows all non-80C187 users to use all the $\overline{M C S}$ pins for chip-selects. In regular operation, all 80C186EA features (including those of the Enhanced Mode 80C186) are present except for the interface to the 80C187. Numerics Mode disables the three chip-select pins and reconfigures them for connection to the 80 C 187.

## TTL vs CMOS Inputs

The inputs of the 80C186EA are rated for CMOS switching levels for improved noise immunity, but the 80C186 inputs are rated for TTL switching levels. In particular, the 80 C 186 EA requires a minimum $\mathrm{V}_{\mathrm{IH}}$ of 3.5 V to recognize a logic one while the 80C186 requires a minimum $\mathrm{V}_{1 \mathrm{H}}$ of only 1.9 V (assuming 5.0 V operation). The solution is to drive the 80C186EA with true CMOS devices, such as those from the HC and AC logic families, or to use pullup resistors where the added current draw is not a problem.

## Timing Specifications

80C186EA timing relationships are expressed in a simplified format over the 80 C 186 . The AC performance of an 80C186EA at a specified frequency will be very close to that of an 80C186 at the same frequency. Check the timings applicable to your design prior to replacing the 80 C 186 .

## PACKAGE INFORMATION

This section describes the pins, pinouts, and thermal characteristics for the 80C186EA in the Plastic Leaded Chip Carrier (PLCC) package and Quad Flat Pack (QFP) package. For complete package specifications and information, see the Intel Packaging Outlines and Dimensions Guide (Order Number: 231369).

## Pin Descriptions

Each pin or logical set of pins is described in Table 2. There are three columns for each entry in the Pin Description Table.

The Pin Name column contains a mnemonic that describes the pin function. Negation of the signal name (for example, RESIN) denotes a signal that is active low.

The Pin Type column contains two kinds of information. The first symbol indicates whether a pin is power (P), ground (G), input only (I), output only (O) or input/output (I/O). Some pins have multiplexed functions (for example, A19/S6). Additional symbols indicate additional characteristics for each pin. Table 1 lists all the possible symbols for this column.

Input pins may be either synchronous or asynchronous. Asynchronous pins require that setup and hold times be met only in order to guarantee recognition at a particular clock edge. Synchronous pins require that setup and hold times be met to guarantee proper operation. For example, missing the setup or hold time for the SRDY pin (a synchronous input) will result in a system failure or lockup. Input pins may also be edge- or level-sensitive. The possible characteristics for input pins are $S(E), S(L), A(E)$ and $A(L)$.

Output states are dependent upon the current activity of the processor. There are four operational states that are different from regular operation: bus hold, reset, Idle Mode and Powerdown Mode. Appropriate characteristics for these states are also indicated in this column, with the legend for all possible characteristics in Table 1.

Finally, the Pin Description column contains a text description of each pin.

As an example, consider AD15:0. I/O signifies the pins are bidirectional. $\mathrm{S}(\mathrm{L})$ signifies that the input function is synchronous and level-sensitive. $H(Z)$ signifies that, as outputs, the pins are high-impedance upon acknowledgement of bus hold. $R(Z)$ signifies that the pins float during reset. $P(X)$ signifies that the pins retain their states during Powerdown Mode.

Table 1. Pin Description Nomenclature

| Symbol | Description |
| :---: | :---: |
| $\begin{aligned} & \hline P \\ & G \\ & \mathrm{I} \\ & \mathrm{O} \\ & \mathrm{I} / \mathrm{O} \end{aligned}$ | Power Pin (Apply $+\mathrm{V}_{\mathrm{CC}}$ Voltage) <br> Ground (Connect to $\mathrm{V}_{\mathrm{SS}}$ ) <br> Input Only Pin <br> Output Only Pin <br> Input/Output Pin |
| $\begin{aligned} & S(E) \\ & S(L) \\ & A(E) \\ & A(L) \end{aligned}$ | Synchronous, Edge Sensitive Synchronous, Level Sensitive Asynchronous, Edge Sensitive Asynchronous, Level Sensitive |
| $\begin{aligned} & H(1) \\ & H(0) \\ & H(Z) \\ & H(Q) \\ & H(X) \end{aligned}$ | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Bus Hold <br> Output Driven to Vss during Bus Hold <br> Output Floats during Bus Hold <br> Output Remains Active during Bus Hold <br> Output Retains Current State during Bus Hold |
| R(WH) <br> $\mathrm{R}(1)$ <br> $\mathrm{R}(0)$ <br> R(Z) <br> R(Q) <br> $R(X)$ | Output Weakly Held at $\mathrm{V}_{\mathrm{CC}}$ during Reset <br> Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Reset <br> Output Driven to $\mathrm{V}_{\text {SS }}$ during Reset <br> Output Floats during Reset <br> Output Remains Active during Reset <br> Output Retains Current State during Reset |
| 1(1) <br> I(0) <br> I(Z) <br> I(Q) <br> I(X) | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Idle Mode <br> Output Driven to $\mathrm{V}_{\text {SS }}$ during Idle Mode <br> Output Floats during Idle Mode <br> Output Remains Active during Idle Mode <br> Output Retains Current State during Idle Mode |
| $P(1)$ <br> $P(0)$ <br> $P(Z)$ <br> $P(Q)$ <br> $P(X)$ | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Powerdown Mode Output Driven to $\mathrm{V}_{\mathrm{SS}}$ during Powerdown Mode Output Floats during Powerdown Mode Output Remains Active during Powerdown Mode Output Retains Current State during Powerdown Mode |

Table 2. 80C186EA Pin Descriptions

| Name | Type | Description |
| :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | P | POWER connections consist of six pins which must be shorted externally to a $\mathrm{V}_{\mathrm{CC}}$ board plane. |
| $\mathrm{V}_{\mathrm{ss}}$ | G | GROUND connections consist of five pins which must be shorted externally to a $V_{\text {SS }}$ board plane. |
| CLKIN | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | CLock INput is an input for an external clock. An external oscillator operating at two times the required 80C186EA operating frequency can be connected to CLKIN. For crystal operation, CLKIN (along with OSCOUT) are the crystal connections to an internal Pierce oscillator. |
| OSCOUT | $\begin{aligned} & \mathrm{O} \\ & \mathrm{H}(\mathrm{Q}) \\ & \mathrm{R}(\mathrm{Q}) \\ & \mathrm{P}(\mathrm{Q}) \end{aligned}$ | OSCillator OUTput is only used when using a crystal to generate the external clock. OSCOUT (along with CLKIN) are the crystal connections to an internal Pierce oscillator. This pin is not to be used as 2 X clock output for non-crystal applications (i.e., this pin is N.C. for non-crystal applications). OSCOUT does not float in ONCE mode. |
| CLKOUT | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(\mathrm{Q}) \\ \mathrm{P}(\mathrm{Q}) \\ \hline \end{gathered}$ | CLocK OUTput provides a timing reference for inputs and outputs of the processor, and is one-half the input clock (CLKIN) frequency. CLKOUT has a $50 \%$ duty cycle and transistions every falling edge of CLKIN. |
| $\overline{\text { RESIN }}$ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | RESet IN causes the 80C186EA to immediately terminate any bus cycle in progress and assume an initialized state. All pins will be driven to a known state, and RESOUT will also be driven active. The rising edge (low-to-high) transition synchronizes CLKOUT with CLKIN before the 80C186EA begins fetching opcodes at memory location OFFFFOH. |
| RESOUT | $\begin{gathered} \hline \mathrm{O} \\ \mathrm{H}(0) \\ \mathrm{R}(1) \\ \mathrm{P}(0) \\ \hline \end{gathered}$ | RESet OUTput that indicates the 80C186EA is currently in the reset state. RESOUT will remain active as long as RESIN remains active. When tied to the TEST/BUSY pin, RESOUT forces the 80C186EA into Numerics Mode. |
| PDTMR | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{~A}(\mathrm{~L}) \\ \mathrm{H}(\mathrm{WH}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Power-Down TiMeR pin (normally connected to an external capacitor) that determines the amount of time the 80C186EA waits after an exit from power down before resuming normal operation. The duration of time required will depend on the startup characteristics of the crystal oscillator. |
| NMI | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | Non-Maskable Interrupt input causes a Type 2 interrupt to be serviced by the CPU. NMI is latched internally. |
| TEST/BUSY | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | TEST/BUSY is sampled upon reset to determine whether the 80C186EA is to enter Numerics Mode. In regular operation, the pin is TEST. TEST is used during the execution of the WAIT instruction to suspend CPU operation until the pin is sampled active (low). In Numerics Mode, the pin is BUSY. BUSY notifies the 80C186EA of 80C187 Numerics Coprocessor activity. |
| AD15:0 | $\begin{aligned} & \hline I / O \\ & S(L) \\ & H(Z) \\ & R(Z) \\ & P(X) \end{aligned}$ | These pins provide a multiplexed Address and Data bus. During the address phase of the bus cycle, address bits 0 through 15 are presented on the bus and can be latched using ALE. 8 - or 16 -bit data information is transferred during the data phase of the bus cycle. |
| $\begin{aligned} & \text { A18:16 } \\ & \text { A19/S6 } \end{aligned}$ | $\begin{aligned} & \hline H(Z) \\ & R(Z) \\ & P(X) \end{aligned}$ | These pins provide multiplexed Address during the address phase of the bus cycle. Address bits 16 through 19 are presented on these pins and can be latched using ALE, A18:16 are driven to a logic 0 during the data phase of the bus cycle. Also during the data phase, S6 is driven to a logic 0 to indicate a CPU-initiated bus cycle or logic 1 to indicate a DMA-initiated bus cycle or a refresh cycle. |

Table 2. 80C186EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| S2:0 | 0 <br> H(Z) <br> R(Z) <br> $P(1)$ | Bus cycle Status are encoded on these pins to provide bus transaction information. $\overline{\mathrm{S} 2: 0}$ are encoded as follows: |
| ALE/QSO | $\begin{gathered} \hline O \\ H(0) \\ R(0) \\ P(0) \\ \hline \end{gathered}$ | Address Latch Enable output is used to strobe address information into a transparent type latch during the address phase of the bus cycle. In Queue Status Mode, QSO provides queue status information along with QS1. |
| $\overline{\mathrm{BHE}}$ | 0 <br> $H(Z)$ <br> R(Z) <br> $P(X)$ | Byte High Enable output to indicate that the bus cycle in progress is transferring data over the upper half of the data bus. BHE and AO have the following logical encoding: |
| $\overline{\text { RD } / \overline{Q S M D}}$ | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{P}(1) \end{gathered}$ | ReaD output signals that the accessed memory or I/O device must drive data information onto the data bus. Upon reset, this pin has an alternate function. As QSMD, it enables Queue Status Mode when grounded. In Queue Status Mode, the ALE/QS0 and WR/QS1 pins provide the following information about processor/instruction queue interaction: |
| $\overline{\text { WR/QS1 }}$ | O <br> $H(Z)$ <br> R(Z) <br> $P(1)$ | WRite output signals that data available on the data bus are to be written into the accessed memory or I/O device. In Queue Status Mode, QS1 provides queue status information along with QSO. |
| ARDY | $\begin{gathered} \hline 1 \\ A(L) \\ S(L) \end{gathered}$ | Asychronous ReaDY is an input to signal for the end of a bus cycle. ARDY is asynchronous on rising CLKOUT and synchronous on falling CLKOUT. ARDY or SRDY must be active to terminate any 80C186EA bus cycle, unless they are ignored due to correct programming of the Chip Select Unit. |
| SRDY | $\begin{gathered} 1 \\ S(L) \end{gathered}$ | Synchronous ReaDY is an input to signal for the end of a bus cycle. ARDY or SRDY must be active to terminate any 80C186EA bus cycle, unless they are ignored due to correct programming of the Chip Select Unit. |
| $\overline{\mathrm{DEN}}$ | $\begin{gathered} O \\ H(Z) \\ R(Z) \\ P(1) \\ \hline \end{gathered}$ | Data ENable output to control the enable of bidirectional transceivers when buffering an 80C186EA system. $\overline{\text { DEN }}$ is active only when data is to be transferred on the bus. |

Table 2. 80C186EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| DT/ $\bar{R}$ | $\begin{gathered} 0 \\ H(Z) \\ R(Z) \\ P(X) \\ \hline \end{gathered}$ | Data Transmit/Receive output controls the direction of a bi-directional buffer when buffering an 80C186EA system. DT/ $\bar{R}$ is only available for the QFP (EIAJ) package (S80C186EA). |
| $\overline{\text { LOCK }}$ | $\begin{gathered} 1 / O \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | LOCK output indicates that the bus cycle in progress is not to be interrupted. The 80C186EA will not service other bus requests (such as HOLD) while $\overline{\text { LOCK }}$ is active. This pin is configured as a weakly held high input while RESIN is active and must not be driven low. |
| HOLD | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | HOLD request input to signal that an external bus master wishes to gain control of the local bus. The 80C186EA will relinquish control of the local bus between instruction boundaries not conditioned by a LOCK prefix. |
| HLDA | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(0) \\ \mathrm{P}(0) \\ \hline \end{gathered}$ | HoLD Acknowledge output to indicate that the 80C186EA has relinquish control of the local bus. When HLDA is asserted, the 80C186EA will (or has) floated its data bus and control signals allowing another bus master to drive the signals directly. |
| $\overline{\text { UCS }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \end{gathered}$ | Upper Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. After reset, $\overline{U C S}$ is configured to be active for memory accesses between OFFCOOH and OFFFFFH. During a processor reset, $\overline{U C S}$ and $\overline{\text { LCS }}$ are used to enable ONCE Mode. |
| $\overline{\text { LCS }}$ | $\begin{gathered} 0 \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Lower Chip Select will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. $\overline{\text { LCS }}$ is inactive after a reset. During a processor reset, UCS and $\overline{\text { LCS }}$ are used to enable ONCE Mode. |
| MCSO/PEREQ <br> MCS1/ERROR <br> $\overline{\text { MCS2 }}$ <br> $\overline{\mathrm{MCS}} / \overline{\mathrm{NCS}}$ | I/O <br> H(1) <br> $\mathrm{R}(1)$ <br> $P(1)$ <br> A(L) | These pins provide a multiplexed function. If enabled, these pins normally comprise a block of Mid-Range Chip Select outputs which will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. In Numerics Mode, three of the pins become handshaking pins for the 80C187. The CoProcessor REQuest input signals that a data transfer is pending. ERROR is an input which indicates that the previous numerics coprocessor operation resulted in an exception condition. An interrupt Type 16 is generated when ERROR is sampled active at the beginning of a numerics operation. Numerics Coprocessor Select is an output signal generated when the processor accesses the 80C187. |
| $\overline{\text { PCS4:0 }}$ | 0 <br> $H(1)$ <br> $R(1)$ <br> $P(1)$ | Peripheral Chip Selects go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. |
| $\begin{array}{\|l\|} \hline \overline{\mathrm{PCS5} / \mathrm{A} 1} \\ \overline{\mathrm{PCS6}} / \mathrm{A} 2 \end{array}$ | $\begin{gathered} \hline 0 \\ H(1) / H(X) \\ R(1) \\ P(1) \end{gathered}$ | These pins provide a multiplexed function. As additional Peripheral Chip Selects, they go active whenever the address of a memory or I/O bus cycle is within the address limitations by the user. They may also be programmed to provide latched Address A2:1 signals. |
| TOOUT T10UT | 0 <br> H(Q) <br> $R(1)$ <br> $P(Q)$ | Timer OUTput pins can be programmed to provide a single clock or continuous waveform generation, depending on the timer mode selected: |
| $\begin{array}{\|l} \hline \text { TOIN } \\ \text { TilN } \end{array}$ | $\begin{gathered} 1 \\ A(L) \\ A(L) \end{gathered}$ | Timer INput is used either as clock or control signals, depending on the timer mode selected. |

Table 2. 80C186EA Pin Descriptions (Continued)

| Name | Type | Description |
| :--- | :---: | :--- |
| DRQ0 |  |  |
| DRQ1 |  |  |$\quad$| I |
| :---: |
| A(L) |$\quad$| DMA ReQuest is asserted by an external request when it is prepared for a |
| :--- |
| DMA transfer. |

## 80C186EA PINOUT

Tables 3 and 4 list the 80C186EA pin names with package location for the 68 -pin Plastic Leaded Chip Carrier (PLCC) component. Figure 9 depicts the complete 80C186EA pinout (PLCC package) as viewed from the top side of the component (i.e., contacts facing down).

Tables 5 and 6 list the 80C186EA pin names with package location for the 80 -pin Quad Flat Pack (EIAJ) component. Figure 6 depicts the complete 80C186EA (EIAJ QFP package) as viewed from the top side of the component (i.e., contacts facing down).

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 17 |
| AD1 | 15 |
| AD2 | 13 |
| AD3 | 11 |
| AD4 | 8 |
| AD5 | 6 |
| AD6 | 4 |
| AD7 | 2 |
| AD8 | 16 |
| AD9 | 14 |
| AD10 | 12 |
| AD111 | 10 |
| AD12 | 7 |
| AD13 | 5 |
| AD14 | 3 |
| AD15 | 1 |
| A16 | 68 |
| A17 | 67 |
| A18 | 66 |
| A19/S6 | 65 |

Table 3. PLCC Pin Names with Package Location

| Bus Control |  | Processor Control |  | 1/0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Name | Location | Name | Location | Name | Location |
| ALE/QSO | 61 | $\overline{\text { RESIN }}$ | 24 | $\overline{\text { UCS }}$ | 34 |
| BHE | 64 | RESOUT | 57 | $\overline{\text { LCS }}$ | 33 |
| So | 52 | CLKIN | 59 | $\overline{\text { MCSO } / P E R E Q}$ | 38 |
| S1 | 53 | OSCOUT | 58 | $\overline{\text { MCS1/ERROR }}$ | 37 |
| $\overline{\text { S2 }}$ | 54 | Clkout | 56 | $\overline{\text { MCS2 }}$ | 36 |
| $\overline{\mathrm{RD}} / \overline{\text { QSMD }}$ | 62 | TEST/BUSY | 47 | $\overline{\mathrm{MCS} 3} / \overline{\mathrm{NCS}}$ | 35 |
| $\overline{\text { WR/QS1 }}$ | 63 | PDTMR | 40 | $\overline{\text { PCSO }}$ | 25 |
| ARDY | 55 | NMI | 46 | $\overline{\text { PCS } 1}$ | 27 |
| SRDY | 49 | NMTO | 45 | $\overline{\text { PCS2 }}$ | 28 |
| $\overline{\mathrm{DEN}}$ | 39 | INT1/SELECT | 44 | $\overline{\text { PCS3 }}$ | 29 |
| LOCK | 48 | INT2/INTAO | 44 | $\overline{\text { PCS4 }}$ | 30 |
| HOLD | 50 | INT3//[TA1/ | 41 |  | 31 |
| HLDA | 51 | IRQ |  | PCS6/A2 | 32 |
|  |  |  |  | TOIN | 20 |
|  |  |  |  | TIOUT | 23 |
| Name | Location |  |  | T1IN | 21 |
|  |  |  |  | DRQ0 | 18 |
| $\mathrm{v}_{\mathrm{CC}}$ | 9, 9 |  |  | DRQ1 | 19 |

Table 4. PLCC Package Locations with Pin Name

| Location | Name |
| :---: | :--- |
| 1 | AD15 |
| 2 | AD7 |
| 3 | AD14 |
| 4 | AD6 |
| 5 | AD13 |
| 6 | AD5 |
| 7 | AD12 |
| 8 | AD4 |
| 9 | VCC |
| 10 | AD11 |
| 11 | AD3 |
| 12 | AD10 |
| 13 | AD2 |
| 14 | AD9 |
| 15 | AD1 |
| 16 | AD8 |
| 17 | AD0 |


| Location | Name |
| :---: | :--- |
| 18 | DRQ0 |
| 19 | DRQ1 |
| 20 | TOIN |
| 21 | T1IN |
| 22 | T0OUT |
| 23 | T1OUT |
| 24 | $\overline{\text { RESIN }}$ |
| 25 | $\overline{\text { PCS0 }}$ |
| 26 | $\overline{V_{S S}}$ |
| 27 | $\overline{\text { PCS1 }}$ |
| 28 | $\overline{\text { PCS2 }}$ |
| 29 | $\overline{\text { PCS3 }}$ |
| 30 | $\overline{\text { PCS4 }}$ |
| 31 | $\overline{\text { PCS5/A1 }}$ |
| 32 | $\overline{\text { PCS6 } / A 2 ~}$ |
| 33 | $\overline{\text { LCS }}$ |
| 34 | $\overline{\mathrm{UCS}}$ |


| Location | Name |
| :---: | :--- |
| 35 | $\overline{\text { MCS3}} / \overline{\text { NCS }}$ |
| 36 | $\overline{M C S 2}$ |
| 37 | $\overline{\text { MCS1/ERROR }}$ |
| 38 | $\overline{M C S 0} / P E R E Q$ |
| 39 | $\overline{\text { DEN }}$ |
| 40 | PDTMR |
| 41 | INT3/INTA1/ |
|  | IRQ |
| 42 | INT2/INTAO |
| 43 | VCC $_{\text {CO }}$ |
| 44 | INT1/SELECT |
| 45 | INTO |
| 46 | NMI |
| 47 | $\overline{\text { TEST/BUSY }}$ |
| 48 | LOCK |
| 49 | SRDY |
| 50 | HOLD |
| 51 | HLDA |


| Location | Name |
| :---: | :--- |
| 52 | $\overline{\mathrm{So}}$ |
| 53 | $\overline{\mathrm{~S} 1}$ |
| 54 | $\overline{\mathrm{~S} 2}$ |
| 55 | ARDY |
| 56 | CLKOUT |
| 57 | RESOUT |
| 58 | OSCOUT |
| 59 | CLKIN |
| 60 | V SS |
| 61 | ALE/QSO |
| 62 | $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ |
| 63 | $\overline{\mathrm{WR} / \mathrm{QS} 1}$ |
| 64 | $\overline{\mathrm{BHE}}$ |
| 65 | $\mathrm{~A} 19 / \mathrm{S} 6$ |
| 66 | A 18 |
| 67 | A 17 |
| 68 | A 16 |



Figure 5. 68-Lead PLCC Pinout Diagram

Table 5. QFP (EIAJ) Pin Name with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 64 |
| AD1 | 66 |
| AD2 | 68 |
| AD3 | 70 |
| AD4 | 74 |
| AD5 | 76 |
| AD6 | 78 |
| AD7 | 80 |
| AD8 | 65 |
| AD9 | 67 |
| AD10 | 69 |
| AD11 | 71 |
| AD12 | 75 |
| AD13 | 77 |
| AD14 | 79 |
| AD15 | 1 |
| A16 | 3 |
| A17 | 4 |
| A18 | 5 |
| A19/S6 | 6 |


| Bus Control |  |
| :--- | :---: |
| Name | Location |
| ALE/QSO | 10 |
| $\overline{\mathrm{BHE}}$ | 7 |
| $\overline{\mathrm{SO}}$ | 23 |
| $\overline{\mathrm{~S} 1}$ | 22 |
| $\overline{\mathrm{~S} 2}$ | 21 |
| $\overline{\mathrm{RD} / \overline{\mathrm{QSMD}}}$ | 9 |
| $\overline{\mathrm{WR} / \mathrm{QS} 1}$ | 8 |
| ARDY | 20 |
| SRDY | 27 |
| $\overline{\mathrm{DT} / \overline{\mathrm{R}}}$ | 37 |
| $\overline{\mathrm{DEN}}$ | 39 |
| $\overline{\text { LOCK }}$ | 28 |
| HOLD | 26 |
| HLDA | 25 |


| Processor Control |  |
| :--- | :---: |
| Name | Location |
| RESIN | 55 |
| RESOUT | 18 |
| CLKIN | 16 |
| OSCOUT | 17 |
| CLKOUT | 19 |
| TEST/BUSY | 29 |
| PDTMR | 38 |
| NMI | 30 |
| INTO | 31 |
| INT1/SELECT | 32 |
| INT2/INTAO | 35 |
| INT3/INTA1/ | 36 |
| IRQ |  |
| N.C. | 11,14, |
|  | 15,63 |


| 1/0 |  |
| :---: | :---: |
| Name | Location |
| $\overline{\text { UCS }}$ | 45 |
| LCS | 46 |
| $\overline{\text { MCSO} / P E R E Q ~}$ | 40 |
| MCS1/ERROR | 41 |
| $\overline{\text { MCS2 }}$ | 42 |
| $\overline{\mathrm{MCS3}} / \overline{\mathrm{NCS}}$ | 43 |
| $\overline{\text { PCSO }}$ | 54 |
| PCS1 | 52 |
| PCS2 | 51 |
| $\overline{\text { PCS3 }}$ | 50 |
| PCS4 | 49 |
| PCS5/A1 | 48 |
| PCS6/A2 | 47 |
| TOOUT | 57 |
| TOIN | 59 |
| T1OUT | 56 |
| T1IN | 58 |
| DRQ0 | 61 |
| DRQ1 | 60 |

Table 6. QFP (EIAJ) Package Location with Pin Names

| Location | Name |
| :---: | :--- |
| 1 | $\mathrm{AD15}$ |
| 2 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 3 | A 16 |
| 4 | A 17 |
| 5 | A 18 |
| 6 | $\mathrm{~A} 19 / \mathrm{S6}$ |
| 7 | $\overline{\mathrm{BHE}}$ |
| 8 | $\overline{\mathrm{WR}} / \mathrm{QS} 1$ |
| 9 | $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ |
| 10 | $\mathrm{ALE} / \mathrm{QSO}$ |
| 11 | $\mathrm{~N} . \mathrm{C}$. |
| 12 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 13 | VSS |
| 14 | $\mathrm{~N} . \mathrm{C}$. |
| 15 | N.C. |
| 16 | CLKIN |
| 17 | OSCOUT |
| 18 | RESOUT |
| 19 | CLKOUT |
| 20 | ARDY |


| Location | Name |
| :---: | :---: |
| 21 | S2 |
| 22 | S1 |
| 23 | $\overline{\text { So }}$ |
| 24 | $V_{\text {SS }}$ |
| 25 | HLDA |
| 26 | HOLD |
| 27 | SRDY |
| 28 | LOCK |
| 29 | TEST/BUSY |
| 30 | NMI |
| 31 | INTO |
| 32 | INT1/SELECT |
| 33 | $\mathrm{V}_{\mathrm{CC}}$ |
| 34 | $V_{\text {CC }}$ |
| 35 | INT2/INTAO |
| 36 | INT3/INTA1/ IRQ |
| 37 | DT/ $\bar{R}$ |
| 38 | PDTMR |
| 39 | DEN |
| 40 | MCSO/PEREQ |


| Location | Name |
| :---: | :---: |
| 41 | MCS1/ERROR |
| 42 | $\overline{M C S 2}$ |
| 43 | $\overline{\text { MCS3 }} / \overline{\text { NCS }}$ |
| 44 | $\mathrm{V}_{\mathrm{CC}}$ |
| 45 | UCS |
| 46 | LCS |
| 47 | PCS6/A2 |
| 48 | PCS5/A1 |
| 49 | $\overline{\text { PCS4 }}$ |
| 50 | $\overline{\text { PCS3 }}$ |
| 51 | PCS2 |
| 52 | $\overline{\text { PCS1 }}$ |
| 53 | $V_{\text {SS }}$ |
| 54 | $\overline{\text { PCSO }}$ |
| 55 | RESIN |
| 56 | T1OUT |
| 57 | TOOUT |
| 58 | TIIN |
| 59 | TOIN |
| 60 | DRQ1 |


| Location | Name |
| :---: | :--- |
| 61 | DRQ0 |
| 62 | VSS $^{2}$ |
| 63 | N.C. |
| 64 | AD0 |
| 65 | AD8 |
| 66 | AD1 |
| 67 | AD9 |
| 68 | AD2 |
| 69 | AD10 |
| 70 | AD3 |
| 71 | AD11 |
| 72 | VCC |
| 73 | VCC |
| 74 | AD4 |
| 75 | AD12 |
| 76 | AD5 |
| 77 | AD13 |
| 78 | AD6 |
| 79 | AD14 |
| 80 | AD7 |



Figure 6. Quad Flat Pack (EIAJ) Pinout Diagram

## PACKAGE THERMAL SPECIFICATIONS

The 80C186EA is specified for operation when Tc (the case temperature) is within the range of $0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ (PLCC package) or $0^{\circ} \mathrm{C}$ to $106^{\circ} \mathrm{C}$ (QFP-EIAJ) package. Tc may be measured in any environment to determine whether the 80C186EA is within the specified operating range. The case temperature must be measured at the center of the top surface.
$T_{A}$ (the ambient temperature) can be calculated from $\theta_{C A}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\mathrm{CA}}$ at various airflows are given in Table 7 for the 68 -pin Plastic Leaded Chip Carrier (PLCC) package.

Table 8 shows the maximum $\mathrm{T}_{\mathrm{A}}$ allowable (without exceeding $\mathrm{T}_{\mathrm{c}}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumption, specified in watts) is calculated by using the maximum ICC as tabulated in the DC specifications and $\mathrm{V}_{\mathrm{CC}}$ of 5.5 V .

$$
T_{A}=T_{C}-P \times \theta_{C A}
$$

Table 7. Thermal Resistance ( $\boldsymbol{\theta}_{\mathbf{C A}}$ ) at Various Airflows (in ${ }^{\circ} \mathrm{C} / \mathrm{Watt}$ )

|  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{0}$ <br> $(0)$ | $\mathbf{2 0 0}$ <br> $\mathbf{( 1 . 0 1 )}$ | $\mathbf{4 0 0}$ <br> $\mathbf{( 2 . 0 3 )}$ | $\mathbf{6 0 0}$ <br> $\mathbf{( 3 . 0 4 )}$ | $\mathbf{8 0 0}$ <br> $\mathbf{( 4 . 0 6 )}$ | $\mathbf{1 0 0 0}$ <br> $(5.07)$ |
| $\theta_{\mathrm{CA}}$ (PLCC) | 29 | 25 | 21 | 19 | 17 | 16.5 |
| $\theta_{\mathrm{CA}}$ (QFP) | 66 | 63 | 60.5 | 59 | 58 | 57 |

Table 8. Maximum $\mathrm{T}_{\mathrm{A}}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TF | 0 | 200 | 400 | 600 | 800 | 1000 |
|  | (MHz) | (0) | (1.01) | (2.03) | (3.04) | (4.06) | (5.07) |
| $\mathrm{T}_{\mathrm{A}}$ (PLCC) | 25 | 78 | 80 | 81 | 82 | 82.5 | 83 |
|  | 32 | 74 | 76 | 78 | 79 | 79.5 | 80 |
|  | 40 | 70 | 72 | 74 | 75 | 76 | 76.5 |
| $\mathrm{T}_{\mathrm{A}}$ (QFP) | 25 | 84 | 85.5 | 86 | 87 | 87 | 87.5 |
|  | 32 | 77.5 | 79 | 80 | 80.5 | 81 | 81.5 |
|  | 40 | 70 | 71.5 | 73 | 74 | 74 | 75 |

## ELECTRICAL SPECIFICATIONS

## Absolute Maximum Ratings*

Storage Temperature $\ldots . . \ldots . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Case Temperature under Bias $\ldots-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Supply Voltage with Respect

Voltage on Other Pins with Respect
to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots \ldots \ldots \ldots \ldots-0.5 \mathrm{~F}$ to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## Operating Conditions

| Symbol | Parameter | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.5 | 5.5 | V |
| $\mathrm{~T}_{\mathrm{F}}$ | Input Clock Frequency |  |  |  |
|  | 80C186EA20 | 0 | 40 | MHz |
|  | 80C186EA16 | 0 | 32 | MHz |
|  | 80C186EA12 | 0 | 25 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature under Bias |  |  |  |
|  | N80C186EA (PLCC) | 0 | +100 | ${ }^{\circ} \mathrm{C}$ |
|  | S80C186EA (QFP) | 0 | +114 | ${ }^{\circ} \mathrm{C}$ |

## Recommended Connections

Power and ground connections must be made to multiple $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$ pins. Every 80C186EA based circuit board should contain separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground $\left(\mathrm{V}_{\mathrm{SS}}\right)$ planes. All $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$ pins must be connected to the appropriate plane. Pins identified as "N.C." must not be connected in the system. Decoupling capacitors should be placed near the 80C186EA. The value and type of decoupling capac-
itors is application and board layout dependent. The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Always connect any unused input pins to an appropriate signal level. In particular, unused interrupt pins (NMI, INT3:0) should be connected to $V_{\text {ss }}$ to avoid unwanted interrupts. Leave any unused output pin or any "N.C." pin unconnected.

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage for All Pins | -0.5 | $0.3 \mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage for All Pins | $0.7 \mathrm{~V}_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=3 \mathrm{~mA}(\mathrm{~min})$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{l}_{\mathrm{OH}}=-2 \mathrm{~mA}(\mathrm{~min})$ |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysterisis on RESIN | 0.30 |  | $\checkmark$ |  |
| ${ }_{\text {ILI }}$ | Input Leakage Current (except $\overline{\text { RD }} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{L C S}, \overline{M C S O} / P E R E Q$, $\overline{M C S 1} / \overline{E R R O R}, \overline{L O C K}$ and TEST/BUSY) | - | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IIL2 | Input Leakage Current ( $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{M C S O} / \mathrm{PEREQ}$, MCS1, ERROR, LOCK and TEST/BUSY | -275 |  | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\text {IN }}=0.7 \mathrm{~V}_{\mathrm{CC}} \\ & \text { (Note 1) } \end{aligned}$ |
| ${ }^{\text {loL }}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}} \\ & \text { (Note 2) } \end{aligned}$ |
| ICC | ```Supply Current Cold (RESET) 80C186EA20 80C186EA16 80C186EA12``` |  | $\begin{gathered} 100 \\ 80 \\ 62.5 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 3) |
| ${ }_{\text {IID }}$ | Supply Current In Idle Mode 80C186EA20 80C186EA16 80C186EA12 |  | $\begin{aligned} & 70 \\ & 56 \\ & 44 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| IPD | ```Supply Current In Powerdown Mode 80C186EA20 80C186EA16 80C186EA12``` |  | $\begin{aligned} & 100 \\ & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \mu \mathrm{~A} \end{aligned}$ |  |
| Cout | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ ( Note 4) |
| $\mathrm{C}_{\text {IN }}$ | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |

## NOTES:

1. $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{M C S O} / P E R E Q, \overline{M C S 1} / \overline{\mathrm{ERROR}}, \overline{\mathrm{LOCK}}$ and $\overline{\mathrm{TEST}} / \mathrm{BUSY}$ have internal pullups that are only activated during RESET. Loading these pins above $\mathrm{IOL}_{\mathrm{OL}}=-275 \mu \mathrm{~A}$ will cause the 80C186EA to enter alternate modes of operation.
2. Output pins are floated using HOLD or ONCE Mode.
3. Measured at worst case temperature and $V_{C C}$ with all outputs loaded as specified in the AC Test Conditions, and with the device in RESET (RESIN held low). RESET is worst case for Icc.
4. Output capacitance is the capacitive load of a floating output pin.

## Icc VERSUS FREQUENCY AND VOLTAGE

The current ( $I_{\mathrm{CC}}$ ) consumption of the 80C186EA is essentially composed of two components; IPD and Iccs.
$I_{P D}$ is the quiescent current that represents internal device leakage, and is measured with all inputs or floating outputs at GND or $V_{C C}$ (no clock applied to the device). IPD is equal to the Powerdown current and is typically less than $50 \mu \mathrm{~A}$.

ICCS is the switching current used to charge and discharge parasitic device capacitance when changing logic levels. Since ICCS is typically much greater than IPD, IPD can often be ignored when calculating ICC.

ICCS is related to the voltage and frequency at which the device is operating. It is given by the formula:

$$
\begin{aligned}
& \text { Power }=V \times I=V^{2} \times C_{D E V} \times f \\
& \therefore I=I_{C C}=I_{C C S}=V \times C_{D E V} \times f
\end{aligned}
$$

Where: $\mathrm{V}=$ Device operating voltage ( $\mathrm{V}_{\mathrm{CC}}$ )
$\mathrm{C}_{\mathrm{DEV}}=$ Device capacitance
$f=$ Device operating frequency
Iccs = Icc = Device current
Measuring $C_{D E V}$ on a device like the 80C186EA would be difficult. Instead, $\mathrm{C}_{\text {DEV }}$ is calculated using the above formula by measuring $I_{C C}$ at a known $V_{C C}$ and frequency (see Table 9). Using this CDEV value, ICC can be calculated at any voltage and frequency within the specified operating range.

EXAMPLE: Calculate the typical ICC when operating at $20 \mathrm{MHz}, 4.8 \mathrm{~V}$.

## PDTMR PIN DELAY CALCULATION

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown. A delay is required only when using the on-chip oscillator to allow the crystal or resonator circuit time to stabilize.

## NOTE:

The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e., a device reset during Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized).

To calculate the value of capacitor required to provide a desired delay, use the equation:

$$
440 \times t=C_{P D} \quad\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where: $t=$ desired delay in seconds
$\mathrm{C}_{\mathrm{PD}}=$ capacitive load on PDTMR in microfarads

EXAMPLE: To get a delay of $300 \mu \mathrm{~s}$, a capacitor value of $C_{P D}=440 \times\left(300 \times 10^{-6}\right)=0.132 \mu \mathrm{~F}$ is required. Round up to standard (available) capacitive values.

## NOTE:

The above equation applies to delay times greater than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ or $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $\mathrm{V}_{\mathrm{CC}}$ and/or lower temperature will decrease delay time, while lower $V_{C C}$ and/or higher temperature will increase delay time.

$$
I_{C C}=I_{C C S}=4.8 \times 0.515 \times 20 \approx 49 \mathrm{~mA}
$$

Table 9. C $_{\text {DEV }}$ Values

| Parameter | Typ | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{DEV}}$ (Device in Reset) | 0.515 | 0.905 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| $\mathrm{C}_{\mathrm{DEV}}$ (Device in Idle) | 0.391 | 0.635 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

1. Max $C_{D E V}$ is calculated at $-40^{\circ} \mathrm{C}$, all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND, and all outputs loaded to 50 pF (including CLKOUT and OSCOUT).
2. Typical $\mathrm{C}_{\mathrm{DEV}}$ is calculated at $25^{\circ} \mathrm{C}$ with all outputs loaded to 50 pF except CLKOUT and OSCOUT, which are not loaded.

80C186EA

## AC SPECIFICATIONS

AC Characteristics-80C186EA20 .

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 40 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 25 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 17 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{2}{ }^{\text {T }}$ C | ns | , |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | , |
| TPL | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |

OUTPUT DELAYS

| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BH}} \mathrm{E}$, LOCK, A19:16 | 3 | 22 | ns | 1, 4, 6, 7 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| T ${ }_{\text {CHOV2 }}$ | $\overline{\text { MCS3:0, }} \overline{\text { LCS }}, \overline{\text { UCS }}, \overline{\text { PCS6:0 }}$, $\overline{\text { NCS }}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 27 | ns | 1, 4, 6, 8 |
| TCLOV1 | BHE, $\overline{D E N}, \overline{L O C K}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 22 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS}}: \mathbf{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS6}} \mathbf{0}$, AD15:0, $\overline{\text { NCS }}, \overline{\text { NTA1: }}, \overline{\mathrm{S}} \mathbf{~ 2 : 0}$ | 3 | 27 | ns | 1, 4, 6 |
| T ${ }_{\text {CHOF }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 25 | ns | 1 |

SYNCHRONOUS INPUTS

| $T_{\text {CHIS }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:OIN, ARDY }}$ | 10 |  | ns | 1,9 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\text {CHIH }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:OIN, ARDY }}$ | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | AD15:0, ARDY, SRDY, DRQ1:0 | 10 |  | ns | 1,10 |
| $T_{\text {CLIH }}$ | AD15:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIS }}$ | HOLD, PEREQ, ERROR | 10 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | HOLD, PEREQ, ERROR | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | $\overline{\text { RESIN }}$ (to CLKIN $)$ | 10 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | $\overline{\text { RESIN }}$ (from CLKIN) | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 12 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 13 for rise and fall times outside 50 pF .
6. See Figure 13 for rise and fall times.
7. TCHOV ${ }_{1}$ applies to $\overline{B H E}, \overline{L O C K}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C186EA operation (SRDY, AD15:0).

AC SPECIFICATIONS (Continued)

## AC Characteristics-80C186EA16

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 32 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 31.25 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 10 | $\infty$ | ns | 1, 2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1, 3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| TCD | CLKIN to CLKOUT Delay | 0 | 20 | ns | 1,4 |
| T | CLKOUT Period |  | $2^{*} \mathrm{~T}_{\mathrm{C}}$ | ns | 1 |
| TPH | CLKOUT High Time | (T/2) - 5 | $(T / 2)+5$ | ns | 1 |
| TPL | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2: }} \mathbf{0}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}$, LOCK, A19:16 | 3 | 23 | ns | 1, 4, 6, 7 |
| TCHOV2 | $\overline{\mathrm{MCS3}} \mathbf{0}$, $\overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS6}} \mathbf{0}, \overline{\mathrm{NCS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 28 | ns | 1, 4, 6, 8 |
| TCLOV1 | BHE, $\overline{\text { DEN, }}$, LOCK, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 23 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS} 3: 0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS} 6: 0}$, AD15:0, $\overline{N C S}, \overline{I N T A 1: 0, ~} \overline{\text { S2:0 }}$ | 3 | 28 | ns | 1, 4, 6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT3:0, T1:0IN, ARDY | 10 |  | ns | 1,9 |
| TCHIH | TEST, NMI, INT3:0, T1:0IN, ARDY | 3 |  | ns | 1,9 |
| TCLIS | AD15:0, ARDY, SRDY, DRQ1:0 | 10 |  | ns | 1,10 |
| TCLIH | AD15:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD, PEREQ, ERROR | 10 |  | ns | 1,9 |
| TCLIH | HOLD, PEREQ, ERROR | 3 |  | ns | 1,9 |
| TCLIS | $\overline{\text { RESIN }}$ (to CLKIN) | 10 |  | ns | 1,9 |
| TCLIH | RESIN (from CLKIN) | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 12 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 13 for rise and fall times outside 50 pF .
6. See Figure 13 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV}}$ applies to $\overline{\mathrm{BHE}}, \overline{\mathrm{LOCK}}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{\text { RD }}$ and $\overline{\text { WR }}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C186EA operation (SRDY, AD15:0).

80C186EA

AC SPECIFICATIONS (Continued)

## AC Characteristics-80C186EA12

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 25 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 40 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 12 | $\infty$ | ns | 1, 2 |
| $\mathrm{T}_{\mathrm{CL}}$ | CLKIN Low Time | 12 | $\infty$ | ns | 1, 2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 23 | ns | 1, 4 |
| T | CLKOUT Period |  | $2^{*} \mathrm{~T}_{\mathrm{C}}$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PH}}$ | CLKOUT High Time | (T/2)-5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPL | CLKOUT Low Time | (T/2)-5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2: }} \mathbf{0}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}$, LOCK, A19:16 | 3 | 25 | ns | 1, 4, 6, 7 |
| TCHOV2 | $\overline{\mathrm{MCS3}} \mathbf{0}$, $\overline{\text { LCS }}, \overline{\mathrm{UCS}}, \overline{\text { PCS6:0 }}, \overline{\mathrm{NCS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 30 | ns | 1, 4, 6, 8 |
| TCLOV1 | BHE, $\overline{\mathrm{DEN}}, \overline{\text { LOCK, RESOUT, HLDA, }}$ T0OUT, T1OUT, A19:16 | 3 | 25 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS}}: \overline{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS}}: \mathbf{0}$, AD15:0, $\overline{\text { NCS }}, \overline{\text { INTA1:0 }}, \overline{\text { S2:0 }}$ | 3 | 30 | ns | 1, 4, 6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT3:0, T1:0IN, ARDY | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, INT3:0, T1:0IN, ARDY | 3 |  | ns | 1,9 |
| TCLIS | AD15:0, ARDY, SRDY, DRQ1:0 | 10 |  | ns | 1,10 |
| TCLIH | AD15:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD, PEREQ, ERROR | 10 |  | ns | 1,9 |
| TCLIH | HOLD, PEREQ, ERROR | 3 |  | ns | 1,9 |
| TCLIS | $\overline{\text { RESIN }}$ (to CLKIN) | 10 |  | ns | 1,9 |
| TCLIH | $\overline{\text { RESIN ( }}$ (rom CLKIN) | 3 |  | ns | 1, 9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 12 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 13 for rise and fall times outside 50 pF .
6. See Figure 13 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV}}^{1}$ applies to $\overline{\mathrm{BHE}} \overline{\mathrm{LOCK}}$ and $\mathrm{A} 19: 16$ only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C186EA operation (SRDY, AD15:0).

AC SPECIFICATIONS (Continued)
Relative Timings (80C186EA20, 16, 12)

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Rising to ALE Falling | T-15 |  | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TPLLL | Chip Selects Valid to ALE Falling | $1 / 2 T-10$ |  | ns | 1 |
| TLLAX | Address Hold from ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{\mathrm{WR}}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\text { RD }}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| $\mathrm{T}_{\text {RHLH }}$ | $\overline{\mathrm{RD}}$ Rising to ALE Rising | $1 / 2 T-10$ |  | ns | 1 |
| TWHLH | $\overline{\text { WR Rising to ALE Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| $\mathrm{T}_{\text {AFRL }}$ | Address Float to $\overline{\mathrm{RD}}$ Falling | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Falling to $\overline{\mathrm{RD}}$ Rising | (2*T) - 5 |  | ns | 2 |
| TWLWH | $\overline{\text { WR }}$ Falling to $\overline{\mathrm{WR}}$ Rising | (2*T) - 5 |  | ns | 2 |
| TRHAV | $\overline{\mathrm{RD}}$ Rising to Address Active | T-15 |  | ns |  |
| T WHDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| T WHDEX | $\overline{\text { WR Rising to } \overline{\text { DEN }} \text { Rising }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TWHPH | $\overline{\text { WR Rising to Chip Select Rising }}$ | $1 / 2 T-10$ |  | ns | 1,4 |
| TRHPH | $\overline{\mathrm{RD}}$ Rising to Chip Select Rising | $1 / 2 T-10$ |  | ns | 1,4 |
| TPHPL | $\overline{\text { CS }}$ Inactive to $\overline{\text { CS }}$ Active | $1 / 2 T-10$ |  | ns | 1 |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/㙰 Low | 0 |  | ns | 5 |
| Tovri | ONCE ( $\overline{\text { UCS, }}$ LCSS) Active to $\overline{\text { RESIN }}$ Rising | T |  | ns | 3 |
| TRHOX | ONCE (UCS, $\overline{\text { LCS }}$ ) to $\overline{\text { RESIN }}$ Rising | T |  | ns | 3 |

## NOTES:

1. Assumes equal loading on both pins.
2. Can be extended using wait states.
3. Not tested.
4. Not applicable to latched A2:1. These signals change only on falling $T_{1}$.
5. For write cycle followed by read cycle.

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 7. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms, for AC specification definitions, test pins, and illustrations.


Figure 7. AC Test Load

## AC TIMING WAVEFORMS



Figure 8. Input and Output Clock Waveform


Figure 9. Output Delay and Float Waveform


NOTE:
RESIN measured to CLKIN, not CLKOUT
Figure 10. Input Setup and Hold


Figure 11. Relative Signal Waveform

DERATING CURVES


Figure 12. Typical Output Delay Variations Versus Load Capacitance

## RESET

The 80C186EA will perform a reset operation any time the RESIN pin is active. The RESIN pin is actually synchronized before it is presented internally, which means that the clock must be operating before a reset can take effect. From a power-on state, $\overline{\text { RESIN }}$ must be held active (low) in order to guarantee correct initialization of the 80C186EA. Failure to provide RESIN while the device is powering up will result in unspecified operation of the device.

Figure 14 shows the correct reset sequence when first applying power to the 80C186EA. An external clock connected to CLKIN must not exceed the $\mathrm{V}_{\mathrm{CC}}$ threshold being applied to the 80C186EA. This is normally not a problem if the clock driver is supplied with the same $V_{C C}$ that supplies the 80C186EA. When attaching a crystal to the device, RESIN must remain active until both $\mathrm{V}_{\mathrm{CC}}$ and CLKOUT are stable (the length of time is application specific and depends on the startup characteristics of the crystal circuit). The RESIN pin is designed to operate correctly using an RC reset circuit, but the designer


Figure 13. Typical Rise and Fall Variations Versus Load Capacitance
must ensure that the ramp time for $\mathrm{V}_{\mathrm{Cc}}$ is not so long that $\overline{\text { RESIN }}$ is never really sampled at a logic low level when $V_{C C}$ reaches minimum operating conditions.

Figure 15 shows the timing sequence when RESIN is applied after $\mathrm{V}_{\mathrm{CC}}$ is stable and the device has been operating. Note that a reset will terminate all activity and return the 80C186EA to a known operating state. Any bus operation that is in progress at the time $\overline{\text { RESIN }}$ is asserted will terminate immediately (note that most control signals will be driven to their inactive state first before floating).

While $\overline{R E S I N}$ is active, signals $\overline{R D} / \overline{\text { QSMD }}, \overline{U C S}$, LCS, $\overline{M C S O} / P E R E Q, ~ M C S 1 / E R R O R, ~ L O C K, ~ a n d ~$ TEST/BUSY are configured as inputs and weakly held high by internal pullup transistors. Forcing UCS and LCS low selects ONCE Mode. Forcing QSMD low selects Queue Status Mode. Forcing TEST/ BUSY high at reset and low four clocks later enables Numerics Mode. Forcing LOCK low is prohibited and results in unspecified operation.


NOTE:
CLKOUT synchronization occurs approximately $11 / 2$ CLKIN periods after RESIN is sampled low.


## BUS CYCLE WAVEFORMS

Figures 16 through 22 present the various bus cycles that are generated by the 80C186EA. What is shown in the figure is the relationship of the various bus signals to CLKOUT. These figures along with the information present in AC Specifications allow the user to determine all the critical timing analysis needed for a given application.


NOTE:
During the data phase of the bus cycle, A19/S6 is driven high for a DMA or refresh cycle.
Figure 16. Read, Fetch and Refresh Cycle Waveform


Figure 17. Write Cycle Waveform


NOTE:
The 80C186EA drives these pins to 0 during Idle and Powerdown Modes.
Figure 18. Halt Cycle Waveform


Figure 19. INTA Cycle Waveform


Figure 20. HOLD/HLDA Waveform


Figure 21. DRAM Refresh Cycle During Hold Acknowledge


## NOTES:

Figure 22. Ready Waveform

## REGISTER BIT SUMMARY

Figures 23 through 30 present the bit definition of each register that is active (not reserved) in the Pe ripheral Control Block (PCB). Each register can be thought to occupy one word (16-bits) of either memory or I/O space, although not all bits in the register necessarily have a function. A register bit is not
guaranteed to return a specific logic value if an " $X$ " appears for the bit definition (i.e., if a zero was written to the register bit it may not be returned as a zero when read). Furthermore, a 0 must be written to any bit that is indicated by an " $X$ " to ensure compatibility with future products or potential product changes.


Figure 23. Interrupt Control Unit Registers (Master Mode)


Figure 24. Interrupt Control Unit Registers (Master Mode)


Figure 25. Interrupt Control Unit Registers (Slave Mode)


Figure 26. Timer Control Unit Registers


Figure 27. Chip-Select Unit Registers


Figure 28. DMA Unit Registers


Figure 29. Refresh Control Unit Registers


Figure 30. Power Management, Relocation and Stepping Registers

## 80C186EA EXPRESS

The Intel EXPRESS program offers an extended temperature range as an enhancement to the 80C186EA operational specifications. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

With the standard commercial temperature range, operational characteristics are guaranteed over a temperature range corresponding to $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ambient. With the extended temperature range option, operational characteristics are guaranteed over a temperature range corresponding to $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ambient.

Package types and EXPRESS versions are identified by a one- or two-letter prefix to the part number. The prefixes are listed in Table 9. All AC and DC specifications are the same for both commercial and EXPRESS parts.

Table 9. Prefix Identification

| Prefix | Package <br> Type | Temperature <br> Range |
| :---: | :--- | :--- |
| N | PLCC | Commercial |
| S | QFP (EIAJ) | Commercial |
| TN | PLCC | Extended |
| TS | QFP (EIAJ) | Extended |

## 80C186EA EXECUTION TIMINGS

A determination of 80C186EA program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.
- All word-data is located on even-address boundaries.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

With a 16 -bit BIU, the 80C186EA has sufficient bus performance to ensure that an adequate number of prefetched bytes will reside in the queue most of the time. Therefore, actual program execution time will not be substantially greater than that derived from adding the instruction timings shown.

## INSTRUCTION SET SUMMARY

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER MOV = Move: |  |  |  |  |  |  |
| Register to Register/Memory | 1000100 w | mod reg r/m |  |  | 2/12 |  |
| Register/memory to register | 1000101 w | mod reg r/m |  |  | 2/9 |  |
| Immediate to register/memory | 1100011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 12-13 | 8/16-bit |
| Immediate to register | 1011 w reg | data | data if $w=1$ |  | 3-4 | 8/16-bit |
| Memory to accumulator | 1010000 w | addr-low | addr-high |  | 8 |  |
| Accumulator to memory | 1010001 w | addr-low | addr-high |  | 9 |  |
| Register/memory to segment register | 10001110 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2/9 |  |
| Segment register to register/memory | 10001100 | $\bmod 0$ reg r/m |  |  | 2/11 |  |
| PUSH = Push: |  |  |  |  |  |  |
| Memory | 11111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  | 16 |  |
| Register | 01010 reg |  |  |  | 10 | - |
| Segment register | 000 reg 110 |  |  |  | 9 |  |
| Immediate | 01101050 | data | datalis $=0$ |  | 10 |  |
|  |  |  |  |  |  |  |
| PUSHM = Push Al | 01100000 |  |  |  | 36 |  |
| $\mathbf{P O P}=\mathbf{P O p}:$ |  |  |  |  |  |  |
| Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 20 |  |
| Register | 01011 reg |  |  |  | 10 |  |
| Segment register | 000 reg 111 | $(\mathrm{reg}=01$ ) |  |  | 8 | . |
| POPA = PopAll \/. | 01100001. |  |  |  | 51 | \%.\%\%\% |
| XCHG = Exchange: |  |  |  |  |  |  |
| Register/memory with register | 1000011 w | mod reg r/m |  |  | 4/17 |  |
| Register with accumulator | 10.010 reg |  |  |  | 3 |  |
| IN = Input from: |  |  |  |  |  |  |
| Fixed port | 1110010 w | port |  |  | 10 | - |
| Variable port | 1110110 w |  |  |  | 8 |  |
| OUT = Output to: |  |  |  |  |  |  |
| Fixed port | 1110011 w | port |  |  | 9 |  |
| Variable port | 1110111 w |  |  |  | 7 |  |
| XLAT = Translate byte to AL | 11010111 |  |  |  | 11 |  |
| LEA = Load EA to register | 10001101 | mod reg r/m |  |  | 6 |  |
| LDS = Load pointer to DS | 11000101 | mod reg r/m | $(\bmod \neq 11)$ |  | 18 |  |
| LES = Load pointer to ES | 11000100 | mod reg r/m | $(\bmod \neq 11)$ |  | 18 |  |
| LAHF = Load AH with flags | 10011111 |  |  |  | 2 |  |
| SAHF = Store AH into flags | 10011110 |  |  |  | 3 |  |
| PUSHF = Push flags | 10011100 |  |  |  | 9 |  |
| POPF $=$ Pop flags | 10011101 |  |  |  | 8 |  |

Shaded areas indicate instructions not available in $8086 / 8088$ microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

## INSTRUCTION SET SUMMARY (Continued)



[^5]INSTRUCTION SET SUMMARY (Continued)


[^6]
## INSTRUCTION SET SUMMARY (Continued)



Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PROCESSOR CONTROL |  |  |  |  |
| CLC = Clear carry | 11111000 |  | 2 |  |
| CMC = Complement carry | 11110101 |  | 2 |  |
| STC $=$ Set carry | 11111001 |  | 2 |  |
| CLD $=$ Clear direction | 11111100 |  | 2 |  |
| STD $=$ Set direction | 11111101 |  | 2 |  |
| CLI = Clear interrupt | 11111010 |  | 2 |  |
| $\mathbf{S T I}=$ Set interrupt | 11111011 |  | 2 |  |
| HLT $=$ Halt | 11110100 |  | 2 |  |
| WAIT $=$ Wait | 10011011 |  | 6 | if $\overline{\text { TEST }}=0$ |
| LOCK = Bus lock prefix | 11110000 |  | 2 |  |
| NOP $=$ No Operation | 10010000 |  | 3 |  |
| (TTT LLL are opcode to processor extension) |  |  |  |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields: if mod $=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field if $\bmod =00$ then DISP $=0^{*}$, disp-low and disphigh 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)+$ DISP
if $\mathrm{r} / \mathrm{m}=010$ then $E A=(B P)+(S I)+D I S P$
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then $\mathrm{EA}=(\mathrm{SI})+\mathrm{DISP}$
if $\mathrm{r} / \mathrm{m}=101$ then $E A=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=(\mathrm{BP})+\mathrm{DISP}^{*}$
if $\mathrm{r} / \mathrm{m}=111$ then $\mathrm{EA}=(B X)+$ DISP
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

## Segment Override Prefix

$$
\begin{array}{lllllll}
\hline 0 & 0 & 1 & \text { reg } & 1 & 1 & 0 \\
\hline
\end{array}
$$

reg is assigned according to the following:

## Segment

reg Register
00 ES
01 CS
10 SS
11 DS
REG is assigned according to the following table:

| $\mathbf{1 6 - B i t}(\mathbf{w}=\mathbf{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.


NOTE:
Units are $\mathrm{mm} /$ (inches).
Figure 31. PLCC Principal Dimensions


NOTE:
Units are mm (inches) unless specified.
Figure 32. QFP (EIAJ) Principal Dimensions

## REVISION HISTORY

Intel 80C186EA devices are marked with a 9-character alphanumeric Intel FPO number underneath the product number. This data sheet (272019-001) is valid for 80C186EA devices with an "A" or " $B$ " as the ninth character in the FPO number, as illustrated in Figure 5 for the 68-lead PLCC package and Figure 6 for the 84-lead QFP (EIAJ) package. Such devices may also be identified by reading a value of 01 H or 02 H from the STEPID register.

The following changes were made between the -001 and -002 versions of the 80 C 188 EA data sheets. The -002 data sheet applies to any 80C188EA with a "B" alpha character after the FPO number. The FPO number location is shown in Figures 5 and 6.

1. Much of the information provided in the -001 version of the data sheet has been removed. Detail descriptions of part functionality may be found in the 80C188EA User's Manual.

## ERRATA

An 80C186EA with a STEPID value of 01 H or 02 H has the following known errata. A device with a STEPID of 01 H or 02 H can be visually identified by noting the presence of an " $A$ " or " $B$ " alpha character, repectively, next to the FPO number. The FPO number location is shown in Figures 5 and 6.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistantly, it is dependent on interrupt timing.

# 80C186EB-20, -16, -13, -8 16-BIT HIGH-INTEGRATION EMBEDDED PROCESSOR 

\author{

- Full Static Operation <br> - True CMOS Inputs and Outputs <br> $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operating Temperature Range
}

Integrated Feature Set

- Low-Power Static CPU Core
- Two Independent UARTs each with an Integral Baud Rate Generator
— Two 8-Bit Multiplexed I/O Ports
— Programmable Interrupt Controller
- Three Programmable 16-Bit Timer/Counters
- Clock Generator
- Ten Programmable Chip Selects with Integral Wait-State Generator
- Memory Refresh Control Unit
- System Level Testing Support (ONCETM Mode)
- Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Speed Versions Available:
- 20 MHz (80C186EB-20)
- 16 MHz (80C186EB-16)
- 13 MHz (80C186EB-13)
- 8 MHz (80C186EB-8)
- Low-Power Operating Modes:
— Idle Mode Freezes CPU Clocks but keeps Peripherals Active
- Powerdown Mode Freezes All Internal Clocks
- Complete System Development Support
- ASM86 Assembler, PL/M 86, Pascal 86, Fortran 86, C-86, and System Utilities
- In-Circuit Emulator (ICETM-186EB)

■ Supports 80C187 Numeric Coprocessor Interface (TN80C186EB Only)

- Available In:
—80-Pin Quad Flat Pack (TS80C186EB)
- 84-Pin Plastic Leaded Chip Carrier (TN80C186EB)

The 80C186EB is a second generation CHMOS High-Integration microprocessor. It has features that are new to the 80C186 family and include a STATIC CPU core, an enhanced Chip Select decode unit, two independent Serial Channels, I/O ports, and the capability of Idle or Powerdown low power modes.



## INTRODUCTION

The 80C186EB is the first product in a new generation of low-power, high-integration microprocessors. It enhances the existing 186 family by offering new features and new operating modes. The 80C186EB is object code compatible with the 80C186/80C188 microprocessors.

The feature set of the 80C186EB meets the needs of low power, space critical applications. Low-Power applications benefit from the static design of the CPU core and the integrated peripherals. Minimum current consumption is achieved by providing a Powerdown mode that halts operation of the device, and freezes the clock circuits. Peripheral design enhancements ensure that non-initialized peripherals consume little current.

Space critical applications benefit from the integration of commonly used system peripherals. Two serial channels are provided for services such as diagnostics, inter-processor communication, modem interface, terminal display interface, and many others. A flexible chip select unit simplifies memory and peripheral interfacing. The interrupt unit provides sources for up to 129 external interrupts and will prioritize these interrupts with those generated from the on-chip peripherals. Three general purpose timer/counters and sixteen multiplexed I/O port pins round out the feature set of the 80 C 186 EB .

## OVERVIEW

Figure 1 shows a block diagram of the 80 C 186 EB . The Execution Unit (EU) is an enhanced 8086 CPU core that includes: dedicated hardware to speed up effective address calculations, enhance execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instruction, and full static operation. The Bus Interface Unit (BIU) is the same as that found on the original 186 family products, except the queuestatus mode has been deleted and buffer interface control has been changed to ease system design timings. An independent internal bus is used to allow communication between the BIU and internal peripherals.

## BUS INTERFACE UNIT

The 80C186EB core incorporates a bus controller that generates local bus control signals. In addition, it employs a HOLD/HLDA protocol to share the local bus with other bus masters.

The bus controller is responsible for generating 20 bits of address, read and write strobes, bus cycle status information, and data (for write operations) information. It is also responsible for reading data off the local bus during a read operation. A READY input pin is provided to extend a bus cycle beyond the minimum four states (clocks).

The 80C186EB local bus controller also generates two control signals ( $\overline{\mathrm{DEN}}$ and DT/ $\overline{\mathrm{R}}$ ) when interfacing to external transceiver chips. (Both $\overline{\mathrm{DEN}}$ and DT/ $\bar{R}$ are available on the TN80C186EB device, only $\overline{\mathrm{DEN}}$ is available on the TS80C186EB device.) This capability allows the addition of transceivers for simple buffering of the mulitplexed address/data bus.

## CLOCK GENERATOR

The 80C186EB provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, and two low-power operating modes.

The oscillator circuit is designed to be used with either a parallel resonant fundamental or third-overtone mode crystal network. Alternatively, the oscillator circuit may be driven from an external clock source. Figure 2 shows the various operating modes of the 80 C 186 EB oscillator circuit.

The crystal or clock frequency chosen must be twice the required processor operating frequency due to the internal divide-by-two counter. This counter is used to drive all internal phase clocks and the external CLKOUT signal. CLKOUT is a $50 \%$ duty cycle processor clock and can be used to drive other system components. All AC timings are referenced to CLKOUT.


270803-3
(A) Crystal Connection

NOTE:
The $L_{1} C_{1}$ network is only required when using a thirdovertone crystal.

(B) Clock Connection

Figure 2. 80C186EB Clock Configurations

The following parameters are recommended when choosing a crystal:

Temperature Range: Application Specific
ESR (Equivalent Series Resistance): $\quad 40 \Omega$ max
C0 (Shunt Capacitance of Crystal):
$C_{L}$ (Load Capacitance):
Drive Level: 7.0 pF max $20 \mathrm{pF} \pm 2 \mathrm{pF}$ 1 mW max

## 80C186EB Peripheral Architecture

The 80C186EB has integrated several common system peripherals with a CPU core to create a compact, yet powerful system. The integrated peripherals are designed to be flexible and provide logical interconnections between supporting units (e.g., the interrupt control unit supports interrupt requests from the timer/counters or serial channels).

The list of integrated peripherals includes:

- 7-Input Interrupt Control Unit
- 3-Channel Timer/Counter Unit
- 2-Channel Serial Communications Unit
- 10-Output Chip-Select Unit
- I/O Port Unit
- Refresh Control Unit
- Power Management Unit

The registers associated with each integrated periheral are contained within a $128 \times 16$ register file called the Peripheral Control Block (PCB). The PCB can be located in either memory or I/O space on any 256 Byte address boundary.

Figure 3 provides a list of the registers associated with the PCB. The Register Bit Summary at the end of this specification individually lists all of the registers and identifies each of their programming attributes.

## INTERRUPT CONTROL UNIT

The 80C186EB can receive interrupts from a number of sources, both internal and external. The interrupt control unit serves to merge these requests on a priority basis, for individual service by the CPU. Each interrupt source can be independently masked by the Interrupt Control Unit (ICU) or all interrupts can be globally masked by the CPU.

Internal interrupt sources include the Timers and Se rial channel 0 . External interrupt sources come from the five input pins INT4:0. The NMI interrupt pin is not controlled by the ICU and is passed directly to the CPU. Although the Timer and Serial channel each have only one request input to the ICU, separate vector types are generated to service individual interrupts within the Timer and Serial channel units.

## TIMER/COUNTER UNIT

The 80C186EB Timer/Counter Unit (TCU) provides three 16 -bit programmable timers. Two of these are highly flexible and are connected to external pins for control or clocking. A third timer is not connected to any external pins and can only be clocked internally. However, it can be used to clock the other two timer channels. The TCU can be used to count external events, time external events, generate non-repetitive waveforms, generate timed interrupts. etc.

| PCB Offset | Function |
| :---: | :---: |
| OOH | Reserved |
| 02H | End Of Interrupt |
| 04H | Poll |
| 06H | Poll Status |
| 08H | Interrupt Mask |
| OAH | Priority Mask |
| OCH | In-Service |
| OEH | Interrupt Request |
| 10H | Interrupt Status |
| 12 H | Timer Control |
| 14H | Serial Control |
| 16H | INT4 Control |
| 18 H | INT0 Control |
| 1AH | INT1 Control |
| 1 CH | INT2 Control |
| 1EH | INT3 Control |
| 20 H | Reserved |
| 22 H | Reserved |
| 24H | Reserved |
| 26 H | Reserved |
| 28 H | Reserved |
| 2AH | Reserved |
| 2 CH | Reserved |
| 2EH | Reserved |
| 30 H | Timer0 Count |
| 32H | Timer0 Compare A |
| 34H | Timer0 Compare B |
| 36 H | Timer0 Control |
| 38 H | Timer1 Count |
| 3AH | Timer1 Compare A |
| 3CH | Timer1 Compare B |
| 3EH | Timer1 Control |


| $\begin{gathered} \text { PCB } \\ \text { Offset } \end{gathered}$ | Function | PCB Offset | Function |
| :---: | :---: | :---: | :---: |
| 40H | Timer2 Count | 80 H | GCS0 Start |
| 42H | Timer2 Compare | 82H | GCSO Stop |
| 44H | Reserved | 84H | GCS1 Start |
| 46H | Timer2 Control | 86H | GCS1 Stop |
| 48H | Reserved | 88H | GCS2 Start |
| 4AH | Reserved | 8AH | GCS2 Stop |
| 4CH | Reserved | 8CH | GCS3 Start |
| 4EH | Reserved | 8EH | GCS3 Stop |
| 50 H | Reserved | 90 H | GCS4 Start |
| 52H | Porto Pin | 92H | GCS4 Stop |
| 54H | Port0 Control | 94H | GCS5 Start |
| 56H | Port0 Latch | 96H | GCS5 Stop |
| 58H | Port1 Direction | 98H | GCS6 Start |
| 5AH | Port1 Pin | 9AH | GCS6 Stop |
| 5 CH | Port1 Control | 9CH | GCS7 Start |
| 5EH | Port1 Latch | 9EH | GCS7 Stop |
| 60 H | Serial0 Baud | AOH | LCS Start |
| 62H | Serial0 Count | A2H | LCS Stop |
| 64H | Serial0 Control | A4H | UCS Start |
| 66H | Serial0 Status | A6H | UCS Stop |
| 68H | Serial0 RBUF | A8H | Relocation |
| 6AH | Serial0 TBUF | AAH | Reserved |
| 6CH | Reserved | ACH | Reserved |
| 6EH | Reserved | AEH | Reserved |
| 70 H | Serial1 Baud | BOH | Refresh Base |
| 72H | Serial1 Count | B2H | Refresh Time |
| 74H | Serial1 Control | B4H | Refresh Control |
| 76H | Serial1 Status | B6H | Refresh Address |
| 78H | Serial1 RBUF | B8H | Power Control |
| 7AH | Serial1 TBUF | BAH | Reserved |
| 7 CH | Reserved | BCH | Step ID |
| 7EH | Reserved | BEH | Reserved |


| PCB |
| :--- | :--- |
| Offset | Function | COH | Reserved |
| :---: | :--- |
| C 2 H | Reserved |
| C 4 H | Reserved |
| C 6 H | Reserved |
| C 8 H | Reserved |
| CAH | Reserved |
| CCH | Reserved |
| CEH | Reserved |
| D 0 H | Reserved |
| D 2 H | Reserved |
| D 4 H | Reserved |
| D 6 H | Reserved |
| D 8 H | Reserved |
| DAH | Reserved |
| FCH | Reserved |
| FEH | Reserved |
| FEH | Reserved |
| F 6 H |  |
| $\mathrm{F} O H$ | Reserved |
| E 2 H | Reserved |
| E 4 H | Reserved |
| E 6 H | Reserved |
| E 8 H | Reserved |
| EAH | Reserved |
| ECH | Reserved |
| FEH | Reserved |

Figure 3. 80C186EB Peripheral Control Block Registers

## SERIAL COMMUNICATIONS UNIT

The Serial Control Unit (SCU) of the 80C186EB contains two independent channels. Each channel is identical in operation except that only channel 0 is supported by the integrated interrupt controller (channel 1 has an external interrupt pin). Each channel has its own baud rate generator that is independent of the Timer/Counter Unit, and can be internally or externally clocked at up to one half the 80C186EB operating frequency.

Independent baud rate generators are provided for each of the serial channels. For the asynchronous modes, the generator supplies an $8 x$ baud clock to both the receive and transmit register logic. A 1x baud clock is provided in the synchronous mode.

## CHIP-SELECT UNIT

The 80C186EB Chip-Select Unit (CSU) integrates logic which provides up to ten programmable chipselects to access both memories and peripherals. In addition, each chip-select can be programmed to automatically insert additional clocks (wait-states) into the current bus cycle and automatically terminate a bus cycle independent of the condition of the READY input pin.

## I/O PORT UNIT

The I/O Port Unit (IPU) on the 80C186EB supports two 8 -bit channels of input, output, or input/output operation. Port 1 is multiplexed with the chip select pins and is output only. Most of Port 2 is multiplexed with the serial channel pins. Port 2 pins are limited to either an output or input function depending on the operation of the serial pin it is multiplexed with.

## REFRESH CONTROL UNIT

The Refresh Control Unit (RCU) automatically generates a periodic memory read bus cycle to keep dynamic or pseudo-static memory refreshed. A 9-bit counter controls the number of clocks between refresh requests.

A 12-bit address generator is maintained by the RCU and is presented on the A12:1 address lines during the refresh bus cycle. Address bits A19:13 are programmable to allow the refresh address block to be located on any 8 Kbyte boundary.

## POWER MANAGEMENT UNIT

The 80C186EB Power Management Unit (PMU) is provided to control the power consumption of the device. The PMU provides three power modes: Active, Idle, and Powerdown.

Active Mode indicates that all units on the 80C186EB are functional and the device consumes maximum power (depending on the level of peripheral operation). Idle Mode freezes the clocks of the Execution and Bus units at a logic zero state (all peripherals continue to operate normally).

The Powerdown mode freezes all internal clocks at a logic zero level and disables the crystal oscillator. All internal registers hold their values provided $V_{\mathrm{CC}}$ is maintained. Current consumption is reduced to just transistor junction leakage.

## 80C187 Interface

The 80C186EB (PLCC package only) supports the direct connection of the 80C187 Numerics Coprocessor.

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80C186EB has a test mode available which forces all output and input/ output pins to be placed in the high-impedance state. ONCE stands for "ON Circuit Emulation". The ONCE mode is selected by forcing the A19/ONCE pin LOW ( 0 ) during a processor reset (this pin is weakly held to a HIGH (1) level) while RESIN is active.

## PACKAGE INFORMATION

This section describes the pins, pinouts, and thermal characteristics for the 80 C 186 EB in the Plastic Leaded Chip Carrier (PLCC) package and Quad Flat Pack (QFP) package. For complete package specifications and information, see the Intel Packaging Outlines and Dimensions Guide (Order Number: 231369).

## Pin Descriptions

The 80C186EB pins are described in this section. Table 1 presents the legend for interpreting the pin descriptions in Table 2. Figure 4 provides an example pin description entry. The "I/O" signifies that the pins are bidirectional (i.e., have both an input and output function). The " S " indicates that, as an input, the signal is synchronized to CLKOUT for proper operation. The " $\mathrm{H}(\mathrm{Z})$ " indicates that these pins will float while the processor is in the Hold Acknowledge state. $R(Z)$ indicates that these pins will float while $\overline{\text { RESIN }}$ is low. $\mathrm{P}(\mathrm{X})$ Indicates that these pins will retain its current value when Idle or Powerdown Modes are entered.

All pins float while the processor is in the ONCETM Mode, except OSCOUT (OSCOUT is required for crystal operation).

| Name | Type | Description |
| :---: | :---: | :--- |
| AD15:0 | I/O | These pins provide a multiplexed |
|  | S(L) | ADDRESS and DATA bus. During |
|  | H(Z) | the address phase of the bus |
|  | R(Z) | cycle, address bits 0 through 15 |
|  | P(X) | are presented on the bus and can <br>  <br>  <br>  <br>  |
|  |  | be latched using ALE. 8- or 16-bit <br> data information are transferred <br> during the data phase of the bus <br> cycle. |

Figure 4. Example Pin Description Entry

Table 1. Pin Description Nomenclature

| Symbol | Description |
| :---: | :---: |
| 1 | Input Only Pin |
| 0 | Output Only Pin |
| 1/0 | Pin can be either input or output |
| - | Pin "must be" connected as described |
| S(..) | Synchronous. Input must meet setup and hold times for proper operation of the processor. The pin is: <br> $\mathrm{S}(\mathrm{E})$ edge sensitive <br> $\mathrm{S}(\mathrm{L})$ level sensitive |
| A(..) | Asynchronous. Input must meet setup and hold only to guarantee recognition. The pin is: <br> $A(E)$ edge sensitive <br> $A(L)$ level sensitive |
| H(..) | While the processor's bus is in the Hold Acknowledge state, the pin: <br> $H(1)$ is driven to $V_{C C}$ <br> $H(0)$ is driven to $V_{S S}$ <br> $H(Z)$ floats <br> $H(Q)$ remains active <br> $H(X)$ retains current state |
| R(..) | While the processor's $\overline{\mathrm{RES}}$ line is low, the pin: <br> $R(1)$ is driven to $V_{C C}$ <br> $R(0)$ is driven to $V_{S S}$ <br> $R(Z)$ floats <br> R(WH) weak pullup <br> $R(W L)$ weak pulldown |
| $\mathrm{P}(.$. | While Idle or Powerdown modes are active, the pin: <br> $P(1)$ is driven to $V_{C C}$ <br> $P(0)$ is driven to $V_{S S}$ <br> $P(Z)$ floats <br> $P(Q)$ remains active ${ }^{(1)}$ <br> $P(X)$ retains current state |

NOTE:

1. Any pin that specifies $P(Q)$ are valid for Idle Mode. All pins are $P(X)$ for Powerdown Mode.

Table 2. 80C186EB Pin Descriptions

| Name | Type | Description |
| :---: | :---: | :---: |
| V cc |  | POWER connections consist of four pins which must be shorted externally to a $\mathrm{V}_{\mathrm{CC}}$ board plane. |
| $\mathrm{V}_{\text {SS }}$ |  | GROUND connections consist of six pins which must be shorted externally to a $\mathrm{V}_{\mathrm{SS}}$ board plane. |
| CLKIN | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | CLock INput is an input for an external clock. An external oscillator operating at two times the required 80C186EB operating frequency can be connected to CLKIN. For crystal operation, CLKIN (along with OSCOUT) are the crystal connections to an internal Pierce oscillator. |
| OSCOUT | 0 <br> $H(Q)$ <br> R(Q) <br> $P(Q)$ | OSCillator OUTput is only used when using a crystal to generate the external clock. OSCOUT (along with CLKIN) are the crystal connections to an internal Pierce oscillator. This pin is not to be used as 2 X clock output for non-crystal applications (i.e., this pin is N.C. for non-crystal applications). OSCOUT does not float in ONCE mode. |
| CLKOUT | 0 <br> $H(Q)$ <br> $R(Q)$ <br> $P(Q)$ | CLock OUTput provides a timing reference for inputs and outputs of the processor, and is one-half the input clock (CLKIN) frequency. CLKOUT has a $50 \%$ duty cycle and transistions every falling edge of CLKIN. |
| $\overline{\text { RESIN }}$ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | RESet IN causes the 80C186EB to immediately terminate any bus cycle in progress and assume an initialized state. All pins will be driven to a known state, and RESOUT will also be driven active. The rising edge (low-to-high) transition synchronizes CLKOUT with CLKIN before the 80C186EB begins fetching opcodes at memory location OFFFFOH. |
| RESOUT | $\begin{gathered} O \\ H(0) \\ R(1) \\ P(0) \\ \hline \end{gathered}$ | RESet OUTput that indicates the 80 C 186 EB is currently in the reset state. RESOUT will remain active as long as $\overline{\text { RESIN }}$ remains active. |
| PDTMR | I/O A(L) H(WH) R(Z) $P(1)$ | Power-Down TiMeR pin (normally connected to an external capacitor) that determines the amount of time the 80C186EB waits after an exit from power down before resuming normal operation. The duration of time required will depend on the startup characteristics of the crystal oscillator. |
| NMI | $\stackrel{1}{A(E)}$ | Non-Maskable Interrupt input causes a TYPE-2 interrupt to be serviced by the CPU. NMI is latched internally. |
| TEST/BUSY | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | TEST is used during the execution of the WAIT instruction to suspend CPU operation until the pin is sampled active (LOW). TEST is alternately known as BUSY when interfacing with an 80C187 numerics coprocessor. |
| AD15:0 | I/O <br> S(L) <br> H(Z) <br> R(Z) <br> $P(X)$ | These pins provide a multiplexed Address and Data bus. During the address phase of the bus cycle, address bits 0 through 15 are presented on the bus and can be latched using ALE. 8- or 16 -bit data information is transferred during the data phase of the bus cycle. |
| A18:16 <br> A19/ONCE | , $H(Z)$ R(WH) $P(X)$ | These pins provide multiplexed Address during the address phase of the bus cycle. Address bits 16 through 19 are presented on these pins and can be latched using ALE. These pins are driven to a logic 0 during the data phase of the bus cycle. During a processor reset ( $\overline{R E S I N}$ active), A19/ONCE is used to enable ONCE mode. A18:16 must not be driven low during reset or improper 80C186EB operation may result. |

Table 2. 80C186EB Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| S2:0 | 0 <br> $H(Z)$ <br> R(Z) <br> $P(1)$ | Bus cycle Status are encoded on these pins to provide bus transaction information. S2:0 are encoded as follows: |
| ALE | $\begin{gathered} O \\ H(0) \\ R(0) \\ P(0) \\ \hline \end{gathered}$ | Address Latch Enable output is used to strobe address information into a transparent type latch during the address phase of the bus cycle. |
| $\overline{\text { BHE }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(\mathrm{X}) \end{gathered}$ | Byte High Enable output to indicate that the bus cycle in progress is transferring data over the upper half of the data bus. BHE and AO have the following logical encoding: |
| $\overline{\mathrm{RD}}$ | 0 <br> H(Z) <br> R(Z) <br> $P(1)$ | ReaD output signals that the accessed memory or I/O device must drive data information onto the data bus. |
| $\overline{W R}$ | 0 <br> H(Z) <br> R(Z) <br> $P(1)$ | WRite output signals that data available on the data bus are to be written into the accessed memory or I/O device. |
| READY | I A(L) | READY input to signal the completion of a bus cycle. READY must be active to terminate any 80C186EB bus cycle, unless it is ignored by correctly programming the Chip-Select Unit. |
| $\overline{\text { DEN }}$ | 0 <br> H(Z) <br> R(Z) <br> $P(1)$ | Data ENable output to control the enable of bi-directional transceivers when buffering a 80 C 186 EB system. $\overline{\text { DEN }}$ is active only when data is to be transferred on the bus. |
| DT/R | $\begin{gathered} 0 \\ \mathrm{O}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(\mathrm{X}) \end{gathered}$ | Data Transmit/Receive output controls the direction of a bi-directional buffer when buffering an 80C186EB system. DT/ $\overline{\mathrm{R}}$ is only available for the PLCC package (TN80C186EB). |
| LOCK | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | LOCK output indicates that the bus cycle in progress is not to be interrupted. The 80C186EB will not service other bus requests (such as HOLD) while $\overline{\text { LOCK }}$ is active. This pin is configured as a weakly held high input while $\overline{\text { RESIN }}$ is active and must not be driven low. |

Table 2. 80C186EB Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| HOLD | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | HOLD request input to signal that an external bus master wishes to gain control of the local bus. The 80C186EB will relinquish control of the local bus between instruction boundaries not conditioned by a LOCK prefix. |
| HLDA | 0 <br> $H(1)$ <br> R(0) <br> P(0) | HoLD Acknowledge output to indicate that the 80C186EB has relinquish control of the local bus. When HLDA is asserted, the 80C186EB will (or has) floated its data bus and control signals allowing another bus master to drive the signals directly. |
| $\overline{N C S}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \end{gathered}$ | Numerics Coprocessor Select output is generated when accessing a numerics coprocessor. NCS is not provided on the TS80C186EB. |
| ERROR | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | ERROR input that indicates the last numerics coprocessor operation resulted in an exception condition. An interrupt TYPE 16 is generated if ERROR is sampled active at the beginning of a numerics operation. ERROR is not provided on the TS80C186EB. |
| PEREQ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | CoProcessor REQuest signals that a data transfer between an External Numerics Coprocessor and Memory is pending. PEREQ is not provided on the TS80C186EB. |
| $\overline{U C S}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Upper Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. After reset, $\overline{U C S}$ is configured to be active for memory accesses between OFFCOOH and OFFFFFH. |
| $\overline{\text { LCS }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Lower Chip Select will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. $\overline{L C S}$ is inactive after a reset. |
|  | $\begin{gathered} O \\ H(X) / H(1) \\ R(1) \\ P(X) / P(1) \end{gathered}$ | These pins provide a multiplexed function. If enabled, each pin can provide a Generic Chip Select output which will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. When not programmed as a Chip-Select, each pin may be used as a general purpose output Port. As an output port pin, the value of the pin can be read internally. |
| $\begin{aligned} & \text { TOOUT } \\ & \text { T1OUT } \end{aligned}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(1) \\ \mathrm{P}(\mathrm{Q}) \\ \hline \end{gathered}$ | Timer OUTput pins can be programmed to provide a single clock or continuous waveform generation, depending on the timer mode selected. |
| $\begin{aligned} & \text { TOIN } \\ & \text { T1IN } \end{aligned}$ | $\begin{gathered} 1 \\ A(L) \\ A(L) \end{gathered}$ | Timer INput is used either as clock or control signals, depending on the timer mode selected. |

Table 2. 80C186EB Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| INTO <br> INT1 <br> INT4 | $\stackrel{1}{\mathrm{~A}(\mathrm{E}, \mathrm{~L})}$ | Maskable INTerrupt input will cause a vector to a specific Type interrupt routine. To allow interrupt expansion, INT0 and/or INT1 can be used with $\overline{I N T A O}$ and INTA1 to interface with an external slave controller. |
| INT2//"NTAO <br> INT3//̄NTA1 | I/O A(E,L) $/ H(1)$ R(Z) /P(1) | These pins provide a multiplexed function. As inputs, they provide a maskable INTerrupt that will cause the CPU to vector to a specific Type interrupt routine. As outputs, each is programmatically controlled to provide an INTERRUPT ACKNOWLEDGE handshake signal to allow interrupt expansion. |
| $\begin{aligned} & \text { P2.7 } \\ & \text { P2.6 } \end{aligned}$ | I/O <br> A(L) <br> $H(X)$ <br> R(Z) <br> $P(X)$ | BI-DIRECTIONAL, open-drain Port pins. |
| $\begin{aligned} & \hline \overline{\text { CTSO }} \\ & \text { P2.4/CTS1 } \end{aligned}$ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | Clear-To-Send input is used to prevent the transmission of serial data on their respective TXD signal pin. CTS1 is multiplexed with an input only port function. |
| $\begin{array}{\|l\|} \hline \text { TXD0 } \\ \text { P2.1/TXD1 } \end{array}$ | $\begin{gathered} \mathrm{O} \\ H(X) / H(Q) \\ R(1) \\ P(X) / P(Q) \end{gathered}$ | Transmit Data output provides serial data information. TXD1 is multiplexed with an output only Port function. During synchronous serial communications, TXD will function as a clock output. |
| $\begin{aligned} & \text { RXD0 } \\ & \text { P2.0/RXD1 } \end{aligned}$ | I/O <br> A(L) <br> R(Z) <br> $H(Q)$ <br> $P(X)$ | Receive Data input accepts serial data information. RXD1 is multiplexed with an input only Port function. During synchronous serial communications, RXD is bi-directional and will become an output for transmission or data (TXD becomes the clock). |
| P2.5/BCLK0 P2.2/BCLK1 | $\stackrel{1}{A(L) / A(E)}$ | Baud CLocK input can be used as an alternate clock source for each of the integrated serial channels. BCLKx is multiplexed with an input only Port function, and cannot exceed a clock rate greater than one-half the operating frequency of the 80C186EB. |
| P2.3/SINT1 | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{X}) / \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(\mathrm{O}) \\ \mathrm{P}(\mathrm{X}) / \mathrm{P}(\mathrm{Q}) \\ \hline \end{gathered}$ | Serial INTerrupt output will go active to indicate serial channel 1 requires service. SINT1 is multiplexed with an output only Port function. |

## 80C186EB PINOUT

Tables 3 and 4 list the 80C186EB pin names with package location for the 84-pin Plastic Leaded Chip Carrier (PLCC) component. Figure 5 depicts the complete 80C186EB pinout (PLCC package) as viewed from the top side of the component (i.e., contacts facing down).
, Tables 5 and 6 list the 80C186EB pin names with package location for the 80-pin Quad Flat Pack (QFP) component. Figure 6 depicts the complete 80C186EB (QFP package) as viewed from the top side of the component (i.e., contacts facing down).

Table 3. PLCC Pin Names with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 61 |
| AD1 | 66 |
| AD2 | 68 |
| AD3 | 70 |
| AD4 | 72 |
| AD5 | 74 |
| AD6 | 76 |
| AD7 | 78 |
| AD8 | 62 |
| AD9 | 67 |
| AD10 | 69 |
| AD11 | 71 |
| AD12 | 73 |
| AD13 | 75 |
| AD14 | 77 |
| AD15 | 79 |
| A16 | 80 |
| A17 | 81 |
| A18 | 82 |
| A19/ONCE | 83 |


| Bus Control |  |
| :--- | :---: |
| Name | Location |
| ALE | 6 |
| $\overline{\mathrm{BHE}}$ | 7 |
| $\overline{\mathrm{So}}$ | 10 |
| $\overline{\mathrm{~S} 1}$ | 9 |
| $\overline{\mathrm{~S} 2}$ | 8 |
| $\overline{\mathrm{RD}}$ | 4 |
| $\overline{\mathrm{WR}}$ | 5 |
| READY | 18 |
| $\overline{\mathrm{DEN}}$ | 11 |
| $\mathrm{DT} / \overline{\mathrm{R}}$ | 16 |
| $\overline{\mathrm{LOCK}}$ | 15 |
| HOLD | 13 |
| HLDA | 12 |


| Power |  |
| :--- | :---: |
| Name | Location |
| $V_{\text {SS }}$ | $2,22,43$ |
|  | $63,65,84$ |
| $V_{\mathrm{CC}}$ | 1,23 |
|  | 42,64 |


| Processor Control |  |
| :--- | :---: |
| Name | Location |
| RESIN | 37 |
| RESOUT | 38 |
| CLKIN | 41 |
| OSCOUT | 40 |
| CLKOUT | 44 |
| TEST/BUSY | 14 |
| NCS | 60 |
| PEREQ | 39 |
| ERROR | 3 |
| PDTMR | 36 |
| NMI | 17 |
| INTO | 31 |
| INT1 | 32 |
| INT2/INTAO | 33 |
| INT3/INTA1 | 34 |
| INT4 | 35 |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{\text { UCS }}$ | 30 |
| LCS | 29 |
| P1.0/GCS0 | 28 |
| P1.1/GCS1 | 27 |
| P1.2/GCS2 | 26 |
| P1.3/GCS3 | 25 |
| P1.4/GCS4 | 24 |
| P1.5/द्GCS5 | 21 |
| P1.6/GCS6 | 20 |
| P1.7/GCS7 | 19 |
| T0OUT | 45 |
| TOIN | 46 |
| T1OUT | 47 |
| T1IN | 48 |
| RXD0 | 53 |
| TXD0 | 52 |
| P2.5/BCLK0 | 54 |
| CTS0 | 51 |
| P2.0/RXD1 | 57 |
| P2.1/TXD1 | 58 |
| P2.2/BCLK1 | 59 |
| P2.3/SINT1 | 55 |
| P2.4/ $\overline{\text { CTS1 }}$ | 56 |
| P2.6 | 50 |
| P2.7 | 49 |

Table 4. PLCC Package Locations with Pin Name

| Location | Name |
| :---: | :--- |
| 1 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 2 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 3 | $\overline{\mathrm{ERROR}}$ |
| 4 | $\overline{\mathrm{RD}}$ |
| 5 | $\overline{\mathrm{WR}}$ |
| 6 | $\overline{\mathrm{ALE}}$ |
| 7 | $\overline{\mathrm{BHE}}$ |
| 8 | $\overline{\mathrm{~S} 2}$ |
| 9 | $\overline{\mathrm{~S} 1}$ |
| 10 | $\overline{\mathrm{S0}}$ |
| 11 | $\overline{\mathrm{DEN}}$ |
| 12 | HLDA |
| 13 | HOLD |
| 14 | $\overline{\mathrm{TEST}} / \mathrm{BUSY}$ |
| 15 | $\overline{\mathrm{LOCK}}$ |
| 16 | $\mathrm{DT} / \overline{\mathrm{R}}$ |
| 17 | NMI |
| 18 | READY |
| 19 | $\mathrm{P} 1.7 / \overline{\mathrm{GCS7}}$ |
| 20 | $\mathrm{P} 1.6 / \overline{\mathrm{GCS}}$ |
| 21 | $\mathrm{P} 1.5 / \overline{\mathrm{GCS5}}$ |


| Location | Name |
| :---: | :--- |
| 22 | $\mathrm{~V}_{\text {SS }}$ |
| 23 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 24 | P1.4/GCS4 |
| 25 | $\mathrm{P} 1.3 / \overline{\mathrm{GCS3}}$ |
| 26 | $\mathrm{P} 1.2 / \overline{\mathrm{GCS} 2}$ |
| 27 | $\mathrm{P} 1.1 / \overline{\mathrm{GCS1}}$ |
| 28 | $\mathrm{P} 1.0 / \overline{\mathrm{GCS0}}$ |
| 29 | $\overline{\mathrm{LCS}}$ |
| 30 | $\overline{\mathrm{UCS}}$ |
| 31 | INT0 |
| 32 | INT1 |
| 33 | INT2/INTA0 |
| 34 | INT3/INTA1 |
| 35 | INT4 |
| 36 | PDTMR |
| 37 | $\overline{\text { RESIN }}$ |
| 38 | RESOUT |
| 39 | PEREQ |
| 40 | OSCOUT |
| 41 | CLKIN |
| 42 | VCC |


| Location | Name |
| :---: | :--- |
| 43 | V SS $^{\prime}$ |
| 44 | CLKOUT |
| 45 | T0OUT |
| 46 | TOIN |
| 47 | T1OUT |
| 48 | T1IN |
| 49 | P2.7 |
| 50 | P2.6 |
| 51 | $\overline{\text { CTS0 }}$ |
| 52 | TXD0 |
| 53 | RXD0 |
| 54 | P2.5/BCLK0 |
| 55 | P2.3/SINT1 |
| 56 | P2.4/CTS1 |
| 57 | P2.0/RXD1 |
| 58 | P2.1/TXD1 |
| 59 | P2.2/BCLK1 |
| 60 | NCS |
| 61 | AD0 |
| 62 | AD8 |
| 63 | VSS |


| Location | Name |
| :---: | :--- |
| 64 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 65 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 66 | AD1 |
| 67 | AD9 |
| 68 | AD2 |
| 69 | AD10 |
| 70 | AD3 |
| 71 | AD11 |
| 72 | AD4 |
| 73 | AD12 |
| 74 | AD5 |
| 75 | AD13 |
| 76 | AD6 |
| 77 | AD14 |
| 78 | AD7 |
| 79 | AD15 |
| 80 | A16 |
| 81 | A17 |
| 82 | A18 |
| 83 | A19/ONCE |
| 84 | $\mathrm{~V}_{\mathrm{SS}}$ |



Figure 5. 84-Pin Plastic Leaded Chip Carrier Pinout Diagram

Table 5. QFP Pin Name with Package Location

| Address/Data Bus |  | Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Name | Location | Name | Location | Name | Location |
| ADO | 10 | ALE | 38 | $\overline{R E S I N}$ | 68 |
| AD1 | 15 | BHE | 39 | RESOUT | 69 |
| AD2 | 17 | $\overline{\text { So }}$ | 42 | CLKIN | 71 |
| AD3 | 19 | S1 | 41 | OSCOUT | 70 |
| AD4 | 21 | $\overline{\mathrm{S} 2}$ | 40 | CLKOUT | 74 |
| AD5 | 23 | $\overline{\mathrm{RD}}$ | 36 | TEST | 46 |
| AD6 | 25 | WR | 37 | PDTMR | 67 |
| AD7 | 27 | READY | $\begin{aligned} & 37 \\ & 49 \end{aligned}$ | NMI | 48 |
| AD8 | 11 | READY | 49 | INTO | 62 |
| AD9 | 16 | DEN | 43 | INT1 | 63 |
| AD10 | 18 | $\overline{\text { LOCK }}$ | 47 | INT2/INTAO | 64 |
| AD11 | 20 | HOLD | 45 | INT3/INTA1 | 65 |
| AD12 | 22 | HLDA | 44 | INT4 | 66 |
| AD13 | 24 |  |  |  |  |
| AD14 | 26 |  | ver |  |  |
| AD15 | 28 | Name | Location |  |  |
| A16 | 29 | VSS | 12, 14, 33 |  |  |
| A18 | 31 |  | 35, 53, 73 |  |  |
| A19/ONCE | 32 | $\mathrm{V}_{\mathrm{CC}}$ | 13, 34 |  |  |
|  |  |  | 54, 72 |  |  |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{\text { UCS }}$ | 61 |
| $\overline{\text { LCS }}$ | 60 |
| P1.0/GCS0 | 59 |
| P1.1/GCS1 | 58 |
| P1.2/GCS2 | 57 |
| P1.3/GCS3 | 56 |
| P1.4/GCS4 | 55 |
| P1.5/GCS5 | 52 |
| P1.6/GCS6 | 51 |
| P1.7/GCS7 | 50 |
| T0OUT | 75 |
| TOIN | 76 |
| T1OUT | 77 |
| T1IN | 78 |
| RXD0 | 3 |
| TXD0 | 2 |
| P2.5/BCLK0 | 4 |
| CTS0 | 1 |
| P2.0/RXD1 | 7 |
| P2.1/TXD1 | 8 |
| P2.2/BCLK1 | 9 |
| P2.3/SINT1 | 5 |
| P2.4/CTS1 | 6 |
| P2.6 | 80 |
| P2.7 | 79 |

Table 6. OFP Package Location with Pin Names

| Location | Name |
| :---: | :--- |
| 1 | CTSO |
| 2 | TXDO |
| 3 | RXDO |
| 4 | P2.5/BCLKO |
| 5 | P2.3/SINT1 |
| 6 | P2.4/CTS1 |
| 7 | P2.0/RXD1 |
| 8 | P2.1/TXD1 |
| 9 | P2.2/BCLK1 |
| 10 | AD0 |
| 11 | AD8 |
| 12 | $\mathrm{~V}_{\text {SS }}$ |
| 13 | VCC |
| 14 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 15 | AD1 |
| 16 | AD9 |
| 17 | AD2 |
| 18 | AD10 |
| 19 | AD3 |
| 20 | AD11 |


| Location | Name |
| :---: | :--- |
| 21 | AD4 |
| 22 | AD12 |
| 23 | AD5 |
| 24 | AD13 |
| 25 | AD6 |
| 26 | AD14 |
| 27 | AD7 |
| 28 | AD15 |
| 29 | A16 |
| 30 | A17 |
| 31 | A18 |
| 32 | A19/ONCE |
| 33 | $V_{\text {SS }}$ |
| 34 | $V_{\mathrm{CC}}$ |
| 35 | $V_{\mathrm{SS}}$ |
| 36 | $\overline{R D}$ |
| 37 | $\overline{\mathrm{~W}}$ |
| 38 | ALE |
| 39 | $\overline{\text { BHE }}$ |
| 40 | $\overline{S 2}$ |


| Location | Name |
| :---: | :---: |
| 41 | S1 |
| 42 | So |
| 43 | $\overline{\text { DEN }}$ |
| 44 | HLDA |
| 45 | HOLD |
| 46 | TEST |
| 47 | $\overline{\text { LOCK }}$ |
| 48 | NMI |
| 49 | READY |
| 50 | P1.7/GCS7 |
| 51 | P1.6/GCS6 |
| 52 | P1.5/GCS5 |
| 53 | $\mathrm{V}_{\text {SS }}$ |
| 54 | $V_{\text {cc }}$ |
| 55 | P1.4/GCS4 |
| 56 | P1.3/GCS3 |
| 57 | P1.2/GCS2 |
| 58 | P1.1/GCS1 |
| 59 | P1.0/GCS0 |
| 60 | LCS |


| Location | Name |
| :---: | :--- |
| 61 | $\overline{\text { UCS }}$ |
| 62 | INTO |
| 63 | INT1 |
| 64 | INT2/IITAT |
| 65 | INT3/INTAT |
| 66 | INT4 |
| 67 | PDTMR |
| 68 | RESIN |
| 69 | RESOUT |
| 70 | OSCOUT |
| 71 | CLKIN |
| 72 | VCC |
| 73 | VSS |
| 74 | CLKOUT |
| 75 | TOOUT |
| 76 | TOIN |
| 77 | T1OUT |
| 78 | T1IN |
| 79 | P2.7 |
| 80 | P2.6 |



NOTE:
This is the FPO number location (indicated by X 's).
Figure 6. Quad Flat Pack Pinout Diagram

## PACKAGE THERMAL SPECIFICATIONS

The 80C186EB is specified for operation when $T_{C}$ (the case temperature) is within the range of $-40^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (PLCC package) or $-40^{\circ} \mathrm{C}$ to $+114^{\circ} \mathrm{C}$ (QFP package). TC may be measured in any environment to determine whether the 80C186EB is within the specified operating range. The case temperature must be measured at the center of the top surface.
$T_{A}$ (the ambient temperature) can be calculated from $\theta_{\mathrm{CA}}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\mathrm{CA}}$ at various airflows are given in Table 7 for the 84-pin Plastic Leaded Chip Carrier (PLCC) package.

Table 8 shows the maximum $T_{A}$ allowable (without exceeding $T_{C}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumption, specified in watts) is calculated by using the maximum ICC as tabulated in the DC specifications and $\mathrm{V}_{\mathrm{CC}}$ of 5.5 V .

$$
T_{A}=T_{C}-P^{*} \theta_{C A}
$$

Table 7. Thermal Resistance ( $\boldsymbol{\theta}_{\mathbf{C A}}$ ) at Various Airflows (in ${ }^{\circ} \mathbf{C} /$ Watt)

|  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 <br> $(0)$ | 200 <br> $(1.01)$ | 400 <br> $(2.03)$ | 600 <br> $(3.04)$ | 800 <br> $(4.06)$ | 1000 <br> $(5.07)$ |
| $\theta_{\mathrm{CA}}$ (PLCC) | 30 | 24 | 21 | 19 | 17 | 16.5 |
| $\theta_{\mathrm{CA}}$ (QFP) | 58 | 47 | 43 | 40 | 38 | 36 |

Table 8. Maximum $T_{A}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow Linear $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec})$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{T}_{\mathrm{F}}$ | 0 | 200 | 400 | 600 | 800 | 1000 |
|  | (MHz) | (0) | (1.01) | (2.03) | (3.04) | (4.06) | (5.07) |
| $\mathrm{T}_{\mathrm{A}}$ (PLCC) | 16 | 91.5 | 93.5 | 94 | 94.5 | 95.5 | 95.5 |
|  | 26 | 88.5 | 91 | 92 | 92.5 | 93.5 | 93.5 |
|  | 32 | 85 | 87.5 | 89.5 | 90.5 | 91.5 | 92 |
| $\mathrm{T}_{\mathrm{A}}$ (QFP) | 16 | 98 | 101 | 102 | 103 | 103.5 | 104 |
|  | 26 | 92 | 96 | 97.5 | 99 | 99.5 | 100 |
|  | 32 | 85 | 90.5 | 92.5 | 94 | 95 | 96 |

## ELECTRICAL SPECIFICATIONS

## Absolute Maximum Ratings

| Parameter | Maximum Ratin |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Case Temp Under Bias | $-65^{\circ} \mathrm{C}$ to $+120^{\circ} \mathrm{C}$ |
| Supply Voltage with respect to $\mathrm{V}_{\mathrm{SS}}$. | $-0.5 \mathrm{~V} \text { to }+6.5 \mathrm{~V}$ |
| Voltage on other Pins with respect to $\mathrm{V}_{\mathrm{SS}}$ | .5 V to $\mathrm{V}_{\mathrm{CC}}+0.5$ |

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## OPERATING CONDITIONS

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.5 | 5.5 | V |
| $\mathrm{T}_{\mathrm{F}}$ | $\begin{aligned} & \text { Input Clock Frequency } \\ & \text { 80C186EB-20 } \\ & 80 \mathrm{C} 186 \mathrm{~EB}-16 \\ & \\ & 80 \mathrm{C} 186 \mathrm{~EB}-13 \\ & 80 \mathrm{C} 186 \mathrm{~EB} \end{aligned}$ | 0 | 40 | MHz |
|  |  | 0 | 32 | MHz |
|  |  | 0 | 26.08 | MHz |
|  |  | 0 | 16 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | ```Case Temperature Under Bias TN80C186EB-XX (PLCC) TS80C186EB-XX (QFP)``` | -40 | +100 | ${ }^{\circ} \mathrm{C}$ |
|  |  | -40 | $+114$ | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED CONNECTIONS

Power and ground connections must be made to multiple $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\text {SS }}$ pins. Every 80C186EB-based circuit board should include separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $\mathrm{V}_{\mathrm{SS}}$ ) planes. Every $\mathrm{V}_{\mathrm{CC}}$ pin must be connected to the power plane, and every $V_{S S}$ pin must be connected to the ground plane. Pins identified as "NC" must not be connected in the system. Liberal decoupling capacitance should be placed near the 80C186EB. The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance is reduced by placing the decoupling capacitors as close as possible to the 80C186EB $V_{C C}$ and $V_{S S}$ package pins.

Always connect any unused input to an appropriate signal level. In particular, unused interrupt inputs (INTO:4) should be connected to $\mathrm{V}_{\mathrm{CC}}$ through a pullup resistor (in the range of $50 \mathrm{~K} \Omega$ ). Leave any unused output pin or any NC pin unconnected.

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | $0.3^{*} \mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | $0.7 * V_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=3 \mathrm{~mA}$ (Min) |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{IOH}^{\prime}=-2 \mathrm{~mA}(\mathrm{Min})$ |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysterisis on RESIN | 0.50 |  | V |  |
| $\mathrm{L}_{\text {LI } 1}$ | Input Leakage Current for pins: AD15:0, READY, HOLD, RESIN, CLKIN, TEST, NMI, INT4:0, TOIN, T1IN, RXDO, $\overline{\text { BCLKO }}, \overline{\mathrm{CTSO}}$, RXD1, $\overline{\mathrm{BCLK1}}, \overline{\mathrm{CTS}} 1$, P2.6, P2. 7 |  | $\pm 15$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| LL2 | Input Leakage Current for pins: ERROR, PEREQ | $\pm 0.275$ | $\pm 7$ | mA | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}}<\mathrm{V}_{\mathrm{CC}}$ |
| ${ }_{\text {L13 }}$ | Input Leakage Current for pins: A19/ONCE, A18:16, LOCK | -0.275 | -5.0 | mA | $\mathrm{V}_{\mathrm{IN}}=0.7 \mathrm{~V}_{\text {CC }}($ Note 1) |
| Lo | Output Leakage Current |  | $\pm 15$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}} \\ & (\text { Note } 2) \end{aligned}$ |
| Icc | Supply Current Cold (RESET)$80 \mathrm{C} 186 \mathrm{~EB}-20$$80 \mathrm{C} 186 \mathrm{~EB}-16$$80 \mathrm{C} 186 \mathrm{~EB}-13$$80 \mathrm{C} 186 \mathrm{~EB}-8$ |  | 108 | mA | (Note 3) |
|  |  |  | 90 | mA | (Note 3) |
|  |  |  | 73 | mA | (Note 3) |
|  |  |  | 45 | mA | (Note 3) |
| ID | Supply Current Idle$80 \mathrm{C} 186 \mathrm{~EB}-20$$80 \mathrm{C} 186 \mathrm{~EB}-16$$80 \mathrm{C} 186 \mathrm{~EB}-13$$80 \mathrm{C} 186 \mathrm{~EB}-8$ |  | 76 | mA | (Note 4) |
|  |  |  | 63 | mA | (Note 4) |
|  |  |  | 48 | mA | (Note 4) |
|  |  |  | 31 | mA | (Note 4) |
| IPD | Supply Current Powerdown$80 \mathrm{C} 186 \mathrm{~EB}-20$$80 \mathrm{C} 186 \mathrm{~EB}-16$$80 \mathrm{C} 186 \mathrm{~EB}-13$$80 \mathrm{C} 186 \mathrm{~EB}-8$ |  | 100 | $\mu \mathrm{A}$ | (Note 5) |
|  |  |  | 100 | $\mu \mathrm{A}$ | (Note 5) |
|  |  |  | 100 | $\mu \mathrm{A}$ | (Note 5) |
|  |  |  | 100 | $\mu \mathrm{A}$ | (Note 5) |
| CIN | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |
| COUT | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ ( Note 6) |

## NOTES:

1. These pins have an internal pull-up device that is active while $\overline{\operatorname{RESIN}}$ is low and ONCE Mode is not active. Sourcing more current than specified (on any of these pins) may invoke a factory test mode.
2. Tested by outputs being floated by invoking ONCE Mode or by asserting HOLD.
3. Measured with the device in RESET and at worst case frequency, $V_{C C}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND.
4. Measured with the device in HALT (IDLE Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $V_{C C}$ or GND.
5. Measured with the device in HALT (Powerdown Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND.
6. Output Capacitance is the capacitive load of a floating output pin.

## Icc VERSUS FREQUENCY AND VOLTAGE

The current (lcc) consumption of the 80C186EB is essentially composed of two components; IPD and lccs.

IPD is the quiescent current that represents internal device leakage, and is measured with all inputs or floating outputs at GND or $\mathrm{V}_{\mathrm{CC}}$ (no clock applied to the device). IPD is equal to the Powerdown current and is typically less than $50 \mu \mathrm{~A}$.

ICCS is the switching current used to charge and discharge parasitic device capacitance when changing logic levels. Since Iccs is typically much greater than IPD, IPD can often be ignored when calculating Icc.

Iccs is related to the voltage and frequency at which the device is operating. It is given by the formula:

$$
\begin{aligned}
& \text { Power }=\mathrm{V} \times \mathrm{I}=\mathrm{V} 2 \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f} \\
& \therefore \mathrm{I}=\mathrm{I}_{\mathrm{CC}}=\mathrm{I}_{\mathrm{CCS}}=\mathrm{V} \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f}
\end{aligned}
$$

Where: $\mathrm{V}=$ Device operating voltage ( $\mathrm{V}_{\mathrm{CC}}$ )
$C_{D E V}=$ Device capacitance
$f=$ Device operating frequency
IcCs $=I_{C C}=$ Device current
Measuring $C_{\text {DEV }}$ on a device like the 80C186EB would be difficult. Instead, $\mathrm{C}_{\text {DEV }}$ is calculated using the above formula by measuring ICC at a known $V_{C C}$ and frequency (see Table 9). Using this CDEV value, Icc can be calculated at any voltage and frequency within the specified operating range.

EXAMPLE: Calculate the typical ICC when operating at $10 \mathrm{MHz}, 4.8 \mathrm{~V}$.

## PDTMR PIN DELAY CALCULATION

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown. A delay is required only when using the on-chip oscillator to allow the crystal or resonator circuit time to stabilize.

## NOTE:

The PDTMR pin function does not apply when RESIN is asserted (i.e., a device reset during Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized).

To calculate the value of capacitor required to provide a desired delay, use the equation:

$$
440 \times t=C_{P D} \quad\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where: $\mathrm{t}=$ desired delay in seconds
$C_{P D}=$ capacitive load on PDTMR in microfarads

EXAMPLE: To get a delay of $300 \mu \mathrm{~s}$, a capacitor value of $\mathrm{C}_{\text {PD }}=440 \times\left(300 \times 10^{-6}\right)=0.132 \mu \mathrm{~F}$ is required. Round up to standard (available) capacitive values.

NOTE:
The above equation applies to delay times greater than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ or $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $\mathrm{V}_{\mathrm{CC}}$ and/or lower temperature will decrease delay time, while lower $V_{C C}$ and/or higher temperature will increase delay time.

$$
I_{C C}=I_{C C S}=4.8 \times 0.583 \times 10 \approx 28 \mathrm{~mA}
$$

Table 9. Device Capacitance ( $C_{\text {DEV }}$ ) Values

| Parameter | Typ | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {DEV }}$ (Device in Reset) | 0.583 | 1.02 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| $\mathrm{C}_{\text {DEV }}$ (Device in Idle) | 0.408 | 0.682 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

1. Max $C_{\text {DEV }}$ is calculated at $-40^{\circ} \mathrm{C}$, all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND, and all outputs loaded to 50 pF (including CLKOUT and OSCOUT). 2. Typical $\mathrm{C}_{\text {DEV }}$ is calculated at $25^{\circ} \mathrm{C}$ with all outputs loaded to 50 pF except CLKOUT and OSCOUT, which are not loaded.

## AC SPECIFICATIONS

AC Characteristics-80C186EB-20

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {F }}$ | CLKIN Frequency | 0 | 40 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 25 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {CH }}$ | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| $\mathrm{T}_{\text {CL }}$ | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{CD}}$ | CLKIN to CLKKOUT Delay | 0 | 17 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{*}{ }^{\text {T }}$ C | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2)-5 | (T/2) +5 | ns | 1 |
| $\mathrm{T}_{\mathrm{PL}}$ | CLKOUT Low Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{T}_{\text {PR }}$ | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| $\mathrm{T}_{\text {PF }}$ | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |

## OUTPUT DELAYS

| TCHOV1 | ALE, S2:0, $\overline{D E N}, ~ D T / \bar{R}, \overline{B H E}$, LOCK, A19:16 | 3 | 20 | ns | 1, 4, 6, 7 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCHOV2 | GCS0:7, $\overline{\text { LCS }}$, UCS, $\overline{\text { NCS, }}$, $\overline{\text { DD }}, \overline{\text { WR }}$ | 3 | 25 | ns | 1, 4, 6, 8 |
| TCLOV1 | $\overline{B H E}, \overline{D E N}, \overline{L O C K}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 20 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}}: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD15:0, $\overline{\text { NCS }}, \overline{\text { NTA1:0 }}, \overline{S 2: 0}$ | 3 | 25 | ns | 1,4,6 |
| TCHOF | $\overline{R D}, \overline{W R}, \overline{B H E}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:16 | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0, P2.6, P2.7 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0 | 3 |  | ns | 1,9 |
| TCLIS | AD15:0, READY | 10 |  | ns | 1,10 |
| TCLIH | READY, AD15:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD, PEREQ, ERROR | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CLIH }}$ | HOLD, PEREQ, ERROR | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 13 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 14 for rise and fall times outside 50 pF .
6. See Figure 14 for rise and fall times.
7. TCHOV1 applies to $\overline{B H E}, \overline{L O C K}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C186EB operation.

AC SPECIFICATIONS (Continued)
AC Characteristics-80C186EB-16

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 32 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 31.25 | $\infty$ | ns | 1 |
| ${ }_{\text {TCH }}$ | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| $\mathrm{T}_{\text {CR }}$ | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 20 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{2 *} \mathrm{~T}_{C}$ | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\text {PL }}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\text {PR }}$ | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| $\mathrm{T}_{\text {PF }}$ | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}$, LOCK, A19:16 | 3 | 22 | ns | 1,4,6,7 |
| TCHOV2 | $\overline{\mathrm{GCS}} 0: 7, \overline{\text { LCS }}, \overline{\mathrm{UCS}}, \overline{\mathrm{NCS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 27 | ns | 1, 4, 6, 8 |
| TCLOV1 | $\overline{B H E}, \overline{D E N}, \overline{L O C K}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 22 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}}: \overline{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD15:0, $\overline{\text { NCS }}, \overline{\text { NTA }} 1: 0, \overline{\text { S2:0 }}$ | 3 | 27 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:16 | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0, P2.6, P2.7 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0 | 3 |  | ns | 1,9 |
| TCLIS | AD15:0, READY | 10 |  | ns | 1,10 |
| $\mathrm{T}_{\text {CLIH }}$ | READY, AD15:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD, PEREQ, ERROR | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CLIH }}$ | HOLD, PEREQ, ERROR | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{C}}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 13 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 14 for rise and fall times outside 50 pF .
6. See Figure 14 for rise and fall times.
7. TCHOV1 applies to $\overline{\mathrm{BHE}}, \overline{\text { LOCK }}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C186EB operation.

80C186EB
ADVANCE ONFORMATRON

AC SPECIFICATIONS (Continued)
AC Characteristics-80C186EB-13

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 26.08 | MHz | 1 |
| $\mathrm{T}_{\mathrm{c}}$ | CLKIN Period | 38.34 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {CH }}$ | CLKIN High Time | 12 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 12 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 23 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{2}{ }^{\text {T }}$ C | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2)-5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PL}}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PR}}$ | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}$, LOCK, A19:16 | 3 | 25 | ns | 1,4,6, 7 |
| TCHOV2 | $\overline{\text { GCS0:7, }} \overline{\text { LCS }}$, $\overline{\text { UCS }}$, $\overline{\text { NCS }}$, $\overline{\text { RD }}$, $\overline{\mathrm{WR}}$ | 3 | 30 | ns | 1, 4, 6, 8 |
| TCLOV1 | $\overline{B H E}, \overline{D E N}, \overline{L O C K}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 25 | ns | 1,4,6 |
| TCLOV2 | $\begin{aligned} & \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}} 7: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \\ & \text { AD15:0, } \overline{\text { NCS }}, \overline{\text { INTA1:0 }}, \mathrm{S} 2: 0 \end{aligned}$ | 3 | 30 | ns | 1,4,6 |
| T ${ }_{\text {CHOF }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0, }}$ A19:16 | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0, P2.6, P2.7 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, INT4:0, BCLK1:0, T1:0IN, READY, CTS1:0 | 3 |  | ns | 1,9 |
| TCLIS | AD15:0, READY | 10 |  | ns | 1,10 |
| TCLIH | READY, AD15:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD, PEREQ, ERROR | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CliH }}$ | HOLD, PEREQ, ERROR | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$ -
4. Specified for a 50 pF load, see Figure 13 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 14 for rise and fall times outside 50 pF .
6. See Figure 14 for rise and fall times.
7. TCHOV1 applies to $\overline{B H E}, \overline{L O C K}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C186EB operation.

AC SPECIFICATIONS (Continued)

## AC Characteristics-80C186EB-8

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 16 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 62.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 15 | $\infty$ | ns | 1, 2 |
| $\mathrm{T}_{\mathrm{CL}}$ | CLKIN Low Time | 15 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1, 3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1, 3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{CD}}$ | CLKIN to CLKOUT Delay | 0 | 27 | ns | 1, 4 |
| T | CLKOUT Period |  | $2^{*} \mathrm{~T}_{\mathrm{C}}$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PH}}$ | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PL}}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| $\mathrm{T}_{\text {PF }}$ | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\mathrm{S} 2: 0}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}$, LOCK, A19:16 | 3 | 30 | ns | 1,4, 6, 7 |
| TCHOV2 | GCS0:7, $\overline{L C S}, \overline{U C S}, \overline{N C S}, \overline{R D}, \overline{W R}$ | 3 | 35 | ns | 1,4, 6, 8 |
| TCLOV1 | $\overline{B H E}, \overline{D E N}, \overline{L O C K}, ~ R E S O U T, ~ H L D A, ~$ T0OUT, T1OUT, A19:16 | 3 | 30 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}} 7: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD15:0, $\overline{\text { NCS }}, \overline{\text { NTA }} 1: 0, \overline{\text { S2:0 }}$ | 3 | 35 | ns | 1, 4, 6 |
| T CHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, $\overline{\text { LOCK, }}$ S2:0, A19:16 | 0 | 30 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 35 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0, P2.6, P2.7 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\mathrm{CHIH}}$ | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0 | 3 |  | ns | 1, 9 |
| TCLIS | AD15:0, READY | 10 |  | ns | 1,10 |
| TCLIH | READY, AD15:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD, PEREQ, ERROR | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CLIH }}$ | HOLD, PEREQ, ERROR | 3 |  | ns | 1, 9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 13 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 14 for rise and fall times outside 50 pF .
6. See Figure 14 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV} 1}$ applies to $\overline{\mathrm{BHE}}, \overline{\mathrm{LOCK}}$ and $\mathrm{A} 19: 16$ only after a HOLD release.
8. $T_{C H O V}$ applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80 C 186 EB operation.

AC SPECIFICATIONS (Continued)
Relative Timings (80C186EB-20, -16, -13, -8)

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Rising to ALE Falling | T-15 |  | ns |  |
| T ${ }_{\text {AVLL }}$ | Address Valid to ALE Falling | $1 / 2 \mathrm{~T}-10$ |  | ns |  |
| TPLLL | Chip Selects Valid to ALE Falling | $1 / 2 T-10$ |  | ns | 1 |
| TLLAX | Address Hold from ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TLLWL | ALE Falling to WR Falling | $1 / 2 T-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\mathrm{RD}}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| TWHLH | $\overline{\text { WR }}$ Rising to ALE Rising | $1 / 2 T-10$ |  | ns | 1 |
| $\mathrm{T}_{\text {AFRL }}$ | Address Float to $\overline{\text { RD }}$ Falling | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Falling to $\overline{\mathrm{RD}}$ Rising | (2*T) -5 |  | ns | 2 |
| TWLWH | $\overline{\text { WR }}$ Falling to $\overline{\text { WR Rising }}$ | (2*T) - 5 |  | ns | 2 |
| TrHAV | $\overline{\mathrm{RD}}$ Rising to Address Active | T-15 |  | ns |  |
| TwhDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| TWHPH | $\overline{\text { WR Rising to Chip Select Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| $\mathrm{T}_{\text {RHPH }}$ | $\overline{\text { RD }}$ Rising to Chip Select Rising | $1 / 2 T-10$ |  | ns | 1 |
| TPHPL | $\overline{\mathrm{CS}}$ Inactive to $\overline{\mathrm{CS}}$ Active | $1 / 2 T-10$ |  | ns | 1 |
| Tovri | ONCE Active to RESIN Rising | T |  | ns | 3 |
| TRHOX | ONCE Hold from RESIN Rising | T |  | ns | 3 |

## NOTES:

1. Assumes equal loading on both pins.
2. Can be extended using wait states.
3. Not tested.

AC SPECIFICATIONS (Continued)
Serial Port Mode 0 Timings (80C186EB-20, 16, -13, -8)

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TXLXL | TXD Clock Period | $T(n+1)$ |  | ns | 1, 2 |
| TXLXH | TXD Clock Low to Clock High ( $n>1$ ) | $2 \mathrm{~T}-35$ | $2 T+35$ | ns | 1 |
| TXLXH | TXD Clock Low to Clock High ( $n=1$ ) | T-35 | $T+35$ | ns | 1 |
| TXHXL | TXD Clock High to Clock Low ( $n>1$ ) | $(\mathrm{n}-1) \mathrm{T}-35$ | $(n-1) T+35$ | ns | 1,2 |
| TXHXL | TXD Clock High to Clock Low ( $\mathrm{n}=1$ ) | T-35 | $T+35$ | ns | 1 |
| T QVXH | RXD Output Data Setup to TXD Clock High ( $n>1$ ) | $(\mathrm{n}-1) \mathrm{T}-35$ |  | ns | 1, 2 |
| T ${ }_{\text {QVXH }}$ | RXD Output Data Setup to TXD Clock High ( $n=1$ ) | T-35 |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $n>1$ ) | 2T-35 |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $n=1$ ) | T-35 |  | ns | 1 |
| TXHQZ | RXD Output Data Float after Last TXD Clock High |  | $T+20$ | ns | 1 |
| TDVXH | RXD Input Data Setup to TXD Clock High | T+20 |  | ns | 1 |
| TXHDX | RXD Input Data Hold after TXD Clock High | 0 |  | ns | 1 |

## NOTES:

1. See Figure 12 for waveforms.
2. $n$ is the value of the BxCMP register ignoring the ICLK Bit (i.e., ICLK $=0$ ).

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 7. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms, for AC specification definitions, test pins, and illustrations.


Figure 7. AC Test Load

## AC TIMING WAVEFORMS



Figure 8. Input and Output Clock Waveform


NOTE:
$20 \% \mathrm{~V}_{\mathrm{CC}}<$ Float $<80 \% \mathrm{~V}_{\mathrm{CC}}$
Figure 9. Output Delay and Float Waveform


Figure 10. Input Setup and Hold


Figure 11. Relative Signal Waveform


270803-34
Figure 12. Serial Port Mode 0 Waveform

## DERATING CURVES

TYPICAL OUTPUT DELAY VARIATIONS VERSUS LOAD CAPACITANCE


Figure 13

TYPICAL RISE AND FALL VARIATIONS VERSUS LOAD CAPACITANCE


Figure 14

## RESET

The 80C186EB will perform a reset operation any time the RESIN pin active. The $\overline{\text { RESIN }}$ pin is actually synchronized before it is presented internally, which means that the clock must be operating before a reset can take effect. From a power-on state, $\overline{R E S I N}$ must be held active (low) in order to guarantee correct initialization of the 80C186EB. Failure to provide RESIN while the device is powering up will result in unspecified operation of the device.

Figure 15 shows the correct reset sequence when first applying power to the 80C186EB. An external clock connected to CLKIN must not exceed the $\mathrm{V}_{\mathrm{CC}}$ threshold being applied to the 80 C 186 EB . This is normally not a problem if the clock driver is supplied with the same $\mathrm{V}_{\mathrm{CC}}$ that supplies the 80 C 186 EB . When attaching a crystal to the device, $\overline{\text { RESIN }}$ must remain active until both $V_{C C}$ and CLKOUT are stable (the length of time is application specific and depends on the startup characteristics of the crystal circuit). The RESIN pin is designed to operate correctly using an RC reset circuit, but the designer
must ensure that the ramp time for $V_{C C}$ is not so long that $\overline{R E S I N}$ is never really sampled at a logic low level when $V_{C C}$ reaches minimum operating conditions.

Figure 16 shows the timing sequence when $\overline{\text { RESIN }}$ is applied after $V_{C C}$ is stable and the device has been operating. Note that a reset will terminate all activity and return the 80C186EB to a known operating state. Any bus operation that is in progress at the time RESIN is asserted will terminate immediately (note that most control signals will be driven to their inactive state first before floating).

While $\overline{R E S I N}$ is active, bus signals $\overline{\text { LOCK }}, \mathrm{A} 19 /$ $\overline{O N C E}$, and A18:16 are configured as inputs and weakly held high by internal pullup transistors. Only $19 / \overline{\text { ONCE }}$ can be overdriven to a low and is used to enable ONCE Mode. Forcing LOCK or A18:16 low at any time while $\overline{\operatorname{RES} I N}$ is low is prohibited and will cause unspecified device operation.


## NOTE:

CLKOUT synchronization occurs on the rising edge of $\overline{\text { RESIN. If } \overline{\text { RESIN }} \text { is sampled high while CLKOUT is high (solid line), then CLKOUT will remain }}$ low for two CLKIN periods. If $\overline{R E S I N}$ is sampled high while CLKOUT is low (dashed line), then CLKOUT will not be affected.

## BUS CYCLE WAVEFORMS

Figures 17 through 23 present the various bus cycles that are generated by the 80C186EB. What is shown in the figure is the relationship of the various
bus signals to CLKOUT. These figures along with the information present in AC Specifications allow the user to determine all the critical timing analysis needed for a given application.

MEMORY READ, I/O READ, INSTRUCTION FETCH, AND REFRESH WAVEFORM


Figure 17

MEMORY WRITE AND I/O WRITE CYCLE WAVEFORM


Figure 18

HALT CYCLE WAVEFORM


## NOTE:

The address driven is typically the location of the next instruction prefetch. Under a majority of instruction sequences the AD15:0 bus will float, while the A19:16 bus remains driven and all bus control signals are driven to their inactive state.

Figure 19

CASCADE MODE INTERRUPT ACKNOWLEDGE CYCLE WAVEFORM


Figure 20

HOLD/HLDA CYCLE WAVEFORMS


Figure 21

REFRESH DURING HLDA CYCLE WAVEFORM


Figure 22

READY CYCLE WAVEFORM


Figure 23

## REGISTER BIT SUMMARY

Figures 24 through 31 present the bit definition of each register that is active (not reserved) in the Peripheral Control Block (PCB). Each register can be thought to occupy one word (16-bits) of either memory or I/O space, although not all bits in the register necessarily have a function. A register bit is not
guaranteed to return a specific logic value if an " $X$ " appears for the bit definition (i.e., if a zero was written to the register bit it may not be returned as a zero when read). Furthermore, a 0 must be written to any bit that is indicated by an " $X$ " to ensure compatibility with future products or potential product changes.


Figure 24. Interrupt Control Unit Registers


Figure 25. Interrupt Control Unit Registers


Figure 26. Timer Control Unit Registers


| 0 | PPO | Port Pin <br> - Value (read only) |
| :---: | :---: | :---: |
| 1 | PP1 |  |
| 2 | PP2 |  |
| 3 | PP3 |  |
| 4 | PP4 |  |
| 5 | PP5 |  |
| 6 | PP6 |  |
| 7 | PP7 |  |
| 8 | X |  |
| 9 | X |  |
| 10 | $X$ |  |
| 11 | $x$ |  |
| 12 | $x$ |  |
| 13 | $X$ |  |
| 14 | $x$ |  |
| 15 | X |  |
|  | $\begin{aligned} & \operatorname{IPIN}(52 H) \\ & 2 P I N(5 A H) \\ & 3 E T=X X F F H \end{aligned}$ |  |




270803-29

Figure 27. I/O Port Unit Registers


Figure 28. Serial Communications Unit Registers


Figure 29. Chip-Select Unit Registers


Figure 30. Refresh Control Unit Registers


Figure 31. Power Management Unit Registers

## 80C186EB EXECUTION TIMINGS

A determination of 80C186EB program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.
- All word-data is located on even-address boundaries.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

With a 16-bit BIU, the 80C186EB has sufficient bus performance to ensure that an adequate number of prefetched bytes will reside in the queue most of the time. Therefore, actual program execution time will not be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY

| Function |  |  | Format |
| :--- | :--- | :--- | :--- |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER (Continued) SEGMENT = Segment Override: |  |  |  |  |  |  |
| CS | 00101110 |  |  |  | 2 |  |
| SS | 00110110 |  |  |  | 2 |  |
| DS | 00111110 |  |  |  | 2 |  |
| ES | 00100110 |  |  |  | 2 |  |
| ARITHMETICADD = Add: |  |  |  |  |  |  |
| Reg/memory with register to either | 000000 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate to register/memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if sw=01 | 4/16 |  |
| Immediate to accumulator | 0000010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| ADC = Add with carry: |  |  |  |  |  |  |
| Reg/memory with register to either | 000100 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate to register/memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s w}=01$ | 4/16 |  |
| Immediate to accumulator | 0001010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| INC = Increment: |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 3/15 |  |
| Register | 01000 reg |  |  | . | 3 |  |
| SUB = Subtract: |  |  |  |  |  |  |
| Reg/memory and register to either | 001010 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate from register/memory | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if sw=01 | 4/16 |  |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| SBB = Subtract with borrow: |  |  |  |  |  |  |
| Reg/memory and register to either | 000110 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} w=01$ | 4/16 |  |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| DEC = Decrement |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 3/15 |  |
| Register | 01001 reg |  |  |  | 3 | , |
| CMP = Compare: |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | mod reg r/m |  |  | 3/10 |  |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 3/10 |  |
| Immediate with register/memory | 100000 sw | $\bmod 111 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 3/10 |  |
| Immediate with accumulator | 0011110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NEG = Change sign register/memory | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | 3/10 |  |
| AAA $=$ ASCll adjust for add | 00110111 |  |  |  | 8 |  |
| DAA = Decimal adjust for add | 00100111 |  |  |  | 4 |  |
| AAS $=$ ASCII adjust for subtract | 00111111 |  | , |  | 7 |  |
| DAS = Decimal adjust for subtract | 00101111 |  |  |  | 4 |  |
| MUL = Multiply (unsigned): | 1111011 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Register-Byte |  |  |  |  | 26-28 |  |
| Register-Word |  | - |  |  | 35-37 |  |
| Memory-Byte |  |  |  |  | 32-34 |  |
| Memory-Word |  |  |  |  | 41-43 |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

## INSTRUCTION SET SUMMARY (Continued)

| Function |  | - F |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LOGIC (Continued) XOR = Exclusive or: |  |  |  |  |  |  |
| Reg/memory and register to either | 001100 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate to register/memory | 1000000 w | $\bmod 110 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 4/16 |  |
| Immediate to accumulator | 0011010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NOT = invert register/memory | 1111011 w | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  | 3/10 |  |
| STRING MANIPULATION |  |  |  |  |  |  |
| MOVS = Move byte/word | 1010010 w |  |  |  | 14 |  |
| CMPS = Compare byte/word | 1010011 w |  |  |  | 22 |  |
| SCAS $=$ Scan byte/word | 1010111 w |  |  |  | 15 |  |
| LODS = Load byte/wd to AL/AX | 1010110 w |  |  |  | 12 | . |
| STOS = Store byte/wd from AL/AX | 1010101 w |  |  |  | 10 |  |
| $\begin{aligned} & \text { Hs = Inpul byterwd from DX port: } \\ & \text { ours = Output bytelwd to DX port. } \end{aligned}$ | $\frac{0110110 \mathrm{w}}{0.110111 \mathrm{w}}$ |  |  |  | 14 <br> 14 |  |
| Repeated by count in CX (REP/REPE/REPZ/REPNE/REPNZ) |  |  |  |  |  |  |
| MOVS = Move string | 11110010 | 1010010 w |  |  | $8+8 n$ |  |
| CMPS = Compare string | 1111001 z | 1010011 w |  |  | $5+22 n$ |  |
| SCAS = Scan string | 1111001 z | 1010111 w |  |  | $5+15 n$ |  |
| LODS = Load string | 11110010 | 1010110 w |  |  | $6+11 n$ |  |
| STOS = Store string | 11110010 | 1010101 w |  |  | $6+9 n$ |  |
| $\mathrm{Hs}=\text { Input string }$ <br> ours = Output sting | $\frac{11110010}{11110010}$ | $\frac{0110110 \mathrm{w}}{0110111 \mathrm{w}}$ |  |  | $8+8 n$ $8+8 n$ |  |
|  |  |  |  |  |  |  |
| CALL = Call: |  |  |  |  |  |  |
| Direct within segment | 11101000 | disp-low | disp-high |  | 15 |  |
| Register/memory | 11111111 | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  | 13/19 |  |
| indirect within segment |  |  |  |  |  |  |
| Direct intersegment | 10011010 | segment offset |  |  | 23 |  |
|  |  | segment selector |  |  |  |  |
| Indirect intersegment | 11111111 | $\bmod 011 \mathrm{r} / \mathrm{m}$ | $(\bmod \neq 11)$ |  | 38 |  |
| JMP = Unconditional jump: |  |  |  |  |  |  |
| Short/long | 11101011 | disp-low |  |  | 14 |  |
| Direct within segment | 11101001 | disp-low | disp-high |  | 14 |  |
| Register/memory | 11111111 | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  | 11/17 |  |
| Direct intersegment | 11101010 | segment offset |  |  | 14 |  |
|  |  | segment selector |  |  |  |  |
| Indirect intersegment | 11111111 | $\bmod 101 \mathrm{r} / \mathrm{m}$ | $(\bmod \neq 11)$ |  | 26 |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


[^7]INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PROCESSOR CONTROL |  |  |  |  |
| CLC = Clear carry | 11111000 |  | 2 |  |
| CMC = Complement carry | 11110101 |  | 2 |  |
| STC $=$ Set carry | 11111001 |  | 2 |  |
| CLD $=$ Clear direction | 11111100 |  | 2 |  |
| STD $=$ Set direction | 11111101 |  | 2 |  |
| $\mathbf{C L I}=$ Clear interrupt | 11111010 |  | 2 |  |
| STI $=$ Set interrupt | 11111011 |  | 2 |  |
| HLT $=$ Halt | 11110100 |  | 2 |  |
| WAIT $=$ Wait | 10011011 |  | 6 | if TEST $=0$ |
| LOCK = Bus lock prefix | 11110000 |  | 2 |  |
| NOP = No Operation | 10010000 |  | 3 |  |
|  | TTT LLL a are opc | extension) |  |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if $\mathrm{mod}=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field if mod $=00$ then DISP $=0^{*}$, disp-low and disphigh 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)+D I S P$
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)+D I S P$
if $\mathrm{r} / \mathrm{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 $\mathrm{r} / \mathrm{m}=101$ then EA $=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+$ DISP* $^{*}$
if $\mathrm{r} / \mathrm{m}=111$ then $\mathrm{EA}=(B X)+\mathrm{DISP}$
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

Segment Override Prefix

| 0 | 0 | 1 | reg | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

reg is assigned according to the following:
Segment
reg Register
00 ES
01 CS

CS
10
SS
11
DS
REG is assigned according to the following table:

| 16-Bit $(\mathbf{w}=\mathbf{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.


Figure 32. PLCC Principal Dimensions


270803-39

## NOTE:

Units are mm (inches) unless specified.
Figure 33. QFP Principal Dimensions

## ERRATA

An 80C186EB with a STEPID value of 0001H has the following known errata. A device with a STEPID of 0001 H can be visually identified by noting the $\mathbf{a b}$ sence of an alpha character next to the FPO number or by the presence of an "A" alpha character next to the FPO number. The FPO number location is shown in Figures 5 and 6.

1. A19/ $\overline{\mathrm{ONCE}}$ is not latched by the rising edge of $\overline{\text { RESIN. A19/ONCE must remain active (LOW) at }}$ all times to remain in the ONCETM Mode. Removing A19/ONCE after RESIN is high will return all output pins to a driving state, however, the 80C186EB will remain in a reset state.
2. During interrupt acknowledge (INTA) bus cycles, the bus controller will ignore the state of the READY pin if the previous bus cycle ignored the state of the READY pin. This errata can only occur if the Chip-Select Unit is being used. All active chip-selects must be programmed to use READY (RDY bit must be programmed to a 1) if waitstates are required for INTA bus cycles.
3. CLKOUT will transition off the rising edge of CLKIN rather than the falling edge of CLKIN. This does not affect any bus timings other than $T_{C D}$.
4. $\overline{\text { RESIN }}$ has a hysterisis of only 130 mV . It is recommended that $\overline{R E S I N}$ be driven by a Schmitt triggered device to avoid processor lockup during reset using an RC circuit.
5. SINT1 will only go active for one clock period when a receive or transmit interrupt is pending (i.e., it does not remain active until the S1STS register is read). If SINT1 is to be connected to any of the 80C186EB interrupt lines (INT0-INT4), then it must be latched by user logic.

An 80C186EB with a STEPID value of 0001 H or 0002 H has the following known errata. Otherwise, an 80C186EB with a STEPID value of 0002H has no known errata (as of this publication). A device with a STEPID of 0002 H can be visually identified by noting the presence of a " $B$ " or " $C$ " alpha character next to the FPO number. The FPO number location is shown in Figures 5 and 6.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistantly, it is dependent on interrupt timing.

## REVISION HISTORY

The following changes have been made between the -001 version and the -002 version of the 80C186EB data sheet. The -002 data sheet applies to all devices with no alpha character or an " $A$ " alpha character after the FPO number (or by reading a STEPID of 0001 H ). The FPO number location is shown in Figures 5 and 6.

1. Figure 1 was updated to correct for incorrect pin names (TXD1 and TEST/BUSY), and to rename the Powerdown Control Unit to the Power Management Unit.
2. Figure 3 was corrected to indicate that the STEP ID register is located at 0 BCH (not OBAH), and to rename the INTx control registers.
3. Page 6, Power Control Unit was changed to Power Management Unit.
4. Figure 4 was corrected to indicate that the AD15:0 are $P(X)$ rather than $P(Z)$.
5. Table 1 was updated. The following list of pins either had changes to their TYPE field or their DESCRIPTION field.
OSCOUT, PDTMR, AD15:0, A19:16, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}$, LOCK, HLDA, P1.0-P1.7, TxOUT, INT4, SINT1.
6. Figures 4 and 5 were updated to change pin name P2.3/SINT to P2.3/SINT1.
7. PDTMR pin capacitance chart was added to page 21.
8. TCD specification was changed to $20,23,27 \mathrm{~ns}$ for the $-16,-13$, and -8 devices respectively.
9. Serial port timings on page 27 were updated.
10. Figures 14 and 15 were updated to correctly identify the names of signals affected by RESIN.
11. Correction of the text describing Figures 26 and 27.
12. Changes 14 CON register location described in Figure 24.
13. The description of P1CON and P2CON in Figure 26 was changed to indicate that a 0 selects the Port function, while a 1 selects the Peripheral function.
14. Changed Figure 30 description to Power Management Unit.
15. Added RESIN hysterisis anamoly to errata descriptions.

The following changes have been made between the -002 version and the -003 version of the 80C186EB data sheet. This -003 data sheet applies to any 80C186EB with a " $B$ " alpha character after the FPO number. The FPO number location is shown in Figures 5 and 6.

1. The data sheet was changed from a Product Preview version to an Advanced Information version.
2. Figures $1,5,6,8,11,12,17,22,23,24,26,29$ and 31 and Tables 3 and 4 were updated to correct for errors.
3. The DC specifications table has changed. Also, notes 3, 4 and 5 have been changed/added.
4. Graphs for ICc versus Frequency have been changed to equations with supporting text.
5. Graphs for PDTMR pin capacitance have been changed to equations with supporting text.
6. AC Hold timings have been changed from 0 ns to 3 ns.
7. READY input setup time has been changed from 13 ns to 10 ns.
8. Serial port MODE 0 timings have been changed.
9. Various typing errors have been corrected throughout the document.

The following changes were made between the -003 and -004 versions of the 80C186EB data sheets. The -004 data sheets applies to any 80C186EB with a "B" alpha character after the FPO number. The FPO number location is shown in Figures 5 and 6.

1. 20 MHz Electrical, DC and AC Specifications were added to the appropriate sections.
2. The following 80C186EB Core Architecture sections were deleted:
Register Set
Instruction Set
Memory Organization
Addressing Modes
Data Types
Interrupts
3. Most of the 80C186EB Peripheral Architecture sections were condensed along with the Register Bit Summary section.
4. Most of the Tables and Figures have been renumbered due to edits.

# 80C186EC-16, -13 <br> 16-BIT HIGH-INTEGRATION EMBEDDED PROCESSOR 

\author{

- Full Static Operation <br> True CMOS Inputs and Outputs <br> - $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operating Temperature Range
}

Integrated Feature Set:

- Low-Power, Static, Enhanced 8086 CPU Core
- Two Independent DMA Supported UARTs, each with an Integral Baud Rate Generator
- Four Independent DMA Channels
- 24 Multiplexed I/O Port Pins
- Two 8259A Compatible Programmable Interrupt Controllers
- Three Programmable 16-Bit Timer/ Counters
- 32-Bit Watchdog Timer
- Ten Programmable Chip Selects with Integral Wait-State Generator
- Memory Refresh Control Unit
- Power Management Unit
- On-Chip Oscillator
- System Level Testing Support (ONCETM Mode)
Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O

■ Low-Power Operating Modes:

- Idle Mode Freezes CPU Clocks but Keeps Peripherals Active
- Powerdown Mode Freezes All Internal Clocks
- Powersave Mode Divides All Clocks by Programmable Prescalar
- Complete System Development Support
- ASM86 Assembler, PL/M 86, Pascal86, Fortran 86, iC-86 and System Utilities
- In-Circuit Emulator (ICETM-186EC)

Supports 80C187 Numerics Processor Extension
Package Types:

- 100-Pin EIAJ Quad Flat Pack (QFP) (S80C186EC)
- 100-Pin Plastic Quad Flat Pack (PQFP) (KU80C186EC)
■ Speed Versions Available:
- 16 MHz (80C186EC-16)
-13 MHz (80C186EC-13) The 80C186EC uses the latest high density CHMOS technology to integrate several of the most common system peripherals with an enhanced 8086 CPU core to create a powerful system on a single monolithic silicon die.
80C186EC-16, -13
16-Bit High-Integration Embedded Processor
CONTENTS PAGE CONTENTS PAGE
Operating Conditions ..... 24-304
Recommended Connections ..... 24-304
DC SPECIFICATIONS ..... 24-305
ICC versus Frequency and Voltage ..... 24-306
PDTMR Pin Delay Calculation ..... 24-306
AC SPECIFICATIONS ..... 24-307
AC Characteristics-80C186EC-16 ..... 24-307
AC Characteristics-80C186EC-13 ..... 24-308
Relative Timings-80C186EC-16, 13 ..... 24-309
Serial Port Mode 0
Timings-80C186EC-16, 13 ..... 24-310
AC TEST CONDITIONS ..... 24-311
AC TIMING WAVEFORMS ..... 24-311
DERATING CURVES ..... 24-314
RESET ..... 24-314
BUS CYCLE WAVEFORMS ..... 24-317
REGISTER BIT SUMMARY ..... 24-324
80C186EC EXECUTION TIMINGS ..... 24-331
INSTRUCTION SET SUMMARY ..... 24-332


Figure 1. 80C186EC Block Diagram

## INTRODUCTION

The 186 Integrated Processor Family incorporates a wide range of VLSI devices tailored to suit the needs of embedded system designers. All 186 Family devices share a common CPU architecture: the industry standard 8086/8088. Code developed on other "X86" platforms can be ported with little or no modification to any of the 186 Integrated Processor Family devices.

Each of the 186 Integrated Processor Family devices adds a full complement of peripherals to the 8086/8088 CPU core. The type of peripherals and level of integration vary between family members. A complete 186 Family system can often be designed with just the addition of RAM, ROM and simple glue logic. The space savings afforded by high-integration are critical as designers continue to strive for smaller size and portability.

The 80 C 186 EC is one of the highest integration members of the 186 Integrated Processor Family. Two serial ports are provided for services such as interprocessor communication, diagnostics and modem interfacing. Four DMA channels allow for high speed data movement as well as support of the onboard serial ports. A flexible chip select unit simplifies memory and peripheral interfacing. The three general purpose timer/counters can be used for a variety of time measurement and waveform generation tasks. A watchdog timer is provided to insure system integrity even in the most hostile of environments. Two 8259A compatible interrupt controllers handle internal interrupts, and, up to 57 external interrupt requests. A DRAM refresh unit and 24 multiplexed I/O ports round out the feature set of the 80C186EC.

## OVERVIEW

Figure 1 shows a block diagram of the 80 C 186 EC . The execution unit (EU) is an enhanced 8086 CPU core that includes: dedicated hardware to speed up effective address calculations, enhanced execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instructions and full static operation. The bus interface unit (BIU) is the same as that found on the original 186 family products, except the queuestatus mode has been deleted and buffer interface control has been changed to ease system design timings. An independent internal bus is used for communication between the BIU and on-chip peripherals.

## 80C186EC CORE ARCHITECTURE

## Bus Interface Unit

The 80C186EC core incorporates a bus controller that generates local bus control signals. In addition, it employs a HOLD/HLDA protocol to share the local bus with other bus masters.

The bus controller is responsible for generating 20 bits of address, read and write strobes, bus cycle status information and data (for write operations) information. It is also responsible for reading data from the local bus during a read operation. A ready input pin is provided to extend a bus cycle beyond the minimum four states (clocks).

The 80C186EC bus controller also generates two control signals ( $\overline{\mathrm{DEN}}$ and DT/ $\overline{\mathrm{R}}$ ) when interfacing to external transceiver chips. This capability allows the addition of transceivers for simple buffering of the multiplexed address/data bus.

## Clock Generator

The 80C186EC provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter and three low-power operating modes.

The oscillator circuit is designed to be used with either a parallel resonant fundamental or third-overtone mode crystal network. Alternatively, the oscillator circuit may be driven from an external clock source. Figure 2 shows the various operating modes of the 80 C 186 EC oscillator circuit.

The crystal or clock frequency chosen must be twice the required processor operating frequency due to the internal divide-by-two counter. This counter is used to drive all internal phase clocks and the external CLKOUT signal. CLKOUT is a $50 \%$ duty cycle processor clock and can be used to drive other system components. All AC timings are referenced to CLKOUT.

The following parameters are recommended when choosing a crystal:
Temperature Range: Application Specific ESR (Equivalent Series Res.): $40 \Omega$ max CO (Shunt Capacitance of Crystal): $\quad 7.0 \mathrm{pF}$ max $C_{L}$ (Load Capacitance):
Drive Level:
$20 \mathrm{pF} \pm 2 \mathrm{pF}$
1 mW (max)

(A) CRYSTAL CONNECTION

(B) CLOCK CONNECTION

NOTE:

1. The LC network is only required when using a third overtone crystal.

Figure 2. 80C186EC Clock Connections

## 80C186EC Peripheral Architecture

The 80C186EC integrates several common system peripherals with a CPU core to create a compact, yet powerful system. The integrated peripherals are designed to be flexbile and provide logical interconnections between supporting units (e.g., the DMA unit can accept requests from the Serial Communications Unit).

The list of integrated peripherals includes:

- Two cascaded, 8259A compatible, Programmable Interrupt Controllers
- 3-Channel Timer/Counter Unit
- 2-Channel Serial Communications Unit
- 4-Channel DMA Unit
- 10-Output Chip-Select Unit
- 32-bit Watchdog Timer Unit
- I/O Port Unit
- Refresh Control Unit
- Power Management Unit

The registers associated with each integrated peripheral are contained within a $128 \times 16$-bit register file called the Peripheral Control Block (PCB). The base address of the PCB is programmable and can be located on any 256 byte address boundary in either memory or I/O space.

Figure 3 provides a list of the registers associated with the PCB. The Register Bit Summary individually lists all of the registers and identifies each of their programming attributes.

| $\begin{array}{\|c\|} \hline \text { PCB } \\ \text { Offset } \end{array}$ | Function |
| :---: | :---: |
| OOH | Master PIC Port 0 |
| 02H | Master PIC Port 1 |
| 04H | Slave PIC Port 0 |
| 06H | Slave PIC Port 1 |
| 08H | Reserved |
| OAH | SCU Int. Req. Ltch. |
| OCH | DMA Int. Req. Ltch. |
| OEH | TCU Int. Req. Ltch. |
| 10 H | Reserved |
| 12H | Reserved |
| 14H | Reserved |
| 16H | Reserved |
| 18H | Reserved |
| 1AH | Reserved |
| 1 CH | Reserved |
| 1 EH | Reserved |
| 20 H | WDT Reload High |
| 22 H | WDT Reload Low |
| 24H | WDT Count High |
| 26H | WDT Count Low |
| 28 H | WDT Clear |
| 2AH | WDT Disable |
| 2CH | Reserved |
| 2EH | Reserved |
| 30 H | TO Count |
| 32H | T0 Compare A |
| 34H | TO Compare B |
| 46 H | TO Control |
| 38H | T1 Count |
| 3AH | T1 Compare A |
| 3 CH | T1 Compare B |
| 3EH | T1 Control |


| $\begin{aligned} & \text { PCB } \\ & \text { Offset } \end{aligned}$ | Function |
| :---: | :---: |
| 40 H | T2 Count |
| 42H | T2 Compare |
| 44H | Reserved |
| 46 H | T2 Control |
| 48 H | Port 3 Direction |
| 4AH | Port 3 Pin State |
| 4CH | Port 3 Mux Control |
| 4EH | Port 3 Data Latch |
| 50 H | Port 1 Direction |
| 52H | Port 1 Pin State |
| 54H | Port 1 Mux Control |
| 56H | Port 1 Data Latch |
| 58H | Port 2 Direction |
| 5AH | Port 2 Pin State |
| 5CH | Port 2 Mux Control |
| 5EH | Port 2 Data Latch |
| 60H | SCU 0 Baud |
| 62H | SCU 0 Count |
| 64H | SCU 0 Control |
| 66H | SCU 0 Status |
| 68H | SCU 0 RBUF |
| 6AH | SCU 0 TBUF |
| 6CH | Reserved |
| 6EH | Reserved |
| 70 H | SCU 1 Baud |
| 72H | SCU 1 Count |
| 74H | SCU 1 Control |
| 76H | SCU 1 Status |
| 78H | SCU 1 RBUF |
| 7AH | SCU 1 TBUF |
| 7CH | Reserved |
| 7EH | Reserved |


| $\left\lvert\, \begin{gathered} \text { PCB } \\ \text { Offset } \end{gathered}\right.$ | Function |
| :---: | :---: |
| 80 H | GCS0 Start |
| 82H | GCSO Stop |
| 84H | GCS1 Start |
| 86H | GCS1 Stop |
| 88 H | GCS2 Start |
| 8AH | GCS2 Stop |
| 8CH | GCS3 Start |
| 8EH | GCS3 Stop |
| 90 H | GCS4 Start |
| 92H | GCS4 Stop |
| 94H | GCS5 Start |
| 96H | GCS5 Stop |
| 98H | GCS6 Start |
| 9AH | GCS6 Stop |
| 9 CH | GCS7 Start |
| 9EH | GCS7 Stop |
| AOH | LCS Start |
| A2H | LCS Stop |
| A4H | UCS Start |
| A6H | UCS Stop |
| A8H | Relocation Register |
| AAH | Reserved |
| ACH | Reserved |
| AEH | Reserved |
| BOH | Refresh Base Addr. |
| B2H | Refresh Time |
| B4H | Refresh Control |
| B6H | Refresh Address |
| B8H | Power Control |
| BAH | Reserved |
| BCH | Step ID |
| BEH | Powersave |


| PCB Offset | Function |
| :---: | :---: |
| COH | DMA 0 Source Low |
| C 2 H | DMA 0 Source High |
| C4H | DMA 0 Dest. Low |
| C6H | DMA 0 Dest. High |
| C8H | DMA 0 Count |
| CAH | DMA 0 Control |
| CCH | DMA Module Pri. |
| CEH | DMA Halt |
| DOH | DMA 1 Source Low |
| D2H | DMA 1 Source High |
| D4H | DMA 1 Dest. Low |
| D6H | DMA 1 Dest. High |
| D8H | DMA 1 Count |
| DAH | DMA 1 Control |
| DCH | Reserved |
| DEH | Reserved |
| EOH | DMA 2 Source Low |
| E2H | DMA 2 Source High |
| E4H | DMA 2 Dest. Low |
| E6H | DMA 2 Dest. High |
| E8H | DMA 2 Count |
| EAH | DMA 2 Control |
| ECH | Reserved |
| EEH | Reserved |
| FOH | DMA 3 Source Low |
| F2H | DMA 3 Source High |
| F4H | DMA 3 Dest. Low |
| F6H | DMA 3 Dest. High |
| F8H | DMA 3 Count |
| FAH | DMA 3 Control |
| FCH | Reserved |
| FEH | Reserved |

Figure 3. 80C186EC Peripheral Control Block Registers

## Programmable Interrupt Controllers

The 80C186EC utilizes two 8259A compatible Programmable Interrupt Controllers (PIC) to manage both internal and external interrupts. The 8259A modules are configured in a master/slave arrangement.

Seven of the external interrupt pins, INTO through INT6, are connected to the master 8259A module. The eighth external interrupt pin, INT7, is connected to the slave 8259A module.

There are a total of 11 internal interrupt sources from the integrated peripherals: 4 Serial, 4 DMA and 3 Timer/Counter.

## Timer/Counter Unit

The 80C186EC Timer/Counter Unit (TCU) provides three 16 -bit programmable timers. Two of these are highly flexible and are connected to external pins for external control or clocking. The third timer is not connected to any external pins and can only be clocked internally. However, it can be used to clock
the other two timer channels. The TCU can be used to count external events, time external events, generate non-repetitive waveforms or generate timed interrupts.

## Serial Communications Unit

The Serial Communications Unit (SCU) of the 80C186EC contains two independent channels. Each channel is identical in operation except that only channel 0 is directly supported by the integrated interrupt controller (the channel 1 interrupts are routed to external interrupt pins). Each channel has its own baud rate generator and can be internally or externally clocked up to one half the 80C186EC operating frequency. Both serial channels can request service from the DMA unit thus providing block reception and transmission without CPU intervention.

Independent baud rate generators are provided for each of the serial channels. For the asynchronous modes, the generator supplies an $8 x$ baud clock to both the receive and transmit shifting register logic. A 1x baud clock is provided in the synchronous mode.

## DMA Unit

The four channel Direct Memory Access (DMA) Unit is comprised of two modules with two channels each. All four channels are identical in operation. DMA transfers can take place from memory to memory, I/O to memory, memory to I/O or I/O to I/O.

DMA requests can be external (on the DRQ pins), internal (from Timer 2 or a serial channel) or software initiated.

The DMA Unit transfers data as bytes only. Each data transfer requires at least two bus cycles, one to fetch data and one to deposit. The minimum clock count for each transfer is 8 , but this will vary depending on synchronization and wait states.

## Chip-Select Unit

The 80C186EC Chip-Select Unit (CSU) integrates logic which provides up to ten programmable chipselects to access both memories and peripherals. In addition, each chip-select can be programmed to automatically insert additional clocks (wait states) into the current bus cycle, and/or automatically terminate a bus cycle independent of the condition of the READY input pin.

## 1/O Port Unit

The I/O Port Unit on the 80C186EC supports two 8bit channels and one 6-bit channel of input, output or input/output operation. Port 1 is multiplexed with the chip select pins and is output only. Port 2 is multiplexed with the pins for serial channels 1 and 2. All Port 2 pins are input/output. Port 3 has a total of 6 pins: four that are multiplexed with DMA and serial port interrupts and two that are non-multiplexed, open drain I/O.

## Refresh Control Unit

The Refresh Control Unit (RCU) automatically generates a periodic memory read bus cycle to keep dynamic or pseudo-static memory refreshed. A 9-bit counter controls the number of clocks between refresh requests.

A 12-bit address generator is maintained by the RCU and is presented on the A12:1 address lines during the refresh bus cycle. Address bits A19:13 are programmable to allow the refresh address block to be located on any 8 Kbyte boundary.

## Watchdog Timer Unit

The Watchdog Timer Unit (WDT) allows for graceful recovery from unexpected hardware and software upsets. The WDT consists of a 32 -bit counter that decrements every clock cycle. If the counter reaches zero before being reset, the WDTOUT pin is
pulled low for four clock cycles. Logically ANDing the WDTOUT pin with the power-on reset signal allows the WDT to reset the device in the event of a WDT timeout. If a less drastic method of recovery is desired, WDTOUT can be connected directly to NMI or one of the INT input pins. The WDT may also be used as a general purpose timer.

## Power Management Unit

The 80C186EC Power Management Unit (PMU) is provided to control the power consumption of the device. The PMU provides four power management modes: Active, Powersave, Idle and Powerdown.

Active Mode indicates that all units on the 80C186EC are operating at $1 / 2$ the CLKIN frequency.

Idle Mode freezes the clocks of the Execution and Bus units at a logic zero state (all peripherals continue to operate normally).

The Powerdown Mode freezes all internal clocks at a logic zero level and disables the crystal oscillator.

In Powersave Mode, all internal clock signals are divided by a programmable prescalar (up to $1 / 64$ the normal frequency). Powersave Mode can be used with Idle Mode as well as during normal (Active Mode) operation.

## $80 C 187$ Interface

The 80C186EC supports the direct connection of the 80C187 Numerics Processor Extension. The 80 C 187 can dramatically improve the performance of calculation intensive applications.

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80C186EC has a test mode available which forces all output and input/ output pins to be placed in the high-impedance state. ONCE stands for "ON Circuit Emulation". The ONCE mode is selected by forcing the A19/S6/ONCE pin low during a processor reset (this pin is weakly held high during reset to prevent inadvertant entrance into ONCE Mode).

## PACKAGE INFORMATION

This section describes the pin functions, pinout and thermal characteristics for the 80C186EC in both the Plastic Quad Flat Pack (JEDEC PQFP) and the EIAJ Quad Flat Pack (QFP). For complete package speci-
fications and information, see the Intel Packaging Outlines and Dimensions Guide (Order Number: 231369).

## Pin Descriptions

Each pin or logical set of pins is described in Table 2. There are four columns for each entry in the Pin Description Table. The following sections describe each column.

## Column 1: Pin Name

In this column is a mnemonic that describes the pin function. Negation of the signal name (i.e. $\overline{\text { RESIN }}$ ) implies that the signal is active low.

## Column 2: Pin Type

A pin may be either power ( $P$ ), ground (G), input only (I), output only (O) or input/output (I/O). Please note that some pins have more than 1 function. A19/S6/ONCE, for example, is normally an output but functions as an input during reset. For this reason A19/S6/ONCE is classified as an input/ output pin.
Column 3: Input Type (for I and I/O types only)
There are two different types of input pins on the 80C186EC: asynchronous and synchronous. Asynchronous pins require that setup and hold times be met only to guarantee recognition. Synchronous input pins require that the setup and hold times be met to guarantee proper operation. Stated simply, missing a setup or hold on an asynchronous pin will result in something minor (i.e. a timer count will be missed) whereas missing a setup or hold on a synchronous pin will result in system failure (the system will 'lock up").
An input pin may also be edge or level sensitive.
Column 4: Output States (for $O$ and I/O types only)
The state of an output or I/O pin is dependent on the operating mode of the device. There are four modes of operation that are different from normal active mode: Bus Hold, Reset, Idle Mode, Powerdown Mode. This column describes the output pin state in each of these modes.

The legend for interpreting the information in the Pin Descriptions is shown in Table 1.

As an example, please refer to the table entry for AD12:0. The " $I / O$ " signifies that the pins are bidirectional (i.e. have both an input and output function). The " S " indicates that, as an input the signal must be synchronized to CLKOUT for proper operation. The " $\mathrm{H}(\mathrm{Z})$ " indicates that these pins will float while the processor is in the Hold Acknowledge state. $R(Z)$ indicates that these pins will float while $\overline{\text { RESIN }}$ is low. $P(0)$ and $I(0)$ indicate that these pins will drive 0 when the device is in either Powerdown or Idle Mode.

Some pins, the I/O Ports for example, can be programmed to perform more than one function. Multifunction pins have a "/" in their signal name between the different functions (i.e. P3.0/RXI1). If the input pin type or output pin state differ between functions, then that will be indicated by separating the state (or type) with a "/" (i.e. $H(X) / H(Q)$ ). In this example when the pin is configured as P3.0 then its hold output state is $H(X)$; when configured as RXI1 its output state is $H(Q)$.

All pins float while the processor is in the ONCE Mode (with the exception of OSCOUT).

Table 1. Pin Description Nomenclature

| Symbol | Description |
| :---: | :---: |
| P | Power Pin (apply + $\mathrm{V}_{\mathrm{Cc}}$ voltage) |
| G | Ground (connect to $\mathrm{V}_{\text {SS }}$ ) |
| 1 | Input only pin |
| 0 | Output only pin |
| I/O | Input/Output pin |
| S(E) | Synchronous, edge sensitive |
| S(L) | Synchronous, level sensitive |
| A(E) | Asynchronous, edge sensitive |
| A(L) | Asynchronous, level sensitive |
| H(1) | Output driven to $\mathrm{V}_{\mathrm{CC}}$ during bus hold |
| H(0) | Output driven to $\mathrm{V}_{\text {SS }}$ during bus hold |
| H(Z) | Output floats during bus hold |
| H(Q) | Output remains active during bus hold |
| H(X) | Output retains current state during bus hold |
| R(WH) | Output weakly held at $\mathrm{V}_{\mathrm{CC}}$ during reset |
| R(1) | Output driven to $\mathrm{V}_{\mathrm{CC}}$ during reset |
| $\mathrm{R}(0)$ | Output driven to $\mathrm{V}_{\text {SS }}$ during reset |
| R(Z) | Output floats during reset |
| $\mathrm{R}(\mathrm{Q})$ | Output remains active during reset |
| $\mathrm{R}(\mathrm{X})$ | Output retains current state during reset |
|  | Output driven to $\mathrm{V}_{C C}$ during Idle Mode |
| $1(0)$ | Output driven to $\mathrm{V}_{\text {SS }}$ during Idie Mode |
| I(Z) | Output floats during Idie Mode |
| I(Q) | Output remains active during Idle Mode |
| I(X) | Output retains current state during Idle Mode |
| $\mathrm{P}(1)$ | Output driven to $\mathrm{V}_{\text {CC }}$ during Powerdown Mode |
| $\mathrm{P}(0)$ | Output driven to $\mathrm{V}_{\text {ss }}$ during Powerdown Mode |
| $\mathrm{P}(\mathrm{Z})$ | Output floats during Powerdown Mode |
| $\mathrm{P}(\mathrm{Q})$ | Output remains active during Powerdown Mode |
| $\mathrm{P}(\mathrm{X})$ | Output retains current state during Powerdown Mode |

Table 2. 80C186EC Pin Descriptions

| Pin Name | Pin Type | Input Type | Output <br> States | Pin Description |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ | P | - | - | POWER $+5 \mathrm{~V} \pm 10 \%$ power supply connection |
| $\mathrm{V}_{S S}$ | G | - | - | GROUND |
| CLKIN | 1 | A(E) | - | CLocK INput is the external clock input. An external oscillator operating at two times the required 80C186EC operating frequency can be connected to CLKIN. For crystal operation, CLKIN (along with OSCOUT) are the crystal connections to an internal Pierce oscillator. |
| OSCOUT | 0 | - | $H(Q)$ <br> R(Q) <br> I(Q) <br> $P(X)$ | OSCillator OUTput is only used when using a crystal to generate the internal clock. OSCOUT (along with CLKIN) are the crystal connections to an internal Pierce oscillator. This pin can not be used as 2 X clock output for noncrytsal applications (i.e. this pin is not connected for noncrystal applications). |
| CLKOUT | 0 | - | $H(Q)$ <br> $R(Q)$ <br> I(Q) <br> $P(X)$ | CLocK OUTput provides a timing reference for inputs and outputs of the processor, and is one-half the input clock (CLKIN) frequency. CLKOUT has a $50 \%$ duty cycle and transitions every falling edge of CLKIN. |
| $\overline{\text { RESIN }}$ | 1 | A(L) | - | RESet IN causes the 80C186EC to immediately terminate any bus cycle in progress and assume an initialized state. All pins will be driven to a known state, and RESOUT will also be driven active. The rising edge (low-to-high) transition synchronizes CLKOUT with CLKIN before the 80C186EC begins fetching opcodes at memory location OFFFFOH. |
| RESOUT | 0 | - | $\begin{gathered} \hline H(0) \\ R(1) \\ I(0) \\ P(0) \\ \hline \end{gathered}$ | RESet OUTput that indicates the 80C186EC is currently in the reset state. RESOUT will remain active as long as $\overline{\text { RESIN }}$ remains active. |
| PDTMR | 1/0 | A(L) | $\begin{aligned} & \mathrm{H}(\mathrm{WH}) \\ & \mathrm{R}(\mathrm{Z}) \\ & \mathrm{P}(\mathrm{WH}) \\ & \mathrm{I}(\mathrm{WH}) \end{aligned}$ | Power-Down TiMeR pin (normally connected to an external capacitor) that determines the amount of time the 80C186EC waits after an exit from Powerdown before resuming normal operation. The duration of time required will depend on the startup characteristics of the crystal oscillator. |
| NMI | 1 | A(E) | - | Non-Maskable Interrupt input causes a TYPE-2 interrupt to be serviced by the CPU. NMI is latched internally. |
| TEST/BUSY | । | A(E) | - | TEST is used during the execution of the WAIT instruction to suspend CPU operation until the pin is sampled active (LOW). TEST is alternately known as BUSY when interfacing with an 80 C 187 numerics coprocessor. |
| A19/S6/ONCE | 1/0 | A(L) | $\begin{gathered} H(Z) \\ R(W H) \\ I(0) \\ P(0) \end{gathered}$ | This pin drives address bit 19 during the address phase of the bus cycle. During T2 and T3 this pin functions as status bit 6 . S6 is low to indicate CPU bus cycles and high to indicate DMA or refresh bus cycles. During a processor reset ( $\overline{R E S I N}$ active) this pin becomes the ONCE input pin. Holding this pin low during reset will force the part into ONCE Mode. |

Table 2. 80C186EC Pin Descriptions (Continued)

| Pin Name <br> Type | Input <br> Type | Output <br> States | Pin Description |
| :--- | :---: | :---: | :---: | :--- | :--- |

Table 2. 80C186EC Pin Descriptions (Continued)

| Pin Name | Pin <br> Type | Input <br> Type | Output <br> States | $\quad$ Pin Description |
| :--- | :---: | :---: | :---: | :--- |$|$| W |
| :--- |
| WR |
| READY |

Table 2. 80C186EC Pin Descriptions (Continued)

| Pin Name | $\begin{aligned} & \text { Pin } \\ & \text { Type } \end{aligned}$ | Input <br> Type | Output States | Pin Description |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { UCS }}$ | 0 | - | $\begin{aligned} & H(1) \\ & R(1) \\ & I(1) \\ & P(1) \end{aligned}$ | Upper Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address range programmed by the user. After reset, $\overline{U C S}$ is configured to be active for memory accesses between OFFCOOH and OFFFFFH. |
| $\overline{\text { LCS }}$ | 0 | - | $\begin{aligned} & H(1) \\ & R(1) \\ & I(1) \\ & P(1) \\ & \hline \end{aligned}$ | Lower Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address range programmed by the user. LCS is inactive after a reset. |
| P1.0/GCS0 P1.1/GCS1 P1.2/GCS2 P1.3/GCS3 P1.4/GCS4 P1.5/GCS5 P1.6/GCS6 P1.7/GCS7 | 0 | - | $\begin{gathered} H(X) / H(1) \\ R(1) \\ I(X) / I(1) \\ P(X) / P(1) \end{gathered}$ | These pins provide a multiplexed function. If enabled, each pin can provide a General purpose Chip Select output which will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. When not programmed as a Chip-Select, each pin may be used as a general purpose output port. |
| $\begin{aligned} & \text { TOOUT } \\ & \text { T1OUT } \end{aligned}$ | 0 | - | H(Q) <br> $R(1)$ <br> I(Q) <br> $P(X)$ | Timer OUTput pins can be programmed to provide single clock or continuous waveform generation, depending on the timer mode selected. |
| $\begin{aligned} & \text { TOIN } \\ & \text { T1IN } \end{aligned}$ | 1 | $\begin{aligned} & A(L) \\ & A(E) \end{aligned}$ | - | Timer INput is used either as clock or control signals, depending on the timer mode selected. This pin may be either level or edge sensitive depending on the programming mode. |
| INT7:0 | 1 | $\begin{aligned} & A(L) \\ & A(E) \end{aligned}$ | - | Maskable INTerrupt input will cause a vector to a specific Type interrupt routine. The INT6:0 pins can be used as cascade inputs from slave 8259A devices. The INT pins can be configured as level or edge sensitive. |
| $\overline{\text { INTA }}$ | 0 | - | $\begin{aligned} & H(1) \\ & R(1) \\ & I(1) \\ & P(1) \end{aligned}$ | INTerrupt Acknowledge output is a handshaking signal used by external 82C59A-2 Programmable Interrupt Controllers. |
| $\begin{aligned} & \mathrm{P} 3.5 \end{aligned}$ | 1/0 | A(L) | $\begin{aligned} & H(X) \\ & R(Z) \\ & I(X) \\ & H(X) \end{aligned}$ | Bidirectional, open-drain port pins. |
| $\begin{aligned} & \text { P3.3/DMAl1 } \\ & \text { P3.2/DMAIO } \end{aligned}$ | 0 | - | $\begin{aligned} & H(X) \\ & R(0) \\ & I(Q) \\ & P(X) \end{aligned}$ | DMA Interrupt output goes active to indicate that the channel has completed a transfer. DMAI1 and DMAIO are multiplexed with output only port functions. |
| P3.1/TXI1 | 0 | - | $\begin{gathered} \mathrm{H}(\mathrm{X}) / \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(0) \\ \mathrm{I}(\mathrm{Q}) \\ \mathrm{P}(\mathrm{X}) \\ \hline \end{gathered}$ | Transmit Interrupt output goes active to indicate that serial channel 1 has completed a transfer. TXI1 is multiplexed with an output only Port function. |

Table 2. 80C 186EC Pin Descriptions (Continued)

| Pin Name | $\begin{aligned} & \text { Pin } \\ & \text { Type } \end{aligned}$ | Input <br> Type | Output States | Pin Description |
| :---: | :---: | :---: | :---: | :---: |
| P3.0/RXI1 | $\bigcirc$ | - | $\begin{gathered} \hline H(X) / H(Q) \\ R(0) \\ I(Q) \\ P(X) \\ \hline \end{gathered}$ | Receive Interrupt output goes active to indicate that serial channel 1 has completed a reception. RXI1 is multiplexed with an output only port function. |
| WDTOUT | 0 | - | H(Q) <br> R(1) <br> I(Q) <br> $P(X)$ | WatchDog Timer OUTput is driven low for four clock cycles when the watchdog timer reaches zero. WDTOUT may be ANDed with the power-on reset signal to reset the 80C186EC when the watchdog timer is not properly reset. |
| $\begin{aligned} & \hline \text { P2.7/द्CTS1 } \\ & \text { P2.3/ } \overline{\text { CTS0 }} \end{aligned}$ | 1/0 | A(L) | $\begin{aligned} & H(X) \\ & R(Z) \\ & I(X) \\ & P(X) \\ & \hline \end{aligned}$ | Clear-To-Send input is used to prevent the transmission of serial data on the TXD signal pin. CTS1 and CTS0 are multiplexed with an I/O Port function. |
| $\begin{aligned} & \text { P2.6/BCLK1 } \\ & \text { P2.2/BCLKO } \end{aligned}$ | I/O | $\begin{gathered} \hline A(L) / \\ A(E) \end{gathered}$ | $\begin{aligned} & H(X) \\ & R(Z) \\ & I(X) \\ & P(X) \end{aligned}$ | Baud CLocK input can be used as an alternate clock source for each of the integrated serial channels. The BCLK inputs are multiplexed with I/O Port functions. The BCLK input frequency cannot exceed $1 / 2$ the operating frequency of the 80 C 186 EC . |
| $\begin{aligned} & \text { P2.5/TXD1 } \\ & \text { P2.1/TXD0 } \end{aligned}$ | I/O | A(L) | $\begin{gathered} H(Q) \\ R(Z) \\ I(X) / I(Q) \\ P(X) \end{gathered}$ | Transmit Data output provides serial data information. The TXD outputs are multiplexed with I/O Port functions. During synchronous serial communications, TXD will function as a clock output. |
| P2.4/RXD1 <br> P2.0/RXD0 | 1/0 | A(L) | $\begin{gathered} H(X) / H(Q) \\ R(Z) \\ I(X) / I(Q) \\ P(X) \end{gathered}$ | Receive Data input accepts serial data information. The RXD pins are multiplexed with I/O Port functions. During synchronous serial communications, RXD is bi-directional and will become an output for transmission of data (TXD becomes the clock). |
| DRQ3:0 | 1 | A(L) | - | DMA ReQuest input pins are used to request a DMA transfer. The timing of the request is dependent on the programmed synchronization mode. |

## NOTE:

1. READY is $A(E)$ for the rising edge of CLKOUT, $S(E)$ for the falling edge of CLKOUT.

## 80C186EC Pinout

Tables 3 and 4 list the 80C186EC pin names with package location for the 100 -pin Plastic Quad Flat Pack (PQFP) component. Figure 4 depicts the complete 80C186EC pinout (PQFP) package as viewed from the top side of the component (i.e. contacts facing down).

Tables 5 and 6 list the 80C186EC pin names with package location for the 100 -pin EIAJ Quad Flat Pack (QFP) component. Figure 5 depicts the complete 80C186EC (QFP package) as viewed from the top side of the component (i.e. contacts facing down).

Table 3. 80C186EC PQFP Pin Functions with Location

| AD Bus |  |
| :--- | :---: |
| Name | Pin |
| AD0 | 73 |
| AD1 | 72 |
| AD2 | 71 |
| AD3 | 70 |
| AD4 | 66 |
| AD5 | 65 |
| AD6 | 64 |
| AD7 | 63 |
| AD8 | 60 |
| AD9 | 59 |
| AD10 | 58 |
| AD11 | 57 |
| AD12 | 56 |
| AD13/CAS0 | 55 |
| AD14/CAS1 | 54 |
| AD15/CAS2 | 53 |
| A16/S3 | 77 |
| A17/S4 | 76 |
| A18/S5 | 75 |
| A19/S6/ONCE | 74 |


| Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: |
| Name | Pin | Name | Pin |
| ALE | 52 | $\overline{\text { RESIN }}$ | 8 |
| $\overline{\text { BHE }}$ | 51 | RESOUT | 7 |
| $\overline{\mathrm{SO}}$ | 78 | CLKIN | 10 |
| S1 | 79 | OSCOUT | 11 |
| $\overline{\mathrm{S} 2}$ | 80 | CLKOUT | 6 |
| $\overline{\mathrm{RD}}$ | 50 | TEST/BUSY | 83 |
| $\overline{W R}$ | 49 | PEREQ | 81 |
| READY | 85 | $\overline{\text { NCS }}$ | 35 |
| DEN | 47 | ERROR | 84 |
| DT/ $\bar{R}$ | 46 | PDTMR | 9 |
| LOCK | 48 | NMI | 82 |
| HOLD | 44 | INTO | 30 |
| HLDA | 45 | INT1 | 31 |
| INTA | 34 | INT2 | 32 |
|  |  | INT3 | 33 |
| Power and Ground |  | INT4 | 40 |
|  |  | INT5 | 41 |
| Name | Pin | INT6 | 42 |
| $\mathrm{V}_{\mathrm{CC}}$ | 13 | INT7 | 43 |


| I/O |  |
| :--- | :---: |
| Name | Pin |
| UCS | 88 |
| LCS | 89 |
|  |  |
| P1.7/GCS7 | 90 |
| P1.6/GCS6 | 91 |
| P1.5/GCS5 | 92 |
| P1.4/GCS4 | 93 |
| P1.3/GCS3 | 94 |
| P1.2/GCS2 | 95 |
| P1.1/GCS1 | 96 |
| P1.0/GCS0 | 97 |
|  |  |
| P2.7/CTS1 | 23 |
| P2.6/BCLK1 | 22 |
| P2.5/TXD1 | 21 |
| P2.4/RXD1 | 20 |
| P2.3/CTS0 | 19 |
| P2.2/BCLK0 | 18 |
| P2.1/TXD0 | 17 |
| P2.0/RXD0 | 16 |
|  |  |
| P3.5 | 29 |
| P3.4 | 28 |
| P3.3/DMA11 | 27 |
| P3.2/DMAIO | 26 |
| P3.1/TXI1 | 25 |
| P3.0/RXI1 | 24 |
| TOIN | 3 |
| T0OUT | 2 |
| T1IN | 5 |
| T1OUT | 4 |
| DRQ0 | 98 |
| DRQ1 | 99 |
| DRQ2 | 100 |
| DRQ3 | 1 |
| WDTOUT | 36 |
|  |  |

Table 4. PQFP Pin Locations with Pin Name

| Pin | Name |
| :---: | :---: |
| 1 | DRQ3 |
| 2 | T0OUT |
| 3 | TOIN |
| 4 | T1OUT |
| 5 | T1IN |
| 6 | CLKOUT |
| 7 | RESOUT |
| 8 | RESIN |
| 9 | PDTMR |
| 10 | CLKIN |
| 11 | OSCOUT |
| 12 | VSS |
| 13 | VCC |
| 14 | VCC |
| 15 | VSS |
| 16 | P2.0/RXDO |
| 17 | P2.1/TXD0 |
| 18 | P2.2/BCLK0 |
| 19 | P2.3/CTS0 |
| 20 | P2.4/RXD1 |
| 21 | P2.5/TXD1 |
| 22 | P2.6/BCLK1 |
| 23 | P2.7/CTS1 |
| 24 | P3.0/RXI1 |
| 25 | P3.1/TXI1 |


| Pin | Name |
| :---: | :---: |
| 26 | DMAIO/P3.2 |
| 27 | DMAI1/P3.3 |
| 28 | P3.4 |
| 29 | P3.5 |
| 30 | INTO |
| 31 | INT1 |
| 32 | INT2 |
| 33 | INT3 |
| 34 | $\overline{\text { INTA }}$ |
| 35 | $\overline{\text { NCS }}$ |
| 36 | $\overline{\text { WDTOUT }}$ |
| 37 | VSS |
| 38 | VCC |
| 39 | VSS |
| 40 | INT4 |
| 41 | INT5 |
| 42 | INT6 |
| 43 | INT7 |
| 44 | HOLD |
| 45 | HLDA |
| 46 | DT/ $\bar{R}$ |
| 47 | $\overline{\text { DEN }}$ |
| 48 | LOCK |
| 49 | $\overline{\text { WR }}$ |
| 50 | $\overline{\text { RD }}$ |


| Pin | Name |
| :---: | :---: |
| 51 | BHE |
| 52 | ALE |
| 53 | AD15 |
| 54 | AD14 |
| 55 | AD13 |
| 56 | AD12 |
| 57 | AD11 |
| 58 | AD10 |
| 59 | AD9 |
| 60 | AD8 |
| 61 | VSS |
| 62 | $V_{\text {CC }}$ |
| 63 | AD7 |
| 64 | AD6 |
| 65 | AD5 |
| 66 | AD4 |
| 67 | $V_{\text {CC }}$ |
| 68 | V SS $^{2}$ |
| 69 | VCC $^{2}$ |
| 70 | AD3 |
| 71 | AD2 |
| 72 | AD1 |
| 73 | ADO |
| 74 | A19/S6/ONCE |
| 75 | A18/S5 |


| Pin | Name |
| :---: | :---: |
| 76 | A17/S4 |
| 77 | A16/S3 |
| 78 | $\overline{\text { S0 }}$ |
| 79 | $\overline{\text { S1 }}$ |
| 80 | $\overline{S 2}$ |
| 81 | PEREQ |
| 82 | NMI |
| 83 | $\overline{\text { TEST }}$ |
| 84 | $\overline{\text { ERROR }}$ |
| 85 | READY |
| 86 | VCC |
| 87 | VSS |
| 88 | $\overline{\text { UCS }}$ |
| 89 | LCS |
| 90 | P1.7/GCS7 |
| 91 | P1.6/GCS6 |
| 92 | P1.5/GCS5 |
| 93 | P1.4/GCS4 |
| 94 | P1.3/GCS3 |
| 95 | P1.2/GCS2 |
| 96 | P1.1/GCS1 |
| 97 | P1.0/GCS0 |
| 98 | DRQ0 |
| 99 | DRQ1 |
| 100 | DRQ2 |



Figure 4. 100-Pin Plastic Quad Flat Pack Package (PQFP).

Table 5. QFP Pin Names with Package Location

| AD Bus |  |
| :--- | :---: |
| Name | Pin |
| AD0 | 76 |
| AD1 | 75 |
| AD2 | 74 |
| AD3 | 73 |
| AD4 | 69 |
| AD5 | 68 |
| AD6 | 67 |
| AD7 | 66 |
| AD8 | 63 |
| AD9 | 62 |
| AD10 | 61 |
| AD11 | 60 |
| AD12 | 59 |
| AD13/CAS0 | 58 |
| AD14/CAS1 | 57 |
| AD15/CAS2 | 56 |
| A16/S3 | 80 |
| A17/S4 | 79 |
| A18/S5 | 78 |
| A19/S6/ONCE | 77 |


| Bus Control |  |
| :--- | :---: |
| Name | Pin |
| ALE | 55 |
| $\overline{\overline{B H E}}$ | 54 |
| $\overline{\overline{S 0}}$ | 81 |
| $\overline{\mathrm{~S} 1}$ | 82 |
| $\overline{\mathrm{~S} 2}$ | 83 |
| $\overline{\mathrm{RD}}$ | 53 |
| $\overline{\mathrm{WR}}$ | 52 |
| READY | 88 |
| $\overline{\mathrm{DEN}}$ | 50 |
| $\mathrm{DT} / \overline{\mathrm{R}}$ | 49 |
| LOCK | 51 |
| HOLD | 47 |
| HLDA | 48 |
| $\overline{\text { INTA }}$ | 37 |


| Processor Control |  |
| :--- | ---: |
| Name | Pin |
| RESIN | 11 |
| RESOUT | 10 |
| CLKIN | 13 |
| OSCOUT | 14 |
| CLKOUT | 9 |
| TEST/BUSY | 86 |
| PEREQ | 84 |
| NCS | 38 |
| ERROR | 87 |
| PDTMR | 12 |
| NMI | 85 |
| INT0 | 33 |
| INT1 | 34 |
| INT2 | 35 |
| INT3 | 36 |
| INT4 | 43 |
| INT5 | 44 |
| INT6 | 45 |
| INT7 | 46 |


| 1/0 |  |
| :---: | :---: |
| Name | Pin |
| UCS | 91 |
| LCS | 92 |
| P1.7/GCS7 | 93 |
| P1.6/GCS6 | 94 |
| P1.5/GCS5 | 95 |
| P1.4/GCS4 | 96 |
| P1.3/GCS3 | 97 |
| P1.2/GCS2 | 98 |
| P1.1/GCS1 | 99 |
| P1.0/GCS0 | 100 |
| P2.7/CTST | 26 |
| P2.6/BCLK1 | 25 |
| P2.5/TXD1 | 24 |
| P2.4/RXD1 | 23 |
| P2.3/CTS0 | 22 |
| P2.2/BCLK0 | 21 |
| P2.1/TXD0 | 20 |
| P2.0/RXD0 | 19 |
| P3. 5 | 32 |
| P3.4 | 31 |
| P3.3/DMAl1 | 30 |
| P3.2/DMAIO | 29 |
| P3.1/TXI1 | 28 |
| P3.0/RXI1 | 27 |
| TOIN | 6 |
| TOOUT | 5 |
| T1IN | 8 |
| T10UT | 7 |
| DRQ0 | 1 |
| DRQ1 | 2 |
| DRQ2 | 3 |
| DRQ3 | 4 |
| WDTOUT | 39 |

Table 6. QFP Package Location with Pin Names

| Pin | Name | Pin | Name | Pin | Name | Pin | Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | DRQ0 | 26 | P2.7/ETS1 | 51 | LOCK | 76 | ADO |
| 2 | DRQ1 | 27 | P3.0/RXI1 | 52 | $\overline{W R}$ | 77 | A19/S6/ONCE |
| 3 | DRQ2 | 28 | P3.1/TXI1 | 53 | $\overline{\mathrm{RD}}$ | 78 | A18/S5 |
| 4 | DRQ3 | 29 | DMAIO/P3. 2 | 54 | $\overline{\text { BHE }}$ | 79 | A17/S4 |
| 5 | TOOUT | 30 | DMAI1/P3.3 | 55 | ALE | 80 | A16/S3 |
| 6 | TOIN | 31 | P3.4 | 56 | AD15 | 81 | S0 |
| 7 | TIOUT | 32 | P3. 5 | 57 | AD14 | 82 | $\overline{51}$ |
| 8 | T1IN | 33 | INTO | 58 | AD13 | 83 | S2 |
| 9 | CLKOUT | 34 | INT1 | 59 | AD12 | 84 | PEREQ |
| 10 | RESOUT | 35 | INT2 | 60 | AD11 | 85 | NMI |
| 11 | RESIN | 36 | INT3 | 61 | AD10 | 86 | TEST |
| 12 | PDTMR | 37 | INTA | 62 | AD9 | 87 | ERROR |
| 13 | CLKIN | 38 | $\overline{\text { NCS }}$ | 63 | AD8 | 88 | READY |
| 14 | OSCOUT | 39 | WDTOUT | 64 | $V_{\text {Ss }}$ | 89 | $V_{\text {CC }}$ |
| 15 | $V_{\text {Ss }}$ | 40 | $V_{\text {Ss }}$ | 65 | $\mathrm{V}_{\mathrm{CC}}$ | 90 | $\mathrm{V}_{\text {SS }}$ |
| 16 | $V_{C c}$ | 41 | $\mathrm{V}_{\mathrm{CC}}$ | 66 | AD7 | 91 | UCS |
| 17 | $V_{\text {cc }}$ | 42 | $\mathrm{V}_{\text {SS }}$ | 67 | AD6 | 92 | LCS |
| 18 | $V_{\text {ss }}$ | 43 | INT4 | 68 | AD5 | 93 | P1.7/GCS7 |
| 19 | P2.0/RXD0 | 44 | INT5 | 69 | AD4 | 94 | P1.6/GCS6 |
| 20 | P2.1/TXD0 | 45 | INT6 | 70 | $\mathrm{V}_{\mathrm{CC}}$ | 95 | P1.5/GCS5 |
| 21 | P2.2/BCLK0 | 46 | INT7 | 71 | $\mathrm{V}_{\text {SS }}$ | 96 | P1.4/GCS4 |
| 22 | P2.3/CTSO | 47 | HOLD | 72 | $\mathrm{V}_{\mathrm{CC}}$ | 97 | P1.3/GCS3 |
| 23 | P2.4/RXD1 | 48 | HLDA | 73 | AD3 | 98 | P1.2/GCS2 |
| 24 | P2.5/TXD1 | 49 | DT/R | 74 | AD2 | 99 | P1.1/GCS1 |
| 25 | P2.6/BCLK1 | 50 | DEN | 75 | AD1 | 100 | P1.0/GCS0 |




## PACKAGE THERMAL SPECIFICATIONS

The 80C186EC is specified for operation when TC (the case temperature) is within the range of $-40^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$. $\mathrm{T}_{\mathrm{C}}$ may be measured in any environment to determine whether the 80C186EC is within the specified operating range. The case temperature must be measured at the center of the top surface.
$\mathrm{T}_{\mathrm{A}}$ (the ambient temperature) can be calculated from $\theta_{C A}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\mathrm{CA}}$ at various airflows are given in Table 7 for the 100 -pin Quad Flat Pack (QFP) package.

Table 8 shows the maximum $T_{A}$ allowable (without exceeding $T_{C}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumptionspecified in Watts) is calculated by using the maximum $\mathrm{I}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{CC}}$ of 5.5 V .

$$
T_{A}=T_{C}-P * \theta_{C A}
$$

Table 7. Thermal Resistance ( $\theta_{\text {CA }}$ ) at Various Airflows (in ${ }^{\circ} \mathrm{C} /$ Watt)

|  | Airflow in $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec})$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} 0 \\ (0) \\ \hline \end{gathered}$ | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{gathered} 400 \\ (2.03) \end{gathered}$ | $\begin{gathered} 600 \\ (3.04) \end{gathered}$ | $\begin{gathered} 800 \\ (4.06) \end{gathered}$ | $\begin{aligned} & 1000 \\ & (5.07) \end{aligned}$ |
| $\theta_{C A}$ (PQFP) | 27.0 | 22.0 | 18.0 | 15.0 | 14.0 | 13.5 |
| $\theta_{\text {CA }}$ (QFP) | 64.5 | 55.5 | 51.0 | TBD | TBD | TBD |

Table 8. Maximum $\mathrm{T}_{\mathrm{A}}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow in $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec})$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \mathbf{T}_{\mathbf{F}} \\ (\mathrm{MHz}) \end{gathered}$ | $\begin{gathered} 0 \\ (0) \end{gathered}$ | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{gathered} 400 \\ (2.03) \end{gathered}$ | $\begin{gathered} 600 \\ (3.04) \end{gathered}$ | $\begin{gathered} 800 \\ (4.06) \end{gathered}$ | $\begin{aligned} & 1000 \\ & (5.07) \end{aligned}$ |
| $\theta_{\text {CA }}$ (PQFP) | TBD | TBD | TBD | TBD | TBD | TBD | TBD |
| $\theta_{\text {CA }}$ (QFP) | TBD | TBD | TBD | TBD | TBD | TBD | TBD |

## ELECTRICAL SPECIFICATIONS

## Absolute Maximum Ratings

Storage Temperature $\ldots \ldots \ldots-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Case Temperature Under Bias...-65 C to $+100^{\circ} \mathrm{C}$
Supply Voltage
with Respect to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots . \ldots-0.5 \mathrm{~V}$ to +6.5 V
Voltage on Other Pins
with Respect to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots-0.5 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

Operating Conditions

| Symbol | Parameter | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.5 | 5.5 | V |
| $\mathrm{~T}_{\mathrm{F}}$ | Input Clock Frequency |  |  |  |
|  | 80C186EC-16 | 0 | 32 | MHz |
|  | $80 \mathrm{C} 186 \mathrm{EC}-13$ | 0 | 26.08 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature Under Bias |  |  |  |
|  | KU80C186EC-XX (PQFP) | $-40^{\circ} \mathrm{C}$ | +100 | ${ }^{\circ} \mathrm{C}$ |
|  | S80C186EC-XX (QFP) | $-40^{\circ} \mathrm{C}$ | +100 | ${ }^{\circ} \mathrm{C}$ |

## Recommended Connections

Power and ground connections must be made to multiple $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\text {SS }}$ pins. Every 80C186EC-based circuit board should include separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $\mathrm{V}_{\mathrm{SS}}$ ) planes. Every $\mathrm{V}_{\mathrm{CC}}$ pin must be connected to the power plane, and every $\mathrm{V}_{\mathrm{Ss}}$ pin must be connected to the ground plane. Liberal decoupling capacitance should be placed near the 80C186EC. The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance is reduced by placing the decoupling capacitors as close as possible to the 80C186EC VCC and $V_{\text {SS }}$ package pins.

Always connect any unused input to an appropriate signal level. In particular, unused interrupt inputs (NMI, INTO:7) should be connected to V SS through a pull-down resistor. Leave any unused output pin unconnected.

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | $0.3{ }^{*} \mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | $0.7 *{ }^{*} \mathrm{CC}$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}^{\prime}=3 \mathrm{~mA}$ (Min) |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{C C}-0.5$ |  | V | $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ (Min) |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysteresis on RESIN | 0.5 |  | V |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current for Pins: AD15:0, READY, HOLD, RESIN, CLKIN, TEST/BUSY, NMI, INT7:0, TOIN, T1IN, P2.7-P2.0, P3.5-P3.0, DRQ3:0, PEREQ, ERROR |  | $\pm 15$ | $\mu \mathrm{A}$ | $0 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ILIU | Input Leakage for Pins with Pullups Active During Reset: <br> A19:16, LOCK | -0.2 | -5 | mA | $\begin{aligned} & V_{I N}=0.7 V_{C C} \\ & \text { (Note 1) } \end{aligned}$ |
| ILO | Output Leakage for Floated Output Pins |  | $\pm 15$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}} \\ & \text { (Note 2) } \end{aligned}$ |
| ICC | Supply Current Cold (in RESET) 80C186EC-16 80C186EC-13 |  | $\begin{aligned} & 85 \\ & 70 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 3) |
| ID | Supply Current in Idle Mode 80C186EC-16 80C186EC-13 |  | $\begin{aligned} & 60 \\ & 50 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | ( Note 4) |
| IPD | Supply Current in Powerdown Mode 80C186EC-16 80C186EC-13 |  | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ | (Note 5) |
| $\mathrm{C}_{\text {IN }}$ | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |
| Cout | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ (Note 6) |

## NOTES:

1. These pins have an internal pull-up device that is active while $\overline{\text { RESIN }}$ is low and ONCE Mode is not active. Sourcing more current than specified (on any of these pins) may invoke a factory test mode.
2. Tested by outputs being floated by invoking ONCE Mode or by asserting HOLD.
3. Measured with the device in RESET and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND.
4. Measured with the device in HALT (IDLE Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\text {CC }}$ or GND.
5. Measured with the device in HALT (Powerdown Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with

ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $V_{C C}$ or GND.
6. Output Capacitance is the capacitive load of a floating output pin.

## Icc versus Frequency and Voltage

The ICC consumed by the 80C186EC is composed of two components:

1. IPD-The quiescent current that represents internal device leakage. Measured with all inputs at either $V_{C C}$ or ground and no clock applied.
2. ICCS-The switching current used to charge and discharge internal parasitic capacitance when changing logic levels. ICCS is related to both the frequency of operation and the device supply voltage ( $\mathrm{V}_{\mathrm{CC}}$ ). $\mathrm{I}_{\mathrm{CCS}}$ is given by the formula:

$$
\begin{gathered}
\text { Power }=\mathrm{V} * \mathrm{I}=\mathrm{V}^{2} * \mathrm{C}_{\mathrm{DEV}}{ }^{*} \mathrm{f} \\
\therefore \mathrm{I} C \mathrm{~S}=\mathrm{V} * \mathrm{C}_{\mathrm{DEV}}^{*} \mathrm{f}
\end{gathered}
$$

Where:

$$
\begin{aligned}
& V=\text { Supply Voltage }\left(V_{C C}\right) \\
& C_{\text {DEV }}=\text { Device Capacitance } \\
& f=\text { Operating Frequency }
\end{aligned}
$$

Measuring CPD on a device like the 80C186EC would be difficult. Instead, $\mathrm{C}_{\text {PD }}$ is calculated using the above formula with ICC values measured at known $V_{C C}$ and frequency. Using the $C_{P D}$ value, the user can calculate ICC at any voltage and frequency within the specified operating range.

Example. Calculate typical $I_{\mathrm{CC}}$ at $14 \mathrm{MHz}, 5.2 \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}$.

$$
\begin{aligned}
I_{C C} & =I_{P D}+I_{C C S} \\
& =0.1 \mathrm{~mA}+5.2 \mathrm{~V} * 0.77 * 14 \mathrm{MHz} \\
& =56.2 \mathrm{~mA}
\end{aligned}
$$

## PDTMR Pin Delay Calculation

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown Mode. A delay is required only when using the on chip oscillator to allow the crystal or resonator circuit to stabilize.

NOTE:
The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e. a device reset while in Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized.

To calculate the value of capacitor to use to provide a desired delay, use the equation:

$$
440 \times t=C_{P D}\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where:
t = desired delay in seconds
$\mathrm{C}_{\mathrm{PD}}=$ capacitive load on PDTMR in microfarads
Example. For a delay of $300 \mu \mathrm{~s}$, a capacitor value of $C_{P D}=440 \times\left(300 \times 10^{-6}=0.132 \mu \mathrm{~F}\right.$ is required. Round up to a standard (available) capacitor value.

## NOTE:

The above equation applies to delay time longer than $10 \mu$ s and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ to $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $V_{C C}$ and/or lower temperatures will decrease delay time, while lower $\mathrm{V}_{\mathrm{CC}}$ and/or higher temperature will increase delay time.

| Parameter | Target Typical | Target Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| CPD | 0.77 | 1.37 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| CPD (Idie Mode) | 0.55 | 0.96 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

## NOTES:

1. Maximum $\mathrm{C}_{P D}$ is measured at $-40^{\circ} \mathrm{C}$ with all outputs loaded as specified in the $A C$ test conditions and the device in reset (or Idle Mode). Due to tester limitations, CLKOUT and OSCOUT also have 50 pF loads that increase Icc by $\mathrm{V}^{*} \mathrm{C}^{*} \mathrm{~F}$. 2. Typical $\mathrm{C}_{\text {PD }}$ is calculated at $25^{\circ} \mathrm{C}$ assuming no loads on CLKOUT or OSCOUT and the device in reset (or Idle Mode).

## AC SPECIFICATIONS

AC Characteristics-80C186EC-16

| Symbol | Parameter | TARGET Min | TARGET Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 32 | MHz | 1 |
| TC | CLKIN Period | 31.25 | $\infty$ | ns | 1 |
| TCH | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 10 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 10 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{CD}}$ | CLKIN to CLKOUT Delay | 0 | 20 | ns | 1,4 |
| T | CLKOUT Period |  | 2*TC | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPL | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| T ${ }_{\text {CHOV1 }}$ | $\begin{aligned} & \text { ALE, } \overline{\bar{S}: 0, \overline{D E N}, ~ D T / \bar{R}} \\ & \text { BHE, } \overline{\text { LOCK, A19:16 }} \end{aligned}$ | 3 | 22 | ns | 1, 4, 6, 7 |
| TCHOV2 | $\begin{aligned} & \overline{\mathrm{GCS}}: \overline{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \\ & \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{NCS}}, \overline{\mathrm{WDTOUT}} \end{aligned}$ | 3 | 27 | ns | 1, 4, 6, 8 |
| TCLOV1 | BHE, $\overline{D E N}, \overline{L O C K}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 22 | ns | 1, 4, 6 |
| TCLOV2 | $\begin{aligned} & \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GSC}}: \mathbf{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \mathrm{AD15:0}, \\ & \overline{\mathrm{NCS}}, \overline{\mathrm{NTA}}, \overline{\mathrm{~S} 2: 0} \end{aligned}$ | 3 | 27 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{LOCK}}$, S2:0, A19:16 | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 25 | ns | 1 |
| INPUT REQUIREMENTS |  |  |  |  |  |
| TCHIS | TEST, NMI, T1IN, TOIN, READY, CTS1:0, BCLK1:0, P3.4, P3.5 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, T1IN, TOIN, READY, CTS1:0, DRQ1:0, BCLK1:0, P3.4, P3.5 | 3 |  | ns | 1,9 |
| TCLIS | AD15:0, READY | 10 |  | ns | 1,10 |
| TCLIH | AD15:0, READY | 3 |  | ns | 1,10 |
| TCLIS |  | 10 |  | ns | 1,9 |
| TCLIH | HOLD, $\overline{\text { RESIN, }}$ REREQ, ERROR, DRQ3:0 | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 16 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 17 for rise and fall times outside 50 pF .
6. See Figure 17 for rise and fall times.
7. TCHOV1 applies to $\overline{\mathrm{BHE}}, \overline{\mathrm{LOCK}}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C186EC operation.

## AC Characteristics-80C186EC-13

| Symbol | Parameter | TARGET Min | TARGET Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 26.08 | MHz | 1 |
| TC | CLKIN Period | 38.34 | $\infty$ | ns | 1 |
| TCH | CLKIN High Time | 12 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 12 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 10 | ns | 1, 3 |
| TCF | CLKIN Fall Time | 1 | 10 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 23 | ns | 1,4 |
| T | CLKOUT Period |  | 2*TC | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| TPL | CLKOUT Low Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{T}_{\mathrm{PR}}$ | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}, \overline{\mathrm{LOCK}}$, A19:16 | 3 | 25 | ns | 1,4, 6, 7 |
| TCHOV2 | $\overline{\text { GCS7:0, }} \overline{\text { LCS }}, \overline{U C S}, \overline{R D}, \overline{W R}, \overline{N C S}$, WDTOUT | 3 | 30 | ns | 1,4, 6, 8 |
| TCLOV1 | BHE, DEN, LOCK, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 25 | ns | 1,4,6 |
| TCLOV2 | $\overline{R D}, \overline{W R}, \overline{G C S 7: 0}, \overline{L C S}, \overline{U C S}, A D 15: 0,$ NCS, INTA, S2:0 | 3 | 30 | ns | 1, 4, 6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{LOCK}}$, S2:0, A19:16 | 0 | 30 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 30 | ns | 1 |
| INPUT REQUIREMENTS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, T1IN, TOIN, READY, CTS1:0, BCLK1:0, P3.4, P3.5 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, T1IN, TOIN, READY, CTS1:0, DRQ3:0, BCLK1:0, P3.4, P3.5 | 3 |  | ns | 1,9 |
| TCLIS | AD15:0, READY | 10 |  | ns | 1, 10 |
| TCLIH | AD15:0, READY | 3 |  | ns | 1,10 |
| TCLIS | HOLD, $\overline{\text { RESIN, PEREQ, ERROR, DRQ3:0 }}$ | 10 |  | ns | 1,9 |
| TCLIH | HOLD, $\overline{\text { RESIN, }}$ REREQ, ERROR, DRQ3:0 | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 16 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 17 for rise and fall times outside 50 pF .
6. See Figure 17 for rise and fall times.
7. TCHOV1 applies to $\overline{B H E}$, LOCK and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C186EC operation.

Relative Timings-80C186EC-16, 13

| Symbol | Parameter | TARGET Min | TARGET Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Active Pulse Width | T-15 |  | ns |  |
| TAVLL | AD Valid Setup before ALE Falls | $1 / 2 T-10$ |  | ns |  |
| TPLLL | Chip Select Valid before ALE Falls | $1 / 2 T-10$ |  | ns | 1 |
| TLLAX | AD Hold after ALE Falls | $1 / 2 T-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{\text { WR }}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\text { RD }}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| TWHLH | $\overline{\text { WR }}$ Rising to Next ALE Rising | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| $\mathrm{T}_{\text {AFRL }}$ | AD Float to $\overline{\mathrm{RD}}$ Falling | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Active Pulse Width | 2T-5 |  | ns | 2 |
| TWLWH | $\overline{\text { WR Active Pulse Width }}$ | 2T-5 |  | ns | 2 |
| TrHAX | $\overline{\mathrm{RD}}$ Rising to Next Address Active | T-15 |  | ns |  |
| T WHDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| TWHPH | $\overline{\text { WR Rise to Chip Select Rise }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TRHPH | $\overline{\mathrm{RD}}$ Rise to Chip Select Rise | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TPHPL | Chip Select Inactive to Next Chip Select Active | $1 / 2 T-10$ |  | ns | 1 |
| Tovrh |  | T |  | ns |  |
| T ${ }_{\text {RHOX }}$ | ONCE Hold after RESIN Rise | T |  | ns |  |
| $\mathrm{T}_{\text {IHIL }}$ | $\overline{\text { INTA }}$ High to Next INTA Low during INTA Cycle | 4T-5 |  | ns | 4 |
| TILIH | INTA Active Pulse Width | $2 \mathrm{~T}-5$ |  | ns | 2, 4 |
| TCVIL | CAS2:0 Setup before 2nd INTA Pulse Low | 8T |  | ns | 2, 4 |
| TILCX | CAS2:0 Hold after 2nd INTA Pulse Low | 4T |  | ns | 2, 4 |
| TIRES | Interrupt Resolution Time |  | 150 | ns | 3 |
| $\mathrm{T}_{\text {IRLH }}$ | IR Low Time to Reset Edge Detector | 50 |  | ns |  |
| TIRHIF | IR Hold Time after 1st INTA Falling | 25 |  | ns | 4,5 |

## NOTES:

1. Assumes equal loading on both pins.
2. Can be extended using wait states.
3. Interrupt resolution time is the delay between an unmasked interrupt request going active and the interrupt output of the 8259A module going active. This is not directly measureable by the user. For interrupt pin INT7 the delay from an active signal to an active input to the CPU would actually be twice the TiRES value since the signal must pass through two 8259A modules.
4. See INTA Cycle Waveforms for definition.
5. To guarantee interrupt is not spurious.

Serial Port Mode 0 Timings-80C186EC-16, 13

| Symbol | Parameter | tARGET Min | TARGET Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TXLXL | TXD Clock Period | $T(n+1)$ |  | ns | 1, 2 |
| TXLXH | TXD Clock Low to Clock High ( $\mathrm{N}>1$ ) | 2T-35 | $2 \mathrm{~T}+35$ | ns | 1 |
| TXLXH | TXD Clock Low to Clock High ( $\mathrm{N}=1$ ) | T-35 | T+35 | ns | 1 |
| $\mathrm{T}_{\text {XHXL }}$ | TXD Clock High to Clock Low ( $\mathrm{N}>1$ ) | $(\mathrm{n}-1) \mathrm{T}-35$ | ( $\mathrm{n}-1$ ) $\mathrm{T}+35$ | ns | 1,2 |
| $\mathrm{T}_{\text {XHXL }}$ | TXD Clock High to Clock Low ( $\mathrm{N}=1$ ) | T-35 | T+35 | ns | 1 |
| T ${ }_{\text {QVXH }}$ | RXD Output Data Setup to TXD Clock High ( $\mathrm{N}>1$ ) | $(\mathrm{n}-1) \mathrm{T}-35$ |  | ns | 1,2 |
| T QVXH | RXD Output Data Setup to TXD Clock High ( $\mathrm{N}=1$ ) | T-35 |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $\mathrm{N}>1$ ) | $2 \mathrm{~T}-35$ |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $\mathrm{N}=1$ ) | T-35 |  | ns | 1 |
| TXHQZ | RXD Output Data Float after Last TXD Clock High |  | T + 20 | ns | 1 |
| T ${ }_{\text {DVXH }}$ | RXD Input Data Setup to TXD Clock High | T+20 |  | ns | 1 |
| TXHDX | RXD Input Data Setup after TXD Clock High | 0 |  | ns | 1 |

## NOTES:

1. See Figure 15 for Waveforms.
2. $n$ is the value in the BxCMP register ignoring the ICLK bit.

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 6. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms for AC specification definitions, test pins and illustrations.


Figure 6. AC Test Load

## AC TIMING WAVEFORMS



Figure 7. Input and Output Clock Waveforms


Figure 8. Output Delay and Float Waveforms


272027-9
Figure 9. Input Setup and Hold


Figure 10. Relative Interrupt Signal Timings


Figure 11. Relative Signal Waveform


272027-11
Figure 12. Serial Port Mode 0 Waveform

DERATING CURVES


Figure 13. Typical Output Delay Variations versus Load Capacitance


272027-13
Figure 14. Typical Rise and Fall Variations versus Load Capacitance

## RESET

The 80C186EC will perform a reset operation any time the RESIN pin is active. The RESIN pin is synchronized before it is presented internally, which means that the clock must be operating before a reset can take effect. From a power-on state, RESIN must be held active (low) in order to guarantee correct initialization of the 80 C 186 EC . Failure to provide RESIN while the device is powering up will result in unspecified operation of the device.

Figure 15 shows the correct reset sequence when first applying power to the 80C186EC. An external clock connected to CLKIN must not exceed the $\mathrm{V}_{\mathrm{CC}}$ threshold being applied to the 80C186EC. This is normally not a problem if the clock driver is supplied with the same $V_{C C}$ that supplies the 80C186EC. When attaching a crystal to the device, RESIN must. remain active until both $\mathrm{V}_{\mathrm{C}}$ and CLKOUT are stable (the length of time is application specific and depends on the startup characteristics of the crystal circuit). The RESIN pin is designed to operate cor-
rectly using a RC reset circuit, but the designer must ensure that the ramp time for $V_{C C}$ is not so long that $\overline{\text { RESIN }}$ is never sampled at a logic low level when $\mathrm{V}_{\mathrm{CC}}$ reaches minimum operating conditions.

Figure 16 shows the timing sequence when $\overline{\text { RESIN }}$ is applied after $\mathrm{V}_{\mathrm{CC}}$ is stable and the device has been operating. Note that a reset will terminate all activity and return the 80C186EC to a known operating state. Any bus operation that is in progress at the time RESIN is asserted will terminate immediately (note that most control signals will be driven to their inactive state first before floating).

While $\overline{R E S I N}$ is active, bus signals $\overline{\text { LOCK, }}$ A19/S16/ONCE and A18:16 are configured as inputs and weakly held high by internal pullup transistors. Only A19/ONCE can be overdriven to a low and is used to enable the ONCETM Mode. Forcing LOCK or A18:16 low at any time while RESIN is low is prohibited and will cause unspecified device operation.


NOTE:
CLKOUT synchronization occurs on the rising edge of $\overline{\operatorname{RESIN}}$. If $\overline{\mathrm{RESIN}}$ is sampled high while CLKOUT is high (solid line), then CLKOUT will remain low for two CLKIN periods. If $\overline{R E S I N}$ is sampled high while CLKOUT is low (dashed line), then CLKOUT will not be affected.


## BUS CYCLE WAVEFORMS

Figures 17 through 23 present the various bus cycles that are generated by the 80 C 186 EC . What is shown in the figure is the relationship of the various
bus signals to CLKOUT. These figures along with the information present in Section 4.5, AC Specifications, allow the user to determine all the critical timing analysis needed for a given application.


Figure 17. Memory Read, I/O Read, Instruction Fetch and Refresh Waveform


Figure 18. Memory Write and I/O Write Cycle Waveform


## NOTES:

1. Address information is invalid. If previous bus cycle was a read, then the AD15:0 lines will float during T1. Otherwise, the AD15:0 lines will continue to drive during T1 (data is invalid). All other control lines are in their inactive state.
2. All address lines drive zeros while in Powerdown or Idle Mode.

Figure 19. Halt Cycle Waveform


Figure 20. Interrupt Acknowledge Cycle Waveform


Figure 21. HOLD/HLDA Cycle Waveforms


Figure 22. Refresh during HLDA Waveforms

notes:

1. $\overline{R E A D Y}$ must be low by either edge to cause a wait state.
2. Lighter lines indicate READ cycles, darker lines indicate WRITE cycles.

Figure 23. READY Cycle Waveforms

## REGISTER BIT SUMMARY

Figures 24 through 37 present the bit definition of each register that is active (not reserved) in the Pe ripheral Control Block (PCB). Each register can be thought to occupy one word (16-bits) of either memory or I/O space, although not all bits in the register necessarily have a function. A register bit is not guaranteed to return a specific logic value if an " $X$ "
appears for the bit definition (i.e., if a zero was written to the register bit it may not be returned as a zero when read). Furthermore, a 0 must be written to any bit that is indicated by an " $X$ " to ensure compatibility with future products or potential product changes. Any register bit that has a specific value in it (a " 0 " or a " 1 "), must be written to that value in order to guarantee proper operation of the 80 C 186 EC .


Figure 24. 8259A Module Initialization Command Words (ICWs)


Figure 25. 8259A Module Initialization Command Words (ICWs) (Continued)


Figure 26. 8259A Module Operation Command Words


Figure 27. Interrupt Request Latch Registers


Figure 28. Watchdog Timer Registers


Figure 29. Timer Control Unit Registers


Figure 30. I/O Port Unit Registers





Figure 31. Serial Communications Unit Registers


Figure 32. Chip-Select Unit Registers


Figure 33. Refresh Control Unit Registers


Figure 34. Power Management Unit Registers


Figure 35. DMA Unit Registers


Figure 36. DMA Unit Registers (Continued)


272027-39

Figure 37. Relocation and Stepping Identifier Registers

## 80C186EC EXECUTION TIMINGS

A determination of 80C186EC program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.
- All word-data is located on even-address boundaries.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

With a 16 -bit BIU, the 80C186EC has sufficient bus performance to ensure that an adequate number of prefetched bytes will reside in the queue most of the time. Therefore, actual program execution time will not be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER MOV = Move: |  |  |  |  |  |  |
| Register to Register/Memory | 1000100 w | mod reg r/m |  |  | 2/12 |  |
| Register/memory to register | 1000101 w | mod reg r/m |  |  | 2/9 |  |
| Immediate to register/memory | 1100011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 12-13 | 8/16-bit |
| Immediate to register | 1011 w reg | data | data if $w=1$ |  | 3-4 | 8/16-bit |
| Memory to accumulator | 1010000 w | addr-low | addr-high |  | 8 |  |
| Accumulator to memory | 1010001 w | addr-low | addr-high |  | 9 |  |
| Register/memory to segment register | 10001110 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2/9 |  |
| Segment register to register/memory | 10001100 | mod 0 reg r/m |  |  | 2/11 |  |
| PUSH = Push: |  |  |  |  |  |  |
| Memory | 11111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  | 16 |  |
| Register | 01010 reg |  |  |  | 10 |  |
| Segment register | 000 reg 110 |  |  |  | 9 |  |
| Immediate | 0.11010 s 0 | data | data $I \mathrm{~s}=0$ |  | 10 |  |
| PUSHA = Push AH........ | 01100000 |  |  |  | 36 |  |
| $\mathbf{P O P}=\mathbf{P o p}:$ |  |  |  |  |  |  |
| Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 20 |  |
| Register | 01011 reg |  |  |  | 10 |  |
| Segment register | 000 reg 111 | $(r e g \neq 01)$ |  |  | 8 |  |
| POPA = Pop Al | 0.1100001 |  |  |  | 51 |  |
| XCHG = Exchange: |  |  |  |  |  |  |
| Register/memory with register | 1000011 w | mod reg r/m |  |  | 4/17 |  |
| Register with accumulator | 10010 reg |  |  |  | 3 |  |
| IN = Input from: |  |  |  |  |  |  |
| Fixed port | 1110010 w | port |  |  | 10 |  |
| Variable port | 1110110 w |  |  |  | 8 |  |
| OUT = Output to: |  |  |  |  |  |  |
| Fixed port | 1110011 w | port |  |  | 9 |  |
| Variable port | 1110111 w |  |  |  | 7 |  |
| XLAT $=$ Translate byte to AL | 11010111 |  |  |  | 11 |  |
| LEA = Load EA to register | 10001101 | mod reg r/m |  |  | 6 |  |
| LDS $=$ Load pointer to DS | 11000101 | mod reg r/m | $(\bmod \neq 11)$ |  | 18 |  |
| LES = Load pointer to ES | 11000100 | mod reg r/m | $(\bmod \neq 11)$ |  | 18 |  |
| LAHF = Load AH with flags | 10011111 |  |  |  | 2 |  |
| SAHF = Store AH into flags | 10011110 |  |  |  | 3 |  |
| PUSHF $=$ Push flags | 10011100 |  |  |  | 9 |  |
| POPF $=$ Pop flags | 10011101 |  |  |  | 8 |  |

Shaded areas indicate instructions not available in $8086 / 8088$ microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER (Continued) SEGMENT $=$ Segment Override: |  |  |  |  |  |  |
| CS | 00101110 |  |  |  | 2 |  |
| SS | 00110110 |  |  |  | 2 |  |
| DS | 00111110 |  |  |  | 2 |  |
| ES | 00100110 |  |  |  | 2 |  |
| ARITHMETIC$\begin{aligned} & \text { ADD }=\text { Add: }\end{aligned}$Reg/memory with register to either $\quad 000000 \mathrm{dw}$ w mod reg r/m |  |  |  |  |  |  |
|  |  |  |  |  | 3/10 |  |
| Immediate to register/memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $s \mathbf{w}=01$ | 4/16 |  |
| Immediate to accumulator | 0000010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| ADC = Add with carry: <br> Reg/memory with register to either $\quad 000000 \mathrm{dw}$ |  |  |  |  |  |  |
|  |  |  |  |  | 3/10 |  |
| Immediate to register/memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16 |  |
| Immediate to accumulator | 0001010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
|  |  |  |  |  |  |  |
|  |  |  |  |  | 3/15 |  |
| Register | 01000 reg |  |  |  | 3 |  |
| SUB = Subtract:Reg/memory and register to either $\quad 001010 \mathrm{dw}$ |  |  |  |  |  |  |
|  |  |  |  |  | 3/10 |  |
| Immediate from register/memory | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} \mathbf{w}=01$ | 4/16 |  |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| SBB = Subtract with borrow:Reg/memory and register to either $\quad 000110 \mathrm{dw}$ |  |  |  |  |  |  |
|  |  |  |  |  | 3/10 |  |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16 |  |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| DEC = Decrement |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 3/15 |  |
| Register | 01001 reg |  |  |  | 3 |  |
| CMP = Compare: |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | mod reg $\mathrm{r} / \mathrm{m}$ |  |  | 3/10 |  |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 3/10 |  |
| Immediate with register/memory | 100000 sw | mod $111 \mathrm{r} / \mathrm{m}$ | data | data if $s$ w $=01$ | 3/10 |  |
| Immediate with accumulator | 0011110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NEG = Change sign register/memory | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | 3/10 |  |
| AAA $=$ ASCII adjust for add | 00110111 |  |  |  | 8 |  |
| DAA = Decimal adjust for add | 00100111 |  |  |  | 4 |  |
| AAS $=$ ASCII adjust for subtract | 00111111 |  |  |  | 7 |  |
| DAS = Decimal adjust for subtract | 00101111 |  |  |  | 4 |  |
| MUL = Multiply (unsigned): | 1111011 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Register-Byte |  |  |  |  | 26-28 |  |
| Register-Word |  |  |  |  | 35-37 |  |
| Memory-Byte |  |  |  |  | 32-34 |  |
| Memory-Word |  |  |  |  | 41-43 |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


[^8]INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PROCESSOR CONTROL |  |  |  |  |
| CLC = Clear carry | 11111000 |  | 2 |  |
| CMC = Complement carry | 11110101 |  | 2 |  |
| STC = Set carry | 11111001 |  | 2 |  |
| CLD = Clear direction | 11111100 |  | 2 |  |
| STD $=$ Set direction | 11111101 |  | 2 |  |
| $\mathbf{C L I}=$ Clear interrupt | 11111010 |  | 2 |  |
| STI $=$ Set interrupt | 11111011 |  | 2 |  |
| HLT $=$ Halt | 11110100 |  | 2 |  |
| WAIT = Wait | 10011011 |  | 6 | if $\overline{\text { TEST }}=0$ |
| LOCK = Bus lock prefix | 11110000 |  | 2 |  |
| NOP $=$ No Operation | 10010000 |  | 3 |  |
|  | TTT LLL are opc | extension |  |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

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 disphigh 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 $\mathrm{EA}=(\mathrm{BX})+(\mathrm{SI})+\mathrm{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 $\mathrm{EA}=(\mathrm{BP})+(\mathrm{SI})+\mathrm{DISP}$
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then $\mathrm{EA}=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=(\mathrm{BP})+$ 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 $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then EA $=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

## Segment Override Prefix

$$
\begin{array}{|lllllll|}
\hline 0 & 0 & 1 & \text { reg } & 1 & 1 & 0 \\
\hline
\end{array}
$$

reg is assigned according to the following:

reg $\quad$| Segment |
| :--- |
| Register |

00 ES
01
CS
10
SS
11
DS
REG is assigned according to the following table:

| $\mathbf{1 6 - B i t}(\mathbf{w}=\mathbf{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.

## 80L186EA-13, -8 <br> 16-BIT HIGH INTEGRATION EMBEDDED PROCESSOR

■ 3V Operation, $\mathrm{V}_{\mathrm{CC}}=2.7 \mathrm{~V}-5.5 \mathrm{~V}$

- Full Static Operation
- True CMOS Inputs and Outputs
- Integrated Feature Set
—Static 186 CPU Core
- Power Save, Idle and Powerdown Modes
- Clock Generator
- 2 Independent DMA Channels
- 3 Programmable 16-Bit Timers
-Dynamic RAM Refresh Control Unit
- Programmable Memory and Peripheral Chip Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- System-Level Testing Support (High Impedance Test Mode)
- Speed Versions Available:
-13 MHz (80L186EA-13)
- 8 MHz (80L186EA-8)

Direct Addressing Capability to
1 Mbyte Memory and 64 Kbyte I/O

- Complete System Development Support
- All 8086/8088 and 80C186 Family Software Development Tools Can Be Used for 80L186EA System Development
- ASM86 Assembler, iC-86, Pascal-86, FORTRAN-86, PL/M-86 and System Utilities
- In-Circuit-Emulator (ICETM-186)
- Available in the Following Packages: -68-Pin Plastic Leaded Chip Carrier (PLCC)
- 80-Pin EIAJ Quad Flat Pack (QFP)

Available in EXPRESS Extended Temperature Range $\left(-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}$ )

The 80L186EA is the $3 V$ version of the 80C186EA Embedded Processor. By reducing $V_{C C}$, further power savings can be realized over the standard 80C186EA, making the 80L186EA ideal for battery-powered portable applications.



## INTRODUCTION

The 80L186EA is the second member of the 186 Integrated Processor Family to go to 3 V operation, following the 80L186EB. The 80L186EA is the 3 V version of the 80C186EA. The 80L186EA is functionally compatible with the industry standard $80 C 186$ embedded processor. Current 80 C 186 users can easily upgrade their designs to use the 80L186EA and benefit from the reduced power consumption of 3 V operation.

The feature set of the 80L186EA meets the needs of battery-powered applications. Battery-powered applications benefit from the static CPU core and peripherals. Minimum current consumption is achieved by combining low voltage operation along with the features of the power management unit, thus maximizing battery life. Peripheral design enhancements ensure that non-initialized peripherals consume little current.

Space-critical applications benefit from the integration of commonly used system peripherals. Two flexible DMA channels perform CPU-independent data transfers. A flexible chip select unit simplifies memory and peripheral interfacing. The interrupt unit provides sources for up to 128 external interrupts and will prioritize these interrupts with those generated from the on-chip peripherals. Three general purpose timer/counters round out the feature set of the 80L186EA.

## OVERVIEW

Figure 1 shows a block diagram of the 80L486EA. The Execution Unit (EU) is an enhanced 8086 CPU core that includes: dedicated hardware to speed up effective address calculations, enhance execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instructions, and static operation. The Bus Interface Unit (BIU) is the same as that found on the original 80 C 186 family products. An independent internal bus is used to allow communication between the BIU and internal peripherals.

## Differences between the 80C186 and the 80L186EA

The 80L186EA is intended as a direct functional upgrade for 80C186 designs. In many cases, it will be possible to replace an existing 80 C 186 with little or no hardware redesign. The following sections describe differences in pinout, operating modes, and AC and DC specifications to keep in mind.

## Pinout Compatibility

The 80L186EA requires a PDTMR pin to time the processor's exit from Powerdown Mode. The original pin arrangement for the 80C186 in the PLCC package did not have any spare leads to use for PDTMR, so the $D T / \bar{R}$ pin was sacrificed. The arrangement of all the other leads in the 68-lead PLCC is identical between the 80C186 and the 80L186EA. DT/ $\overline{\mathrm{R}}$ may be readily synthesized by latching the $\overline{\mathrm{S} 1}$ status output. Therefore, upgrading a PLCC 80C186 to PLCC 80L186EA is particularly straightforward. You must connect a capacitor to the 80L186EA PDTMR pin in order to use Powerdown Mode.

The 80-lead QFP (EIAJ) pinouts are distinctly different between the 80C186 and the 80L186EA. In addition to the PDTMR pin, the 80L186EA has more power and ground pins and the overall arrangement of pins was shifted. A new circuit board layout for the 80L186EA is required.

## Operating Modes

The 80C186 has two operating modes, Compatible and Enhanced. Compatible Mode is a pin-to-pin replacement for the NMOS 80186, except for numerics coprocessing. In Enhanced Mode, the processor has a Refresh Control Unit and the Power-Save feature.

In regular operation, all 80L186EA features (including those of the Enhanced Mode 80C186) are present.

## PACKAGE INFORMATION

This section describes the pins, pinouts, and thermal characteristics for the 80L186EA in the Plastic Leaded Chip Carrier (PLCC) package and Quad Flat Pack (QFP) package. For complete package specifications and information, see the Intel Packaging Outlines and Dimensions Guide (Order Number: 231369).

## Pin Descriptions

Each pin or logical set of pins is described in Table 2. There are three columns for each entry in the Pin Description Table.

The Pin Name column contains a mnemonic that describes the pin function. Negation of the signal name (for example, $\overline{R E S I N}$ ) denotes a signal that is active low.

The Pin Type column contains two kinds of information. The first symbol indicates whether a pin is power (P), ground (G), input only (I), output only (O) or input/output (I/O). Some pins have multiplexed functions (for example, A19/S6). Additional symbols indicate additional characteristics for each pin. Table 4 lists all the possible symbols for this column.

Input pins may be either synchronous or asynchronous. Asynchronous pins require that setup and hold times be met only in order to guarantee recognition at a particular clock edge. Synchronous pins require that setup and hold times be met to guarantee proper operation. For example, missing the setup or hold time for the SRDY pin (a synchronous input) will result in a system failure or lockup. Input pins may also be edge- or level-sensitive. The possible characteristics for input pins are $S(E), S(L), A(E)$ and $A(L)$.

Output states are dependent upon the current activity of the processor. There are four operational states that are different from regular operation: bus hold, reset, Idle Mode and Powerdown Mode. Appropriate characteristics for these states are also indicated in this column, with the legend for all possible characteristics in Table 1.

Finally, the Pin Description column contains a text description of each pin.

As an example, consider AD15:0. 1/O signifies the pins are bidirectional. $S(L)$ signifies that the input function is synchronous and level-sensitive. $H(Z)$ signifies that, as outputs, the pins are high-impedance upon acknowledgement of bus hold. $R(Z)$ signifies that the pins float during reset. $P(X)$ signifies that the pins retain their states during Powerdown Mode.

Table 1. Pin Description Nomenclature

| Symbol | Description |
| :---: | :---: |
| $\begin{aligned} & \mathrm{P} \\ & \mathrm{G} \\ & \mathrm{I} \\ & \mathrm{O} \\ & \mathrm{I} / \mathrm{O} \end{aligned}$ | Power Pin (Apply $+\mathrm{V}_{\mathrm{cc}}$ Voltage) <br> Ground (Connect to $\mathrm{V}_{\mathrm{SS}}$ ) <br> Input Only Pin <br> Output Only Pin <br> Input/Output Pin |
| S(E) <br> S(L) <br> A(E) <br> A(L) | Synchronous, Edge Sensitive Synchronous, Level Sensitive Asynchronous, Edge Sensitive Asynchronous, Level Sensitive |
| $H(1)$ <br> $\mathrm{H}(0)$ <br> H(Z) <br> H(Q) <br> $\mathrm{H}(\mathrm{X})$ | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Bus Hold <br> Output Driven to VSs during Bus Hold <br> Output Floats during Bus Hold <br> Output Remains Active during Bus Hold <br> Output Retains Current State during Bus Hold |
| R(WH) <br> R(1) <br> $\mathrm{R}(0)$ <br> R(Z) <br> $\mathrm{R}(\mathrm{Q})$ <br> R(X) | Output Weakly Held at $\mathrm{V}_{\mathrm{CC}}$ during Reset <br> Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Reset <br> Output Driven to $\mathrm{V}_{\text {SS }}$ during Reset <br> Output Floats during Reset <br> Output Remains Active during Reset <br> Output Retains Current State during Reset |
| I(1) <br> I(0) <br> I(Z) <br> I(Q) <br> I(X) | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Idle Mode <br> Output Driven to VSS during Idle Mode <br> Output Floats during Idle Mode <br> Output Remains Active during Idle Mode <br> Output Retains Current State during Idle Mode |
| $\begin{aligned} & P(1) \\ & P(0) \\ & P(Z) \\ & P(Q) \\ & P(X) \\ & \hline \end{aligned}$ | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Powerdown Mode <br> Output Driven to $\mathrm{V}_{\mathrm{SS}}$ during Powerdown Mode <br> Output Floats during Powerdown Mode <br> Output Remains Active during Powerdown Mode <br> Output Retains Current State during Powerdown Mode |

80L186EA-13, -8

Table 2. 80L186EA Pin Descriptions

| Name | Type | Description |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ | P | POWER connections consist of six pins which must be shorted externally to a $\mathrm{V}_{\mathrm{CC}}$ board plane. |
| $\mathrm{V}_{\text {SS }}$ | G | GROUND connections consist of five pins which must be shorted externally to a $V_{\text {SS }}$ board plane. |
| CLKIN | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | CLocK INput is an input for an external clock. An external oscillator operating at two times the required 80L186EA operating frequency can be connected to CLKIN. For crystal operation, CLKIN (along with OSCOUT) are the crystal connections to an internal Pierce oscillator. |
| OSCOUT | $\begin{gathered} O \\ H(Q) \\ R(Q) \\ P(Q) \end{gathered}$ | OSCillator OUTput is only used when using a crystal to generate the external clock. OSCOUT (along with CLKIN) are the crystal connections to an internal Pierce oscillator. This pin is not to be used as 2 X clock output for non-crystal applications (i.e., this pin is N.C. for non-crystal applications). OSCOUT does not float in ONCE mode. |
| CLKOUT | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(\mathrm{Q}) \\ \mathrm{P}(\mathrm{Q}) \end{gathered}$ | CLocK OUTput provides a timing reference for inputs and outputs of the processor, and is one-half the input clock (CLKIN) frequency. CLKOUT has a $50 \%$ duty cycle and transistions every falling edge of CLKIN. |
| $\overline{\text { RESIN }}$ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | RESet IN causes the 80L186EA to immediately terminate any bus cycle in progress and assume an initialized state. All pins will be driven to a known state, and RESOUT will also be driven active. The rising edge (low-to-high) transition synchronizes CLKOUT with CLKIN before the 80L186EA begins fetching opcodes at memory location OFFFFOH. |
| RESOUT | $\begin{gathered} 0 \\ H(0) \\ R(1) \\ P(0) \\ \hline \end{gathered}$ | RESet OUTput that indicates the 80L186EA is currently in the reset state. RESOUT will remain active as long as $\overline{\text { RESIN }}$ remains active. |
| PDTMR | $\begin{gathered} 1 / O \\ A(L) \\ H(W H) \\ R(Z) \\ P(1) \\ \hline \end{gathered}$ | Power-Down TiMeR pin (normally connected to an external capacitor) that determines the amount of time the 80L186EA waits after an exit from power down before resuming normal operation. The duration of time required will depend on the startup characteristics of the crystal oscillator. |
| NMI | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | Non-Maskable Interrupt input causes a Type 2 interrupt to be serviced by the CPU. NMI is latched internally. |
| $\overline{\text { TEST }}$ | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | TEST is used during the execution of the WAIT instruction to suspend CPU operation until the pin is sampled active (low). |
| AD15:0 | I/O <br> S(L) <br> H(Z) <br> R(Z) <br> $P(X)$ | These pins provide a multiplexed Address and Data bus. During the address phase of the bus cycle, address bits 0 through 15 are presented on the bus and can be latched using ALE. 8- or 16-bit data information is transferred during the data phase of the bus cycle. |
| $\begin{aligned} & \text { A18:16 } \\ & \text { A19/S6 } \end{aligned}$ | $\begin{aligned} & \mathrm{H}(\mathrm{Z}) \\ & \mathrm{R}(\mathrm{Z}) \\ & \mathrm{P}(\mathrm{X}) \end{aligned}$ | These pins provide multiplexed Address during the address phase of the bus cycle. Address bits 16 through 19 are presented on these pins and can be latched using ALE. A18:16 are driven to a logic 0 during the data phase of the bus cycle. Also during the data phase, S 6 is driven to a logic 0 to indicate a CPU-initiated bus cycle or logic 1 to indicate a DMA-initiated bus cycle or a refresh cycle. |

Table 2. 80L186EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| S2:0 | $\begin{gathered} O \\ H(Z) \\ R(Z) \\ P(1) \end{gathered}$ | Bus cycle Status are encoded on these pins to provide bus transaction information. $\mathrm{S2}: 0$ are encoded as follows: |
| ALE/QSO | $\begin{gathered} O \\ H(0) \\ R(0) \\ P(0) \end{gathered}$ | Address Latch Enable output is used to strobe address information into a transparent type latch during the address phase of the bus cycle. In Queue Status Mode, QSO provides queue status information along with QS1. |
| $\overline{\mathrm{BHE}}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(\mathrm{X}) \end{gathered}$ | Byte High Enable output to indicate that the bus cycle in progress is transferring data over the upper half of the data bus. $\overline{B H E}$ and AO have the following logical encoding: |
| $\overline{\mathrm{RD}} / \overline{\text { QSMD }}$ | $\begin{gathered} I / O \\ H(Z) \\ R(W H) \\ P(1) \end{gathered}$ | ReaD output signals that the accessed memory or I/O device must drive data information onto the data bus. Upon reset, this pin has an alternate function. As QSMD, it enables Queue Status Mode when grounded. In Queue Status Mode, the ALE/QS0 and WR/QS1 pins provide the following information about processor/instruction queue interaction: |
| $\overline{\text { WR/QS1 }}$ | $\begin{gathered} O \\ H(Z) \\ R(Z) \\ P(1) \end{gathered}$ | WRite output signals that data available on the data bus are to be written into the accessed memory or I/O device. In Queue Status Mode, QS1 provides queue status information along with QSO. |
| ARDY | $\begin{aligned} & 1 \\ & A(L) \\ & S(L) \end{aligned}$ | Asychronous ReaDY is an input to signal for the end of a bus cycle. ARDY is asynchronous on rising CLKOUT and synchronous on falling CLKOUT. ARDY or SRDY must be active to terminate any 80L186EA bus cycle, unless they are ignored due to correct programming of the Chip Select Unit. |
| SRDY | $\begin{gathered} 1 \\ S(L) \end{gathered}$ | Synchronous ReaDY is an input to signal for the end of a bus cycle. ARDY or SRDY must be active to terminate any 80L186EA bus cycle, unless they are ignored due to correct programming of the Chip Select Unit. |
| $\overline{\text { DEN }}$ | $\begin{gathered} 0 \\ \mathrm{H}(Z) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \end{gathered}$ | Data ENable output to control the enable of bidirectional transceivers when buffering an 80L186EA system. $\overline{\text { DEN }}$ is active only when data is to be transferred on the bus. |

Table 2. 80L186EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| DT/ $\bar{R}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(\mathrm{X}) \\ \hline \end{gathered}$ | Data Transmit/Receive output controls the direction of a bi-directional buffer when buffering an 80L186EA system. DT/ $\overline{\mathrm{R}}$ is only available for the QFP (EIAJ) package (S80L186EA). |
| $\overline{\text { LOCK }}$ | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | LOCK output indicates that the bus cycle in progress is not to be interrupted. The 80L186EA will not service other bus requests (such as HOLD) while LOCK is active. This pin is configured as a weakly held high input while $\overline{\text { RESIN }}$ is active and must not be driven low. |
| HOLD | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | HOLD request input to signal that an external bus master wishes to gain control of the local bus. The 80L186EA will relinquish control of the local bus between instruction boundaries not conditioned by a LOCK prefix. |
| HLDA | $\begin{gathered} O \\ H(1) \\ R(0) \\ P(0) \end{gathered}$ | HoLD Acknowledge output to indicate that the 80L186EA has relinquish control of the local bus. When HLDA is asserted, the 80L186EA will (or has) floated its data bus and control signals allowing another bus master to drive the signals directly. |
| $\overline{U C S}$ | $\begin{gathered} O \\ H(1) \\ R(1) \\ P(1) \end{gathered}$ | Upper Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. After reset, UCS is configured to be active for memory accesses between OFFCOOH and OFFFFFH. During a processor reset, UCS and LCS are used to enable ONCE Mode. |
| $\overline{L C S}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Lower Chip Select will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. LCS is inactive after a reset. During a processor reset, $\overline{\mathrm{UCS}}$ and $\overline{\mathrm{LCS}}$ are used to enable ONCE Mode. |
| $\overline{\text { MCS0 }}$ $\overline{\text { MCS1 }}$ $\overline{\text { MCS2 }}$ $\overline{\text { MCS3 }}$ | $\begin{gathered} O \\ H(1) \\ R(1) \\ P(1) \\ A(L) \\ \hline \end{gathered}$ | If enabled, these pins comprise a block of Mid-Range Chip Select outputs which will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. |
| $\overline{\text { PCS4:0 }}$ | $\begin{gathered} O \\ H(1) \\ R(1) \\ P(1) \end{gathered}$ | Peripheral Chip Selects go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. |
| $\overline{\text { PCS5 } / A 1 ~}$ $\overline{\text { PCS6/A2 }}$ | $\begin{gathered} 0 \\ H(1) / H(X) \\ R(1) \\ P(1) \end{gathered}$ | These pins provide a multiplexed function. As additional Peripheral Chip Selects, they go active whenever the address of a memory or I/O bus cycle is within the address limitations by the user. They may also be programmed to provide latched Address A2:1 signals. |
| $\begin{aligned} & \text { TOOUT } \\ & \text { T10UUT } \end{aligned}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(1) \\ \mathrm{P}(\mathrm{Q}) \\ \hline \end{gathered}$ | Timer OUTput pins can be programmed to provide a single clock or continuous waveform generation, depending on the timer mode selected. |
| TOIN T1IN | $\begin{gathered} 1 \\ A(L) \\ A(L) \end{gathered}$ | Timer INput is used either as clock or control signals, depending on the timer mode selected. |

Table 2. 80L186EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| DRQ0 DRQ1 | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | DMA ReQuest is asserted by an external request when it is prepared for a DMA transfer. |
| INTO <br> INT1/SELECT | $\stackrel{1}{A(E, L)}$ | Maskable INTerrupt input will cause a vector to a specific Type interrupt routine. To allow interrupt expansion, INT0 and/or INT1 can be used with INTAO and INTA1 to interface with an external slave controller. INT1 becomes SELECT when the ICU is configured for Slave Mode. |
| INT2/INTAO <br> INT3//्NTA1/IRQ | $\begin{gathered} 1 / O \\ A(E, L) \\ / H(1) \\ R(Z) \\ / P(1) \end{gathered}$ | These pins provide multiplexed functions. As inputs, they provide a maskable INTerrupt that will cause the CPU to vector to a specific Type interrupt routine. As outputs, each is programmatically controlled to provide an INTerrupt Acknowledge handshake signal to allow interrupt expansion. INT3/INTA1 becomes IRQ when the ICU is configured for Slave Mode. |
| N.C. | - | No Connect. For compatibility with future products, do not connect to these pins. |

## 80L186EA PINOUT

Tables 3 and 4 list the 80L186EA pin names with package location for the 68 -pin Plastic Leaded Chip Carrier (PLCC) component. Figure 2 depicts the complete 80L186EA pinout (PLCC package) as viewed from the top side of the component (i.e., contacts facing down).

Tables 5 and 6 list the 80L186EA pin names with package location for the 80-pin Quad Flat Pack (EIAJ) component. Figure 2 depicts the complete 80L186EA (EIAJ QFP package) as viewed from the top side of the component (i.e., contacts facing down).

Table 3. PLCC Pin Names with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 17 |
| AD1 | 15 |
| AD2 | 13 |
| AD3 | 11 |
| AD4 | 8 |
| AD5 | 6 |
| AD6 | 4 |
| AD7 | 2 |
| AD8 | 16 |
| AD9 | 14 |
| AD10 | 12 |
| AD11 | 10 |
| AD12 | 7 |
| AD13 | 5 |
| AD14 | 3 |
| AD15 | 1 |
| A16 | 68 |
| A17 | 67 |
| A18 | 66 |
| A19/S6 | 65 |


| Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: |
| Name | Location | Name | Location |
| ALE/QSO | 61 | $\overline{\text { RESIN }}$ | 24 |
| $\overline{\text { BHE }}$ | 64 | RESOUT | 57 |
| $\overline{\text { So }}$ | 52 | CLKIN | 59 |
| S1 | 53 | OSCOUT | 58 |
| S2 | 54 | Clkout | 56 |
|  | 62 | TEST | 47 |
| $\overline{\text { WR/QS1 }}$ | 63 | PDTMR | 40 |
| ARDY | 55 | NMI | 46 |
| SRDY | 49 | INTO | 45 |
| $\overline{\mathrm{DEN}}$ | 39 | INT1/SELECT | 44 |
| LOCK | 48 | INT2/INTAO | 42 |
| HOLD | 50 | INT3/[/NTA1/ | 41 |
| HLDA | 51 | IRQ |  |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{\text { UCS }}$ | 34 |
| $\overline{\text { LCS }}$ | 33 |
| $\overline{\text { MCS0 }}$ | 38 |
| $\overline{\text { MCS1 }}$ | 37 |
| $\overline{\text { MCS2 }}$ | 36 |
| $\overline{\text { MCS3 }}$ | 35 |
| $\overline{\text { PCS0 }}$ | 25 |
| $\overline{\text { PCS1 }}$ | 27 |
| $\overline{\text { PCS2 }}$ | 28 |
| $\overline{\text { PCS3 }}$ | 29 |
| $\overline{\text { PCS4 }}$ | 30 |
| $\overline{\text { PCS5/A1 }}$ | 31 |
| $\overline{\text { PCS6/A2 }}$ | 32 |
| TOOUT | 22 |
| TOIN | 20 |
| T1OUT | 23 |
| T1IN | 21 |
| DRQ0 | 18 |
| DRQ1 | 19 |

Table 4. PLCC Package Locations with Pin Name

| Location | Name |
| :---: | :--- |
| 1 | AD15 |
| 2 | AD7 |
| 3 | AD14 |
| 4 | AD6 |
| 5 | AD13 |
| 6 | AD5 |
| 7 | AD12 |
| 8 | AD4 |
| 9 | VCC |
| 10 | AD11 |
| 11 | AD3 |
| 12 | AD10 |
| 13 | AD2 |
| 14 | AD9 |
| 15 | AD1 |
| 16 | AD8 |
| 17 | AD0 |


| Location | Name |
| :---: | :--- |
| 18 | DRQ0 |
| 19 | DRQ1 |
| 20 | TOIN |
| 21 | T1IN |
| 22 | T0OUT |
| 23 | T1OUT |
| 24 | $\overline{\text { RESIN }}$ |
| 25 | $\overline{\text { PCS0 }}$ |
| 26 | VSS |
| 27 | $\overline{\text { PCS1 }}$ |
| 28 | $\overline{\text { PCS2 }}$ |
| 29 | $\overline{\text { PCS3 }}$ |
| 30 | $\overline{\text { PCS4 }}$ |
| 31 | $\overline{\text { PCS5/A1 }}$ |
| 32 | $\overline{\text { PCS6/A2 }}$ |
| 33 | $\overline{\mathrm{LCS}}$ |
| 34 | $\overline{\mathrm{UCS}}$ |


| Location | Name |
| :---: | :--- |
| 35 | $\overline{\text { MCS3 }}$ |
| 36 | $\overline{M C S 2}$ |
| 37 | $\overline{M C S 1}$ |
| 38 | $\overline{M C S 0}$ |
| 39 | $\overline{\text { DEN }}$ |
| 40 | PDTMR |
| 41 | INT3/INTA1/ |
|  | IRQ |
| 42 | INT2/INTAO |
| 43 | VCC |
| 44 | INT1/SELECT |
| 45 | INTO |
| 46 | NMI |
| 47 | $\overline{\text { TEST }}$ |
| 48 | LOCK |
| 49 | SRDY |
| 50 | HOLD |
| 51 | HLDA |


| Location | Name |
| :---: | :--- |
| 52 | $\overline{\mathrm{So}}$ |
| 53 | $\overline{\mathrm{~S} 1}$ |
| 54 | $\overline{\mathrm{~S} 2}$ |
| 55 | ARDY |
| 56 | CLKOUT |
| 57 | RESOUT |
| 58 | OSCOUT |
| 59 | CLKIN |
| 60 | VSS |
| 61 | $\mathrm{ALE} / \mathrm{QSO}$ |
| 62 | $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ |
| 63 | $\overline{\mathrm{WR} / \mathrm{QS} 1}$ |
| 64 | $\overline{\mathrm{BHE}}$ |
| 65 | $\mathrm{~A} 19 / \mathrm{S} 6$ |
| 66 | A 18 |
| 67 | A 17 |
| 68 | A 16 |



Table 5. QFP (EIAJ) Pin Name with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 64 |
| AD1 | 66 |
| AD2 | 68 |
| AD3 | 70 |
| AD4 | 74 |
| AD5 | 76 |
| AD6 | 78 |
| AD7 | 80 |
| AD8 | 65 |
| AD9 | 67 |
| AD10 | 69 |
| AD11 | 71 |
| AD12 | 75 |
| AD13 | 77 |
| AD14 | 79 |
| AD15 | 1 |
| A16 | 3 |
| A17 | 4 |
| A18 | 5 |
| A19/S6 | 6 |


| Bus Control |  |
| :--- | :---: |
| Name | Location |
| ALE/QSO | 10 |
| $\overline{\overline{B H E}}$ | 7 |
| $\overline{S 0}$ | 23 |
| $\overline{S 1}$ | 22 |
| $\overline{S 2}$ | 21 |
| $\overline{R D} / \overline{Q S M D}$ | 9 |
| $\overline{W R} / Q S 1$ | 8 |
| ARDY | 20 |
| SRDY | 27 |
| $\overline{D T / \bar{R}}$ | 37 |
| $\overline{\overline{D E N}}$ | 39 |
| $\overline{L O C K}$ | 28 |
| HOLD | 26 |
| HLDA | 25 |


| Processor Control |  |
| :--- | :---: |
| Name | Location |
| RESIN | 55 |
| RESOUT | 18 |
| CLKIN | 16 |
| OSCOUT | 17 |
| CLKOUT | 19 |
| TEST | 29 |
| PDTMR | 38 |
| NMI | 30 |
| INTO | 31 |
| INT1/SELECT | 32 |
| INT2/INTAO | 35 |
| INT3/INTA1/ | 36 |
| IRQ |  |
| N.C. | 11,14, |
|  | 15,63 |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{\text { UCS }}$ | 45 |
| $\overline{\text { LCS }}$ | 46 |
| $\overline{\text { MCS0 }}$ | 40 |
| $\overline{\text { MCS1 }}$ | 41 |
| $\overline{\text { MCS2 }}$ | 42 |
| $\overline{\text { MCS3 }}$ | 43 |
| $\overline{\text { PCS0 }}$ | 54 |
| $\overline{\text { PCS1 }}$ | 52 |
| $\overline{\text { PCS2 }}$ | 51 |
| $\overline{\text { PCS3 }}$ | 50 |
| $\overline{\text { PCS4 }}$ | 49 |
| $\overline{\text { PCS5/A1 }}$ | 48 |
| $\overline{\text { PCS6/A2 }}$ | 47 |
| T0OUT | 57 |
| TOIN | 59 |
| T1OUT | 56 |
| T1IN | 58 |
| DRQ0 | 61 |
| DRQ1 | 60 |

Table 6. QFP (EIAJ) Package Location with Pin Names

| Location | Name |
| :---: | :--- |
| 1 | AD15 |
| 2 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 3 | A 16 |
| 4 | A 17 |
| 5 | A 18 |
| 6 | $\mathrm{~A} 19 / \mathrm{S} 6$ |
| 7 | $\overline{\mathrm{BHE}}$ |
| 8 | $\overline{\mathrm{WR} / \mathrm{QS} 1}$ |
| 9 | $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ |
| 10 | $\mathrm{ALE} / \mathrm{QSO}$ |
| 11 | $\mathrm{~N} . \mathrm{C}$. |
| 12 | VSS |
| 13 | V SS |
| 14 | $\mathrm{~N} . \mathrm{C}$. |
| 15 | N.C. |
| 16 | CLKIN |
| 17 | OSCOUT |
| 18 | RESOUT |
| 19 | CLKOUT |
| 20 | ARDY |


| Location | Name |
| :---: | :---: |
| 21 | S2 |
| 22 | S1 |
| 23 | So |
| 24 | $\mathrm{V}_{\text {SS }}$ |
| 25 | HLDA |
| 26 | HOLD |
| 27 | SRDY |
| 28 | LOCK |
| 29 | TEST |
| 30 | NMI |
| 31 | INTO |
| 32 | INT1/SELECT |
| 33 | $\mathrm{V}_{\mathrm{CC}}$ |
| 34 | $\mathrm{V}_{\mathrm{cc}}$ |
| 35 | INT2/INTAO |
| 36 | $\begin{aligned} & \text { INT3/NTA1/ } \\ & \text { IRQ } \end{aligned}$ |
| 37 | DT/ $\overline{\text { R }}$ |
| 38 | PDTMR |
| 39 | $\overline{\text { DEN }}$ |
| 40 | MCSO |


| Location | Name |
| :---: | :---: |
| 41 | $\overline{\text { MCS1 }}$ |
| 42 | $\overline{\mathrm{MCS2}}$ |
| 43 | $\overline{\text { MCS3 }}$ |
| 44 | $\mathrm{V}_{\mathrm{CC}}$ |
| 45 | UCS |
| 46 | LCS |
| 47 | $\overline{\text { PCS6/A2 }}$ |
| 48 | PCS5/A1 |
| 49 | $\overline{\text { PCS4 }}$ |
| 50 | $\overline{\text { PCS3 }}$ |
| 51 | $\overline{\text { PCS2 }}$ |
| 52 | PCS1 |
| 53 | $V_{S S}$ |
| 54 | $\overline{\text { PCSO }}$ |
| 55 | $\overline{\text { RESIN }}$ |
| 56 | T1OUT |
| 57 | TOOUT |
| 58 | T1IN |
| 59 | TOIN |
| 60 | DRQ1 |


| Location | Name |
| :---: | :--- |
| 61 | DRQ0 |
| 62 | VSS $^{\prime}$ |
| 63 | N.C. |
| 64 | AD0 |
| 65 | AD8 |
| 66 | AD1 |
| 67 | AD9 |
| 68 | AD2 |
| 69 | AD10 |
| 70 | AD3 |
| 71 | AD11 |
| 72 | VCC $^{73}$ |
| 73 | VCC |
| 74 | AD4 |
| 75 | AD12 |
| 76 | AD5 |
| 77 | AD13 |
| 78 | AD6 |
| 79 | AD14 |
| 80 | AD7 |



Figure 3. Quad Flat Pack (EIAJ) Pinout Diagram

## PACKAGE THERMAL SPECIFICATIONS

The 80L186EA is specified for operation when $T_{C}$ (the case temperature) is within the range of $0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ (PLCC package) or $0^{\circ} \mathrm{C}$ to $106^{\circ} \mathrm{C}$ (QFP-EIAJ) package. $T_{C}$ may be measured in any environment to determine whether the 80L186EA is within the specified operating range. The case temperature must be measured at the center of the top surface.
$T_{A}$ (the ambient temperature) can be calculated from $\theta_{C A}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\mathrm{CA}}$ at various airflows are given in Table 7 for the 68 -pin Plastic Leaded Chip Carrier (PLCC) package.

Table 8 shows the maximum $T_{A}$ allowable (without exceeding $\mathrm{T}_{\mathrm{C}}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumption, specified in watts) is calculated by using the maximum ICC as tabulated in the DC specifications and $V_{C C}$ of 5 V .

$$
T_{A}=T_{C} \cdot P \times \theta_{C A}
$$

Table 7. Thermal Resistance ( $\theta_{\text {CA }}$ ) at Various Airflows (in ${ }^{\circ} \mathrm{C} /$ Watt)

|  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{array}{\|c} 0 \\ (0) \end{array}$ | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{array}{\|c} \hline 400 \\ (2.03) \end{array}$ | $\begin{array}{\|c\|} \hline 600 \\ (3.04) \end{array}$ | $\begin{array}{\|c} \hline 800 \\ (4.06) \end{array}$ | $\begin{array}{\|l} \hline 1000 \\ (5.07) \end{array}$ |
| $\theta_{\text {CA }}$ (PLCC) | 29 | 25 | 21 | 19 | 17 | 16.5 |
| $\theta_{C A}$ (QFP) | 66 | 63 | 60.5 | 59 | 58 | 57 |

Table 8. Maximum $\mathrm{T}_{\mathrm{A}}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TF | 0 | 200 | 400 | 600 | 800 | 1000 |
|  | (MHz) | (0) | (1.01) | (2.03) | (3.04) | (4.06) | (5.07) |
| $\mathrm{T}_{\mathrm{A}}$ (PLCC) | 25 | 78 | 80 | 81 | 82 | 82.5 | 83 |
|  | 32 | 74 | 76 | 78 | 79 | 79.5 | 80 |
|  | 40 | 70 | 72 | 74 | 75 | 76 | 76.5 |
| TA (QFP) | 25 | 84 | 85.5 | 86 | 87 | 87 | 87.5 |
|  | 32 | 77.5 | 79 | 80 | 80.5 | 81 | 81.5 |
|  | 40 | 70 | 71.5 | 73 | 74 | 74 | 75 |

## ELECTRICAL SPECIFICATIONS

## ABSOLUTE MAXIMUM RATINGS*

Storage Temperature $\ldots . . . . . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Case Temperature under Bias ... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Supply Voltage with Respect

Voltage on Other Pins with Respect
to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots \ldots \ldots \ldots . .-0.5 \mathrm{~F}$ to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## OPERATING CONDITIONS

| Symbol | Parameter | Min | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 2.7 | 5.5 | V |
| $\mathrm{~T}_{\mathrm{F}}$ | Input Clock Frequency |  |  |  |
|  | 80L186EA13 | 0 | 26 | MHz |
|  | 80L186EA8 | 0 | 16 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature under Bias |  |  |  |
|  | N80L186EA (PLCC) | 0 | +100 | ${ }^{\circ} \mathrm{C}$ |
|  | S80L186EA (QFP) | 0 | +114 | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED CONNECTIONS

Power and ground connections must be made to multiple $V_{C C}$ and $V_{S S}$ pins. Every 80L186EA based circuit board should contain separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $\mathrm{V}_{\mathrm{SS}}$ ) planes. All $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$ pins must be connected to the appropriate plane. Pins identified as "N.C." must not be connected in the system. Decoupling capacitors should be placed near the 80L186EA. The value and type of decoupling capac-
itors is application and board layout dependent. The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Always connect any unused input pins to an appropriate signal level. In particular, unused interrupt pins (NMI, INT3:0) should be connected to $\mathrm{V}_{\text {SS }}$ to avoid unwanted interrupts. Leave any unused output pin or any "N.C." pin unconnected.

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | $0.3 * V_{\text {CC }}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | $0.7 *{ }^{\text {C }}$ C | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=1.6 \mathrm{~mA}(\mathrm{Min})$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{IOH}=-1 \mathrm{~mA}(\mathrm{Min})$ |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysterisis on RESIN | 0.30 |  | V |  |
| lıl1 | Input Leakage Current (except $\overline{R D} / \overline{Q S M D}, \overline{U C S}, \overline{L C S}, \overline{M C S O}$, $\overline{\text { MCS1, LOCK }}$ and TEST) |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IIL2 | Input Leakage Current ( $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{\mathrm{MCSO}}$, $\overline{\text { MCS1, LOCK }}$ and TEST) | -275 |  | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0.7 \mathrm{~V}_{\text {CC }}$ (Note 1) |
| loL | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}} \\ & \text { (Note 2) } \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Supply Current (RESET; 5.5V) <br> 80L186EA-13 <br> 80L186EA-8 |  | 40 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 3) <br> (Note 3) |
| $\mathrm{I}_{\mathrm{CC}}$ | Supply Current (RESET, 2.7V) 80L186EA-13 80L186EA-8 |  | 20 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 3) <br> (Note 3) |
| 1105 | $\begin{aligned} & \text { Supply Current Idle (5.5V) } \\ & \text { 80L186EA-13 } \\ & \text { 80L186EA-8 } \end{aligned}$ |  | 28 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| 1103 | Supply Current Idle (2.7V) 80L186EA-13 80L186EA-8 |  | 14 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| IpD5 | Supply Current Powerdown (5.5V) <br> 80L186EA-13 <br> 80L186EA-8 |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |  |
| $\mathrm{I}_{\text {PD3 }}$ | $\begin{aligned} & \text { Supply Current Powerdown (2.7V) } \\ & \text { 80L186EA-13 } \\ & \text { 80L186EA-8 } \end{aligned}$ |  | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |  |
| $\mathrm{C}_{\text {IN }}$ | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ ( Note 4) |
| Cout | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |

## NOTES:

1. $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{\mathrm{MCSO}}, \overline{\mathrm{MCS}}, \overline{\mathrm{LOCK}}$ and $\overline{T E S T}$ have internal pullups that are only activated during RESET. Loading these pins above lol $=-275 \mu \mathrm{~A}$ will cause the 80L186EA to enter alternate modes of operation.
2. Output pins are floated using HOLD or ONCE Mode.
3. Measured at worst case temperature and $\mathrm{V}_{C C}$ with all outputs loaded as specified in the $A C$ Test Conditions, and with the device in RESET (RESIN held low).
4. Output capacitance is the capacitive load of a floating output pin.

## Icc VERSUS FREQUENCY AND VOLTAGE

The current (ICC) consumption of the 80L186EA is essentially composed of two components; IPD and ICCS.
$I_{P D}$ is the quiescent current that represents internal device leakage, and is measured with all inputs or floating outputs at GND or $V_{\mathrm{CC}}$ (no clock applied to the device). IPD is equal to the Powerdown current and is typically less than $50 \mu \mathrm{~A}$.

ICCS is the switching current used to charge and discharge parasitic device capacitance when changing logic levels. Since ICCS is typically much greater than IPD, IPD can often be ignored when calculating ICC.

ICCS is related to the voltage and frequency at which the device is operating. It is given by the formula:

$$
\text { Power }=\mathrm{V} \times \mathrm{I}=\mathrm{V}^{2} \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f}
$$

$$
\therefore \mathrm{I}=\mathrm{I}_{\mathrm{CC}}=\mathrm{I}_{\mathrm{CCS}}=\mathrm{V} \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f}
$$

Where: $\mathrm{V}=$ Device operating voltage $\left(\mathrm{V}_{\mathrm{CC}}\right)$
$C_{D E V}=$ Device capacitance
$f=$ Device operating frequency
$I_{C C S}=I_{C C}=$ Device current
Measuring $C_{\text {DEV }}$ on a device like the 80L186EA would be difficult. Instead, $\mathrm{C}_{\text {DEV }}$ is calculated using the above formula by measuring $I_{C C}$ at a known $V_{C C}$ and frequency (see Table 9). Using this CDEV value, $I_{C C}$ can be calculated at any voltage and frequency within the specified operating range.

EXAMPLE: Calculate the typical ICC when operating at $20 \mathrm{MHz}, 4.8 \mathrm{~V}$.

## PDTMR PIN DELAY CALCULATION

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown. A delay is required only when using the on-chip oscillator to allow the crystal or resonator circuit time to stabilize.

## NOTE:

The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e., a device reset during Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized).

To calculate the value of capacitor required to provide a desired delay, use the equation:

$$
440 \times t=C_{P D} \quad\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where: $t=$ desired delay in seconds

$$
\begin{aligned}
& \mathrm{C}_{P D}= \text { capacitive load on PDTMR in mi- } \\
& \text { crofarads }
\end{aligned}
$$

EXAMPLE: To get a delay of $300 \mu \mathrm{~s}$, a capacitor value of $C_{P D}=440 \times\left(300 \times 10^{-6}\right)=0.132 \mu \mathrm{~F}$ is required. Round up to standard (available) capacitive values.

## NOTE:

The above equation applies to delay times greater than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ or $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $V_{C C}$ and/or lower temperature will decrease delay time, while lower $V_{C C}$ and/or higher temperature will increase delay time.

$$
I_{C C}=I_{C C S}=4.8 \times 0.515 \times 20 \approx 49 \mathrm{~mA}
$$

Table 9. C $_{\text {DEV }}$ Values

| Parameter | Typ | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $C_{\text {DEV }}$ (Device in Reset) | 0.515 | 0.905 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| $\mathrm{C}_{\text {DEV }}$ (Device in Idle) | 0.391 | 0.635 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

1. Max $C_{D E V}$ is calculated at $-40^{\circ} \mathrm{C}$, all floating outputs driven to $V_{C C}$ or GND, and all outputs loaded to 50 pF (including CLKOUT and OSCOUT). 2. Typical $\mathrm{C}_{\text {DEV }}$ is calculated at $25^{\circ} \mathrm{C}$ with all outputs loaded to 50 pF except CLKOUT and OSCOUT, which are not loaded.

## AC SPECIFICATIONS

AC Characteristics-80L186EA13

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 2C | MHz | 1 |
| TC | CLKIN Period | 38.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {CH }}$ | CLKIN High Time | 12 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 12 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 45 | ns | 1, 4 |
| T | CLKOUT Period |  | ${ }^{*}{ }^{\text {T }}$ C | ns | 1 |
| TPH | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| ${ }_{\text {TPL }}$ | CLKOUT Low Time | (T/2)-5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 15 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 15 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, LOCK | 3 | 27 | ns | 1,4,6,7 |
| TCHOV2 | $\overline{\mathrm{MCS3}} \mathbf{0}$, $\overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\text { PCS6:0 }}$, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 32 | ns | 1,4, 6, 8 |
| TCHOV3 | $\overline{\text { S2:0, }} \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}, \mathrm{A} 19: 16$ | 3 | 30 | ns | 1, 4, 6, 11 |
| TCLOV1 | LOCK, RESOUT, HLDA, TOOUT, T1OUT | 3 | 27 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS}}: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS6}} \mathbf{0}$, INTA1:0 | 3 | 32 | ns | 1,4,6 |
| TCLOV3 | BHE, DEN, A19:16 | 3 | 30 | ns | 1,4,6 |
| TCLOV4 | AD15:0 | 3 | 34 | ns | 1,4,6 |
| TCLOV5 | S2:0 | 3 | 38 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:16 | 0 | 30 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 35 | ns | 1 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 9 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 10 for rise and fall times outside 50 pF .
6. See Figure io for tise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV}}^{1} 1 \mathrm{applies}$ to $\overline{\text { LOCK }}$ and only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L186EA operation (SRDY, AD15:0).
11. $\mathrm{T}_{\mathrm{CHO}}$ applies to $\overline{\mathrm{BHE}}$ and A19:16 only after a HOLD release.

AC SPECIFICATIONS (Continued)

AC Characteristics-80L186EA13 (Continued)

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT3:0, T1:0IN, ARDY | 25 |  | ns | 1, 9 |
| $\mathrm{T}_{\mathrm{CHIH}}$ | TEST, NMI, INT3:0, T1:OIN, ARDY | 3 |  | ns | 1, 9 |
| TCLIS | AD15:0, ARDY, SRDY, DRQ1:0 | 25 |  | ns | 1,10 |
| TCLIH | AD15:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 25 |  | ns | 1,9 |
| TCLIH | HOLD | 3 |  | ns | 1,9 |
| TCLIS | $\overline{\text { RESIN ( }}$ (o CLKIN) | 25 |  | ns | 1, 9 |
| TCLIH | $\overline{\text { RESIN }}$ (from CLKIN) | 3 |  | ns | 1, 9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 9 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 10 for rise and fall times outside 50 pF .
6. See Figure 10 for rise and fall times.
7. TCHOV1 applies to LOCK and only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L186EA operation (SRDY, AD15:0).
11. $\mathrm{T}_{\mathrm{CHOV} 3}$ applies to $\overline{\mathrm{BHE}}$ and $\mathrm{A} 19: 16$ only after a HOLD release.

AC SPECIFICATIONS (Continued)

## AC Characteristics-80L186EA8

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 2 C | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 38.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {CH }}$ | CLKIN High Time | 12 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 12 | $\infty$ | ns | 1,2 |
| $\mathrm{T}_{\text {CR }}$ | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{CD}}$ | CLKIN to CLKOUT Delay | 0 | 95 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{2 *}{ }^{\text {c }}$ c | ns | 1 |
| ${ }_{\text {TPH }}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| TPL | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\text {PR }}$ | CLKOUT Rise Time | 1 | 15 | ns | 1,5 |
| $\mathrm{T}_{\text {PF }}$ | CLKOUT Fall Time | 1 | 15 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHOV1 }}$ | ALE, LOCK | 3 | 27 | ns | 1,4,6,7 |
| TCHOV2 | MCS3:0, $\overline{\text { LCS }}$, UCS $, \overline{\text { PCS6:0, }} \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 32 | ns | 1,4,6, 8 |
| TCHOV3 | S2:0, $\overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}, \mathrm{A} 19: 16$ | 3 | 30 | ns | 1, 4, 6, 11 |
| TCLOV1 | $\overline{B H E}, \overline{D E N}, \overline{L O C K}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 27 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS}}: \mathbf{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS6}} \mathbf{0}$, INTA1:0 | 3 | 35 | ns | 1,4,6 |
| TCLOV3 | BHE, DEN, A19:16 | 3 | 30 | ns | 1, 4, 6 |
| TCLOV4 | AD15:0 | 3 | 35 | ns | 1,4,6 |
| TCLOV5 | S2:0 | 3 | 40 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0, }}$ A19:16 | 0 | 30 | ns | 1 |
| TCLOF | $\overline{\text { DEN, }}$ AD15:0 | 0 | 35 | ns | 1 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{C}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 9 for capacitive derating information.
5. Specified for a 50 pF lead, see Figure 10 for rise and fall times outside 50 pF .
6. See Figure 10 for rise and fall times.
7. TCHOV 1 applies to $\overline{\text { LOCK }}$ and only after a HOLD release.
8. TCHOV2 applies to RD and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L186EA operation (SRDY, AD15:0).
11. $\mathrm{T}_{\mathrm{CHOV} 3}$ applies to $\overline{\mathrm{BHE}}$ and $\mathrm{A} 19: 16$ only after a HOLD release.

AC SPECIFICATIONS (Continued)

AC Characteristics-80L186EA8 (Continued)

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, INT3:0, T1:0IN, ARDY | 25 |  | ns | 1,9 |
| TCHIH | TEST, NMI, INT3:0, T1:0IN, ARDY | 3 |  | ns | 1,9 |
| TCLIS | AD15:0, ARDY, SRDY, DRQ1:0 | 25 |  | ns | 1,10 |
| TCLIH | AD15:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 25 |  | ns | 1,9 |
| TCLIH | HOLD | 3 |  | ns | 1,9 |
| TCLIS | $\overline{\text { RESIN }}$ (to CLKIN) | 25 |  | ns | 1,9 |
| TCLIH | $\overline{\text { RESIN ( }}$ (rom CLKIN) | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee ICC. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 9 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 10 for rise and fall times outside 50 pF .
6. See Figure 10 for rise and fall times.
7. TCHOV1 applies to LOCK and only after a HOLD release.
8. TCHOV2 applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L186EA operation (SRDY, AD15:0).
11. $\mathrm{T}_{\mathrm{CHO}} 3$ applies to $\overline{\mathrm{BHE}}$ and $\mathrm{A} 19: 16$ only after a HOLD release.

## AC SPECIFICATIONS (Continued)

Relative Timings-80L188EA-13,-8

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Rising to ALE Falling | T-15 |  | ns |  |
| TAVLL | Address Valid to ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TPLLL | Chip Selects Valid to ALE Falling | $1 / 2 T-10$ |  | ns | 1 |
| TLLAX | Address Hold from ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{W R}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\mathrm{RD}}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| $\mathrm{T}_{\text {RHLH }}$ | $\overline{\mathrm{RD}}$ Rising to ALE Rising | $1 / 2 T-10$ |  | ns | 1 |
| TWHLH | $\overline{\text { WR Rising to ALE Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| $\mathrm{T}_{\text {AFRL }}$ | Address Float to $\overline{\mathrm{RD}}$ Falling | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Falling to $\overline{\mathrm{RD}}$ Rising | (2*T) -5 |  | ns | 2 |
| TWLWH | $\overline{\text { WR }}$ Falling to $\overline{\mathrm{WR}}$ Rising | (2*T) - 5 |  | ns | 2 |
| T RHAV | $\overline{\mathrm{RD}}$ Rising to Address Active | T-15 |  | ns |  |
| T WHDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| $\mathrm{T}_{\text {WHDEX }}$ | $\overline{\text { WR Rising to } \overline{\text { DEN }} \text { Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| TWHPH | $\overline{\text { WR Rising to Chip Select Rising }}$ | $1 / 2 T-10$ |  | ns | 1,4 |
| $\mathrm{T}_{\text {RHPH }}$ | $\overline{\mathrm{RD}}$ Rising to Chip Select Rising | $1 / 2 T-10$ |  | ns | 1,4 |
| TPHPL | $\overline{\mathrm{CS}}$ Inactive to $\overline{\mathrm{CS}}$ Active | $1 / 2 T-10$ |  | ns | 1 |
| T DXDL | ' $\overline{\mathrm{EEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | ns | 5 |
| ToVRH | ONCE (UCS, $\overline{\text { LCS }}$ ) Active to RESIN Rising | T |  | ns | 3 |
| TRHOX | ONCE (UCS, $\overline{\text { LCS }}$ ) to $\overline{\text { RESIN }}$ Rising | T |  | ns | 3 |

## NOTES:

1. Assumes equal loading on both pins.
2. Can be extended using wait states.
3. Not tested.
4. Not applicable to latched A2:1. These signals change only on falling $T_{1}$.
5. For write cycle followed by read cycle.

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 4. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms, for AC specification definitions, test pins, and illustrations.


Figure 4. AC Test Load

## AC TIMING WAVEFORMS



Figure 5. Input and Output Clock Waveform


NOTE:
$20 \% V_{C C}<$ Float $<80 \% V_{C C}$
Figure 6. Output Delay and Float Waveform


NOTE:
$\overline{\text { RESIN }}$ measured to CLKIN, not CLKOUT
Figure 7. Input Setup and Hold


Figure 8. Relative Signal Waveform

## DERATING CURVES



Figure 9. Typical Output Delay Variations Versus Load Capacitance


272021-11
Figure 10. Typical Rise and Fall Variations Versus Load Capacitance

## 80L186EA EXPRESS

The Intel EXPRESS program offers an extended temperature range as an enhancement to the 80L186EA operational specifications. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

With the standard commercial temperature range, operational characteristics are guaranteed over a temperature range corresponding to $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ambient. With the extended temperature range option, operational characteristics are guaranteed over a temperature range corresponding to $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ambient.

Package types and EXPRESS versions are identified by a one- or two-letter prefix to the part number. The prefixes are listed in Table 10. All AC and DC specifications are the same for both commercial and EXPRESS parts.

Table 10. Prefix Identification

| Prefix | Package <br> Type | Temperature <br> Range |
| :---: | :--- | :--- |
| N | PLCC | Commercial |
| $\mathbf{S}$ | QFP (EIAJ) | Commercial |
| TN | PLCC | Extended |
| TS | QFP (EIAJ) | Extended |



Figure 11. PLCC Principal Dimensions


272021-13
NOTE:
Units are mm (inches) unless specified.
Figure 12. QFP (EIAJ) Principal Dimensions

## REVISION HISTORY

Intel 80L186EA devices are marked with a 9-character alphanumeric Intel FPO number underneath the product number. This data sheet (272021-001) is valid for 80L186EA devices with an "A" as the ninth character in the FPO number, as illustrated in Figure 2 for the 68-lead PLCC package and Figure 3 for the 80-lead QFP (EIAJ) package. Such devices may also be identified by reading a value of 01 H from the STEPID register.

The following changes were made from revision -001 to -002 of this data sheet:

1. AC and DC specifications for 13 MHz parts were added.

## 80L186EA

An 80L186EA with a STEPID value of 01 H or 02 H has the following known errata. A device with a STEPID of 01 H or 02 H can be visually identified by noting the presence of a " $A$ " or " $B$ " alpha character, respectively, next to the FPO number. The FPO number location is shown in Figures 2 and 3.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority input exists. This errata will not occur consistantly, it is dependent on interrupt timing.

# 80L186EB-13, 8 <br> 16-BIT HIGH-INTEGRATION EMBEDDED PROCESSOR 

\author{

- 3V Operation, $\mathrm{V}_{\mathrm{cc}}=2.7 \mathrm{~V}-5.5 \mathrm{~V}$ <br> - Full Static Operation <br> - True CMOS Inputs and Outputs <br> $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operating Temperature Range
}
- Integrated Feature Set
- Low-Power Static CPU Core
- Two Independent UARTs each with an Integral Baud Rate Generator
— Two 8-Bit Multiplexed I/O Ports
- Programmable Interrupt Controller
—Three Programmable 16-Bit Timer/Counters
- Clock Generator
- Ten Programmable Chip Selects with Integral Wait-State Generator
- Memory Refresh Control Unit
- System Level Testing Support (ONCETM Mode)
- Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Speed Version Available:
-     - 13 MHz (80L186EB-13)
-8 MHz (80L186EB-8)
- Low-Power Operating Modes:
- Idle Mode Freezes CPU Clocks but keeps Peripherals Active
- Powerdown Mode Freezes All Internal Clocks
- Complete System Development Support
- ASM86 Assembler, PL/M 86, Pascal 86, Fortran 86, C-86, and System Utilities
— In-Circuit Emulator (ICETM-186EB)
- Available In:
- 80-Pin Quad Flat Pack (TS80L186EB)
- 84-Pin Plastic Leaded Chip Carrier (TN80L186EB)

The 80L186EB is the $3 V$ version of the 80 C 186 EB embedded processor. By reducing $\mathrm{V}_{\mathrm{CC}}$, further power savings can be realized over the standard 80C186EB, making the 80L186EB ideal for battery-powered portable applications.



Figure 1. 80L186EB Block Diagram

## INTRODUCTION

The 80L186EB is the first product in a new generation of low-power, high-integration microprocessors. It enhances the existing 186 family by offering new features and new operating modes. The 80L186EB is object code compatible with the 80C186/80C188 microprocessors.

The feature set of the 80L186EB meets the needs of battery-powered applications. Battery-powered applications benefit from the static CPU core and peripherals. Minimum current consumption is achieved by combining low voltage operation along with the features of the power management unit, thus maximizing battery life. Peripheral design enhancements ensure that non-initialized peripherals consume little current.

Space critical applications benefit from the integration of commonly used system peripherals. Two serial channels are provided for services such as diagnostics, inter-processor communication, modem interface, terminal display interface and many others. A flexible chip select unit simplifies memory and peripheral interfacing. The interrupt unit provides sources for up to 129 external interrupts and will prioritize these interrupts with those generated from the on-chip peripherals. Three general purpose timer/counters and sixteen multiplexed I/O port pins round out the feature set of the 80L186EB.

## OVERVIEW

Figure 1 shows a block diagram of the 80L186EB. The Execution Unit (EU) is an enhanced 8086 CPU core that includes: dedicated hardware to speed up effective address calculations, enhance execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instructions and full static operation. The Bus Interface Unit (BIU) is the same as that found on the original 186 family products, except the queuestatus mode has been deleted and buffer interface control has been changed to ease system design timings. An independent internal bus is used to allow communication between the BIU and internal peripherals.

## PACKAGE INFORMATION

This section describes the pins, pinouts, and thermal characteristics for the 80L186EB in the Plastic Leaded Chip Carrier (PLCC) package and Quad Flat Pack (QFP) package. For complete package specifications and information, see the Intel Packaging Handbook (Order Number: 240800).

## 80L186EB PINOUT

Tables 1 and 2 list the 80L186EB pin names with package location for the 84-pin Plastic Leaded Chip Carrier (PLCC) component. Figure 2 depicts the complete 80L186EB pinout (PLCC package) as viewed from the top side of the component (i.e., contacts facing down).

Tables 3 and 4 list the 80L186EB pin names with package location for the 80 -pin Quad Flat Pack (QFP) component. Figure 3 depicts the complete 80L186EB (QFP package) as viewed from the top side of the component (i.e., contacts facing down).

Table 1. PLCC Pin Names with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 61 |
| AD1 | 66 |
| AD2 | 68 |
| AD3 | 70 |
| AD4 | 72 |
| AD5 | 74 |
| AD6 | 76 |
| AD7 | 78 |
| AD8 | 62 |
| AD9 | 67 |
| AD10 | 69 |
| AD11 | 71 |
| AD12 | 73 |
| AD13 | 75 |
| AD14 | 77 |
| AD15 | 79 |
| A16 | 80 |
| A17 | 81 |
| A18 | 82 |
| A19/ONCE | 83 |


| Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: |
| Name | Location | Name | Location |
| ALE | 6 | $\overline{\text { RESIN }}$ | 37 |
| BHE | 7 | RESOUT | 38 |
| $\overline{\mathrm{So}}$ | 10 | CLKIN | 41 |
| S1 | 9 | OSCOUT | 40 |
| $\overline{\text { S2 }}$ | 8 | CLKOUT | 44 |
| $\overline{\mathrm{RD}}$ | 4 | TEST | 14 |
| $\overline{\mathrm{WR}}$ | 5 | NC | 60 |
| READY | 18 | NC | 39 |
| $\overline{\mathrm{DEN}}$ | 11 | NC | 3 |
| DT/ $\bar{R}$ | 16 | PDTMR | 36 |
| LOCK | 15 | NMI | 17 |
| HOLD | 13 | INTO | 31 |
| HLDA | 12 | INT1 | 32 |
|  |  | INT2/INTA0 | 33 |
|  |  | INT3/\/NTA1 | 34 |
| Power |  | INT4 | 35 |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{\text { UCS }}$ | 30 |
| LCS | 29 |
| P1.0/GCSO | 28 |
| P1.1/GCS1 | 27 |
| P1.2/GCS2 | 26 |
| P1.3/GCS3 | 25 |
| P1.4/GCS4 | 24 |
| P1.5/GCS5 | 21 |
| P1.6/GCS6 | 20 |
| P1.7/GCS7 | 19 |
| T0OUT | 45 |
| TOIN | 46 |
| T1OUT | 47 |
| T1IN | 48 |
| RXDO | 53 |
| TXDO | 52 |
| P2.5/BCLK0 | 54 |
| CTS0 | 51 |
| P2.0/RXD1 | 57 |
| P2.1/TXD1 | 58 |
| P2.2/BCLK1 | 59 |
| P2.3/SINT1 | 55 |
| P2.4/CTS1 | 56 |
| P2.6 | 50 |
| P2.7 | 49 |

Table 2. PLCC Package Locations with Pin Name

| Location | Name |
| :---: | :---: |
| 1 | $\mathrm{V}_{\text {cc }}$ |
| 2 | $V_{\text {ss }}$ |
| 3 | NC |
| 4 | RD |
| 5 | $\bar{W} \bar{R}$ |
| 6 | ALE |
| 7 | BHE |
| 8 | S2 |
| 9 | S1 |
| 10 | So |
| 11 | DEN |
| 12 | HLDA |
| 13 | HOLD |
| 14 | TEST |
| 15 | LOCK |
| 16 | DT/R |
| 17 | NMI |
| 18 | READY |
| 19 | P1.7/GCS7 |
| 20 | P1.6/GCS6 |
| 21 | P1.5/GCS5 |


| Location | Name |
| :--- | :--- |
| 22 | $\mathrm{~V}_{\text {SS }}$ |
| 23 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 24 | $\mathrm{P} 1.4 / \overline{\mathrm{GCS}}$ |
| 25 | $\mathrm{P} 1.3 / \mathrm{GCS3}$ |
| 26 | $\mathrm{P} 1.2 / \mathrm{GCS2}$ |
| 27 | $\mathrm{P} 1.1 / \mathrm{GCS1}$ |
| 28 | $\mathrm{P} 1.0 / \mathrm{GCSO}$ |
| 29 | $\overline{\text { LCS }}$ |
| 30 | $\overline{\text { UCS }}$ |
| 31 | INTO |
| 32 | INT1 |
| 33 | INT2/INTAO |
| 34 | INT3/INTA1 |
| 35 | INT4 |
| 36 | PDTMR |
| 37 | $\overline{\text { RESIN }}$ |
| 38 | RESOUT |
| 39 | NC |
| 40 | OSCOUT |
| 41 | CLKIN |
| 42 | VCC |


| Location | Name |
| :---: | :--- |
| 43 | V SS $^{2}$ |
| 44 | CLKOUT |
| 45 | TOOUT |
| 46 | TOIN |
| 47 | T1OUT |
| 48 | T1IN |
| 49 | P2.7 |
| 50 | P2.6 |
| 51 | CCSO |
| 52 | TXDO |
| 53 | RXDO |
| 54 | P2.5/BCLKO |
| 55 | P2.3/SINT1 |
| 56 | P2.4/CTS1 |
| 57 | P2.0/RXD1 |
| 58 | P2.1/TXD1 |
| 59 | P2.2/BCLK1 |
| 60 | NC |
| 61 | ADO |
| 62 | AD8 |
| 63 | $V_{\text {SS }}$ |


| Location | Name |
| :---: | :--- |
| 64 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 65 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 66 | AD1 |
| 67 | AD9 |
| 68 | AD2 |
| 69 | AD10 |
| 70 | AD3 |
| 71 | AD11 |
| 72 | AD4 |
| 73 | AD12 |
| 74 | AD5 |
| 75 | AD13 |
| 76 | AD6 |
| 77 | AD14 |
| 78 | AD7 |
| 79 | AD15 |
| 80 | A16 |
| 81 | A17 |
| 82 | A18 |
| 83 | A19/ONCE |
| 84 | $V_{\text {SS }}$ |



## NOTE:

This is the FPO number location (indicated by X 's).
Figure 2. 84-Pin Plastic Leaded Chip Carrier Pinout Diagram

Table 3. QFP Pin Name with Package Location

| Address/Data Bus |  | Bus Control |  |
| :---: | :---: | :---: | :---: |
| - Name | Location | Name | Location |
| AD0 | 10 | ALE | 38 |
| AD1 | 15 | $\overline{\text { BHE }}$ | 39 |
| AD2 | 17 | $\overline{\text { So }}$ | 42 |
| AD3 | 19 | $\overline{\mathrm{S} 1}$ | 41 |
| AD4 | 21 | $\overline{\mathrm{S} 2}$ | 40 |
| AD5 | 23 | $\overline{\text { RD }}$ | 36 |
| AD6 | 25 | $\overline{W R}$ | 37 |
| AD7 | 27 | READY | 49 |
| AD8 | 11 | $\overline{\text { DEN }}$ |  |
| AD9 | 16 | DEN | 43 |
| AD10 | 18 | $\overline{\text { LOCK }}$ | 47 |
| AD11 | 20 | HOLD | 45 |
| AD12 | 22 | HLDA | 44 |
| AD13 | 24 |  |  |
| AD14 | 26 |  |  |
| AD15 | 28 |  |  |
| A16 | 29 |  |  |
| A17 | 30 |  |  |
| A18 | 31 |  |  |
| A19/ONCE | 32 | . |  |


| Processor Control |  |
| :--- | :---: |
| Name | Location |
| $\overline{\text { RESIN }}$ | 68 |
| RESOUT | 69 |
| CLKIN | 71 |
| OSCOUT | 70 |
| CLKOUT | 74 |
| TEST | 46 |
| PDTMR | 67 |
| NMI | 48 |
| INTO | 62 |
| INT1 | 63 |
| INT2/INTAO | 64 |
| INT3/INTA1 | 65 |
| INT4 | 66 |


| Power |  |
| :---: | :---: |
| Name | Location |
| $V_{\mathrm{CC}}$ | 13,34, |
|  | 54,72 |
| $\mathrm{~V}_{\mathrm{SS}}$ | $12,14,33$, |
|  | $35,53,73$ |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{U C S}$ | 61 |
| $\overline{\text { LCS }}$ | 60 |
| P1.0/GCS0 | 59 |
| P1.1/GCS1 | 58 |
| P1.2/GCS2 | 57 |
| P1.3/GCS3 | 56 |
| P1.4/GCS4 | 55 |
| P1.5/高CS5 | 52 |
| P1.6/GCS6 | 51 |
| P1.7/GCS7 | 50 |
| T0OUT | 75 |
| T0IN | 76 |
| T1OUT | 77 |
| T1IN | 78 |
| RXD0 | 3 |
| TXD0 | 2 |
| P2.5/BCLK0 | 4 |
| CTS0 | 1 |
| P2.0/RXD1 | 7 |
| P2.1/TXD1 | 8 |
| P2.2/BCLK1 | 9 |
| P2.3/SINT1 | 5 |
| P2.4/CTS1 | 6 |
| P2.6 | 80 |
| P2.7 | 79 |

Table 4. QFP Package Location with Pin Names

| Location | Name |
| :---: | :--- |
| 1 | CTS0 |
| 2 | TXD0 |
| 3 | RXD0 |
| 4 | P2.5/BCLK0 |
| 5 | P2.3/SINT1 |
| 6 | P2.4/CTS1 |
| 7 | P2.0/RXD1 |
| 8 | P2.1/TXD1 |
| 9 | P2.2/BCLK1 |
| 10 | AD0 |
| 11 | AD8 |
| 12 | VSS |
| 13 | VCC |
| 14 | $\mathrm{~V} S$ |
| 15 | AD1 |
| 16 | AD9 |
| 17 | AD2 |
| 18 | AD10 |
| 19 | AD3 |
| 20 | AD11 |


| Location | Name |
| :---: | :--- |
| 21 | AD4 |
| 22 | AD12 |
| 23 | AD5 |
| 24 | AD13 |
| 25 | AD6 |
| 26 | AD14 |
| 27 | AD7 |
| 28 | AD15 |
| 29 | A16 |
| 30 | A17 |
| 31 | A18 |
| 32 | A19/ONCE |
| 33 | $V_{S S}$ |
| 34 | $\mathrm{~V} C \mathrm{C}$ |
| 35 | $\mathrm{~V} S$ |
| 36 | $\overline{R D}$ |
| 37 | $\overline{W R}$ |
| 38 | ALE |
| 39 | $\overline{\text { BHE }}$ |
| 40 | $\overline{S 2}$ |


| Location | Name |
| :---: | :---: |
| 41 | S1 |
| 42 | $\overline{\mathrm{SO}}$ |
| 43 | $\overline{\text { DEN }}$ |
| 44 | HLDA |
| 45 | HOLD |
| 46 | TEST |
| 47 | LOCK |
| 48 | NMI |
| 49 | READY |
| 50 | P1.7/GCS7 |
| 51 | P1.6/GCS6 |
| 52 | P1.5/GCS5 |
| 53 | $\mathrm{V}_{\text {SS }}$ |
| 54 | $V_{\text {cc }}$ |
| 55 | P1.4/GCS4 |
| 56 | P1.3/GCS3 |
| 57 | P1.2/GCS2 |
| 58 | P1.1/GCS1 |
| 59 | P1.0/GCS0 |
| 60 | LCS |


| Location | Name |
| :---: | :--- |
| 61 | UCS |
| 62 | INTO |
| 63 | INT1 |
| 64 | INT2/INTAO |
| 65 | INT3/INTA1 |
| 66 | INT4 |
| 67 | PDTMR |
| 68 | $\overline{\text { RESIN }}$ |
| 69 | RESOUT |
| 70 | OSCOUT |
| 71 | CLKIN |
| 72 | VCC |
| 73 | VSS |
| 74 | CLKOUT |
| 75 | T0OUT |
| 76 | TOIN |
| 77 | T1OUT |
| 78 | T1IN |
| 79 | P2.7 |
| 80 | P2.6 |



270921-4
NOTE:
This is the FPO number location (indicated by X 's).
Figure 3. Quad Flat Pack Pinout Diagram

## PACKAGE THERMAL SPECIFICATIONS

The 80L186EB is specified for operation when $T_{C}$ (the case temperature) is within the range of $-40^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (PLCC package) or $-40^{\circ} \mathrm{C}$ to $+114^{\circ} \mathrm{C}$ (QFP package). $T_{C}$ may be measured in any environment to determine whether the 80L186EB is within the specified operating range. The case temperature must be measured at the center of the top surface.
$T_{A}$ (the ambient temperature) can be calculated from $\theta_{C A}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\mathrm{CA}}$ at various airflows are given in Table 5 for the 84-pin Plastic Leaded Chip Carrier (PLCC) package.

Table 6 shows the maximum $T_{A}$ allowable (without exceeding $T_{C}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumption, specified in watts) is calculated by using the maximum ICC as tabulated in the DC specifications and $\mathrm{V}_{\mathrm{CC}}$ of 5 V .

$$
T_{A}=T_{C}-P^{*} \theta_{C A}
$$

Table 5. Thermal Resistance ( $\theta_{\mathrm{CA}}$ ) at Various Airflows (in ${ }^{\circ} \mathrm{C} /$ Watt)

|  | Airflow Linear $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec})$ |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{0}$ <br> $\mathbf{( 0 )}$ | $\mathbf{2 0 0}$ <br> $\mathbf{( 1 . 0 1 )}$ | $\mathbf{4 0 0}$ <br> $\mathbf{2} .03)$ | $\mathbf{6 0 0}$ <br> $\mathbf{( 3 . 0 4 )}$ | $\mathbf{8 0 0}$ <br> $\mathbf{( 4 . 0 6 )}$ | $\mathbf{1 0 0 0}$ <br> $\mathbf{( 5 . 0 7 )}$ |
| $\theta_{\mathrm{CA}}$ (PLCC) | 30 | 24 | 21 | 19 | 17 | 16.5 |
| $\theta_{\mathrm{CA}}$ (QFP) | 58 | 47 | 43 | 40 | 38 | 36 |

Table 6. Maximum $\mathrm{T}_{\mathrm{A}}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{T}_{\mathrm{F}}$ | (0) | $\begin{array}{\|c} \hline 200 \\ (1.01) \end{array}$ | $\begin{array}{\|c} \hline 400 \\ (2.03) \end{array}$ | $\begin{array}{\|c\|} \hline 600 \\ (3.04) \end{array}$ | $\begin{gathered} 800 \\ (4.06) \end{gathered}$ | $\begin{array}{\|r\|} \hline 1000 \\ \hline(5.07 \\ \hline \end{array}$ |
|  | (MHz) |  |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{A}}$ (PLCC) | 16 | 91.5 | 93.5 | 94 | 94.5 | 95.5 | 95.5 |
| $\mathrm{T}_{\mathrm{A}}$ (QFP) | 16 | 98 | 101 | 102 | 103 | 103.5 | 104 |

## ELECTRICAL SPECIFICATIONS

Absolute Maximum Ratings
Parameter Maximum Rating
Storage Temperature $\ldots \ldots \ldots-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Case Temp Under Bias $\ldots \ldots \ldots-65^{\circ} \mathrm{C}$ to $+120^{\circ} \mathrm{C}$
Supply Voltage wrt $\mathrm{V}_{\mathrm{SS}} \ldots \ldots .-0.5 \mathrm{~V}$ to +6.5 V

| Voltage on other Pins |
| :--- |
| with Respect to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots$. |

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

OPERATING CONDITIONS

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{C C}$ | Supply Voltage | 2.7 | 5.5 | V |
| $\mathrm{T}_{\mathrm{F}}$ | $\begin{aligned} & \text { Input Clock Frequency } \\ & \text { 80L186EB13 } \\ & \text { 80L186EB8 } \end{aligned}$ | 0 | 26 | MHz |
|  |  | 0 | 16 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature Under Bias N80L186EB (PLCC) S80L186EB (QFP) | -40 | +100 | ${ }^{\circ} \mathrm{C}$ |
|  |  | -40 | +114 | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED CONNECTIONS

Power and ground connections must be made to multiple $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\text {SS }}$ pins. Every 80L186EB-based circuit board should include separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $\mathrm{V}_{S S}$ ) planes. Every $\mathrm{V}_{\mathrm{CC}}$ pin must be connected to the power plane, and every $V_{S S}$ pin must be connected to the ground plane. Pins identified as "NC" must not be connected in the system. Liberal decoupling capacitance should be placed near the 80L186EB. The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance is reduced by placing the decoupling capacitors as close as possible to the $80 \mathrm{~L} 186 \mathrm{~EB} \mathrm{~V}_{\mathrm{CC}}$ and $V_{\text {SS }}$ package pins.

Always connect any unused input to an appropriate signal level. In particular, unused interrupt inputs (INTO:4) should be connected to $\mathrm{V}_{\mathrm{CC}}$ through a pull-up resistor (in the range of $100 \mathrm{~K} \Omega$ ). Leave any unused output pin or any NC pin unconnected.

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | $0.3 * \mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | $0.7 * V_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}(\mathrm{Min})($ Note 1) |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{C C}-0.5$ |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ (Min) (Note 1) |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysterisis on RESIN | 0.50 |  | V |  |
| LII | Input Leakage Current for pins: <br> AD15:0, READY, HOLD, RESIN, CLKIN, TEST, NMI, INT4:0, TOIN, T1IN, RXDO, $\overline{\text { BCLKO }}, \overline{\mathrm{CTSO}}, \mathrm{RXD} 1, \overline{\mathrm{BCLK}}, \overline{\mathrm{CTS}} 1$, SINT1, P2.6, P2.7 |  | $\pm 15$ | $\mu \mathrm{A}$ | $\mathrm{O} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| LIL2 | Input Leakage Current for pins: A19/ONCE, A18:16, $\overline{\text { LOCK }}$ | -0.275 | -5 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0.7 \mathrm{~V}_{\mathrm{CC}}$ (Note 2) |
| Lo | Output Leakage Current |  | $\pm 15$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}} \\ & (\text { Note } 3) \end{aligned}$ |
| ICC5 | Supply Current (RESET, 5.5V) 80L186EB-13 80L186EB-8 |  | $\begin{aligned} & 70 \\ & 45 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 4) (Note 4) |
| ICC3 | Supply Current (RESET, 2.7V) 80L186EB-13 <br> 80L186EB-8 |  | $\begin{aligned} & 26 \\ & 22 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 4) (Note 4) |
| IID5 | Supply Current Idle (5.5V) 80L186EB-13 80L186EB-8 |  | $\begin{aligned} & 48 \\ & 31 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 5) (Note 5) |
| IID3 | Supply Current Idle (2.7V) 80L186EB-13 80L186EB-8 |  | $\begin{array}{r} 24 \\ 15 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ | (Note 5) (Note 5) |
| IPD5 | Supply Current Powerdown (5.5V) 80L186EB-13 <br> 80L186EB-8 |  | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ | (Note 6) (Note 6) |
| IPD3 | Supply Current Powerdown (2.7V) 80L186EB-13 <br> 80L186EB-8 |  | $\begin{aligned} & 30 \\ & 30 \end{aligned}$ | $\underset{\mu \mathrm{A}}{\mu \mathrm{~A}}$ | (Note 6) (Note 6) |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |
| Cout | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ ( Note 7) |

## NOTES:

1. $\mathrm{l}_{\mathrm{OL}}$ and $\mathrm{l}_{\mathrm{OH}}$ measured at $\mathrm{V}_{\mathrm{CC}}=2.7 \mathrm{~V}$.
2. These pins have an internal pull-up device that is active while $\overline{\operatorname{RESIN}}$ is low and ONCE Mode is not active. Sourcing more current than specified (on any of these pins) may invoke a factory test mode.
3. Tested by outputs being floated by invoking ONCE Mode or by asserting HOLD.
4. Measured with the device in RESET and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND.
5. Measured with the device in HALT (IDLE Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $V_{C C}$ or GND.
6. Measured with the device in HALT (Powerdown Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $V_{C C}$ or GND.
7. Output Capacitance is the capacitive load of a floating output pin.

## Icc VERSUS fREQUENCY aND VOLtage

The current (ICC) consumption of the 80L186EB is essentially composed of two components; IPD and Iccs.

IPD is the quiescent current that represents internal device leakage, and is measured with all inputs or floating outputs at GND or VCC (no clock applied to the device). IPD is equal to the Powerdown current and is typically less than $50 \mu \mathrm{~A}$.

Iccs is the switching current used to charge and discharge parasitic device capacitance when changing logic levels. Since Iccs is typically much greater than IPD, IPD can often be ignored when calculating Icc.

ICCS is related to the voltage and frequency at which the device is operating. It is given by the formula:

$$
\begin{aligned}
& \text { Power }=V \times I=V V^{2} \times C_{D E V} \times f \\
& \therefore I=I_{C C}=I_{C C S}=V \times C_{D E V} \times f
\end{aligned}
$$

Where: $\mathrm{V}=$ Device operating voltage ( $\mathrm{V}_{\mathrm{CC}}$ )
$C_{\text {DEV }}=$ Device capacitance
$f=$ Device operating frequency

$$
I_{C C S}=I_{C C}=\text { Device current }
$$

Measuring CDEV on a device like the 80C186EB would be difficult. Instead, $\mathrm{C}_{\text {DEV }}$ is calculated using the above formula by measuring $\mathrm{I}_{\mathrm{CC}}$ at a known $\mathrm{V}_{\mathrm{CC}}$ and frequency (see Table 7). Using this CDEV value, ICC can be calculated at any voltage and frequency within the specified operating range.

EXAMPLE: Calculate the typical ICc when operating at $8 \mathrm{MHz}, 3 \mathrm{~V}$.

$$
I_{C C}=I_{C C S}=3 \times 0.583 \times 8 \approx 14 \mathrm{~mA}
$$

## PDTMR PIN DELAY CALCULATION

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown. A delay is required only when using the on-chip oscillator to allow the crystal or resonator circuit time to stabilize.

## NOTE:

The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e., a device reset during Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized).

To calculate the value of capacitor required to provide a desired delay, use the equation:

$$
440 \times t=C_{P D} \quad\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where: $t=$ desired delay in seconds
$\mathrm{C}_{\mathrm{PD}}=$ capacitive load on PDTMR in microfarads

EXAMPLE: To get a delay of $300 \mu \mathrm{~s}$, a capacitor value of $\mathrm{C}_{P D}=440 \times\left(300 \times 10^{-6}\right)=0.132 \mu \mathrm{~F}$ is required. Round up to standard (available) capacitive values.

## NOTE:

The above equation applies to delay times greater than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ or $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $\mathrm{V}_{\mathrm{CC}}$ and/or lower temperature will decrease delay time, while lower $V_{C C}$ and/or higher temperature will increase delay time.

Table 7. Device Capacitance ( $C_{\text {DEV }}$ ) Values

| Parameter | Typ | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {DEV }}$ (Device in Reset) | 0.583 | 1.02 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| $\mathrm{C}_{\text {DEV }}$ (Device in Idle) | 0.408 | 0.682 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

NOTES:

1. Max $C_{D E V}$ is calculated at $-40^{\circ} \mathrm{C}$, all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND, and all outputs loaded to 50 pF (including CLKOUT and OSCOUT). 2. Typical $\mathrm{C}_{\text {DEV }}$ is calculated at $25^{\circ} \mathrm{C}$ with all outputs loaded to 50 pF except CLKOUT and OSCOUT, which are not loaded.

## AC SPECIFICATIONS

## AC Characteristics-(80L186EB-8)

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 16 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 62.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {CH }}$ | CLKIN High Time | 15 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 15 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 50 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{*}{ }^{\text {T }}$ C | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{T}_{\text {PL }}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PR}}$ | CLKOUT Rise Time | 1 | 15 | ns | 1,5 |
| $\mathrm{T}_{\text {PF }}$ | CLKOUT Fall Time | 1 | 15 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{D E N}, ~ D T / \bar{R}, \overline{B H E}$, LOCK, A19:16 | 3 | 30 | ns | 1,4,6, 7 |
| TCHOV2 | $\overline{\mathrm{GCSO}} \mathbf{7}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{NCS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 35 | ns | 1,4,6,7 |
| TCLOV1 | $\overline{\text { BHE, }} \overline{\text { DEN }}, \overline{\text { LOCK, RESOUT, HLDA, }}$ TOOUT, T1OUT, A19:16 | 3 | 30 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}}: \overline{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD15:0, $\overline{\text { NCS }}, \overline{\text { NTA1: }} \mathbf{0}, \mathrm{S} 2: 0$ | 3 | 35 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 30 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 35 | ns | 1 |

SYNCHRONOUS INPUTS

| TCHIS | TEST, NMI, INT4:0, T1:OIN, P2.6, P2.7 READY, CTS1:0, BCLK1:0 | 25 | ns | 1,9 |
| :---: | :---: | :---: | :---: | :---: |
| TCHIH | TEST, NMI, INT4:0, T1:OIN, BCLK1:0 READY, CTS1:0 | 3 | ns | 1,9 |
| TCLIS | AD15:0, READY | 25 | ns | 1,10 |
| TCLIH | READY, AD15:0 | 3 | ns | 1,10 |
| TCLIS | HOLD | 25 | ns | 1,9 |
| TCLIH | HOLD | 3 | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 10 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 11 for rise and fall times outside 50 pF .
6. See Figure 11 for rise and fall times.
7. TCHOV1 applies to $\overline{B H E}, \overline{L O C K}$ and A19:16 only after a HOLD release.
8. $\mathrm{T}_{\mathrm{CHOV} 2}$ applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L186EB operation.

80L186EB

## AC SPECIFICATIONS

AC Characteristics-(80L186EB-13)

| Symbol | Parameter |  |  |  |  |  |  | Min | Max | Units | Notes |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |  |  |  |  |  |  |
| $T_{F}$ | CLKIN Frequency | 0 | 26 | MHz | 1 |  |  |  |  |  |  |
| $T_{C}$ | CLKIN Period | 38.5 | $\infty$ | ns | 1 |  |  |  |  |  |  |
| $T_{C H}$ | CLKIN High Time | 15 | $\infty$ | ns | 1,2 |  |  |  |  |  |  |
| $T_{C L}$ | CLKIN Low Time | 15 | $\infty$ | ns | 1,2 |  |  |  |  |  |  |
| $T_{C R}$ | CLKIN Rise Time | 1 | 8 | ns | 1,3 |  |  |  |  |  |  |
| $T_{\text {CF }}$ | CLKIN Fall Time | 1 | 8 | ns | 1,3 |  |  |  |  |  |  |


| OUTPUT CLOCK |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 40 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{*}{ }^{\text {T }}$ C | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{TPL}^{\text {P }}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 10 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 10 | ns | 1,5 |


| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{D E N}, ~ D T / \bar{R}, \overline{B H E}$, LOCK, A19:16 | 3 | 25 | ns | 1,4, 6, 7 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCHOV2 | GCS0:7, LCS, $\overline{\text { UCS }}$, $\overline{\text { NCS }}$, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 30 | ns | 1, 4, 6, 7 |
| TCLOV1 | BHE, DEN, $\overline{\text { LOCK, RESOUT, HLDA, }}$ TOOUT, T1OUT, A19:16 | 3 | 25 | ns | 1,4,6 |
| TCLOV2 | $\begin{aligned} & \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}} 7: 0, \overline{L C S}, \overline{\mathrm{UCS}}, \mathrm{A15:8,} \\ & \text { AD7:0, } \end{aligned}$ | 3 | 30 | ns | 1,4,6 |
| TCLOV3 | S2:0 | 3 | 35 | ns | 1, 4, 6 |
| T ${ }_{\text {CHOF }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:16 | 0 | 30 | ns | 1 |
| TCLOF | $\overline{\text { DEN }}$ | 0 | 35 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, INT4:0, T1:OIN, P2.6, P2.7 READY, CTS1:0, BCLK1:0 | 20 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | $\begin{aligned} & \text { TEST, NMI, INT4:0, T1:OIN, BCLK1:0 } \\ & \text { READY, CTS1:0 } \end{aligned}$ | 3 |  | ns | 1, 9 |
| TCLIS | AD15:0, READY | 20 |  | ns | 1,10 |
| TCLIH | READY, AD15:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 20 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CLIH }}$ | HOLD | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 10 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 11 for rise and fall times outside 50 pF .
6. See Figure 11 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV} 1}$ applies to $\overline{\mathrm{BHE}}, \overline{\mathrm{LOCK}}$ and $\mathrm{A} 19: 16$ only after a HOLD release.
8. $\mathrm{T}_{\mathrm{CHOV}}$ applies to $\overline{\mathrm{RD}}$ and $\bar{W}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L186EB operation.

AC SPECIFICATIONS (Continued)
Relative Timings (80L186EB-8, -13)

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Rising to ALE Falling | T-15 |  | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Falling | $1 / 2 \mathrm{~T}-10$ |  | ns |  |
| TPLLL | Chip Selects Valid to ALE Falling | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TLLAX | Address Hold from ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{\text { WR }}$ Falling | $1 / 2 \mathrm{~T}-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\mathrm{RD}}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| T WHLH | $\overline{\text { WR Rising to ALE Rising }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| $\mathrm{T}_{\text {AFRL }}$ | Address Float to $\overline{\mathrm{RD}}$ Falling | 0 |  | ns |  |
| $\mathrm{T}_{\text {RLRH }}$ | $\overline{\text { RD Falling to } \overline{\mathrm{RD}} \text { Rising }}$ | (2*T) - 5 |  | ns | 2 |
| TWLWH | $\overline{\text { WR }}$ Falling to $\overline{\text { WR Rising }}$ | (2*T) - 5 |  | ns | 2 |
| TRHAX | $\overline{\mathrm{RD}}$ Rising to Address Active | T-15 |  | ns |  |
| T WHDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| T WHPH | $\overline{\text { WR Rising to Chip Select Rising }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TRHPH | $\overline{\mathrm{RD}}$ Rising to Chip Select Rising | $1 / 2 T-10$ |  | ns | 1 |
| TPHPL | $\overline{C S}$ Active to $\overline{C S}$ Inactive | $1 / 2 T-10$ |  | ns | 1 |
| TovRh | ONCE Active to RESIN Rising | 1 T |  | ns |  |
| $\mathrm{T}_{\text {RHOX }}$ | ONCE Hold from RESIN Rising | 1 T |  | ns |  |

## NOTES:

1. Assumes equal loading on both pins.

## AC SPECIFICATIONS (Continued)

Serial Port Mode 0 Timings (80L186EB-8, -13)

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TXLXL | TXD Clock Period | $\mathrm{T}(\mathrm{N}+1)$ |  | ns | 1,2 |
| TXLXH | TXD Clock Low to Clock High ( $\mathrm{N}>1$ ) | 2T-35 | $2 T+35$ | ns | 1, 2 |
| TXLXH | TXD Clock Low to Clock High ( $\mathrm{N}=1$ ) | T-35 | T+35 | ns | 1,2 |
| TXHXL | TXD Clock High to Clock Low ( $\mathrm{N}>1$ ) | $T(N-1)-35$ | $T(N-1)+35$ | ns | 2 |
| TXHXL | TXD Clock High to Clock Low ( $\mathrm{N}=1$ ) | T-35 | $T+35$ | ns | 2 |
| TQVXH | RXD Output Data Setup to TXD Clock High ( $n>1$ ) | $T(n-1)-35$ |  | ns | 1,2 |
| TQVXH | RXD Output Data Setup to TXD Clock High ( $n=1$ ) | T-35 |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $n>1$ ) | $2 \mathrm{~T}-35$ |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $n=1$ ) | T-35 |  | ns | 1 |
| TXHQZ | RXD Output Data Float after Last TXD Clock High |  | $T+20$ | ns | 1 |
| TDVXH | RXD Input Data Setup to TXD Clock High | $T+20$ |  | ns | 1 |
| TXHDX | RXD Input Data Hold after TXD Clock High | 0 |  | ns | 1 |

## NOTES:

1. See Figure 9 for waveforms.
2. $n$ is the value of the BxCMP register ignoring the ICLK Bit (i.e., ICLK $=0$ ).

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 4. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms, for AC specification definitions, test


Figure 4. AC Test Load

## AC TIMING WAVEFORMS



Figure 5. Input and Output Clock Waveform


Figure 6. Output Delay and Float Waveform


Figure 7. Input Setup and Hold


Figure 8. Relative Signal Waveform


Figure 9. Serial Port Mode 0 Waveform

## DERATING CURVES



Figure 10. Typical Output Delay Variations vs Load Capacitance


270921-13
Figure 11. Typical Rise and Fall Variations vs Load Capacitance


Figure 12. PLCC Principal Dimensions


Figure 13. QFP Principal Dimensions

## ERRATA

An 80L186EB with a STEPID value of 0001 H has the following known errata. A device with a STEPID of 0001 H can be visually identified by noting the absence of an alpha character next to the FPO number or by the presence of an "A" alpha character next to the FPO number. The FPO number location is shown in Figures 2 and 3.

1. A19/ONCE is not latched by the rising edge of RESIN. A19/ONCE must remain active (LOW) at all times to remain in the ONCETM Mode. Removing A19/ONCE after RESIN is high will return all output pins to a driving state, however, the 80L186EB will remain in a reset state.
2. During interrupt acknowledge (INTA) bus cycles, the bus controller will ignore the state of the READY pin if the previous bus cycle ignored the state of the READY pin. This errata can only occur if the Chip-Select Unit is being used. All active chip-selects must be programmed to use READY (RDY bit must be programmed to a 1) if waitstates are required for INTA bus cycles.
3. CLKOUT will transition off the rising edge of CLKIN rather than the falling edge of CLKIN. This does not affect any bus timings other than $\mathrm{T}_{\mathrm{CICO}}$.
4. $\overline{\text { RESIN }}$ has a hysterisis of only 130 mV . It is recommended that RESIN be driven with a Schmitt triggered device to avoid processor lockup during reset when using an RC circuit.
5. SINT1 will only go active for one clock period when a receive or transmit interrupt is pending (i.e., it does not remain active until the S1STS register is read). If SINT1 is to be connected to any of the 80L186EB interrupt lines (INTO-INT4), then it must be latched by user logic.

An 80L188EB with a STEPID value of 0001 H or 0002 H has the following known errata. Otherwise, an 80L188EB with a STEPID value of 0002H has no known errata (as of this publication). A device with a STEPID of 0002H can be visually identified by noting the presence of a " $B$ " or " $C$ " alpha character next to the FPO number. The FPO number location is shown in Figures 2 and 3.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistantly, it is dependent on interrupt timing.

## REVISION HISTORY

The following changes have been made between the -001 version and this (-002) version of the 80L186EB data sheet. This -002 data sheet applies to any 80L186EB with a "B" alpha character after the FPO number. The FPO number location is shown in Figures 2 and 3.

1. The data sheet was changed from a Product Preview version to an Advance Information version.
2. The DC specifications table has changed. Also, notes have been changed/added.
3. Graphs for $I_{C C}$ versus Frequency have been changed to equations with supporting text.
4. Graphs for PDTMR pin capacitance have been changed to equations with supporting text.
5. Serial port MODE 0 timings have been changed.
6. Various typing errors have been corrected throughout the document.

The following changes were made between the -002 and -003 versions of the 80L188EB data sheets. The -003 data sheet applies to any 80L188EB with a "B" alpha character after the FPO number. The FPO number location is shown in Figures 2 and 3.

1. 13 MHz Electrical, DC and AC Specifications were added to the appropriate sections.
2. The timing $T_{C L O V 3}$ was added to the AC Specifications for S2:0.
3. An errata appearing on both $A$ and $B$ steppings (INTA1) was added.

## 80C187 <br> 80-BIT MATH COPROCESSOR

- High Performance 80-Bit Internal Architecture
- Implements ANSI/IEEE Standard 7541985 for Binary Floating-Point Arithmetic
- Upward Object-Code Compatible from 8087
- Fully Compatible with 387TMDX and 387TMSX Math Coprocessors. Implements all 387 Architectural Enhancements over 8087
- Directly Interfaces with 80C186 CPU
- 80C186/80C187 Provide a Software/ Binary Compatible Upgrade from 80186/82188/8087 Systems
- Expands 80C186's Data Types to Include 32-, 64-, 80-Bit Floating-Point, 32-, 64-Bit Integers and 18-Digit BCD Operands
- Directly Extends 80C186's Instruction Set to Trigonometric, Logarithmic, Exponential, and Arithmetic Instructions for All Data Types
- Full-Range Transcendental Operations for SINE, COSINE, TANGENT, ARCTANGENT, and LOGARITHM
- Built-In Exception Handling
- Eight 80-Bit Numeric Registers, Usable as Individually Addressable General Registers or as a Register Stack

■ Available in 40-Pin CERDIP and 44-Pin PLCC Package

The Intel 80C187 is a high-performance math coprocessor that extends the architecture of the 80C186 with floating-point, extended integer, and BCD data types. A computing system that includes the 80C187 fully conforms to the IEEE Floating-Point Standard. The 80C187 adds over seventy mnemonics to the instruction set of the 80 C 186 , including support for arithmetic, logarithmic, exponential, and trigonometric mathematical operations. The 80C187 is implemented with 1.5 micron, high-speed CHMOS III technology and packaged in both a 40 -pin CERDIP and a 44 -pin PLCC package. The 80 C 187 is upward object-code compatible from the 8087 math coprocessor and will execute code written for the 80387DX and 80387SX math coprocessors.



Figure 2. Register Set

## FUNCTIONAL DESCRIPTION

The 80C187 Math Coprocessor provides arithmetic instructions for a variety of numeric data types. It also executes numerous built-in transcendental functions (e.g. tangent, sine, cosine, and log functions). The 80 C 187 effectively extends the register and instruction set of the 80 C 186 CPU for existing data types and adds several new data types as well. Figure 2 shows the additional registers visible to programs in a system that includes the 80C187. Essentially, the 80 C 187 can be treated as an additional resource or an extension to the CPU. The 80C186 CPU together with an 80C187 can be used as a single unified system.

A 80 C 186 system that includes the 80 C 187 is completely upward compatible with software for the 8086/8087.

The 80C187 interfaces only with the 80C186 CPU. The interface hardware for the 80 C 187 is not implemented on the 80C188.

## PROGRAMMING INTERFACE

The 80C187 adds to the CPU additional data types, registers, instructions, and interrupts specifically designed to facilitate high-speed numerics processing. All new instructions and data types are directly supported by the assembler and compilers for high-level languages. The 80 C 187 also supports the full 80387DX instruction set.

All communication between the CPU and the 80 C 187 is transparent to applications software. The

CPU automatically controls the 80C187 whenever a numerics instruction is executed. All physical memory and virtual memory of the CPU are available for storage of the instructions and operands of programs that use the 80C187. All memory addressing modes are available for addressing numerics operands.

The end of this data sheet lists by class the instructions that the 80 C 187 adds to the instruction set.

## NOTE:

The 80C187 Math Coprocessor is also referred to as a Numeric Processor Extension (NPX) in this document.

## Data Types

Table 1 lists the seven data types that the 80C187 supports and presents the format for each type. Operands are stored in memory with the least significant digit at the lowest memory address. Programs retrieve these values by generating the lowest address. For maximum system performance, all operands should start at even physical-memory addresses; operands may begin at odd addresses, but will require extra memory cycles to access the entire operand.

Internally, the 80C187 holds all numbers in the ex-tended-precision real format. Instructions that load operands from memory automatically convert operands represented in memory as 16 -, 32-, or 64 -bit integers, 32- or 64-bit floating-point numbers, or 18digit packed BCD numbers into extended-precision real format. Instructions that store operands in memory perform the inverse type conversion.

## Numeric Operands

A typical NPX instruction accepts one or two operands and produces one (or sometimes two) results. In two-operand instructions, one operand is the contents of an NPX register, while the other may be a memory location. The operands of some instructions are predefined; for example, FSQRT always takes the square root of the number in the top stack element (refer to the section on Data Registers).

## Register Set

Figure 2 shows the 80C187 register set. When an 80 C 187 is present in a system, programmers may use these registers in addition to the registers normally available on the CPU.

## DATA REGISTERS

80 C 187 computations use the extended-precision real data type.

Table 1. Data Type Representation in Memory


## NOTES:

1. $S=$ Sign bit $(0=$ Positive, $1=$ Negative $)$
2. $d_{n}=$ Decimal digit (two per byte)
3. $\mathrm{X}=$ Bits have no significance; 80 C 187 ignores when loading, zeros when storing
4. $\Delta=$ Position of implicit binary point
5. I = Integer bit of significand; stored in temporary real, implicit in single and double precision
6. Exponent Bias (normalized values):

Single: 127 (7FH)
Double: 1023 (3FFH)
Extended Real: 16383 (3FFFH)
7. Packed BCD: $(-1)^{S}\left(D_{17} \ldots D_{0}\right)$
8. Real: $(-1)^{S}(2 \mathrm{E}-\mathrm{BIAS})\left(\mathrm{F}_{0}, \mathrm{~F}_{1} \ldots\right)$

The 80C187 register set can be accessed either as a stack, with instructions operating on the top one or two stack elements, or as individually addressable registers. The TOP field in the status word identifies the current top-of-stack register. A "push" operation decrements TOP by one and loads a value into the new top register. A "pop" operation stores the value from the current top register and then increments TOP by one. The 80C187 register stack grows "down" toward lower-addressed registers.

Instructions may address the data registers either implicitly or explicitly. Many instructions operate on the register at the TOP of the stack. These instructions implicitly address the register at which TOP points. Other instructions allow the programmer to explicitly specify which register to use. This explicit addressing is also relative to TOP.

## TAG WORD

The tag word marks the content of each numeric data register, as Figure 3 shows. Each two-bit tag represents one of the eight data registers. The principal function of the tag word is to optimize the NPX's performance and stack handling by making it possible to distinguish between empty and nonempty register locations. It also enables exception handers to identify special values (e.g. NaNs or denormals) in the contents of a stack location without the need to perform complex decoding of the actual data.

## STATUS WORD

The 16 -bit status word (in the status register) shown in Figure 4 reflects the overall state of the 80C187. It may be read and inspected by programs.

Bit 15, the B-bit (busy bit) is included for 8087 compatibility only. It always has the same value as the ES bit (bit 7 of the status word); it does not indicate the status of the BUSY output of 80 C 187 .

Bits 13-11 (TOP) point to the 80C187 register that is the current top-of-stack.

The four numeric condition code bits $\left(\mathrm{C}_{3}-\mathrm{C}_{0}\right)$ are similar to the flags in a CPU; instructions that perform arithmetic operations update these bits to reflect the outcome. The effects of these instructions on the condition code are summarized in Tables 2 through 5.

Bit 7 is the error summary (ES) status bit. This bit is set if any unmasked exception bit is set; it is clear otherwise. If this bit is set, the ERROR signal is asserted.

Bit 6 is the stack flag (SF). This bit is used to distinguish invalid operations due to stack overflow or underflow from other kinds of invalid operations. When SF , is set, bit $9\left(\mathrm{C}_{1}\right)$ distinguishes between stack overflow ( $C_{1}=1$ ) and underflow ( $C_{1}=0$ ).

Figure 4 shows the six exception flags in bits 5-0 of the status word. Bits $5-0$ are set to indicate that the 80 C 187 has detected an exception while executing an instruction. A later section entitled "Exception Handling" explains how they are set and used.

Note that when a new value is loaded into the status word by the FLDENV or FRSTOR instruction, the value of ES (bit 7) and its reflection in the B-bit (bit 15) are not derived from the values loaded from memory but rather are dependent upon the values of the exception flags (bits $5-0$ ) in the status word and their corresponding masks in the control word. If ES is set in such a case, the ERROR output of the 80 C 187 is activated immediately.


Figure 3. Tag Word


Figure 4. Status Word

## CONTROL WORD

The NPX provides several processing options that are selected by loading a control word from memory into the control register. Figure 5 shows the format and encoding of fields in the control word.

Table 2. Condition Code Interpretation

| Instruction | CO(S) | C3(Z) | C1(A) | C2(C) |
| :---: | :---: | :---: | :---: | :---: |
| FPREM, FPREM1 (See Table 3) |  | $\begin{aligned} & \text { icant } \\ & \text { it } \\ & \text { Q0 } \end{aligned}$ | $\begin{aligned} & \text { Q1 } \\ & \text { or } O / \bar{U} \end{aligned}$ | Reduction 0 = Complete 1 = Incomplete |
| FCOM, FCOMP, FCOMPP, FTST FUCOM, FUCOMP, FUCOMPP, FICOM, FICOMP |  |  | $\begin{aligned} & \text { Zero or } \\ & 0 / \bar{U} \end{aligned}$ | Operand is not Comparable (Table 4) |
| FXAM |  |  | $\begin{gathered} \text { Sign } \\ \text { or } \mathrm{O} / \overline{\mathrm{U}} \end{gathered}$ | Operand Class (Table 5) |
| FCHS, FABS, FXCH, FINCSTP, FDECSTP, Constant Loads, FXTRACT, FLD, FILD, FBLD, FSTP (Ext Real) |  |  | $\begin{aligned} & \text { Zero } \\ & \text { or } \mathrm{O} / \overline{\mathrm{U}} \end{aligned}$ | UNDEFINED |
| FIST, FBSTP, <br> FRNDINT, FST, <br> FSTP, FADD, FMUL, <br> FDIV, FDIVR, <br> FSUB, FSUBR, <br> FSCALE, FSQRT, <br> FPATAN, F2XM1, <br> FYL2X, FYL2XP1 |  |  | Roundup <br> or $\mathrm{O} / \overline{\mathrm{U}}$ | UNDEFINED |
| FPTAN, FSIN, FCOS, FSINCOS |  |  | Roundup or O/U, Undefined if $\mathrm{C} 2=1$ | Reduction 0 = Complete 1 = incomplete |
| FLDENV, FRSTOR | Each Bit Loaded from Memory |  |  |  |
| FLDCW, FSTENV, FSTCW, FSTSW, FCLEX, FINIT, FSAVE | UNDEFINED |  |  |  |

O/U When both IE and SF bits of status word are set, indicating a stack exception, this bit distinguishes between stack overflow ( $\mathrm{C} 1=1$ ) and underfiow ( $\mathrm{C} 1=0$ ).
Reduction If FPREM or FPREM1 produces a remainder that is less than the modulus, reduction is complete. When reduction is incomplete the value at the top of the stack is a partial remainder, which can be used as input to further reduction. For FPTAN, FSIN, FCOS, and FSINCOS, the reduction bit is set if the operand at the top of the stack is too large. In this case the original operand remains at the top of the stack.
Roundup When the PE bit of the status word is set, this bit indicates whether one was added to the least significant bit of the result during the last rounding.
UNDEFINED Do not rely on finding any specific value in these bits.

The low-order byte of this control word configures exception masking. Bits 5-0 of the control word contain individual masks for each of the six exceptions that the 80C187 recognizes.

The high-order byte of the control word configures the 80 C 187 operating mode, including precision, rounding, and infinity control.

- The "infinity control bit" (bit 12) is not meaningful to the 80 C 187 , and programs must ignore its value. To maintain compatibility with the 8087, this bit can be programmed; however, regardless of its value, the 80 C 187 always treats infinity in the affine sense $(-\infty<+\infty)$. This bit is initialized to zero both after a hardware reset and after the FINIT instruction.
- The rounding control (RC) bits (bits 11-10) provide for directed rounding and true chop, as well
as the unbiased round to nearest even mode specified in the IEEE standard. Rounding control affects only those instructions that perform rounding at the end of the operation (and thus can generate a precision exception); namely, FST, FSTP, FIST, all arithmetic instructions (except FPREM, FPREM1, FXTRACT, FABS, and FCHS), and all transcendental instructions.
- The precision control (PC) bits (bits 9-8) can be used to set the 80C187 internal operating precision of the significand at less than the default of 64 bits (extended precision). This can be useful in providing compatibility with early generation arithmetic processors of smaller precision. PC affects only the instructions ADD, SUB, DIV, MUL, and SQRT. For all other instructions, either the precision is determined by the opcode or extended precision is used.

Table 3. Condition Code Interpretation after FPREM and FPREM1 Instructions

| Condition Code |  |  |  | Interpretation after FPREM and FPREM1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| C2 | C3 | C1 | C0 |  |  |
| 1 | X | X | X |  | Incomplete Reduction: Further Iteration Required for Complete Reduction |
| 0 | Q1 | Q0 | Q2 | Q MOD 8 | Complete Reduction: C0, C3, C1 Contain Three Least Significant Bits of Quotient |
|  | 0 | 0 | 0 | 0 |  |
|  | 0 | 1 | 0 | 1 |  |
|  | 1 | 0 | 0 | 2 |  |
|  | 1 | 1 | 0 | 3 |  |
|  | 0 | 0 | 1 | 4 |  |
|  | 0 | 1 | 1 | 5 |  |
|  | 1 | 0 | 1 | 6 |  |
|  | 1 | 1 | , | 7 |  |

Table 4. Condition Code Resulting from Comparison

| Order | C3 | C2 | C0 |
| :--- | :---: | :---: | :---: |
| TOP > Operand | 0 | 0 | 0 |
| TOP < Operand | 0 | 0 | 1 |
| TOP = Operand | 1 | 0 | 0 |
| Unordered | 1 | 1 | 1 |

Table 5. Condition Code Defining Operand Class

| C3 | C2 | C1 | C0 | Value at TOP |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | + Unsupported |
| 0 | 0 | 0 | 1 | + NaN |
| 0 | 0 | 1 | 0 | - Unsupported |
| 0 | 0 | 1 | 1 | - NaN |
| 0 | 1 | 0 | 0 | + Normal |
| 0 | 1 | 0 | 1 | + Infinity |
| 0 | 1 | 1 | 0 | - Normal |
| 0 | 1 | 1 | 1 | - Infinity |
| 1 | 0 | 0 | 0 | +0 |
| 1 | 0 | 0 | 1 | + Empty |
| 1 | 0 | 1 | 0 | -0 |
| 1 | 0 | 1 | 1 | - Empty |
| 1 | 1 | 0 | 0 | + Denormal |
| 1 | 1 | 1 | 1 | - Denormal |

## INSTRUCTION AND DATA POINTERS

Because the NPX operates in parallel with the CPU, any exceptions detected by the NPX may be reported after the CPU has executed the ESC instruction which caused it. To allow identification of the failing numerics instruction, the 80C187 contains registers that aid in diagnosis. These registers supply the opcode of the failing numerics instruction, the address of the instruction, and the address of its numerics memory operand (if appropriate).

The instruction and data pointers are provided for user-written exception handlers. Whenever the 80C187 executes a new ESC instruction, it saves the address of the instruction (including any prefixes that may be present), the address of the operand (if present), and the opcode.

The instruction and data pointers appear in the format shown by Figure 6. The ESC instruction FLDENV, FSTENV, FSAVE and FRSTOR are used to transfer these values between the registers and memory. Note that the value of the data pointer is undefined if the prior ESC instruction did not have a memory operand.

## Interrupt Description

CPU interrupt 16 is used to report exceptional conditions while executing numeric programs. Interrupt 16 indicates that the previous numerics instruction caused an unmasked exception. The address of the faulty instruction and the address of its operand are stored in the instruction pointer and data pointer registers. Only ESC instructions can cause this inter-
rupt. The CPU return address pushed onto the stack of the exception handler points to an ESC instruction (including prefixes). This instruction can be restarted after clearing the exception condition in the NPX. FNINIT, FNCLEX, FNSTSW, FNSTENV, and FNSAVE cannot cause this interrupt.

## Exception Handling

The 80C187 detects six different exception conditions that can occur during instruction execution. Table 6 lists the exception conditions in order of precedence, showing for each the cause and the default action taken by the 80C187 if the exception is masked by its corresponding mask bit in the control word.

Any exception that is not masked by the control word sets the corresponding exception flag of the status word, sets the ES bit of the status word, and asserts the ERROR signal. When the CPU attempts to execute another ESC instruction, interrupt 16 occurs. The exception condition must be resolved via an interrupt service routine. The return address pushed onto the CPU stack upon entry to the service routine does not necessarily point to the failing instruction nor to the following instruction. The 80C187 saves the address of the floating-point instruction that caused the exception and the address of any memory operand required by that instruction.

If error trapping is required at the end of a series of numerics instructions (specifically, when the last ESC instruction modifies memory data and that data is used in subsequent nonnumerics instructions), it is necessary to insert the FNOP instruction to force the 80 C 187 to check its ERROR input.


Figure 5. Control Word


Figure 6. Instruction and Data Pointer Image in Memory

Table 6. Exceptions

| Exception | Cause | Default Action <br> (If Exception is Masked) |
| :--- | :--- | :--- |
| Invalid <br> Operation | Operation on a signalling NaN, <br> unsupported format, indeterminate <br> form (0* $0,0 / 0),(+\infty)$ <br> $+(-\infty)$, etc.), or stack <br> overflow/underflow (SF is also set) | Result is a quiet NaN, <br> integer indefinite, or <br> BCD indefinite |
| Denormalized <br> Operand | At least one of the operands is <br> denormalized, i.e. it has the smallest <br> exponent but a nonzero significand | The operand is normalized, <br> and normal processing <br> continues |
| Zero Divisor | The divisor is zero while the dividend <br> is a noninfinite, nonzero number | Result is $\infty$ |
| Overflow | The result is too large in magnitude <br> to fit in the specified format | Result is largest finite <br> value or $\infty$ |
| Underflow | The true result is nonzero but too small <br> to be represented in the specified format, and, <br> if underflow exception is masked, denormalization <br> causes loss of accuracy | Result is denormalized <br> or zero |
| Inexact <br> Result <br> (Precision) | The true result is not exactly representable <br> in the specified format (e.g. 1/3); <br> the result is rounded according to the <br> rounding mode | Normal processing <br> continues |

## Initialization

After FNINIT or RESET, the control word contains the value 037FH (all exceptions masked, precision control 64 bits, rounding to nearest) the same values as in an 8087 after RESET. For compatibility with the 8087, the bit that used to indicate infinity control (bit 12) is set to zero; however, regardless of its setting, infinity is treated in the affine sense. After FNINIT or RESET, the status word is initialized as follows:

- All exceptions are set to zero.
- Stack TOP is zero, so that after the first push the stack top will be register seven (111B).
- The condition code $\mathrm{C}_{3}-\mathrm{C}_{0}$ is undefined.
- The B-bit is zero.

The tag word contains FFFFH (all stack locations are empty).

80C186/80C187 initialization software should execute an FNINIT instruction (i.e. an FINIT without a preceding WAIT) after RESET. The FNINIT is not strictly required for 80 C 187 software, but Intel recommends its use to help ensure upward compatibility with other processors.

## 8087 Compatibility

This section summarizes the differences between the 80 C 187 and the 8087. Many changes have been designed into the 80C187 to directly support the IEEE standard in hardware. These changes result in increased performance by elminating the need for software that supports the standard.

## GENERAL DIFFERENCES

The 8087 instructions FENI/FNENI and FDISI/ FNDISI perform no useful function in the 80C187 Numeric Processor Extension. They do not alter the state of the 80C187 Numeric Processor Extension. (They are treated similarly to FNOP, except that ERROR is not checked.) While 8086/8087 code containing these instructions can be executed on the 80C186/80C187, it is unlikely that the exceptionhandling routines containing these instructions will be completely portable to the 80C187 Numeric Processor Extension.

The $80 C 187$ differs from the 8087 with respect to instruction, data, and exception synchronization. Except for the processor control instructions, all of the 80C187 numeric instructions are automatically synchronized by the 80 C186 CPU. When necessary, the

80C186 automatically tests the BUSY line from the 80 C 187 Numeric Processor Extension to ensure that the 80C187 Numeric Processor Extension has completed its previous instruction before executing the next ESC instruction. No explicit WAIT instructions are required to assure this synchronization. For the 8087 used with 8086 and 8088 CPUs, explicit WAITs are required before each numeric instruction to ensure synchronization. Although 8086/8087 programs having explicit WAIT instructions will execute on the $80 \mathrm{C} 186 / 80 \mathrm{C} 187$, these WAIT instructions are unnecessary.

The 80C187 supports only affine closure for infinity arithmetic, not projective closure.

Operands for FSCALE and FPATAN are no longer restricted in range (except for $\pm \infty$ ); F2XM1 and FPTAN accept a wider range of operands.

Rounding control is in effect for FLD constant.
Software cannot change entries of the tag word to values (other than empty) that differ from actual register contents.

After reset, FINIT, and incomplete FPREM, the 80 C 187 resets to zero the condition code bits $\mathrm{C}_{3}-$ $\mathrm{C}_{0}$ of the status word.

In conformance with the IEEE standard, the 80C187 does not support the special data formats pseudozero, pseudo-NaN, pseudoinfinity, and unnormal.

The denormal exception has a different purpose on the 80 C 187 . A system that uses the denormal-exception handler solely to normalize the denormal operands, would better mask the denormal exception on the 80C187. The 80C187 automatically normalizes denormal operands when the denormal exception is masked.

## EXCEPTIONS

A number of differences exist due to changes in the IEEE standard and to functional improvements to the architecture of the 80C186/80C187:

1. The 80C186/80C187 traps exceptions only on the next ESC instruction; i.e. the 80C186 does not notice unmasked 80C187 exceptions on the 80C186 ERROR input line until a later numerics instruction is executed. Because the 80C186 does not sample ERROR on WAIT and FWAIT instructions, programmers should place an FNOP instruction at the end of a sequence of numerics instructions to force the 80C186 to sample its ERROR input.
2. The 80 C 187 Numeric Processor Extension signals exceptions through a dedicated ERROR line to the CPU. The 80C187 error signal does not pass through an interrupt controller (the 8087 INT signal does). Therefore, any interrupt-controlleroriented instructions in numerics exception handlers for the $8086 / 8087$ should be deleted.
3. Interrupt vector 16 must point to the numerics exception handling routine.
4. The ESC instruction address saved in the 80C187 Numeric Processor Extension includes any leading prefixes before the ESC opcode. The corresponding address saved in the 8087 does not include leading prefixes.
5. When the overflow or underflow exception is masked, the 80C187 differs from the 8087 in rounding when overflow or underflow occurs. The 80 C 187 produces results that are consistent with the rounding mode.
6. When the underflow exception is masked, the 80 C 187 sets its underflow flag only if there is also a loss of accuracy during denormalization.
7. Fewer invalid-operation exceptions due to denormal operands, because the instructions FSQRT, FDIV, FPREM, and conversions to BCD or to integer normalize denormal operands before proceeding.
8. The FSQRT, FBSTP, and FPREM instructions may cause underflow, because they support denormal operands.
9. The denormal exception can occur during the transcendental instructions and the FXTRACT instruction.
10. The denormal exception no longer takes precedence over all other exceptions.
11. When the denormal exception is masked, the 80C187 automatically normalizes denormal operands. The 8087 performs unnormal arithmetic, which might produce an unnormal result.
12. When the operand is zero, the FXTRACT instruction reports a zero-divide exception and leaves $-\infty$ in $\mathrm{ST}(1)$.
13. The status word has a new bit (SF) that signals when invalid-operation exceptions are due to stack underflow or overflow.
14. FLD extended precision no longer reports denormal exceptions, because the instruction is not numeric.
15. FLD single/double precision when the operand is denormal converts the number to extended precision and signals the denormalized oper-
and exception. When loading a signalling NaN , FLD single/double precision signals an invalidoperand exception.
16. The 80 C 187 only generates quiet NaNs (as on the 8087); however, the 80C187 distinguishes between quiet NaNs and signalling NaNs . Signalling NaNs trigger exceptions when they are used as operands; quiet NaNs do not (except for FCOM, FIST, and FBSTP which also raise IE for quiet NaNs ).
17. When stack overflow occurs during FPTAN and overflow is masked, both $\mathrm{ST}(0)$ and $\mathrm{ST}(1)$ contain quiet NaNs. The 8087 leaves the original operand in ST(1) intact.
18. When the scaling factor is $\pm \infty$, the FSCALE (ST(0), ST(1) instruction behaves as follows
(ST(0) and ST(1) contain the scaled and scaling operands respectively):

- FSCALE $(0, \infty)$ generates the invalid operation exception.
- FSCALE (finite, $-\infty$ ) generates zero with the same sign as the scaled operand.
- FSCALE (finite, $+\infty$ ) generates $\infty$ with the same sign as the scaled operand.
The 8087 returns zero in the first case and raises the invalid-operation exception in the other cases.

19. The 80 C 187 returns signed infinity/zero as the unmasked response to massive overflow/underflow. The 8087 supports a limited range for the scaling factor; within this range either massive overflow/underflow do not occur or undefined results are produced.

Table 7. Pin Summary

| Pin <br> Name | Function | Active <br> State | Input/ <br> Output |
| :--- | :--- | :---: | :---: |
| CLK | CLocK <br> CKM <br> RESET | ClocKing Mode <br> System reset | High |

## HARDWARE INTERFACE

In the following description of hardware interface, an overbar above a signal name indicates that the active or asserted state occurs when the signal is at a low voltage. When no overbar is present above the signal name, the signal is asserted when at the high voltage level.

## Signal Description

In the following signal descriptions, the 80C187 pins are grouped by function as follows:

1. Execution Control- CLK, CKM, RESET
2. NPX Handshake- PEREQ, BUSY, ERROR
3. Bus Interface Pins- $D_{15}-D_{0}, \overline{N P W R}, \overline{\text { NPRD }}$
4. Chip/Port Select- $\overline{\text { NPS1 }}$, NPS2, CMD0, CMD1
5. Power Supplies - $\mathrm{V}_{\mathrm{CC}}$, $\mathrm{V}_{\mathrm{SS}}$

Table 7 lists every pin by its identifier, gives a brief description of its function, and lists some of its characteristics. Figure 7 shows the locations of pins on the CERDIP package, while Figure 8 shows the locations of pins on the PLCC package. Table 8 helps to locate pin identifiers in Figures 7 and 8.

## Clock (CLK)

This input provides the basic timing for internal operation. This pin does not require MOS-level input; it will operate at either TTL or MOS levels up to the maximum allowed frequency. A minimum frequency must be provided to keep the internal logic properly functioning. Depending on the signal on CKM, the signal on CLK can be divided by two to produce the internal clock signal (in which case CLK may be up to 32 MHz in frequency), or can be used directly (in which case CLK may be up to 12.5 MHz ).

## Clocking Mode (CKM)

This pin is a strapping option. When it is strapped to $V_{\text {CC }}$ (HIGH), the CLK input is used directly; when strapped to $V_{\text {SS }}$ (LOW), the CLK input is divided by two to produce the internal clock signal. During the RESET sequence, this input must be stable at least four internal clock cycles (i.e. CLK clocks when CKM is HIGH; $2 \times$ CLK clocks when CKM is LOW) before RESET goes LOW.


Figure 7. CERDIP Pin Configuration


Figure 8. PLCC Pin Configuration

Table 8. PLCC Pin Cross-Reference

| Pin Name | CERDIP Package | PLCC Package |
| :--- | :---: | :---: |
| BUSY | 25 | 28 |
| CKM | 39 | 44 |
| CLK | 32 | 36 |
| CMD0 | 29 | 32 |
| CMD1 | 31 | 35 |
| $D_{0}$ | 23 | 26 |
| $D_{1}$ | 22 | 25 |
| $D_{2}$ | 21 | 24 |
| $D_{3}$ | 20 | 22 |
| $D_{4}$ | 19 | 21 |
| $D_{5}$ | 18 | 20 |
| $D_{6}$ | 17 | 19 |
| $D_{7}$ | 16 | 18 |
| $D_{8}$ | 15 | 17 |
| $D_{9}$ | 14 | 16 |
| $D_{10}$ | 12 | 14 |
| $D_{11}$ | 11 | 13 |
| $D_{12}$ | 8 | 9 |
| $D_{13}$ | 7 | 8 |
| $D_{14}$ | 6 | 7 |
| $D_{15}$ | 5 | 5 |
| ERROR | 26 | 29 |
| No Connect | 2 | 37 |
| NPRD | 27 | 30 |
| NPS1 | 34 | 38 |
| NPS2 | 33 | 37 |
| NPWR | 28 | 31 |
| PEREQ | 24 | 27 |
| RESET | 35 | 39 |
| $V_{\text {CC }}$ | $3,9,13,37,40$ | $1,3,10,15,42$ |
| VSS | $1,30,36,38$ | $2,34,41,43$ |

## System Reset (RESET)

A LOW to HIGH transition on this pin causes the 80 C 187 to terminate its present activity and to enter a dormant state. RESET must remain active (HIGH) for at least four internal clock periods. (The relation of the internal clock period to CLK depends on CLKM; the internal clock may be different from that of the CPU.) Note that the 80 C 187 is active internally for 25 clock periods after the termination of the RESET signal (the HIGH to LOW transition of RESET); therefore, the first instruction should not be written to the 80C187 until 25 internal clocks after the falling edge of RESET. Table 9 shows the status of the output pins during the reset sequence. After a reset, all output pins return to their inactive states.

Table 9. Output Pin Status during Reset

| Output <br> Pin Name | Value <br> during Reset |
| :---: | :---: |
| BUSY | HIGH |
| ERROR | HIGH |
| PEREQ | LOW |
| $D_{15}-D_{0}$ | TRI-STATE OFF |

## Processor Extension Request (PEREQ)

When active, this pin signals to the CPU that the 80C187 is ready for data transfer to/from its data FIFO. When there are more than five data transfers,

PEREQ is deactivated after the first three transfers and subsequently after every four transfers. This signal always goes inactive before BUSY goes inactive.

## Busy Status (BUSY)

When active, this pin signals to the CPU that the 80 C 187 is currently executing an instruction. This pin is active HIGH. It should be connected to the 80C186's TEST/BUSY pin. During the RESET sequence this pin is HIGH. The 80C186 uses this HIGH state to detect the presence of an 80C187.

## Error Status (ERROR)

This pin reflects the ES bit of the status register. When active, it indicates that an unmasked exception has occurred. This signal can be changed to inactive state only by the following instructions (without a preceding WAIT): FNINIT, FNCLEX, FNSTENV, FNSAVE, FLDCW, FLDENV, and FRSTOR. This pin should be connected to the ERROR pin of the CPU. ERROR can change state only when BUSY is active.

## Data Pins ( $\mathrm{D}_{15}-\mathrm{D}_{0}$ )

These bidirectional pins are used to transfer data and opcodes between the CPU and 80C187. They are normally connected directly to the corresponding CPU data pins. Other buffers/drivers driving the local data bus must be disabled when the CPU reads from the NPX. High state indicates a value of one. $D_{0}$ is the least significant data bit.

## Numeric Processor Write ( (NPWR)

A signal on this pin enables transfers of data from the CPU to the NPX. This input is valid only when $\overline{\text { NPS1 }}$ and NPS2 are both active.

## Numeric Processor Read (NPRD)

A signal on this pin enables transfers of data from the NPX to the CPU. This input is valid only when NPS1 and NPS2 are both active.

## Numeric Processor Selects ( $\overline{\text { NPS1 }}$ and NPS2)

Concurrent assertion of these signals indicates that the CPU is performing an escape instruction and enables the 80 C 187 to execute that instruction. No
data transfer involving the 80 C 187 occurs unless the device is selected by these lines.

## Command Selects (CMDO and CMD1)

These pins along with the select pins allow the CPU to direct the operation of the 80C187.

## System Power (Vcc)

System power provides the $+5 \mathrm{~V} \pm 10 \% \mathrm{DC}$ supply input. All $\mathrm{V}_{\mathrm{CC}}$ pins should be tied together on the circuit board and local decoupling capacitors should be used between $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\text {SS }}$.

## System Ground (VSS)

All $V_{\text {SS }}$ pins should be tied together on the circuit board and local decoupling capacitors should be used between $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$.

## Processor Architecture

As shown by the block diagram (Figure 1), the 80C187 NPX is internally divided into three sections: the bus control logic (BCL), the data interface and control unit, and the floating-point unit (FPU). The FPU (with the support of the control unit which contains the sequencer and other support units) executes all numerics instructions. The data interface and control unit is responsible for the data flow to and from the FPU and the control registers, for receiving the instructions, decoding them, and sequencing the microinstructions, and for handling some of the administrative instructions. The BCL is responsible for CPU bus tracking and interface.

## BUS CONTROL LOGIC

The BCL communicates solely with the CPU using I/O bus cycles. The BCL appears to the CPU as a special peripheral device. It is special in two respects: the CPU initiates I/O automatically when it encounters ESC instructions, and the CPU uses reserved I/O addresses to communicate with the BCL. The BCL does not communicate directly with memory. The CPU performs all memory access, transferring input operands from memory to the 80C187 and transferring outputs from the 80C187 to memory. A dedicated communication protocol makes possible high-speed transfer of opcodes and operands between the CPU and 80C187.

Table 10. Bus Cycles Definition

| NPS1 | NPS2 | CMD0 | CMD1 | $\overline{\text { NPRD }}$ | $\overline{\text { NPWR }}$ | Bus Cycle Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| $\mathbf{x}$ | 0 | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | 80C187 Not Selected |
| 1 | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | 80 C 187 Not Selected |
| 0 | 1 | 0 | 0 | 1 | 0 | Opcode Write to 80C187 |
| 0 | 1 | 0 | 0 | 0 | 1 | CW or SW Read from 80C187 |
| 0 | 1 | 1 | 0 | 0 | 1 | Read Data from 80C187 |
| 0 | 1 | 1 | 0 | 1 | 0 | Write Data to 80C187 |
| 0 | 1 | 0 | 1 | 1 | 0 | Write Exception Pointers |
| 0 | 1 | 0 | 1 | 0 | 1 | Reserved |
| 0 | 1 | 1 | 1 | 0 | 1 | Read Opcode Status |
| 0 | 1 | 1 | 1 | 1 | 0 | Reserved |

## DATA INTERFACE AND CONTROL UNIT

The data interface and control unit latches the data and, subject to BCL control, directs the data to the FIFO or the instruction decoder. The instruction decoder decodes the ESC instructions sent to it by the CPU and generates controls that direct the data flow in the FIFO. It also triggers the microinstruction sequencer that controls execution of each instruction. If the ESC instruction is FINIT, FCLEX, FSTSW, FSTSW AX, FSTCW, FSETPM, or FRSTPM, the control executes it independently of the FPU and the sequencer. The data interface and control unit is the one that generates the BUSY, PEREQ, and ERROR signals that synchronize 80 C 187 activities with the CPU.

## FLOATING-POINT UNIT

The FPU executes all instructions that involve the register stack, including arithmetic, logical, transcendental, constant, and data transfer instructions. The
data path in the FPU is 84 bits wide ( 68 significant bits, 15 exponent bits, and a sign bit) which allows internal operand transfers to be performed at very high speeds.

## Bus Cycles

The pins $\overline{\mathrm{NPS} 1}, \mathrm{NPS} 2, \mathrm{CMDO}, \mathrm{CMD1}, \overline{\mathrm{NPRD}}$ and NPWR identify bus cycles for the NPX. Table 10 defines the types of 80 C 187 bus cycles.

## 80C187 ADDRESSING

The $\overline{\text { NPS1 }}$, NPS2, CMD0, and CMD1 signals allow the NPX to identify which bus cycles are intended for the NPX. The NPX responds to I/O cycles when the $1 / \mathrm{O}$ address is $00 \mathrm{~F} 8 \mathrm{H}, 00 \mathrm{FAH}, 00 \mathrm{FCH}$, or 00 FEH . The correspondence betwen 1/O addresses and control signals is defined by Table 11. To guarantee correct operation of the NPX, programs must not perform any I/O operations to these reserved port addresses.

Table 11. I/O Address Decoding

| I/O Address <br> (Hexadecimal) | 80C187 Select and Command Inputs |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | NPS2 | $\overline{\text { NPS1 }}$ | CMD1 | CMD0 |
| OOF8 | 1 | 0 | 0 | 0 |
| OOFA | 1 | 0 | 0 | 1 |
| OOFC | 1 | 0 | 1 | 0 |
| OOFE | 1 | 0 | 1 | 1 |

## CPU/NPX SYNCHRONIZATION

The pins BUSY, PEREQ, and ERROR are used for various aspects of synchronization between the CPU and the NPX.

BUSY is used to synchronize instruction transfer from the CPU to the 80C187. When the 80C187 recognizes an ESC instruction, it asserts BUSY. For most ESC instructions, the CPU waits for the 80C187 to deassert BUSY before sending the new opcode.

The NPX uses the PEREQ pin of the CPU to signal that the NPX is ready for data transfer to or from its data FIFO. The NPX does not directly access memory; rather, the CPU provides memory access services for the NPX.

Once the CPU initiates an 80C187 instruction that has operands, the CPU waits for PEREQ signals that indicate when the 80 C 187 is ready for operand transfer. Once all operands have been transferred (or if the instruction has no operands) the CPU continues program execution while the 80 C 187 executes the ESC instruction.

In 8086/8087 systems, WAIT instructions are required to achieve synchronization of both commands and operands. The 80C187, however, does not require WAIT instructions. The WAIT or FWAIT instruction commonly inserted by high-level compilers and assembly-language programmers for exception synchronization is not treated as an instruction by the 80C186 and does not provide exception trapping. (Refer to the section "System Configuration for 8087-Compatible Exception Trapping".)

Once it has started to execute a numerics instruction and has transferred the operands from the CPU, the 80C187 can process the instruction in parallel with and independent of the host CPU. When the NPX detects an exception, it asserts the ERROR signal, which causes a CPU interrupt.

## OPCODE INTERPRETATION

The CPU and the NPX use a bus protocol that adapts to the numerics opcode being executed. Only the NPX directly interprets the opcode. Some of the results of this interpretation are relevant to the CPU. The NPX records these results (opcode status information) in an internal 16 -bit register. The 80C186 accesses this register only via reads from NPX port 00FEH. Tables 10 and 11 define the signal combinations that correspond to each of the following steps.

1. The CPU writes the opcode to NPX port 00F8H. This write can occur even when the NPX is busy or is signalling an exception. The NPX does not necessarily begin executing the opcode immediately.
2. The CPU reads the opcode status information from NPX port 00FEH.
3. The CPU initiates subsequent bus cycles according to the opcode status information. The opcode status information specifies whether to wait until the NPX is not busy, when to transfer exception pointers to port 00FCH, when to read or write operands and results at port 00 FAH , etc.

For most instructions, the NPX does not start executing the previously transferred opcode until the CPU (guided by the opcode status information) first writes exception pointer information to port 00FCH of the NPX. This protocol is completely transparent to programmers.

## Bus Operation

With respect to bus interface, the 80 C 187 is fully asynchronous with the CPU, even when it operates from the same clock source as the CPU. The CPU initiates a bus cycle for the NPX by activating both NPS1 and NPS2, the NPX select signals. During the CLK period in which NPS1 and NPS2 are activated, the 80C187 also examines the $\overline{\text { NPRD }}$ and NPRW
input signals to determine whether the cycle is a read or a write cycle and examines the CMDO and CMD1 inputs to determine whether an opcode, operand, or control/status register transfer is to occur. The ${ }^{80 C 187}$ activates its BUSY output some time after the leading edge of the NPRD or NPRW signal. Input and ouput data are referenced to the trailing edges of the NPRD and NPRW signals.

The 80C187 activates the PEREQ signal when it is ready for data transfer. The 80C187 deactivates PEREQ automatically.

## System Configuration

The 80C187 can be connected to the 80C186 CPU as shown by Figure 9. (Refer to the 80C186 Data Sheet for an explanation of the 80C186's signals.) This interface has the following characteristics:

- The 80C187's $\overline{N P S 1}$, ERROR, PEREQ, and BUSY pins are connected directly to the corresponding pins of the 80C186.
- The 80 C 186 pin $\overline{\mathrm{MCS3}} / \overline{\mathrm{NPS}}$ is connected to NPS1; NPS2 is connected to $\mathrm{V}_{\mathrm{CC}}$. Note that if the 80C186 CPU's DEN signal is used to gate external data buffers, it must be combined with the $\overline{\mathrm{NPS}}$ signal to insure numeric accesses will not activate these buffers.
- The $\overline{N P R D}$ and $\overline{N P R W}$ pins are connected to the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ pins of the 80C186.
- CMD1 and CMD0 come from the latched $A_{2}$ and $A_{1}$ of the 80C186, respectively.
- The 80C187 BUSY output connects to the 80C186 TEST/BUSY input. During RESET, the signal at the 80 C 187 BUSY output automatically programs the 80 C 186 to use the 80 C 187 .
- The 80C187 can use the CLKOUT signal of the 80C186 to conserve board space when operating at 12.5 MHz or less. In this case, the 80 C 187 CKM input must be pulled HIGH. For operation in excess of 12.5 MHz , a double-frequency external oscillator for CLK input is needed. In this case, CKM must be pulled LOW.


Figure 9. 80C186/80C187 System Configuration

## System Configuration for 80186/ 80187-Compatible Exception Trapping

When the 80C187 ERROR output signal is connected directly to the 80C186 ERROR input, floatingpoint exceptions cause interrupt \#16. However, existing software may be programmed to expect float-ing-point exceptions to be signalled over an external interrupt pin via an interrupt controller.

For exception handling compatible with the 80186/ 82188/8087, the 80C186 can be wired to recognize exceptions through an external interrupt pin, as Figure 10 shows. (Refer to the 80C186 Data Sheet for an explanation of the 80C186's signals.) With this arrangement, a flip-flop is needed to latch BUSY upon assertion of ERROR. The latch can then be cleared during the exception-handler routine by forcing a $\overline{\text { PCS }}$ pin active. The latch must also be cleared at RESET in order for the 80C186 to work with the 80 C 187.


270640-8
*For input clocking options, refer to Figure 9.
Figure 10. System Configuration for 8087-Compatible Exception Trapping
$80 C 187$

## ELECTRICAL DATA

## Absolute Maximum Ratings*

Case Temperature Under Bias $\left(\mathrm{T}_{\mathrm{C}}\right) \ldots 0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin
with Respect to Ground . . . -0.5 V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Power Dissipation. . . . . . . . . . . . . . . . . . . . . . . . . . . 1.5 W

NOTICE: This is a production data sheet. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## Power and Frequency Requirements

The typical relationship between ICC and the frequency of operation $F$ is as follows:

$$
\mathrm{I}_{\mathrm{typ}}=55+5 * \mathrm{~F} \mathrm{~mA} \quad \text { where } \mathrm{F} \text { is in } \mathrm{MHz}
$$

When the frequency is reduced below the minimum operating frequency specified in the AC Characteristics table, the internal states of the 80C187 may become indeterminate. The 80 C 187 clock cannot be stopped; otherwise, ICC would increase significantly beyond what the equation above indicates.

DC Characteristics $\mathrm{T}_{\mathrm{C}}=0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{ICL}}$ | Clock Input LOW Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{ICH}}$ | Clock Input HIGH Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output LOW Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=3.0 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 156 | mA | 16 MHz |
|  |  |  | 135 | mA | 12.5 MHz |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | I/O Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\mathrm{OUT}} \leq \mathrm{V}_{\mathrm{CC}}-0.45 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{O}}$ | I/O or Output Capacitance |  | 12 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{CLK}}$ | Clock Capacitance |  | 20 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |

## AC Characteristics

$T_{C}=0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V unless otherwise specified

| Symbol | Parameter | 12.5 MHz |  | 16 MHz |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min <br> (ns) | Max <br> (ns) | Min <br> (ns) | Max <br> (ns) |  |
| $T_{\text {dvwh }}(t 6)$ <br> $\mathrm{T}_{\text {whdx }}$ (t7) | Data Setup to $\overline{\text { NPWR }}$ Data Hold from $\overline{\text { NPWR }}$ | $\begin{aligned} & 43 \\ & 14 \end{aligned}$ |  | $\begin{aligned} & 33 \\ & 14 \end{aligned}$ |  |  |
| $\mathrm{T}_{\text {rirh }}$ (t8) <br> $T_{\text {wiwh }}$ (t9) | $\overline{\text { NPRD }}$ Active Time NPWR Active Time | $\begin{aligned} & 59 \\ & 59 \end{aligned}$ |  | $\begin{aligned} & 54 \\ & 54 \end{aligned}$ |  |  |
| $\begin{aligned} & \mathrm{T}_{\mathrm{avwl}}(\mathrm{t} 10) \\ & \mathrm{T}_{\mathrm{avrl}}(\mathrm{t} 11) \\ & \hline \end{aligned}$ | Command Valid to NPWR Command Valid to NPRD | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  |  |
| $T_{\text {mhrl }}(\mathrm{t} 12)$ | Min Delay from PEREQ Active to $\overline{\text { NPRD Active }}$ | 40 |  | 30 |  |  |
| $T_{\text {whax }}(\mathrm{t} 18)$ <br> $T_{\text {rhax }}$ (t19) | Command Hold from $\overline{\text { NPWR }}$ Command Hold from NPRD | $\begin{aligned} & 12 \\ & 12 \end{aligned}$ |  | $\begin{aligned} & 8 \\ & 8 \end{aligned}$ |  |  |
| $\begin{aligned} & \mathrm{T}_{\text {ivcl }}(\mathrm{t} 20) \\ & \mathrm{T}_{\text {clih }}(\mathrm{t} 21) \\ & \mathrm{T}_{\mathrm{rscl}}(\mathrm{t} 24) \\ & \mathrm{T}_{\text {clrs }}(\mathrm{t} 25) \end{aligned}$ | $\overline{\text { NPRD, }} \overline{\text { NPWR, }}$, RESET to <br> CLK Setup Time <br> NPRD, $\overline{N P W R}$, RESET from <br> CLK Hold Time <br> RESET to CLK Setup <br> RESET from CLK Hold | 46 <br> 26 <br> 21 <br> 14 |  | $\begin{gathered} 38 \\ 18 \\ 19 \\ 9 \end{gathered}$ |  | Note 1 <br> Note 1 <br> Note 1 <br> Note 1 |
| $\mathrm{T}_{\text {cmdi }}(\mathrm{t} 26)$ | Command Inactive Time Write to Write <br> Read to Read <br> Read to Write <br> Write to Read | $\begin{aligned} & 69 \\ & 69 \\ & 69 \\ & 69 \end{aligned}$ |  | $\begin{aligned} & 59 \\ & 59 \\ & 59 \\ & 59 \end{aligned}$ |  |  |

NOTE:

1. This is an asynchronous input. This specification is given for testing purposes only, to assure recognition at a specific CLK edge.

Timing Responses
All timings are measured at 1.5 V unless otherwise specified

| Symbol | Parameter | 12.5 MHz |  | 16 MHz |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min <br> (ns) | $\begin{gathered} \text { Max } \\ \text { (ns) } \end{gathered}$ | Min <br> (ns) | Max <br> (ns) |  |
| $\begin{aligned} & \mathrm{T}_{\text {rhqz }}(\mathrm{t} 27) \\ & \mathrm{T}_{\text {rlqv }}(\mathrm{t} 28) \\ & \hline \end{aligned}$ | $\overline{\text { NPRD }}$ Inactive to Data Float* $\overline{\text { NPRD }}$ Active to Data Valid |  | $\begin{aligned} & 18 \\ & 50 \end{aligned}$ |  | $\begin{array}{r} 18 \\ 45 \\ \hline \end{array}$ | Note 2 Note 3 |
| Tillbh ( t 29 ) | ERROR Active to Busy Inactive | 104 |  | 104 |  | Note 4 |
| $\mathrm{T}_{\text {wlbv }}(\mathrm{t} 30)$ | NPWR Active to Busy Active |  | 80 |  | 60 | Note 4 |
| $\mathrm{T}_{\text {klml }}(\mathrm{t} 31)$ | $\overline{\text { NPRD }}$ or $\overline{N P W R}$ Active to PEREQ Inactive |  | 80 |  | 60 | Note 5 |
| $\mathrm{T}_{\text {rhah }}$ (332) | Data Hold from NPRD Inactive | 2 |  | 2 |  | Note 3 |
| $\mathrm{T}_{\text {rlibh }}(\mathrm{t} 33)$ | RESET Inactive to BUSY Inactive |  | 80 |  | 60 |  |

## NOTES:

*The data float delay is not tested.
2. The float condition occurs when the measured output current is less than $\mathrm{I}_{\mathrm{OL}}$ on $\mathrm{D}_{15}-\mathrm{D}_{0}$.
3. $D_{15}-D_{0}$ loading: $C_{L}=100 \mathrm{pF}$.
4. BUSY loading: $C_{L}=100 \mathrm{pF}$.
5. On last data transfer of numeric instruction.

## Clock Timings

|  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | nbol | Para |  | Min <br> (ns) | Max (ns) | $\begin{gathered} \text { Min } \\ \text { (ns) } \end{gathered}$ | Max (ns) | Conditions |
| $\mathrm{T}_{\text {clcl }}$ | (t1a) <br> (t1B) | CLK Period | $\begin{aligned} & \text { CKM }=1 \\ & \text { CKM }=0 \end{aligned}$ | $\begin{aligned} & 80 \\ & 40 \end{aligned}$ | $\begin{aligned} & 250 \\ & 125 \end{aligned}$ | $\begin{gathered} \text { N/A } \\ 31.25 \end{gathered}$ | $\begin{aligned} & \text { N/A } \\ & 125 \end{aligned}$ | Note 6 Note 6 |
|  | $\begin{aligned} & \text { (t2a) } \\ & \text { (t2b) } \\ & \hline \end{aligned}$ | CLK Low Time | $\begin{aligned} & \text { CKM }=1 \\ & C K M=0 \end{aligned}$ | $\begin{gathered} 35 \\ 9 \end{gathered}$ |  | $\begin{gathered} \text { N/A } \\ 7 \end{gathered}$ |  | Note 6 Note 7 |
| Tchcl | (t3a) <br> ( t 3 b ) | CLK High Time | $\begin{aligned} & \text { CKM }=1 \\ & \text { CKM }=0 \end{aligned}$ | $\begin{aligned} & 35 \\ & 13 \end{aligned}$ |  | $\begin{gathered} \mathrm{N} / \mathrm{A} \\ 9 \end{gathered}$ |  | Note 6 <br> Note 8 |
| $T_{\text {ch2ch1 }}(4)$ |  |  |  |  | 10 |  | 8 | Note 9 |
| $\mathrm{T}_{\text {chich2 }}$ (t5) |  |  |  |  | 10 |  | 8 | Note 10 |

## NOTES:

*16 MHz operation is available only in divide-by-2 mode (CKM strapped LOW).
6. At 1.5 V
7. At 0.8 V
8. At 2.0 V
9. $C K M=1: 3.7 \mathrm{~V}$ to 0.8 V at $16 \mathrm{MHz}, 3.5 \mathrm{~V}$ to 1.0 V at 12.5 MHz
10. $\mathrm{CKM}=1: 0.8 \mathrm{~V}$ to 3.7 V at $16 \mathrm{MHz}, 1.0 \mathrm{~V}$ to 3.5 V at 12.5 MHz

AC DRIVE AND MEASUREMENT POINTS-CLK INPUT


AC SETUP, HOLD, AND DELAY TIME MEASUREMENTS-GENERAL


AC TEST LOADING ON OUTPUTS
$\square$
DATA TRANSFER TIMING (INITIATED BY CPU)


DATA CHANNEL TIMING (INITIATED BY 80C187)


ERROR OUTPUT TIMING


CLK, RESET TIMING (CKM = 1)


CLK, $\overline{\text { NPRD, }}$ NPWR TIMING (CKM $=1$ )


CLK, RESET TIMING (CKM $=0$ )


RESET must meet timing shown to guarantee known phase of internal divide by 2 circuits.

## NOTE:

RESET, $\overline{\text { NPWR, }} \overline{\text { NPRD }}$ inputs are asynchronous to CLK. Timing requirements are given for testing purposes only, to assure recognition at a specific CLK edge.

CLK, $\overline{\text { NPRD, }} \overline{\text { NPWR }}$ TIMING (CKM $=0$ )


RESET, BUSY TIMING


## 80C187 EXTENSIONS TO THE CPU's INSTRUCTION SET

Instructions for the 80C187 assume one of the five forms shown in Table 12. In all cases, instructions are at least two bytes long and begin with the bit pattern 11011B, which identifies the ESCAPE class of instruction. Instructions that refer to memory operands specify addresses using the CPU's addressing modes.

MOD (Mode field) and R/M (Register/Memory specifier) have the same interpretation as the corresponding fields of CPU instructions (refer to Programmer's Reference Manual for the CPU). The

DISP (displacement) is optionally present in instructions that have MOD and R/M fields. Its presence depends on the values of MOD and R/M, as for instructions of the CPU.

The instruction summaries that follow assume that the instruction has been prefetched, decoded, and is ready for execution; that bus cycles do not require wait states; that there are no local bus HOLD requests delaying processor access to the bus; and that no exceptions are detected during instruction execution. Timings are given in internal 80C187 clocks and include the time for opcode and data transfer between the CPU and the NPX. If the instruction has MOD and R/M fields that call for both base and index registers, add one clock.

Table 12. Instruction Formats


NOTES:
OP = Instruction opcode, possibly split into two fields OPA and OPB

MF $=$ Memory Format
$00-32$-Bit Real
$01-32$-Bit Integer
10— 64-Bit Real
11- 16-Bit Integer
*In FSUB and FDIV, the low-order bit of OPB is the R (reversed)
$d=$ Destination
0-Destination is ST(0)
0 - Destination is ST(i)
R XOR d = 0- Destination (op) Source
R XOR d = 1-Source (op) Destination
$P=P o p$
0- Do not pop stack
1- Pop stack after operation
$E S C=11011$

$111=$ Eighth Stack Element

80C187 Extensions to the 80C186 Instruction Set


Shaded areas indicate instructions not available in 8087.

## NOTE:

a. When loading single- or double-precision zero from memory, add 5 clocks.

80C187 Extensions to the 80C186 Instruction Set (Continued)

| Instruction | Encoding |  |  | Clock Count Range |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \text { Byte } \\ 0 \end{gathered}$ | Byte <br> 1 | Optional <br> Bytes 2-3 | 32-Bit Real | 32-Bit <br> Integer | 64-Bit Real | 16-Bit Integer |
| CONSTANTS (Continued) |  |  |  |  |  |  |  |
| FLDL2E $=$ Load $\log _{2}(\mathrm{e})$ into ST(0) | ESC 001 | 11101010 | . |  | 42 |  |  |
| FLDLG2 $=$ Load $\log _{10}(2)$ into ST(0) | ESC 001 | 11101100 |  |  | 43 |  |  |
| FLDLN2 $=$ Load $\log _{\mathrm{e}}(2)$ into ST(0) | ESC 001 | 11101101 |  |  | 43 |  |  |
| ARITHMETIC |  |  |  |  |  |  |  |
| FADD = Add |  |  |  |  |  |  |  |
| Integer/real memory with ST(0) | ESC MF 0 | MOD $000 \mathrm{R} / \mathrm{M}$ | DISP | 44-52 | 77-92 | 65-73 | 77-91 |
| ST(i) and ST(0) | ESCdP0 | 11000 ST(i) |  |  |  |  |  |
| FSUB = Subtract |  |  |  |  |  |  |  |
| Integer/real memory with ST(0) | ESC MF 0 | MOD 10 R R/M | DISP | 44-52 | 77-92 | 65-73 | 77-91c |
| ST(i) and ST(0) | ESCdPO | 1110 R R/M |  |  |  |  |  |
| FMUL = Multiply |  |  |  |  |  |  |  |
| Integer/real memory with ST(0) | ESC MF 0 | MOD 001 R/M | DISP | 47-57 | 81-102 | 68-93 | 82-93 |
| $\mathrm{ST}(\mathrm{i})$ and $\mathrm{ST}(0)$ | ESCdPO | $11001 \mathrm{R} / \mathrm{M}$ |  |  |  |  |  |
| FDIV $=$ Divide |  |  |  |  |  |  |  |
| Integer/real memory with ST(0) | ESC MF 0 | MOD 11 R R/M | DISP | 108 | 140-147 | 128 | 142-1469 |
| ST(i) and ST(0) | ESCdP0 | 1111 R R/M |  |  |  |  | s |
| FSQRTI = Square root | ESC 001 | 11111010 |  |  |  |  |  |
| FSCALE = Scale ST(0) by ST(1) | ESC 001 | 11111101 |  |  |  |  |  |
| FPREM = Partial remainder of |  |  |  |  |  |  |  |
| ST(0) $\div$ ST(1) | ESC 001 | 11111000 |  |  |  |  |  |
| FPREM1 = Partial remainder |  |  |  |  |  |  |  |
| $\begin{aligned} & \text { Frindivt = Round ST(0) } \\ & \text { to integer } \end{aligned}$ | ESC001 | $11111100$ |  |  |  | 2 |  |
| $\begin{aligned} & \text { FXTRACT = Extract components } \\ & \text { of ST(0) } \end{aligned}$$\square$ |  |  |  |  |  |  |  |
| FABS = Absolute value of ST(0) | ESC 001 | 11100001 |  |  |  |  |  |
| FCHS = Change sign of ST(0) | ESC 001 | 11100000 |  |  |  |  | " |

Shaded areas indicate instructions not available in 8087.

## NOTES:

b. Add 3 clocks to the range when $d=1$.
c. Add 1 clock to each range when $R=1$.
d. Add 3 clocks to the range when $\mathrm{d}=0$.
e. typical $=54($ When $d=0,48-56$, typical $=51)$.
f. Add 1 clock to the range when $R=1$.
g. 153-159 when $R=1$.
h. Add 3 clocks to the range when $d=1$.
i. $-0 \leq \operatorname{ST}(0) \leq+\infty$.

80C187 Extensions to the 80C186 Instruction Set (Continued)


Shaded areas indicate instructions not available in 8087.

## NOTES:

j. These timings hold for operands in the range $|\mathrm{x}|<\pi / 4$. For operands not in this range, up to 78 clocks may be needed to reduce the operand.
k. $0 \leq|\mathrm{ST}(0)|<263$.
l. $-1.0 \leq \mathrm{ST}(0) \leq 1.0$.
$\mathrm{m} .0 \leq \mathrm{ST}(0)<\infty,-\infty<\mathrm{ST}(1)<+\infty$.
n. $0 \leq|\mathrm{ST}(0)|<(2-\sqrt{ }(2)) / 2,-\infty<\mathrm{ST}(1)<+\infty$.

## DATA SHEET REVISION REVIEW

The following list represents the key differences between the -002 and the -001 version of the 80C187 data sheet. Please review this summary carefully.

1. Figure 10, titled "System Configuration for 8087-Compatible Exception Trapping", was replaced with a revised schematic. The previous configuration was faulty. Updated timing diagrams on Data Transfer Timing, Error Output; and RESET/BUSY.

## HIGH INTEGRATION 8-BIT MICROPROCESSOR

Integrated Feature Set

- Enhanced 8086-2 CPU
- Clock Generator
- 2 Independent DMA Channels
- Programmable Interrupt Controller
- 3 Programmable 16-Bit Timers
- Programmable Memory and Peripheral Chip-Select Logic
- Programmable Wait State Generator
- Local Bus Controller

16-Bit Internal Architecture with 8-Bit Data Bus Interface

- High-Performance 8 MHz Processor -2 MByte/Sec Bus Bandwidth Interface @ 8 MHz

Direct Addressing Capability to 1 MByte of Memory and 64 KByte I/O

- Completely Object Code Compatible with All Existing 8086/8088 Software - 10 New Instruction Types
- Complete System Development Support
-Development Software: ASM86
Assembler, PL/M-86, Pascal-86, Fortran-86, C-86, and System Utilities
- In-Circuit-Emulator (I2ICETM-186/188)
- Numeric Coprocessing Capability Through 8087 Interface
- Available in 68 Pin:
- Ceramic Leadless Chip Carrier (LCC)
- Ceramic Pin Grid Array (PGA)
- Plastic Leaded Chip Carrier (PLCC)
(See Packaging Outlines and Dimensions, Order \# 231369)
- Available in EXPRESS
- Standard Temperature with Burn-In
- Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )


210706-1
Figure 1. 80188 Block Diagram


Figure 2. 80188 Pinout Diagram

Table 1. 80188 Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ | $\begin{aligned} & \hline 9 \\ & 43 \end{aligned}$ | $1$ | SYSTEM POWER: + 5 volt power supply. |
| $\mathrm{V}_{\text {SS }}$ | $\begin{aligned} & 26 \\ & 60 \end{aligned}$ | $1$ | SYSTEM GROUND |
| RESET | 57 | 0 | RESET OUTPUT: Indicates that the 80188 CPU is being reset, and can be used as a system reset. It is active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods corresponding to the length of the RES signal. |
| $\begin{aligned} & \hline \mathrm{X} 1 \\ & \mathrm{X} 2 \end{aligned}$ | $\begin{aligned} & 59 \\ & 58 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | CRYSTAL INPUTS: X1 and X2 provide external connections for a fundamental mode parallel resonant crystal for the internal oscillator. Instead of using a crystal, an external clock may be applied to X1 while minimizing stray capacitance on X2. The input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). |
| CLKOUT | 56 | 0 | CLOCK OUTPUT: Provides the system with a $50 \%$ duty cycle waveform. All device pin timings are specified relative to CLKOUT. |
| $\overline{\text { RES }}$ | 24 | 1 | PROCESSOR RESET: Causes the 80188 to immediately terminate its present activity, clear the internal logic, and enter a dormant state. This signal may be asynchronous to the 80188 clock. The 80188 begins fetching instructions approximately $61 / 2$ clock cycles after RES is returned HIGH. For proper initialization, $\mathrm{V}_{\mathrm{CC}}$ must be within specifications and the clock signal must be stable for more than 4 clocks with RES held low. RES is internally synchronized. This input is provided with a Schmitt-trigger to facilitate power-on $\overline{\text { RES }}$ generation via an RC network. When RES occurs, the 80188 will drive the status lines to an inactive level for one clock, and then float them. |
| $\overline{\text { TEST }}$ | 47 | 1/0 | TEST: Is examined by the WAIT instruction. If the TEST input is HIGH when "WAIT" execution begins, instruction execution will suspend. TEST will be resampled until it goes LOW, at which time execution will resume. If interrupts are enabled while the 80188 is waiting for TEST, interrupts will be serviced. During power-up, active RES is required to configure TEST as an input. This pin is synchronized internally. |
| TMR IN 0 TMR IN 1 | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | $1$ | TIMER INPUTS: Are used either as clock or control signals, depending upon the programmed timer mode. These inputs are active HIGH (or LOW-to-HIGH transitions are counted) and internally synchronized. |
| TMR OUT 0 TMR OUT 1 | $\begin{aligned} & 22 \\ & 23 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | TIMER OUTPUTS: Are used to provide single pulse or continuous waveform generation, depending upon the timer mode selected. |
| $\begin{aligned} & \hline \text { DRQ0 } \\ & \text { DRQ1 } \end{aligned}$ | $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | $1$ | DMA REQUEST: Is asserted HIGH by an external device when it is ready for DMA Channel 0 or 1 to perform a transfer. These signals are level-triggered and internally synchronized. |
| NMI | 46 | 1 | NON-MASKABLE INTERRUPT: Causes a Type 2 interrupt. An NMI transition from LOW to HIGH is latched and synchronized internally, and initiates the interrupt at the next instruction boundary. NMI must be asserted for at least one clock. The NonMaskable Interrupt cannot be avoided by programming. |
| INTO <br> INT1/SELECT <br> INT2/INTAO <br> INT3/INTA1/ <br> IRQ | $\begin{aligned} & 45 \\ & 44 \\ & 42 \\ & 41 \end{aligned}$ | $\begin{gathered} \hline 1 \\ 1 \\ \text { I/O } \\ \text { I/O } \end{gathered}$ | MASKABLE INTERRUPT REQUESTS: Can be requested by activating one of these pins. When configured as inputs, these pins are active HIGH. Interrupt Requests are synchronized internally. INT2 and INT3 may be configured to provide active-LOW interruptacknowledge output signals. All interrupt inputs may be configured to be either edge- or level-triggered. To ensure recognition, all interrupt requests must remain active until the interrupt is acknowledged. When Slave Mode is selected, the function of these pins changes (see Interrupt Controller section of this data sheet). |

Table 1. 80188 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & 65 \\ & 66 \\ & 67 \\ & 68 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | ADDRESS BUS OUTPUTS (16-19) and BUS CYCLE STATUS (36): Indicate the four most significant address bits during $T_{1}$. These signals are active HIGH. During $T_{2}, T_{3}, T_{W}$, and $T_{4}$, the S 6 pin is LOW to indicate a CPU-initiated bus cycle or HIGH to indicate a DMA-initiated bus cycle. During the same T-states, S3, S4, and S5 are always LOW. The status pins float during bus HOLD or RESET. |  |  |
| $\begin{aligned} & \text { AD7 } \\ & \text { AD6 } \\ & \text { AD5 } \\ & \text { AD4 } \\ & \text { AD3 } \\ & \text { AD2 } \\ & \text { AD1 } \\ & \text { AD0 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 4 \\ & 4 \\ & 6 \\ & 8 \\ & 11 \\ & 13 \\ & 15 \\ & 17 \end{aligned}$ | $\begin{aligned} & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & \hline \end{aligned}$ | ADDRESS/DATA BUS (0-7): Signals constitute the time multiplexed memory or I/O address ( $T_{1}$ ) and data ( $T_{2}, T_{3}, T_{W}$, and $T_{4}$ ) bus. The bus is active HIGH. |  |  |
| $\begin{aligned} & \text { A15 } \\ & \text { A14 } \\ & \text { A13 } \\ & \text { A12 } \\ & \text { A11 } \\ & \text { A10 } \\ & \text { A9 } \\ & \text { A8 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 3 \\ & 3 \\ & 5 \\ & 7 \\ & 10 \\ & 12 \\ & 14 \\ & 16 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | ADDRESS-ONLY BUS (8-15): Containing valid address from $\mathrm{T}_{1}-\mathrm{T}_{4}$. The bus is active HIGH. |  |  |
| S7 | 64 | 0 | This signal is HIGH to indicate that the 80188 has an 8 -bit data bus. S7 floats during HOLD. |  |  |
| ALE/QSO | 61 | 0 | ADDRESS LATCH ENABLE/QUEUE STATUS 0 : Is provided by the 80188 to latch the address. ALE is active HIGH. Addresses are guaranteed to be valid on the trailing edge of ALE. The ALE rising edge is generated off the rising edge of the CLKOUT immediately preceding $\mathrm{T}_{1}$ of the associated bus cycle, effectively one-half clock cycle earlier than in the 8088. The trailing edge is generated off the CLKOUT rising edge in $T_{1}$ as in the 8088. Note that ALE is never floated. |  |  |
| $\overline{\text { WR/QS1 }}$ | 63 | 0 | WRITE STROBE/QUEUE STATUS 1: Indicates that the data on the bus is to be written into a memory or an I/O device. WR is active for $T_{2}, T_{3}$, and $T_{W}$ of any write cycle. It is active LOW, and floats during HOLD. When the 80188 is in queue status mode, the ALE/QS0 and WR/QS1 pins provide information about processor/ instruction queue interaction. |  |  |
|  |  |  | QS1 | QSO | Queue Operation |
|  |  |  | 0 0 1 | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | No Queue Operation First Opcode Byte Fetched from the Queue Subsequent Byte Fetched from the Queue Empty the Queue |

Table 1. 80188 Pin Description (Continued)


Table 1. 80188 PIn Description (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| HOLD (input) HLDA (output) | $\begin{aligned} & 50 \\ & 51 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | HOLD: Indicates that another bus master is requesting the local bus. The HOLD input is active HIGH. HOLD may be asynchronous with respect to the 80188 clock. The 80188 will issue a HLDA in response to a HOLD request at the end of $T_{4}$ or $T_{i}$. Simultaneous with the issuance of HLDA, the 80188 will float the local bus and control lines. After HOLD is detected as being LOW, the 80188 will lower HLDA. When the 80188 needs to run another bus cycle, it will again drive the local bus and control lines. |
| $\overline{\text { UCS }}$ | 34 | 0 | UPPER MEMORY CHIP SELECT: Is an active LOW output whenever a memory reference is made to the defined upper portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ block) of memory. This line is not floated during bus HOLD. The address range activating UCS is software programmable. |
| $\overline{\text { LCS }}$ | 33 | 0 | LOWER MEMORY CHIP SELECT: Is active LOW whenever a memory reference is made to the defined lower portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ ) of memory. This line is not floated during bus HOLD. The address range activating LCS is software programmable. |
| $\overline{\text { MCS0 }}$ <br> $\overline{\text { MCS1 }}$ <br> MCS2 <br> MCS3 | $\begin{aligned} & 38 \\ & 37 \\ & 36 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{aligned} & 10 \\ & 0 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | MID-RANGE MEMORY CHIP SELECT SIGNALS: Are active LOW when a memory reference is made to the defined mid-range portion of memory ( $8 \mathrm{~K}-512 \mathrm{~K}$ ). These lines are not floated during bus HOLD. The address ranges activating MCSO -3 are software programmable. |
| PCS0 <br> PCS1 <br> PCS2 <br> PCS3 <br> PCS4 | $\begin{aligned} & 25 \\ & 27 \\ & 28 \\ & 29 \\ & 30 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | PERIPHERAL CHIP SELECT SIGNALS 0-4: Are active LOW when a reference is made to the defined peripheral area ( 64 K byte I/O space). These lines are not floated during bus HOLD. The address ranges activating PCSO-4 are software programmable. |
| $\overline{\text { PCS5/A1 }}$ | 31 | 0 | PERIPHERAL CHIP SELECT 5 or LATCHED A1: May be programmed to provide a sixth peripheral chip select, or to provide an internally latched A1 signal. The address range activating PCS5 is software programmable. $\overline{\text { PCS5 }} / \mathrm{A} 1$ does not float during bus HOLD. When programmed to provide latched A1, this pin will retain the previously latched value during HOLD. |
| $\overline{\text { PCS6/A2 }}$ | 32 | 0 | PERIPHERAL CHIP SELECT 6 or LATCHED A2: May be programmed to provide a seventh peripheral chip select, or to provide an internally latched A2 signal. The address range activating PCS6 is software-programmable. PCS6/A2 does not float during bus HOLD. When programmed to provide latched A2, this pin will retain the previously latched value during HOLD. |
| DT/ $\bar{R}$ | 40 | 0 | DATA TRANSMIT/RECEIVE: Controls the direction of data flow through an external data bus transceiver. When LOW, data is transferred to the 80188 . When HIGH the 80188 places write data on the data bus. |
| $\overline{\text { DEN }}$ | 39 | 0 | DATA ENABLE: Is provided as a data bus transceiver output enable. $\overline{D E N}$ is active LOW during each memory and I/O access. DEN is HIGH whenever $D T / \bar{R}$ changes state. During RESET, $\overline{D E N}$ is driven HIGH for one clock, then floated. DEN also floats during bus HOLD. |

## FUNCTIONAL DESCRIPTION

## Introduction

The following Functional Description describes the base architecture of the 80188 . The 80188 is a very high integration 8 -bit microprocessor. It combines $15-20$ of the most common microprocessor system components onto one chip while providing twice the performance of the standard 8088. The 80188 is object code compatible with the 8086,8088 microprocessors and adds 10 new instruction types to the 8086, 8088 instruction set.

## 80188 BASE ARCHITECTURE

The 8086, 8088, 80186, 80188 and 80286 family all contain the same basic set of registers, instructions, and addressing modes. The 80188 processor is upward compatible with the $8086,8088,80186$, and 80286 CPUs.

## Register Set

The 80188 base architecture has fourteen registers as shown in Figures 3a and 3b. These registers are grouped into the following categories.

## GENERAL REGISTERS

Eight 16-bit general purpose registers may be used for arithmetic and logical operands. Four of these ( $A X, B X, C X$, and DX) can be used as 16 -bit registers or split into pairs of separate 8 -bit registers.

## 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.)

## 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 selects the specific registers for operand and address calculations.

## STATUS AND CONTROL REGISTERS

Two 16-bit special purpose registers record or alter certain aspects of the 80188 processor state. These are the Instruction Pointer Register, which contains the offset address of the next sequential instruction to be executed, and the Status Word Register, which contains status and control flag bits (see Figures 3a and 3 b ).

## STATUS WORD DESCRIPTION

The Status Word records specific characteristics of the result of logical and arithmetic instructions (bits $0,2,4,6,7$, and 11) and controls the operation of the 80188 within a given operating mode (bits 8, 9, and 10). The Status Word Register is 16 -bits wide. The function of the Status Word bits is shown in Table 2.


Figure 3a. 80188 Register Set


Figure 3b. Status Word Format

Table 2. Status Word Bit Functions

| Bit <br> Position | Name | Function |
| :---: | :---: | :--- |
| 0 | CF | Carry Flag-Set on high-order <br> bit carry or borrow; cleared <br> otherwise |
| 2 | PF | Parity Flag-Set if low-order <br> 8 bits of result contain an even <br> number of 1-bits; cleared <br> otherwise |
| 4 | AF | Set on carry from or borrow to <br> the low order four bits of AL; <br> cleared otherwise |
| 6 | ZF | Zero Flag-Set if result is zero; <br> cleared otherwise |
| 8 | SF | Sign Flag-Set equal to high- <br> order bit of result (0 if positive, <br> 1 if negative) |
| 9 | TF | Single Step Flag-Once set, a <br> single step interrutt occurs <br> after the next instruction <br> executes. TF is cleared by the <br> single step interrupt. |
| 10 | Interrupt-Enable Flag-When <br> set, maskable interrupts will <br> cause the CPU to transfer <br> control to an interrupt vector <br> specified location. |  |
| 11 | DF | Direction Flag-Causes string <br> instructions to auto decrement <br> the appropriate index register <br> when set. Clearing DF causes <br> auto increment. |
| OF | Overflow Flag-Set if the <br> signed result cannot be <br> expressed within the number <br> of bits in the destination <br> operand; cleared otherwise |  |

## Instruction Set

The instruction set is divided into seven categories: data transfer, arithmetic, shift/rotate/logical, string manipulation, control transfer, high-level instructions, and processor control. These categories are summarized in Figure 4.

An 80188 instruction can reference anywhere from zero to several operands. An operand can reside in a register, in the instruction itself, or in memory. Specific operand addressing modes are discussed later in this data sheet.

## Memory Organization

Memory is organized in sets of segments. Each segment is a linear contiguous sequence of up to 64 K ( $2^{16}$ ) 8 -bit bytes. Memory is addressed using a twocomponent address (a pointer) that consists of a 16bit base segment and a 16 -bit offset. The 16 -bit base values are contained in one of four internal segment registers (code, data, stack, extra). The physical address is calculated by shifting the base value LEFT by four bits and adding the 16 -bit offset value to yield a 20 -bit physical address (see Figure 5). This allows for a 1 MByte physical address size.

All instructions that address operands in memory must specify the base segment and the 16 -bit offset value. For speed and compact instruction encoding, the segment register used for physical address generation is implied by the addressing mode used (see Table 3). These rules follow the way programs are written (see Figure 6) 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 overridden for special cases. The stack, data, and extra segments may coincide for simple programs.

| GENERAL PURPOSE |  | MOVS |  | Move byte or word string |
| :---: | :---: | :---: | :---: | :---: |
| MOV | Move byte or word | INS |  | Input bytes or word string |
| PUSH | Push word onto stack | OUTS |  | Output bytes or word string |
| POP | Pop word off stack | CMPS |  | Compare byte or word string |
| PUSHA | Push all registers on stack | SCAS |  | Scan byte or word string |
| POPA | Pop all registers from stack | LODS |  | Load byte or word string |
| XCHG | Exchange byte or word |  |  | Load byte or word string |
| XLAT | Translate byte | STOS |  | Store byte or word string |
| INPUT/OUTPUT |  | REP |  | Repeat |
| IN | Input byte or word | REPE/REPZ |  | Repeat while equal/zero |
| OUT | Output byte or word | REPNE/REPNZ |  | Repeat while not equal/not zero |
| ADDRESS OBJECT |  | LOGICALS |  |  |
| LEA | Load effective address | NOT | "Not" byte or word |  |
| LDS | Load pointer using DS | AND | "And" byte or word |  |
| LES | Load pointer using ES | OR | "Inclusive or" byte or word |  |
| FLAG TRANSFER |  | XOR | "Exclusive or" byte or word |  |
| LAHF | Load AH register from flags | TEST | "Test" byte or word |  |
| SAHF | Store AH register in flags | SHIFTS |  |  |
| PUSHF | Push flags onto stack | SHL/SAL | Shift logical/arithmetic left byte or word |  |
|  |  | SHR | Shift logical right byte or word |  |
| POPF | Pop flags off stack | SAR |  | arithmetic right byte or word |
| ADDITION |  | ROTATES |  |  |
| ADD | Add byte or word | ROL | Rotate left byte or word |  |
| ADC | Add byte or word with carry | ROR | Rotate right byte or word |  |
| INC | Increment byte or word by 1 | RCL | Rotate through carry left byte or word |  |
| AAA | ASCII adjust for addition | RCR | Rotate through carry right byte or word |  |
| DAA | Decimal adjust for addition | FLAG OPERATIONS |  |  |
| SUBTRACTION |  | STC | Set carry flag |  |
| SUB | Subtract byte or word | CLC | Clear carry flag |  |
| SBB | Subtract byte or word with borrow | CMC | Complement carry flag |  |
| DEC | Decrement byte or word by 1 | STD | Set direction flag |  |
| NEG | Negate byte or word | CLD | Clear direction flag |  |
| CMP | Compare byte or word | STI | Set interrupt enable flag |  |
| AAS | ASCII adjust for subtraction | CLI | Clear interrupt enable flag |  |
| DAS | Decimal adjust for subtraction | EXTERNAL SYNCHRONIZATION |  |  |
| MULTIPLICATION |  | HLT | Halt until interrupt or reset |  |
| MUL | Multiply byte or word unsigned | WAIT | Wait for TEST pin active |  |
| IMUL | Integer multiply byte or word | ESC | Escape to extension processor |  |
| AAM | ASCII adjust for multiply | LOCK | Lock bus during next instruction |  |
| DIVISION |  | NO OPERATION |  |  |
| DIV | Divide byte or word unsigned | NOP | No operation |  |
| IDIV | Integer divide byte or word | HIGH LEVEL INSTRUCTIONS |  |  |
| AAD | ASCII adjust for division | ENTER | Format stack for procedure entry |  |
| CBW | Convert byte to word | LEAVE | Restore stack for procedure exit |  |
| CWD | Convert word to doubleword | BOUND | Detects values outside prescribed range |  |

Figure 4. 80188 Instruction Set

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

Figure 4. 80188 Instruction Set (Continued)

To access operands that do not reside in one of the four immediately available segments, a full 32 -bit pointer can be used to reload both the base (segment) and offset values.


Figure 5. Two Component Address
Table 3. Segment Register Selection Rules

| Memory <br> Reference <br> Needed | Segment <br> Register <br> Used | Implicit Segment <br> Selection Rule |
| :--- | :--- | :--- |
| Instructions | Code (CS) | Instruction prefetch and <br> immediate data. <br> Stack |
| Stack (SS) | All stack pushes and <br> pops; any memory <br> references which use BP |  |
| Register as a base |  |  |
| register. |  |  |
| External | Extra (ES) | All string instruction <br> references which use <br> Dhe DI register as an <br> Data <br> (Global) |
| Local Data | Data (DS) | All other data references. |



Figure 6. Segmented Memory Helps Structure Software

## Addressing Modes

The 80188 provides eight categories of addressing modes to specify operands. Two addressing modes are provided for instructions that operate on register or immediate 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: a segment base and an offset. The segment base is supplied by a 16 -bit segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset, also called the effective address, is calculated by summing any combination of the following three address elements:

- the displacement (an 8- or 16 -bit immediate value contained in the instruction);
- the base (contents of either the BX or BP base registers); and
- the index (contents of either the SI or DI index registers).

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 80188 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 an 8087 Numeric Data Coprocessor with the 80188.
- Ordinal: An unsigned binary numeric value contained in an 8 -bit byte or a 16 -bit word.
- Pointer: A 16 - or 32 -bit quantity, composed of a 16 -bit offset component or a 16 -bit segment base component in addition to a 16 -bit offset component.
- String: A contiguous sequence of bytes or words. A string may contain from 1 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 BCD: A byte (packed) representation of two decimal digits $(0-9)$. One digit is stored in each nibble (4-bits) of the byte.
- Floating Point: A signed 32-, 64-, or 80-bit real number representation. (Floating point operands are supported using an 8087 Numeric Data Coprocessor with the 80188.)

In general, individual data elements must fit within defined segment limits. Figure 7 graphically represents the data types supported by the 80188 .

## I/O Space

The I/O space consists of 64 K 8 -bit or 32 K 16 -bit ports. Separate 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 $00 \mathrm{FF}(\mathrm{H})$ are reserved

## Interrupts

An interrupt transfers execution to a new program location. The old program address (CS:IP) and machine state (Status Word) 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.


NOTE:
*Supported using an 8087 Numeric Data Coprocessor with the 80188.

Figure 7. 80188 Supported Data Types
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. If the exception was caused by executing an ESC instruction with the ESC trap bit set in the relocation register, the return instruction will point to the ESC instruction, or to the segment override prefix immediately preceding the ESC instruction if the prefix was present. In all other cases, the
return address from an exception will point at the instruction immediately following the instruction causing the exception.

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. Table 4 shows the 80188 predefined types and default priority levels. For each interrupt, an 8-bit vector must be supplied to the 80188 which identifies the appropriate table entry. Exceptions supply the interrupt vector internally. In addition, internal peripherals and noncascaded external interrupts will generate their own vectors through the internal interrupt controller. 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. Non-maskable hardware interrupts use a predefined internally supplied vector.

## Interrupt Sources

The 80188 can service interrupts generated by software or hardware. The software interrupts are generated by specific instructions (INT, ESC, unused OP , etc.) or the results of conditions specified by instructions (array bounds check, INTO, DIV, IDIV, etc.). All interrupt sources are serviced by an indirect call through an element of a vector table. This vector table is indexed by using the interrupt vector type (Table 4), multiplied by four. All hardware-generated interrupts are sampled at the end of each instruction. Thus, the software interrupts will begin service first. Once the service routine is entered and interrupts are enabled, any hardware source of sufficient priority can interrupt the service routine in progress.

Those pre-defined 80188 interrupts which cannot be masked by programming are described below.

## DIVIDE ERROR EXCEPTION (TYPE 0)

Generated when a DIV or IDIV instruction quotient cannot be expressed in the number of bits in the destination.

## SINGLE-STEP INTERRUPT (TYPE 1)

Generated after most instructions if the TF flag is set. Interrupts will not be generated after prefix instructions (e.g., REP), instructions which modify segment registers (e.g., POP DS), or the WAIT instruction.

## NON-MASKABLE INTERRUPT-NMI (TYPE 2)

An external interrupt source which cannot be masked.

Table 4. 80188 Interrupt Vectors

| Interrupt Name | Vector Type | Vector Address | Default Priority | Related Instructions | Applicable Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Divide Error Exception | 0 | OOH | 1 | DIV, IDIV | 1 |
| Single Step Interrupt | 1 | 04H | 1A | All | 2 |
| Non-Maskable Interrupt (NMI) | 2 | 08H | 1 | All |  |
| Breakpoint Interrupt | 3 | OCH | 1 | INT | 1 |
| INTO Detected <br> Overflow <br> Exception <br> A | 4 | 10H | 1 | INTO | 1 |
| Array Bounds Exception | 5 | 14H | 1 | BOUND | 1 |
| Unused Opcode Exception | 6 | 18H | 1 | Undefined Opcodes | 1 |
| ESC Opcode | 7 | 1 CH | 1 | ESC Opcodes | 1,3 |
| Timer 0 Interrupt | 8 | 2 H | 2A |  | 4,5 |
| Timer 1 Interrupt | 18 | 48H | 2B |  | 4,5 |
| Timer 2 Interrupt | 19 | 4 CH | 2 C |  | 4,5 |
| Reserved | 9 | 24H | 3 |  |  |
| DMA 0 Interrupt | 10 | 28H | 4 |  | 5 |
| DMA 1 Interrupt | 11 | 2 CH | 5 |  | 5 |
| INTO Interrupt | 12 | 30 H | 6 |  |  |
| INT1 Interrupt | 13 | 34H | 7 |  |  |
| INT2 Interrupt | 14 | 38 H | 8 |  |  |
| INT3 Interrupt | 15 | 3 CH | 9 |  |  |
| Reserved | 16, 17 | 40H, 44 H |  |  |  |
| Reserved | 20-31 | $50 \mathrm{H} \ldots . .7 \mathrm{CH}$ |  |  |  |

## NOTES:

Default priorities for the interrupt sources are used only if the user does not program each source into a unique priority level.

1. Generated as a result of an instruction execution.
2. Performed in same manner as 8088.
3. An ESC opcode will cause a trap if the power bit is set in the peripheral control block relocation register.
4. All three timers constitute one source of request to the interrupt controller. As such, they share the same priority level with respect to other interrupt sources. However, the timers have a defined priority order among themselves ( $2 A>2 B>2 C$ ). 5. The vector type numbers for these sources are programmable in Slave Mode.

## BREAKPOINT INTERRUPT (TYPE 3)

A one-byte version of the INT instruction. It uses 12 as an index into the service routine address table (because it is a type 3 interrupt).

## INTO DETECTED OVERFLOW EXCEPTION (TYPE 4)

Generated during an INTO instruction if the OF bit is set.

## ARRAY BOUNDS EXCEPTION (TYPE 5)

Generated during a BOUND instruction if the array index is outside the array bounds. The array bounds are located in memory at a location indicated by one of the instruction operands. The other operand indicates the value of the index to be checked.

## UNUSED OPCODE EXCEPTION (TYPE 6)

Generated if execution is attempted on undefined opcodes.

## ESCAPE OPCODE EXCEPTION (TYPE 7)

Generated if execution is attempted of ESC opcodes (D8H-DFH). This exception will only be generated if a bit in the relocation register is set. The return address of this exception will point to the ESC instruction causing the exception. If a segment override prefix preceded the ESC instruction, the return address will point to the segment override prefix.

Hardware-generated interrupts are divided into two groups: maskable interrupts and non-maskable interrupts. The 80188 provides maskable hardware interrupt request pins INTO-INT3. In addition, maskable interrupts may be generated by the 80188 integrated DMA controller and the integrated timer unit. The vector types for these interrupts are shown in Table 4. Software enables these inputs by setting the Interrupt Flag bit (IF) in the Status Word. The interrupt controller is discussed in the peripheral section of this data sheet.

Further maskable interrupts are disabled while servicing an interrupt because the IF bit is reset as part of the response to an interrupt or exception. The saved Status Word will reflect the enable status of the processor prior to the interrupt. The interrupt flag will remain zero unless specifically set. The interrupt return instruction restores the Status Word, thereby restoring the original status of IF bit. If the interrupt return re-enables interrupts, and another interrupt is pending, the 80188 will immediately service the highest-priority interrupt pending, i.e., no instructions of the main line program will be executed.

## Non-Maskable Interrupt Request (NMI)

A non-maskable interrupt (NMI) is also provided. This interrupt is serviced regardless of the state of the IF bit. 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. The IF bit is cleared at the beginning of an NMI interrupt to prevent maskable interrupts from being serviced.

## Single-Step Interrupt

The 80188 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 Status 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.

## Initialization and Processor Reset

Processor initialization is accomplished by driving the RES input pin LOW. $\overline{\text { RES }}$ must be LOW during power-up to ensure proper device initialization, $\overline{\text { RES }}$ forces the 80188 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as RES is active. After RES becomes inactive and an internal processing interval elapses, the 80188 begins execution with the instruction at physical location FFFFO(H). $\overline{\text { RES }}$ also sets some registers to predefined values as shown in Table 5.

Table 5. 80188 Initlal Register State after RESET

| Status Word | FOO2(H) |
| :--- | :--- |
| Instruction Pointer | $0000(\mathrm{H})$ |
| Code Segment | FFFF(H) |
| Data Segment | $0000(\mathrm{H})$ |
| Extra Segment | $0000(\mathrm{H})$ |
| Stack Segment | $0000(\mathrm{H})$ |
| Relocation Register | $20 \mathrm{FF}(\mathrm{H})$ |
| UMCS | $\mathrm{FFFB}(\mathrm{H})$ |

## THE 80188 COMPARED TO THE 80186

The 80188 CPU is an 8 -bit processor designed around the 80186 internal structure. Most internal functions of the 80188 are identical to the equivalent 80186 functions. The 80188 handles the external bus the same way the 80186 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. The differences between the 80188 and the 80186 are outlined below. Internally, there are three differences between the 80188 and the 80186 . All changes are related to the 8 -bit bus interface.

- The queue length is 4 bytes in the 80188, whereas the 80186 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 necessary to fetch instructions 8 bits at a time.
- To further optimize the queue, the prefetching algorithm was changed. The 80188 BIU will fetch a new instruction to load into the queue each time there is a 1 -byte hole (space available) in the queue. The 80186 waits until a 2-byte space is available.
- The internal execution time of the instruction is affected by the 8 -bit interface. All 16-bit fetches and writes from/to memory take an additional four clock cycles. The CPU may also be limited by the speed of instruction fetches when a series of simple operations occur. When the more sophisticated instructions of the 80188 are being used, the queue has time to fill and the execution proceeds as fast as the execution unit will allow.

The 80188 and 80186 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 well on an 80188 or an 80186.

The hardware interface of the 80188 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 80188. 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 80188 and has been eliminated.


## 80188 Clock Generator

The 80188 provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, synchronous and asynchronous ready inputs, and reset circuitry.

## Oscillator

The oscillator circuit of the 80188 is designed to be used with a parallel resonant fundamental mode crystal. This is used as the time base for the 80188. The crystal frequency selected will be double the CPU clock frequency. Use of an LC or RC circuit is not recommended with this oscillator. If an external oscillator is used, it can be connected directly to input pin X1 in lieu of a crystal. The output of the oscillator is not directly available outside the 80188. The recommended crystal configuration is shown in Figure 8.

Intel recommends the following values for crystal selection parameters.

[^9]

Figure 8. Recommended 8 MHz 80188 Crystal Configuration

## Clock Generator

The 80188 clock generator provides the $50 \%$ duty cycle processor clock for the 80188 . It does this by dividing the oscillator output by 2 forming the symmetrical clock. If an external oscillator is used, the state of the clock generator will change on the falling edge of the oscillator signal. The CLKOUT pin provides the processor clock signal for use outside the 80188. This may be used to drive other system components. All timings are referenced to the output clock.

## READY Synchronization

The 80188 provides both synchronous and asynchronous ready inputs. Asynchronous ready synchronization is accomplished by circuitry which samples ARDY in the middle of $T_{2}, T_{3}$, and again in the middle of each $T_{W}$ until ARDY is sampled HIGH. One-half CLKOUT cycle of resolution time is used for full synchronization of a rising ARDY signal. A high-to-low transition on ARDY may be used as an indication of the not ready condition but it must be performed synchronously to CLKOUT either in the middle of $T_{2}, T_{3}$, or $T_{W}$, or at the falling edge of $T_{3}$ or $T_{W}$.

A second ready input (SRDY) is provided to interface with externally synchronized ready signals. This input is sampled at the end of $T_{2}, T_{3}$, and again at the end of each $T_{W}$ until it is sampled HIGH. By using this input rather than the asynchronous ready input, the half-clock cycle resolution time penalty is eliminated.

This input must satisfy set-up and hold times to guarantee proper operation of the circuit.

In addition, the 80188, as part of the integrated chipselect logic, has the capability to program WAIT states for memory and peripheral blocks. This is discussed in the Chip Select/Ready Logic description.

## RESET Logic

The 80188 provides both a $\overline{\text { RES }}$ input pin and a synchronized RESET output pin for use with other system components. The RES input pin on the 80188 is provided with hysteresis in order to facilitate poweron Reset generation via an RC network. RESET output is guaranteed to remain active for at least five clocks given a RES input of at least six clocks. RESET may be delayed up to approximately two and one-half clocks behind RES.

Multiple 80188 processors may be synchronized through the RES input pin, since this input resets both the processor and divide-by-two internal counter in the clock generator. In order to ensure that the divide-by-two counters all begin counting at the same time, the active going edge of RES must satisfy a 25 ns setup time before the falling edge of the 80188 clock input. In addition, in order to ensure that all CPUs begin executing in the same clock cycle, the reset must satisfy a 25 ns setup time before the rising edge of the CLKOUT signal of all the processors.

## LOCAL BUS CONTROLLER

The 80188 provides a local bus controller to generate the local bus control signals. In addition, it employs a HOLD/HLDA protocol for relinquishing the local bus to other bus masters. It also provides outputs that can be used to enable external buffers and to direct the flow of data on and off the local bus.

## Memory/Peripheral Control

The 80188 provides ALE, $\overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ bus control signals. The $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ signals are used to strobe data from memory or I/O to the 80188 or to strobe data from the 80188 to memory or I/O. The ALE line provides a strobe to latch the address when it is valid. The 80188 local bus controller does not provide a memory///O signal. If this is required, use the $\overline{\mathrm{S} 2}$ signal (which will require external latching), make the memory and I/O spaces nonoverlapping, or use only the integrated chip-select circuitry.

## Transceiver Control

The 80188 generates two control signals for external transceiver chips. This capability allows the addition of transceivers for extra buffering without adding
external logic. These control lines, DT/信 and $\overline{\mathrm{DEN}}$, are generated to control the flow of data through the transceivers. The operation of these signals is shown in Table 6.

Table 6. Transceiver Control Signals Description

| Pin Name | Function |
| :--- | :--- |
| $\overline{\text { DEN (Data Enable) }}$Enables the output <br> DT/ $\bar{R}$ (Data Transmit/ <br> drivers of the <br> transceivers. It is active <br> Lew during memory, <br> Leceive)I/O, or INTA cycles. <br> Determines the direction <br> of travel through the <br> transceivers. A HIGH <br> level directs data away <br> from the processor <br> during write operations, <br> while a LOW level directs <br> data toward the <br> processor during a read <br> operation. |  |

## Local Bus Arbitration

The 80188 uses a HOLD/HLDA system of local bus exchange. This provides an asynchronous bus exchange mechanism. This means multiple masters utilizing the same bus can operate at separate clock frequencies. The 80188 provides a single HOLD/ HLDA pair through which all other bus masters may gain control of the local bus. External circuitry must arbitrate which external device will gain control of the bus when there is more than one alternate local bus master. When the 80188 relinquishes control of the local bus, it floats $\overline{\mathrm{DEN}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{SO}}-\overline{\mathrm{S} 2}, \overline{L O C K}$, ADO-AD7, A8-A19, $\overline{\mathrm{S}}$, and $\mathrm{DT} / \overline{\mathrm{R}}$ to allow another master to drive these lines directly.

The 80188 HOLD latency time, i.e., the time between HOLD request and HOLD acknowledge, is a function of the activity occurring in the processor when the HOLD request is received. A HOLD request is the highest-priority activity request which the processor may receive: higher than instruction fetching or internal DMA cycles. However, if a DMA cycle is in progress, the 80188 will complete the transfer before relinquishing the bus. This implies that if a HOLD request is received just as a DMA transfer begins, the HOLD latency time can be as great as 4 bus cycles. This will occur if a DMA word transfer operation is taking place from an odd address to an odd address. This is a total of 16 clocks or more, if WAIT states are required. In addition, if locked transfers are performed, the HOLD latency time will be increased by the length of the locked transfer.

## Local Bus Controller and Reset

During RESET the local bus controller will perform the following actions:

- Drive $\overline{\mathrm{DEN}}, \overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ HIGH for one clock cycle, then float.

NOTE:
$\overline{R D}$ is also provided with an internal puli-up device to prevent the processor from inadvertently entering Queue Status Mode during RESET.

- Drive $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ to the inactive state (all HIGH) and then float.
- Drive $\overline{L O C K}$ HIGH and then float.
- Three-state ADO-7, A8-19, S7, DT/作.
- Drive ALE LOW (ALE is never floated).
- Drive HLDA LOW.


## INTERNAL PERIPHERAL INTERFACE

All the 80188 integrated peripherals are controlled by 16 -bit registers contained within an internal 256byte control block. The control block may be mapped into either memory or I/O space. Internal logic will recognize control block addresses and respond to bus cycles. During bus cycles to internal registers, the bus controller will signal the operation externally (i.e., the $\overline{R D}, \overline{W R}$, status, address, data, etc., lines will be driven as in a normal bus cycle), but $\mathrm{D}_{7-0}$, SRDY, and ARDY will be ignored. The base address of the control block must be on an even 256-byte boundary (i.e., the lower 8 bits of the base address are all zeros). All of the defined registers within this control block may be read or written by the 80188 CPU at any time

The control block base address is programmed by a 16-bit relocation register contained within the control block at offset FEH from the base address of the control block (see Figure 9). It provides the upper 12 bits of the base address of the control block. Note that mapping the control register block into an address range corresponding to a chip-select range is not recommended (the chip select circuitry is discussed later in this data sheet. In addition, bit 12 of this register determines whether the control block will be mapped into I/O or memory space. If this bit is 1 , the control block will be located in memory space. If the bit is 0 , the control block will be located in I/O space. If the control register block is mapped into I/O space, the upper 4 bits of the base address must be programmed as 0 (since I/O addresses are only 16 bits wide).

Whenever mapping the 188 peripheral control block to another location, the programming of the relocation register should be done with a byte write (i.e. OUT DX,AL). Any access to the control block is done 16 bits at a time. Thus, internally, the relocation register will get written with 16 bits of the AX register while externally, the BIU will run only one 8 -bit bus cycle. If a word instruction is used (i.e. OUT $D X, A X)$, the relocation register will be written on the first bus cycle. The Bus Interface Unit (BIU) will then run a second bus cycle which is unnecessary. The address of the second bus cycle will no longer be within the control block (i.e. the control block was moved on the first cycle), and therefore, will require the generation of an external ready signal to complete the cycle. For this reason we recommend byte operations to the relocation register. Byte instructions may also be used for the other registers in the control block and will eliminate half of the bus cycles required if a word operation had been specified. Byte operations are only valid on even addresses though, and are undefined on odd addresses.

In addition to providing relocation information for the control block, the relocation register contains bits which place the interrupt controller into Slave Mode, and cause the CPU to interrupt upon encountering ESC instructions. At RESET, the relocation register is set to 20FFH which maps the control block to start at FFOOH in I/O space. An offset map of the 256 -byte control register block is shown in Figure 10.

## CHIP-SELECT/READY GENERATION LOGIC

The 80188 contains logic which provides programmable chip-select generation for both memories and peripherals. In addition, it can be programmed to provide READY (or WAIT state) generation. It can also provide latched address bits A1 and A2. The chip-select lines are active for all memory and I/O cycles in their programmed areas, whether they be generated by the CPU or by the integrated DMA unit.

## Memory Chip Selects

The 80188 provides 6 memory chip select outputs for 3 address areas: upper memory, lower memory, and midrange memory. One each is provided for upper memory and lower memory, while four are provided for midrange memory.

The range for each chip select is user-programmable and can be set to $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}, 16 \mathrm{~K}, 32 \mathrm{~K}, 64 \mathrm{~K}$, 128 K (plus 1 K and 256 K for upper and lower chip selects). In addition, the beginning or base address


Figure 9. Relocation Register

|  | OFFSET |
| :---: | :---: |
| Relocation Register | FEH |
|  | DAH |
|  | DOH |
| DMA Descriptors Channel 0 | CAH |
|  | COH |
| Chip-Select Control Registers |  |
|  | AOH |
| Timer 2 Control Registers | 66H |
|  | 60H |
| Timer 1 Control Registers | 5EH |
|  | 58 H |
| Timer 0 Control Registers | 56 H |
|  | 50 H |
| Interrupt Controller Registers |  |
|  | 20 H |

Figure 10. Internal Register Map
of the midrange memory chip select may also be selected. Only one chip select may be programmed to be active for any memory location at a time. All chip select sizes are in bytes.

## Upper Memory $\overline{\text { CS }}$

The 80188 provides a chip select, called UCS, for the top of memory. The top of memory is usually used as the system memory because after reset the 80188 begins executing at memory location FFFFOH.

The upper limit of memory defined by this chip select is always FFFFFH, while the lower limit is programmable. By programming the lower limit, the size of the select block is also defined. Table 7 shows the relationship between the base address selected and the size of the memory block obtained.

Table 7. UMCS Programming Values

| Starting <br> Address <br> (Base <br> Address) | Memory <br> Block <br> Size | UMCs Value <br> (Assuming <br> R0= $=\mathbf{R 1}=\mathbf{R 2}=\mathbf{0})$ |
| :---: | :---: | :---: |
| FFC00 | 1 K | FFF8H |
| FF800 | 2 K | FFB8H |
| FF000 | 4 K | FF38H |
| FE000 | 8 K | FE38H |
| FC000 | 16 K | FC38H |
| F8000 | 32 K | F838H |
| F0000 | 64 K | F038H |
| E0000 | 128 K | E038H |
| C0000 | 256 K | C038H |

The lower limit of this memory block is defined in the UMCS register (see Figure 11). This register is at offset $A O H$ in the internal control block. The legal values for bits 6-13 and the resulting starting address and memory block sizes are given in Table 7. Any combination of bits 6-13 not shown in Table 7 will result in undefined operation. After reset, the UMCS register is programmed for a 1 K area. It must be reprogrammed if a larger upper memory area is desired.

The internal generation of any 20-bit address whose upper 16 bits are equal to or greater than the UMCS value (with bits $0-5$ as " 0 ") asserts UCS. UMCS bits R2-R0 specify the ready mode for the area of memory defined by the chip select register, as explained later.

## Lower Memory $\overline{\mathbf{C S}}$

The 80188 provides a chip select for low memory called $\overline{\text { LCS. }}$. The bottom of memory contains the interrupt vector table, starting at location 00000 H .

The lower limit of memory defined by this chip select is always OH , while the upper limit is programmable. By programming the upper limit, the size of the memory block is defined. Table 8 shows the relationship between the upper address selected and the size of the memory block obtained.

Table 8. LMCS Programming Values

| Upper <br> Address | Memory <br> Block <br> Size | LMCS Value <br> (Assuming <br> $\mathbf{R 0}=\mathbf{R 1}=\mathbf{R 2}=\mathbf{0})$ |
| :---: | :---: | :---: |
| $003 F F H$ | 1 K | 0038 H |
| $007 F F H$ | 2 K | 0078 H |
| 00FFFH | 4 K | 00 F 8 H |
| $01 F F F H$ | 8 K | 0178 H |
| 03FFFH | 16 K | $03 F 8 \mathrm{H}$ |
| 07FFFH | 32 K | 07 F 8 H |
| OFFFFH | 64 K | 0FF8H |
| 1FFFFH | 128 K | 1FF8H |
| 3FFFFH | 256 K | 3FF8H |

The upper limit of this memory block is defined in the LMCS register (see Figure 12) at offset A2H in the internal control block. The legal values for bits 6-15 and the resulting upper address and memory block sizes are given in Table 8. Any combination of bits 6-15 not shown in Table 8 will result in undefined operation. After RESET, the LMCS register value is undefined. However, the LCS chip-select line will not become active until the LMCS register is accessed.

Any internally generated 20 -bit address whose upper 16 bits are less than or equal to LMCS (with bits 0-5 " 1 ") will assert $\overline{\text { LCS. LMCS register bits R2-R0 }}$ specify the READY mode for the area of memory defined by this chip-select register.

## Mid-Range Memory $\overline{\text { CS }}$

The 80188 provides four $\overline{M C S}$ lines which are active within a user-locatable memory block. This block can be located within the 80188 1M byte memory address space exclusive of the areas defined by $\overline{U C S}$ and LCS. Both the base address and size of this memory block are programmable.

The size of the memory block defined by the midrange select lines, as shown in Table 9, is determined by bits 8-14 of the MPCS register (see Figure 13). This register is at location A8H in the internal control block. One and only one of bits 8-14 must be set at a time. Unpredictable operation of the MCS lines will otherwise occur. Each of the four chip-select lines is active for one of the four equal contiguous divisions of the mid-range block. If the total block size is 32 K , each chip select is active for 8 K of memory with MCSO being active for the first range and $\overline{M C S 3}$ being active for the last range.

The EX and MS in MPCS relate to peripheral functionality as described in a later section.

Table 9. MPCS Programming Values

| Total Block <br> Size | Individual <br> Select Size | MPCS Bits <br> $14-8$ |
| :---: | :---: | :---: |
| 8 K | 2 K | 0000001 B |
| 16 K | 4 K | 0000010 B |
| 32 K | 8 K | 0000100 B |
| 64 K | 16 K | 0001000 B |
| 128 K | 32 K | 0010000 B |
| 256 K | 64 K | 0100000 B |
| 512 K | 128 K | 1000000 B |

The base address of the mid-range memory block is defined by bits 15-9 of the MMCS register (see Figure 14). This register is at offset A6H in the internal control block. These bits correspond to bits A19-A13 of the 20 -bit memory address. Bits A12-A0 of the base address are always 0 . The base address may be set at any integer multiple of the size of the total memory block selected. For example, if the mid-range block size is 32 K (or the size of the block for which each MCS line is active is 8 K ), the block could be located at 10000 H or 18000 H , but not at 14000 H , since the first few integer multiples of a 32 K memory block are $\mathrm{OH}, 8000 \mathrm{H}$, $10000 \mathrm{H}, 18000 \mathrm{H}$, etc. After RESET, the contents of both of these registers are undefined. However, none of the MCS lines will be active until both the MMCS and MPCS registers are accessed.

| OFFSET: AOH | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 | 1 | U | U | U | U | U | U | U | U | 1 | 1 | 1 | R2 | R1 | R0 |
|  | A19 |  |  |  |  |  |  |  |  | A10 |  |  |  |  |  |  |

Figure 11. UMCS Register

|  |  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OFFSET: | A2H | 0 | 0 | U | U | U | U | U | U | U | U | 1 | 1 | 1 | R2 | R1 | R0 |
| A19 : A10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 12. LMCS Register

OFFSET: A8H

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | M6 | M5 | M4 | M3 | M2 | M1 | M0 | EX | MS | 1 | 1 | 1 | R2 | R1 | R0 |

Figure 13. MPCS Register

OFFSET: A6H


Figure 14. MMCS Register

MMCS bits R2-RO specify READY mode of operation for all four mid-range chip selects.

The 512 K block size for the mid-range memory chip selects is a special case. When using 512 K , the base address would have to be at either locations 00000 H or 80000 H . If it were to be programmed at 00000 H when the LCS line was programmed, there would be an internal conflict between the LCS ready generation logic and the MCS ready generation logic. Likewise, if the base address were programmed at 80000 H , there would be a conflict with the UCS ready generation logic. Since the LCS chip-select line does not become active until programmed, while the UCS line is active at reset, the memory base can be set only at 00000 H . If this base address is selected, however, the LCS range must not be programmed.

## Peripheral Chip Selects

The 80188 can generate chip selects for up to seven peripheral devices. These chip selects are active for seven contiguous blocks of 128 bytes above a programmable base address. The base address may be located in either memory or I/O space.

Seven $\overline{\mathrm{CS}}$ lines called $\overline{\mathrm{PCSO}}-6$ are generated by the 80188. The base address is user-programmable;
however it can only be a multiple of 1 K bytes, i.e., the least significant 10 bits of the starting address are always 0 .
$\overline{\text { PCS5 }}$ and $\overline{\text { PCS6 }}$ can also be programmed to provide latched address bits A1 and A2. If so programmed, they cannot be used as peripheral selects. These outputs can be connected directly to the A0 and A1 pins used for selecting internal registers of 8 -bit peripheral chips.

The starting address of the peripheral chip-select block is defined by the PACS register (see Figure 15). The register is located at offset A 4 H in the internal control block. Bits 15-6 of this register correspond to bits $19-10$ of the 20 -bit Programmable Base Address (PBA) of the peripheral chip-select block. Bits 9-0 of the PBA of the peripheral chip-select block are all zeros. If the chip-select block is located in I/O space, bits 12-15 must be programmed zero, since the I/O address is only 16 bits wide. Table 10 shows the address range of each peripheral chip select with respect to the PBA contained in PACS register.


Figure 15. PACS Register

The user should program bits 15-6 to correspond to the desired peripheral base location. PACS bits 0-2 are used to specify READY mode for $\overline{\text { PCSO }}-\overline{\mathrm{PCS3}}$.

Table 10. PCS Address Ranges

| $\overline{\text { PCS }}$ Line | Active between Locations |
| :--- | :--- |
| $\overline{\text { PCS0 }}$ | PBA $-\mathrm{PBA}+127$ |
| $\overline{\text { PCS1 }}$ | PBA $+128-\mathrm{PBA}+255$ |
| $\overline{\text { PCS2 }}$ | PBA $+256-\mathrm{PBA}+383$ |
| $\overline{\text { PCS3 }}$ | PBA $+384-\mathrm{PBA}+511$ |
| $\overline{\text { PCS4 }}$ | PBA $+512-\mathrm{PBA}+639$ |
| $\overline{\text { PCS5 }}$ | PBA $+640-\mathrm{PBA}+767$ |
| $\overline{\text { PCS6 }}$ | PBA $+768-\mathrm{PBA}+895$ |

The mode of operation of the peripheral chip selects is defined by the MPCS register (which is also used to set the size of the mid-range memory chip-select block, see Figure 13). The register is located at offset A8H in the internal control block. Bit 7 is used to select the function of PCS5 and PCS6, while bit 6 is used to select whether the peripheral chip selects are mapped into memory or I/O space. Table 11 describes the programming of these bits. After RESET, the contents of both the MPCS and the PACS registers are undefined, however none of the PCS lines will be active until both of the MPCS and PACS registers are accessed.

Table 11. MS, EX Programming Values

| Bit | Description |
| :--- | :--- |
| MS | $1=$ Peripherals mapped into memory space. |
|  | $0=$ Peripherals mapped into I/O space. |
| EX | $0=5 \overline{\text { PCS }}$ lines. A1, A2 provided. |
|  | $1=7 \overline{\text { PCS lines. A1, A2 are not provided. }}$ |

MPCS bits 0-2 specify the READY mode for $\overline{\text { PCS4 }}-$ $\overline{\text { PCS6 }}$ as outlined below.

## READY Generation Logic

The 80188 can generate a READY signal internally for each of the memory or peripheral CS lines. The number of WAIT states to be inserted for each peripheral or memory is programmable to provide $0-3$ wait states for all accesses to the area for which the chip select is active. In addition, the 80188 may be programmed to either ignore external READY for each chip-select range individually or to factor external READY with the integrated ready generator.

READY control consists of 3 bits for each $\overline{\mathrm{CS}}$ line or group of lines generated by the 80188. The interpretation of the READY bits is shown in Table 12.

Table 12. READY Bits Programming

| R2 | R1 | R0 | Number of WAIT States Generated |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | o wait states, external RDY <br> also used. <br> 0 |
| 0 | 1 | 1 wait state inserted, external RDY <br> a |  |
| 0 | 1 | 0 | also used. <br> 2 wait states inserted, external RDY <br> also used. <br> 0 |
| 1 | 1 | 3 wait states inserted, external RDY <br> also used. |  |
| 1 | 0 | 0 | 0 wait states, external RDY <br> ignored. |
| 1 | 0 | 1 | 1 wait state inserted, external RDY <br> ignored. <br> 2 |
| 1 | 1 | 0 | 2 wait states inserted, external RDY <br> ignored. |
| 1 | 1 | 1 | 3 wait states inserted, external RDY <br> ignored. |

The internal READY generator operates in parallel with external READY, not in series if the external READY is used $\left(\mathrm{R}_{2}=0\right)$. For example, if the internal generator is set to insert two wait states, but activity on the external READY lines will insert four wait states, the processor will only insert four wait states, not six. This is because the two wait states generated by the internal generator overlapped the first two wait states generated by the external ready signal. Note that the external ARDY and SRDY lines are always ignored during cycles accessing internal peripherals.

R2-R0 of each control word specifies the READY mode for the corresponding block, with the exception of the peripheral chip selects: R2-RO of PACS set the $\overline{\text { PCSO }}-3$ READY mode, R2-RO of MPCS set the $\overline{\text { PCS4-6 READY mode. }}$

## Chip Select/Ready Logic and Reset

Upon RESET, the Chip-Select/Ready Logic will perform the following actions:

- All chip-select outputs will be driven HIGH.
- Upon leaving RESET, the UCS line will be programmed to provide chip selects to a 1 K block with the accompanying READY control bits set at 011 to insert 3 wait states in conjunction with external READY (i.e., UMCS resets to FFFBH).
- No other chip select or READY control registers have any predefined values after RESET. They will not become active until the CPU accesses their control registers. Both the PACS and MPCS registers must be accessed before the $\overline{\mathrm{PCS}}$ lines will become active.


## DMA Channels

The 80188 DMA controller provides two independent DMA channels. Data transfers can occur between memory and I/O spaces (e.g., Memory to I/O) or within the same space (e.g., Memory to Memory or I/O to I/O). Each DMA channel maintains both a 20-bit source and destination pointer which can be optionally incremented or decremented after each data transfer. Each data transfer consumes 2 bus cycles (a minimum of 8 clocks), one cycle to fetch data and the other to store data. This provides a data transfer rate of one MByte/sec at 8 MHz .

## DMA Operation

Each channel has six registers in the control block which define each channel's operation. The control registers consist of a 20 -bit Source pointer ( 2 words), a 20 -bit Destination pointer ( 2 words), a 16bit Transfer Count Register, and a 16-bit Control Word.

The format of the DMA Control Blocks is shown in Table 13. The Transfer Count Register (TC) specifies the number of DMA transfers to be performed. Up to 64 K byte transfers can be performed with automatic termination. The Control Word defines the channel's operation (see Figure 17). All registers may be modified or altered during any DMA activity. Any changes made to these registers will be reflected immediately in DMA operation.

Table 13. DMA Control Block Format

| Register Name | Register Address |  |
| :--- | :---: | :---: |
|  | Ch. 0 | Ch. 1 |
| Control Word | CAH | DAH |
| Transfer Count | $\mathrm{C8H}$ | D8H |
| Destination Pointer (upper 4 | C 6 H | D6H |
| bits) |  |  |
| Destination Pointer | C 4 H | D4H |
| Source Pointer (upper 4 bits) | C 2 H | D2H |
| Source Pointer | COH | DOH |



Figure 16. DMA Unit Block Diagram


Figure 17. DMA Control Register

## DMA Channel Control Word Register

Each DMA Channel Control Word determines the mode of operation for the particular 80188 DMA channel. This register specifies:

- the mode of synchronization;
- whether interrupts will be generated after the last transfer;
- whether DMA activity will cease after a programmed number of DMA cycles;
- the relative priority of the DMA channel with respect to the other DMA channel;
- whether the source pointer will be incremented, decremented, or maintained constant after each transfer;
- whether the source pointer addresses memory or I/O space;
- whether the destination pointer will be incremented, decremented, or maintained constant after each transfer; and
- whether the destination pointer will address memory or I/O space.

The DMA channel control registers may be changed while the channel is operating. However, any changes made during operation will affect the current DMA transfer.

## DMA Control Word Bit Descriptions

DEST: $\quad \mathrm{M} / \overline{\mathrm{IO}}$ Destination pointer is in memory (1) or I/O (0) space.
DEC Decrement destination pointer by 1 after each transfer.
INC Increment destination pointer by 1 after each transfer. If both INC and DEC are specified, the pointer will not be changed after each cycle.
SOURCE: $\quad \mathrm{M} / \overline{\mathrm{IO}}$ Source pointer is in memory (1) or I/O (0) space.

DEC Decrement source pointer by 1 after each transfer.
INC Increment source pointer by 1 after each transfer. If both INC and DEC are specified, the pointer will not be changed after each cycle.

TC:

INT:
SYN:

P:

TDRQ: Enable/Disable (1/0) DMA requests from Timer 2.
CHG/NOCHG: Change/Do Not Change (1/0) the ST/STOP bit. If this bit is set when writing the control word, the ST/STOP bit will be programmed by the write to the control word. If this bit is cleared when writing the control word, the ST/STOP bit will not be altered. This bit is not stored; it will always be read as 0 .
ST/STOP: Start/Stop (1/0) Channel.

## DMA Destination and Source Pointer Registers

Each DMA channel maintains a 20-bit source and a 20-bit destination pointer. Each of these pointers takes up two full 16-bit registers in the peripheral control block. The lower four bits of the upper register contain the upper four bits of the 20-bit physical address (see Figure 18). These pointers may be individually incremented or decremented after each transfer. Each pointer may point into either memory or I/O space. Since the DMA channels can perform transfers to or from odd addresses, there is no restriction on values for the pointer registers.

## DMA Transfer Count Register

Each DMA channel maintains a 16-bit transfer count register (TC). The register is decremented after every DMA cycle, regardless of the state of the TC bit in the DMA Control Register. If the TC bit in the DMA control word is set or if unsynchronized transfers are programmed, DMA activity will terminate when the transfer count register reaches zero.

## DMA Requests

Data transfers may be either source or destination synchronized, that is either the source of the data or the destination of the data may request the data transfer. In addition, DMA transfers may be unsyn-
chronized; that is, the transfer will take place continually until the correct number of transfers has occurred. When source or unsynchronized transfers are performed, the DMA channel may begin another transfer immediately after the end of a previous DMA transfer. This allows a complete transfer to take place every 2 bus cycles or eight clock cycles (assuming no wait states). When destination synchronized transfers are performed, data will not be fetched from the source address until the destination device signals that it is ready to receive it. Also, the DMA controller will relinquish control of the bus after every transfer. If no other bus activity is initiated, another destination synchronized DMA cycle will begin after two processor clocks. This allows the destination device time to remove its request if another transfer is not desired. Since the DMA controller will relinquish the bus, the CPU can initiate a bus cycle. As a result, a complete bus cycle will often be inserted between destination synchronized transfers. Table 14 shows the maximum DMA transfer rates.

Table 14. Maximum DMA Transfer
Rates @ CLKOUT = $8 \mathbf{M H z}$

| Type of <br> Synchronization <br> Selected | CPU Running | CPU Halted |
| :--- | :---: | :---: |
| Unsynchronized <br> Source Synch <br> Destination Synch | $1.0 \mathrm{MBytes} / \mathrm{sec}$ <br> $1.0 \mathrm{MBytes} / \mathrm{sec}$ | $1.0 \mathrm{MBytes} / \mathrm{sec}$ <br> $1.0 \mathrm{MBytes} / \mathrm{sec}$ |



Figure 18. DMA Pointer Register Format

## DMA Acknowledge

No explicit DMA acknowledge pulse is provided. Since both source and destination pointers are maintained, a read from a requesting source, or a write to a requesting destination, should be used as the DMA acknowledge signal. Since the chip-select lines can be programmed to be active for a given block of memory or I/O space, and the DMA pointers can be programmed to point to the same given block, a chip-select line could be used to indicate a DMA acknowledge.

## DMA Priority

The DMA channels may be programmed to give one channel priority over the other, or they may be programmed to alternate cycles when both have DMA requests pending. DMA cycles always have priority over internal CPU cycles except between locked memory accesses or word accesses to odd memory locations; also, an external bus hold takes priority over an internal DMA cycle. Because an interrupt request cannot suspend a DMA operation and the CPU cannot access memory during a DMA cycle, interrupt latency time will suffer during sequences of continuous DMA cycles. An NMI request, however, will cause all internal DMA activity to halt. This allows the CPU to quickly respond to the NMI request.

## DMA Programming

DMA cycles will occur whenever the ST/STOP bit of the Control Register is set. If synchronized transfers
are programmed, a DRQ must also be generated. Therefore, the source and destination transfer pointers, and the transfer count register (if used) must be programmed before the ST/STOP bit is set.

Each DMA register may be modified while the channel is operating. If the CHG/ $\overline{\mathrm{NOCHG}}$ bit is cleared when the control register is written, the ST/STOP bit of the control register will not be modified by the write. If multiple channel registers are modified, it is recommended that a LOCKED string transfer be used to prevent a DMA transfer from occurring between updates to the channel registers.

## DMA Channels and Reset

Upon RESET, the DMA channels will perform the following actions:

- The ST/ $\overline{S T O P}$ bit for each channel will be reset to STOP.
- Any transfer in progress is aborted.


## TIMERS

The 80188 provides three internal 16-bit programmable timers (see Figure 19). Two of these are highly flexible and are connected to four external pins (2 per timer). They can be used to count external events, time external events, generate nonrepetitive waveforms, etc. The third timer is not connected to any external pins, and is useful for real-time coding and time delay applications. In addition, the third timer can be used as a prescaler to the other two, or as a DMA request source.


Figure 19. Timer Block Diagram

## Timer Operation

The timers are controlled by 11 16-bit registers in the peripheral control block. The configuration of these registers is shown in Table 15. The count register contains the current value of the timer. It can be read or written at any time independent of whether the timer is running or not. The value of this register will be incremented for each timer event. Each of the timers is equipped with a MAX COUNT register, which defines the maximum count the timer will reach. After reaching the MAX COUNT register value, the timer count value will reset to zero during that same clock, i.e., the maximum count value is never stored in the count register itself. Timers 0 and 1 are, in addition, equipped with a second MAX COUNT register, which enables the timers to alternate their count between two different MAX COUNT values. If a single MAX COUNT register is used, the timer output pin will switch LOW for a single clock, 2 clocks after the maximum count value has been reached. In the dual MAX COUNT register mode, the output pin will indicate which MAX COUNT register is currently in use, thus allowing nearly complete freedom in selecting waveform duty cycles. For the timers with two MAX COUNT registers, the RIU bit in the control register determines which is used for the comparison.

Each timer gets serviced every fourth CPU-clock cycle, and thus can operate at speeds up to one-quarter the internal clock frequency (one-eighth the crystal rate). External clocking of the timers may be done at up to a rate of one-quarter of the internal CPUclock rate ( 2 MHz for an 8 MHz CPU clock). Due to internal synchronization and pipelining of the timer circuitry, a timer output may take up to 6 clocks to respond to any individual clock or gate input.

Since the count registers and the maximum count registers are all 16 bits wide, 16 bits of resolution are provided. Any Read or Write access to the timers will add one wait state to the minimum four-clock bus cycle, however. This is needed to synchronize and coordinate the internal data flows between the internal timers and the internal bus.

The timers have several programmable options.

- All three timers can be set to halt or continue on a terminal count.
- Timers 0 and 1 can select between internal and external clocks, alternate between MAX COUNT registers and be set to retrigger on external events.
- The timers may be programmed to cause an interrupt on terminal count.

These options are selectable via the timer mode/ control word.

## Timer Mode/Control Register

The mode/control register (see Figure 20) allows the user to program the specific mode of operation or check the current programmed status for any of the three integrated timers.

Table 15. Timer Control Block Format

| Register Name | Register Offset |  |  |
| :--- | :---: | :---: | :---: |
|  | Tmr. 0 | Tmr. 1 | Tmr. 2 |
| Mode/Control Word | 56 H | 5 EH | 66 H |
| Max Count B | 54 H | 5 CH |  |
| not present | $\mathbf{2 4}$ |  |  |
| Max Count A |  | 5 AH | 62 H |
| Count Register | 50 H | 58 H | 60 H |


| 15 | 14 | 13 | $\mathbf{1 2}$ | $\mathbf{1 1}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | 1 | 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EN | $\overline{\text { NH }}$ | INT | RIU | 0 | $\bullet \bullet$ | MC | RTG | P | EXT | ALT | CONT |

Figure 20. Timer Mode/Control Register

## EN

The enable bit provides programmer control over the timer's RUN/HALT status. When set, the timer is enabled to increment subject to the input pin constraints in the internal clock mode (discussed previously). When cleared, the timer will be inhibited from counting. All input pin transitions during the time EN is zero will be ignored. If CONT is zero, the EN bit is automatically cleared upon maximum count.

## $\overline{\text { INH }}$

The inhibit bit allows for selective updating of the enable (EN) bit. If $\overline{\mathrm{NH}}$ is a one during the write to the mode/control word, then the state of the EN bit will be modified by the write. If $\overline{\mathrm{NH}}$ is a zero during the wite, the EN bit will be unaffected by the operation. This bit is not stored; it will always be a 0 on a read.

## INT

When set, the INT bit enables interrupts from the timer, which will be generated on every terminal count. If the timer is configured in dual MAX COUNT register mode, an interrupt will be generated each time the value in MAX COUNT register $A$ is reached, and each time the value in MAX COUNT register $B$ is reached. If this enable bit is cleared after the interrupt request has been generated, but before a pending interrupt is serviced, the interrupt request will still be in force. (The request is latched in the Interrupt Controller.)

## RIU

The Register In Use bit indicates which MAX COUNT register is currently being used for comparison to the timer count value. A zero value indicates register A. The RIU bit cannot be written, i.e., its value is not affected when the control register is written. It is always cleared when the ALT bit is zero.

## MC

The Maximum Count bit is set whenever the timer reaches its final maximum count value. If the timer is configured in dual MAX COUNT register mode, this bit will be set each time the value in MAX COUNT register $A$ is reached, and each time the value in MAX COUNT register $B$ is reached. This bit is set regardless of the timer's interrupt-enable bit. The MC bit gives the user the ability to monitor timer status through software instead of through interrupts. Programmer intervention is required to clear this bit.

## RTG

Retrigger bit is only active for internal clocking (EXT $=0$ ). In this case it determines the control function provided by the input pin.

If RTG $=0$, the input level gates the internal clock on and off. If the input pin is HIGH, the timer will count; if the input pin is LOW, the timer will hold its value. As indicated previously, the input signal may be asynchronous with respect to the 80188 clock.

When RTG $=1$, the input pin detects LOW-to-HIGH transitions. The first such transition starts the timer running, clearing the timer value to zero on the first clock, and then incrementing thereafter. Further transitions on the input pin will again reset the timer to zero, from which it will start counting up again. If CONT $=0$, when the timer has reached maximum count, the EN bit will be cleared, inhibiting further timer activity.

## P

The prescaler bit is ignored unless internal clocking has been selected (EXT $=0$ ). If the $P$ bit is a zero, the timer will count at one-fourth the internal CPU clock rate. If the P bit is a one, the output of timer 2 will be used as a clock for the timer. Note that the user must initialize and start timer 2 to obtain the prescaled clock.

## EXT

The external bit selects between internal and external clocking for the timer. The external signal may be asynchronous with respect to the 80188 clock. If this bit is set, the timer will count LOW-to-HIGH transitions on the input pin. If cleared, it will count an internal clock while using the input pin for control. In this mode, the function of the external pin is defined by the RTG bit. The maximum input to output transition latency time may be as much as 6 clocks. However, clock inputs may be pipelined as closely together as every 4 clocks without losing clock pulses.

## ALT

The ALT bit determines which of two MAX COUNT registers is used for count comparison. If ALT $=0$, register $A$ for that timer is always used, while if ALT $=1$, the comparison will alternate between register $A$ and register $B$ when each maximum count is reached. This alternation allows the user to change one MAX COUNT register while the other is being used, and thus provides a method of generating non-repetitive waveforms. Square waves and pulse outputs of any duty cycle are a subset of available signals obtained by not changing the final count registers. The ALT bit also determines the function of
the timer output pin. If ALT is zero, the output pin will go LOW for one clock, the clock after the maximum count is reached. If ALT is one, the output pin will reflect the current MAX COUNT register being used ( $0 / 1$ for B/A).

## CONT

Setting the CONT bit causes the associated timer to run continuously, while resetting it causes the timer to halt upon maximum count. If CONT $=0$ and ALT $=1$, the timer will count to the MAX COUNT register $A$ value, reset, count to the register $B$ value, reset, and halt.

Not all mode bits are provided for timer 2. Certain bits are hardwired as indicated below:

$$
\mathrm{ALT}=0, \mathrm{EXT}=0, \mathrm{P}=0, \mathrm{RTG}=0, \mathrm{RIU}=0
$$

## Count Registers

Each of the three timers has a 16-bit count register. The contents of this register may be read or written by the processor at any time. If the register is written while the timer is counting, the new value will take effect in the current count cycle.

## Max Count Registers

Timers 0 and 1 have two MAX COUNT registers, while timer 2 has a single MAX COUNT register. These contain the number of events the timer will count. In timers 0 and 1, the MAX COUNT register used can alternate between the two max count values whenever the current maximum count is reached. A timer resets when the timer count register equals the max count value being used. If the timer count register or the max count register is changed so that the max count is less than the timer count, the timer does not immediately reset. Instead, the timer counts up to OFFFFH, "wraps around" to zero, counts up to the max count value, and then resets.

## Timers and Reset

Upon RESET, the Timers will perform the following actions:

- All EN (Enable) bits are reset preventing timer counting.
- For Timers 0 and 1, the RIU bits are reset to zero and the ALT bits are set to one. This results in the Timer Out pins going HIGH.


## INTERRUPT CONTROLLER

The 80188 can receive interrupts from a number of sources, both internal and external. The internal interrupt controller serves to merge these requests on a priority basis, for individual service by the CPU.

Internal interrupt sources (Timers and DMA channels) can be disabled by their own control registers or by mask bits within the interrupt controller. The 80188 interrupt controller has its own control register that sets the mode of operation for the controller.

The interrupt controller will resolve priority among requests that are pending simultaneously. Nesting is provided so interrupt service routines for lower priority interrupts may be interrupted by higher priority interrupts. A block diagram of the interrupt controller is shown in Figure 21.

The 80188 has a special Slave Mode in which the internal interrupt controller acts as a slave to an external master. The controller is programmed into this mode by setting bit 14 in the peripheral control block relocation register. (See Slave Mode section.)

## MASTER MODE OPERATION

## Interrupt Controller External Interface

Five pins are provided for external interrupt sources. One of these pins is NMI, the non-maskable interrupt. NMI is generally used for unusual events such as power-fail interrupts. The other four pins may be configured in any of the following ways:

- As four interrupt input lines with internally generated interrupt vectors.
- As an interrupt line and interrupt acknowledge line pair (Cascade Mode) with externally generated interrupt vectors plus two interrupt input lines with internally generated vectors.
- As two pairs of interrupt/interrupt acknowledge lines (Cascade Mode) with externally generated interrupt vectors.

External sources in the Cascade Mode use externally generated interrupt vectors. When an interrupt is acknowledged, two INTA cycles are initiated and the vector is read into the 80188 on the second cycle. The capability to interface to external 8259A programmable interrupt controllers is provided when the inputs are configured in Cascade Mode.

## Interrupt Controller Modes of Operation

The basic modes of operation of the interrupt controller in Master Mode are similar to the 8259A. The interrupt controller responds identically to internal interrupts in all three modes: the difference is only in the interpretation of function of the four external interrupt pins. The interrupt controller is set into one of these three modes by programming the correct bits in the INT0 and INT1 control registers. The modes of interrupt controller operation are as follows:

## FULLY NESTED MODE

When in the fully nested mode four pins are used as direct interrupt requests as in Figure 22. The vectors for these four inputs are generated internally. An inservice bit is provided for every interrupt source. If a lower-priority device requests an interrupt while the in-service bit (IS) is set, no interrupt will be generated by the interrupt controller. In addition, if another interrupt request occurs from the same interrupt source while the in-service bit is set, no interrupt will be generated by the interrupt controller. This allows interrupt service routines to operate with interrupts enabled, yet be suspended only by interrupts of higher priority than the in-service interrupt.

When a service routine is completed, the proper IS bit must be reset by writing the proper pattern to the EOI register. This is required to allow subsequent interrupts from this interrupt source and to allow servicing of lower-priority interrupts. An EOI com-


Figure 21. Interrupt Controller Block Diagram
mand is executed at the end of the service routine just before the return from interrupt instruction. If the fully nested structure has been upheld, the next highest-priority source with its IS bit set is then serviced.

## CASCADE MODE

The 80188 has four interrupt pins and two of them have dual functions. In the fully nested mode the four pins are used as direct interrupt inputs and the corresponding vectors are generated internally. In the Cascade Mode, the four pins are configured into interrupt input-dedicated acknowledge signal pairs. The interconnection is shown in Figure 23. INTO is an interrupt input interfaced to an 8259A, while INT2/INTAO serves as the dedicated interrupt acknowledge signal to that peripheral. The same is true for INT1 and INT3/INTA1. Each pair can selectively be placed in the Cascade Mode by programming the proper value into INT0 and INT1 control registers. The use of the dedicated acknowledge signals eliminates the need for the use of external logic to generate $\overline{\text { NTA }}$ and device select signals.

The primary Cascade Mode allows the capability to serve up to 128 external interrupt sources through the use of external master and slave 8259As. Three levels of priority are created, requiring priority resolution in the 80188 interrupt controller, the master 8259As, and the slave 8259As. If an external interrupt is serviced, one IS bit is set at each of these levels. When the interrupt service routine is completed, up to three end-of-interrupt commands must be issued by the programmer.

## SPECIAL FULLY NESTED MODE

This mode is entered by setting the SFNM bit in INTO or INT1 control register. It enables complete nestability with external 8259A masters. Normally, an interrupt request from an interrupt source will not be recognized unless the in-service bit for that source is reset. If more than one interrupt source is connected to an external interrupt controller, all of the interrupts will be funneled through the same 80188 interrupt request pin. As a result, if the external interrupt controller receives a higher-priority interrupt, its interrupt will not be recognized by the 80188 controller until the 80188 in-service bit is reset. In Special Fully Nested Mode, the 80188 interrupt controller will allow interrupts from an external pin regardless of the state of the in-service bit for an interrupt source in order to allow multiple interrupts from a single pin. An in-service bit will continue to be set, however, to inhibit interrupts from other lowerpriority 80188 interrupt sources.

Special procedures should be followed when resetting IS bits at the end of interrupt service routines. Software polling of the IS register in the external master 8259A is required to determine if there is more than one bit set. If so, the IS bit in the 80188 remains active and the next interrupt service routine is entered.

## Operation in a Polled Environment

The controller may be used in a polled mode if interrupts are undesirable. When polling, the processor disables interrupts and then polls the interrupt controller whenever it is convenient. Polling the interrupt controller is accomplished by reading the Poll Word (Figure 32). Bit 15 in the poll word indicates to the processor that an interrupt of high enough priority is requesting service. Bits 0-4 indicate to the processor the type vector of the highest-priority source requesting service. Reading the Poll Word causes the In-Service bit of the highest priority source to be set.

It is desirable to be able to read the Poll Word information without guaranteeing service of any pending interrupt, i.e., not set the indicated in-service bit. The 80188 provides a Poll Status Word in addition to the conventional Poll Word to allow this to be done. Poll Word information is duplicated in the Poll Status Word, but reading the Poll Status Word does not set the associated in-service bit. These words are located in two adjacent memory locations in the register file.


Figure 22. Fully Nested (Direct) Mode Interrupt Controller Connections

## Master Mode Features

## PROGRAMMABLE PRIORITY

The user can program the interrupt sources into any of eight different priority levels. The programming is done by placing a 3 -bit priority level ( $0-7$ ) in the control register of each interrupt source. (A source with a priority level of 4 has higher priority over all priority levels from 5 to 7 . Priority registers containing values lower than 4 have greater priority). All interrupt sources have preprogrammed default priority levels (see Table 4).

If two requests with the same programmed priority level are pending at once, the priority ordering scheme shown in Table 4 is used. If the serviced interrupt routine reenables interrupts, other interrupt requests can be serviced.

## END-OF-INTERRUPT COMMAND

The end-of-interrupt (EOI) command is used by the programmer to reset the In-Service (IS) bit when an interrupt service routine is completed. The EOI command is issued by writing the proper pattern to the EOI register. There are two types of EOI commands, specific and nonspecific. The nonspecific command does not specify which IS bit is reset. When issued, the interrupt controller automatically resets the IS bit of the highest priority source with an active service routine. A specific EOI command requires that the programmer send the interrupt vector type to the interrupt controller indicating which source's is bit is to be reset. This command is used when the fully nested structure has been disturbed or the highest priority IS bit that was set does not belong to the service routine in progress.

## TRIGGER MODE

The four external interrupt pins can be programmed in either edge- or level-trigger mode. The control register for each external source has a level-trigger mode (LTM) bit. All interrupt inputs are active HIGH. In the edge sense mode or the level-trigger mode, the interrupt request must remain active (HIGH) until the interrupt request is acknowledged by the 80188 CPU. In the edge-sense mode, if the level remains high after the interrupt is acknowledged, the input is disabled and no further requests will be generated. The input level must go LOW for at least one clock cycle to re-enable the input. In the level-trigger mode, no such provision is made: holding the interrupt input HIGH will cause continuous interrupt requests.

## INTERRUPT VECTORING

The 80188 Interrupt Controller will generate interrupt vectors for the integrated DMA channels and the integrated Timers. In addition, the Interrupt Controller will generate interrupt vectors for the external interrupt lines if they are not configured in Cascade or Special Fully Nested Modes. The interrupt vectors generated are fixed and cannot be changed (see Table 4).

## Interrupt Controller Registers

The Interrupt Controller register model is shown in Figure 24. It contains 15 registers. All registers can both be read or written unless specified otherwise.

## IN-SERVICE REGISTER

This register can be read from or written into. The format is shown in Figure 25. It contains the In-Service bit for each of the interrupt sources. The In-Service bit is set to indicate that a source's service routine is in progress. When an In-Service bit is set, the interrupt controller will not generate interrupts to the CPU when it receives interrupt requests from devices with a lower programmed priority level. The TMR bit is the In-Service bit for all three timers; the DO and D1 bits are the In-Service bits for the two DMA channels; the $10-13$ are the in-Service bits for the external interrupt pins. The IS bit is set when the processor acknowledges an interrupt request either by an interrupt acknowledge or by reading the poll register. The IS bit is reset at the end of the interrupt service routine by an end-of-interrupt command.

## INTERRUPT REQUEST REGISTER

The internal interrupt sources have interrupt request bits inside the interrupt controller. The format of this register is shown in Figure 25. A read from this register yields the status of these bits. The TMR bit is the logical OR of all timer interrupt requests. D0 and D1 are the interrupt request bits for the DMA channels.

The state of the external interrupt input pins is also indicated. The state of the external interrupt pins is not a stored condition inside the interrupt controller, therefore the external interrupt bits cannot be written. The external interrupt request bits are set when an interrupt request is given to the interrupt controller, so if edge-triggered mode is selected, the bit in the register will be HIGH only after an inactive-to-active transition. For internal interrupt sources, the register bits are set when a request arrives and are reset when the processor acknowledges the requests.

Writes to to the interrupt request register will affect the D0 and D1 interrupt request bits. Setting either bit will cause the corresponding interrupt request while clearing either bit will remove the corresponding interrupt request. All other bits in the register are read-only.

## MASK REGISTER

This is a 16 -bit register that contains a mask bit for each interrupt source. The format for this register is shown in Figure 25. A one in a bit position corresponding to a particular source masks the source from generating interrupts. These mask bits are the exact same bits which are used in the individual control registers; programming a mask bit using the mask register will also change this bit in the individual control registers, and vice versa.


Figure 23. Cascade and Special Fully Nested Mode Interrupt Controller Connections

|  | OFFSET3EH |
| :---: | :---: |
| INT3 CONTROL REGISTER |  |
| INT2 CONTROL REGISTER | 3 CH |
| INT1 CONTROL REGISTER | 3AH |
| INTO CONTROL REGISTER | 38 H |
| DMA 1 CONTROL REGISTER | 36H |
| DMA 0 CONTROL REGISTER | 34H |
| TIMER CONTROL REGISTER | 32 H |
| INTERRUPT STATUS REGISTER | 30 H |
| INTERRUPT REQUEST REGISTER | 2EH |
| IN-SERVICE REGISTER | 2 CH |
| PRIORITY MASK REGISTER | 2AH |
| MASK REGİSTER | 28H |
| POLL STATUS REGISTER | 26 H |
| POLL REGISTER | 24H |
| EOI REGISTER | 22 H |

Figure 24. Interrupt Controller Registers (Master Mode)

## PRIORITY MASK REGISTER

This register masks all interrupts below a particular interrupt priority level. The format of this register is shown in Figure 26. The code in the lower three bits of this register inhibits interrupts of priority lower (a higher priority number) than the code specified. For example, 100 written into this register masks interrupts of level five (101), six (110), and seven (111). The register is reset to seven (111) upon RESET so no interrupts are masked due to priority number.

## INTERRUPT STATUS REGISTER

This register contains general interrupt controller status information. The format of this register is shown in Figure 27. The bits in the status register have the following functions:
DHLT: DMA Halt Transfer; setting this bit halts all DMA transfers. It is automatically set whenever a non-maskable interrupt occurs, and it is reset when an IRET instruction is executed. This bit allows prompt service of all nonmaskable interrupts. This bit may also be set by the programmer.
IRTx: These three bits represent the individual timer interrupt request bits. These bits differentiate between timer interrupts, since the timer IR bit in the interrupt request register is the "OR" function of all timer interrupt requests. Note that setting any one of these three bits initiates an interrupt request to the interrupt controller.

| 15 | 14 |  |  |  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | - | - | - | 0 | 0 | 0 | 13 | 12 | 11 | 10 | D1 | D0 | 0 | TMR |

Figure 25. In-Service, Interrupt Request, and Mask Register Formats

| 15 | 14 |  |  |  |  |  |  |  |  |  |  | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | - | $\bullet$ | 0 | PRM2 | PRM1 | PRM0 |

Figure 26. Priority Mask Register Format


Figure 27. Interrupt Status Register Format (non-RMX Mode)

## TIMER, DMA 0, 1; CONTROL REGISTERS

These registers are the control words for all the internal interrupt sources. The format for these registers is shown in Figure 28. The three bit positions PR0, PR1, and PR2 represent the programmable priority level of the interrupt source. The MSK bit inhibits interrupt requests from the interrupt source. The MSK bits in the individual control registers are the exact same bits as are in the Mask Register; modifying them in the individual control registers will also modify them in the Mask Register, and vice versa.

## INTO-INT3 CONTROL REGISTERS

These registers are the control words for the four external input pins. Figure 29 shows the format of the INTO and INT1 Control registers; Figure 30 shows the format of the INT2 and INT3 Control registers. In Cascade Mode or Special Fully Nested Mode, the control words for INT2 and INT3 are not used.

The bits in the various control registers are encoded as follows:
PRO-2: Priority programming information. Highest priority $=000$, lowest priority $=111$.
LTM: Level-trigger mode bit. $1=$ level-triggered; $0=$ edge-triggered. Interrupt Input levels are active high. In level-triggered mode, an interrupt is generated whenever the external line is high. In edge-triggered mode, an interrupt will be generated only
when this level is preceded by an inac-tive-to-active transition on the line. In both cases, the level must remain active until the interrupt is acknowledged.
MSK: $\quad$ Mask bit, $1=$ mask; $0=$ non-mask.
C: $\quad$ Cascade mode bit, $1=$ cascade; $0=$ direct.
SFNM: Special Fully Nested Mode bit, $1=$ SFNM.

## EOI REGISTER

The end of the interrupt register is a command register which can only be written into. The format of this register is shown in Figure 31. It initiates an EOI command when written to by the 80188 CPU.

The bits in the EOI register are encoded as follows: $\mathrm{S}_{\mathrm{x}}$ : Encoded information that specifies an interrupt source vector type as shown in Table 4. For example, to reset the inService bit for DMA channel 0 , these bits should be set to 01010, since the vector type for DMA channel 0 is 10.

NOTE:
To reset the single In-Service bit for any of the three timers, the vector type for timer 0 (8) should be written in this register.
NSPEC/: A bit that determines the type of EOI comSPEC mand. Nonspecific $=1$, Specific $=0$.

| 15 | 14 |  |  |  |  |  |  |  |  |  | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | 0 | MSK | PR2 | PR1 | PR0 |

Figure 28. Timer/DMA Control Register Formats


Figure 29. INTO/INT1 Control Register Formats


Figure 30. INT2/INT3 Control Register Formats

## POLL AND POLL STATUS REGISTERS

These registers contain polling information. The format of these registers is shown in Figure 32. They can only be read. Reading the Poll register constitutes a software poll. This will set the IS bit of the highest priority pending interrupt. Reading the poll status register will not set the is bit of the highest priority pending interrupt; only the status of pending interrupts will be provided.

Encoding of the Poll and Poll Status register bits are as follows:
Sx: Encoded information that indicates the vector type of the highest priority interrupting source. Valid only when INTREQ $=1$.
INTREQ: This bit determines if an interrupt request is present. Interrupt Request $=1$; no In terrupt Request $=0$.

## SLAVE MODE OPERATION

When Slave Mode is used, the internal 80188 interrupt controller will be used as a slave controller to an external master interrupt controller. The internal 80188 resources will be monitored by the internal
interrupt controller, while the external controller functions as the system master interrupt controller. Upon reset, the 80188 will be in Master Mode. To provide for slave mode operation bit 14 of the relocation register should be set.

Because of pin limitations caused by the need to interface to an external 8259A master, the internal interrupt controller will no longer accept external inputs. There are however, enough 80188 interrupt controller inputs (internally) to dedicate one to each timer. In this mode, each timer interrupt source has its own mask bit, IS bit, and control word.

In Slave Mode each peripheral must be assigned a unique priority to ensure proper interrupt controller operation. Therefore, it is the programmer's responsibility to assign correct priorities and initialize interrupt control regisers before enable interrupts.

## Slave Mode External Interface

The configuration of the 80188 with respect to an external 8259A master is shown in Figure 33. The INTO (pin 45) input is used as the 80188 CPU interrupt input. IRQ (pin 41) functions as an output to send the 80188 slave-interrupt-request to one of the 8 master-PIC-inputs.


Figure 31. EOI Register Format


Figure 32. Poll and Poll Status Register Format


Figure 33. Slave Mode Interrupt Controller Connections

Correct master-slave interface requires decoding of the slave addresses (CASO-2). Slave 8259As do this internally. Because of pin limitations, the 80188 slave address will have to be decoded externally. SELECT (pin 44) is used as a slave-select input. Note that the slave vector address is transferred internally, but the READY input must be supplied externally.
$\overline{\text { INTAO }}$ (pin 42) is used as an acknowledge output, suitable to drive the $\mathbb{N T T A}$ input of an 8259A.

## Interrupt Nesting

Slave Mode operation allows nesting of interrupt requests. When an interrupt is acknowledged, the priority logic masks off all priority levels except those with equal or higher priority.

## Vector Generation in the Slave Mode

Vector generation in Slave Mode is exactly like that of an 8259A or 82C59A slave. The interrupt controller generates an 8 -bit vector type number which the CPU multiplies by four to use as an address into the vector table. The five most significant bits of this type number are user-programmable while the three least significant bits are defined according to Figure 34. The significant five bits of the vector are programmed by writing to the Interrupt Vector register at offset 20 H .

## Specific End-of-Interrupt

In Slave Mode the specific EOI command operates to reset an in-service bit of a specific priority. The user supplies a 3-bit priority-level value that points to an in-service bit to be reset. The command is executed by writing the correct value in the Specific EOI register at offset 22 H .

## Interrupt Controller Registers in the Slave Mode

All control and command registers are located inside the internal peripheral control block. Figure 34 shows the offsets of these registers.

## END-OF-INTERRUPT REGISTER

The end-of-interrupt register is a command register which can only be written. The format of this register is shown in Figure 35. It initiates an EOI command when written by the 80188 CPU.

The bits in the EOI register are encoded as follows:
$\mathrm{V} \mathrm{T}_{\mathrm{x}}$ : Three least-significant vector type bits corresponding to the source for which the IS bit is to be reset. Figure 34 indicates these bits.

## IN-SERVICE REGISTER

This register can be read from or written into. It contains the in-service bit for each of the internal interrupt sources. The format for this register is shown in Figure 36. Bit positions 2 and 3 correspond to the DMA channels; positions 0,4 , and 5 correspond to the integral timers. The source's is bit is set when the processor acknowledges its interrupt request.

## INTERRUPT REQUEST REGISTER

This register indicates which internal peripherals have interrupt requests pending. The format of this register is shown in Figure 36. The interrupt request bits are set when a request arrives from an internal source, and are reset when the processor acknowledges the request. As in Master Mode, D0 and D1 are read/write, all other bits are read only.

## MASK REGISTER

This register contains a mask bit for each interrupt source. The format for this register is shown in Figure 36. If the bit in this register corresponding to a particular interrupt source is set, any interrupts from that source will be masked. These mask bits are exactly the same bits which are used in the individual control registers, i.e., changing the state of a mask bit in this register will also change the state of the mask bit in the individual interrupt control register corresponding to the bit.

## CONTROL REGISTERS

These registers are the control words for all the internal interrupt sources. The format of these registers is shown in Figure 37. Each of the timers and both of the DMA channels have their own Control Register.

The bits of the Control Registers are encoded as follows:
$\mathrm{pr}_{\mathrm{x}}$ : 3 -bit encoded field indicating a priority level for the source.
msk: mask bit for the priority level indicated by $\mathrm{pr}_{\mathrm{x}}$ bits.

| TIMER 2 CONTROL REGISTER (VECTOR TYPE xxxxx 101) | 3AH |
| :---: | :---: |
| TIMER 1 CONTROL REGISTER (VECTOR TYPE xxxxx 100) | 38H |
| DMA 1 CONTROL REGISTER (VECTOR TYPE xxxxx 011) | 36H |
| DMA 0 CONTROL REGISTER (VECTOR TYPE xxxxx 010) | 34H |
| TIMER 0 CONTROL REGISTER (VECTOR TYPE xxxxx 000) | 32H |
| INTERRUPT STATUS REGISTER | 30 H |
| INTERRUPT REQUEST REGISTER | 2EH |
| IN-SERVICE REGISTER | 2 CH |
| PRIORITY-LEVEL MASK REGISTER | 2AH |
| MASK REGISTER | 28H |
| SPECIFIC EOI REGISTER | 22 H |
| INTERRUPT VECTOR REGISTER | 2 H |

Figure 34. Interrupt Controller Registers
(Slave Mode)


Figure 35. Specific EOI Register Format

| 15 | 14 | 13 |  |  |  |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | - | - | - | - | 0 | 0 | 0 | TMR2 | TMR1 | D1 | D0 | 0 | TMRO |

Figure 36. In-Service, Interrupt Request, and Mask Register Format

## INTERRUPT VECTOR REGISTER

This register provides the upper five bits of the interrupt vector address. The format of this register is shown in Figure 38. The interrupt controller itself provides the lower three bits of the interrupt vector as determined by the priority level of the interrupt request.

The format of the bits in this register is:
$t_{x}$ : 5-bit field indicating the upper five bits of the vector address.

## PRIORITY-LEVEL MASK REGISTER

This register indicates the lowest priority-level interrupt which will be serviced.

The encoding of the bits in this register is:
$m_{x}$ : 3-bit encoded field indication priority-level value. All levels of lower priority will be masked.

## Interrupt Controller and Reset

Upon RESET, the interrupt controller will perform the following actions:

- All SFNM bits reset to 0, implying Fully Nested Mode.
- All PR bits in the various control registers set to 1. This places all sources at lowest priority (level 111).
- All LTM bits reset to 0 , resulting in edge-sense mode.
- All Interrupt Service bits reset to 0 .
- All Interrupt Request bits reset to 0.
- All MSK (Interrupt Mask) bits set to 1 (mask).
- All C (Cascade) bits reset to 0 (non-Cascade).
- All PRM (Priority Mask) bits set to 1, implying no levels masked.
- Initialized to Master Mode.


## INTERRUPT STATUS REGISTER

This register is defined as in Master Mode except that DHLT is not implemented. (See Figure 27).


Figure 37. Control Word Format

| 15 | 14 | 13 |  |  |  |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $\bullet$ | - | - | - | 0 | 14 | t3 | t2 | $t 1$ | to | 0 | 0 | 0 |

Figure 38. Interrupt Vector Register Format

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | - | $\bullet$ | - | - | 0 | 0 | 0 | 0 | 0 | 0 | m2 | m1 | m0 |

Figure 39. Priority Level Mask Register


Figure 40. Typical 80188 Computer


210706-15
Figure 41. Typical 80188 Multi-Master Bus Interface

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias $\ldots .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on any Pin with
Respect to Ground. . . . . . . . . . . . . -1.0 V to +7 V
Power Dissipation
3 Watt

NOTICE: This is a production data sheet. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.
D.C. CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

Applicable to 80188 ( 8 MHz )

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage <br> (All except X1 and $\overline{\mathrm{RES}})$ | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{IH} 1}$ | Input High Voltage ( $\overline{\mathrm{RES}})$ | 3.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{CLI}}$ | X1 Input Low Voltage | -0.5 | 0.6 | V |  |
| $\mathrm{~V}_{\mathrm{CHI}}$ | X1 Input High Voltage | 3.9 | $\mathrm{~V}_{\mathrm{CC}}+1.0$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{a}}=2.5 \mathrm{~mA}$ for $\overline{\mathrm{SO} 0}-\overline{S 2}$ <br> $\mathrm{I}_{\mathrm{a}}=2.0 \mathrm{~mA}$ for all other outputs |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OA}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | $600^{*}$ | mA | $\mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ |
|  |  |  | 550 | mA | $\mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
|  |  |  | 415 | mA | $\mathrm{~T}_{\mathrm{A}}=+70^{\circ} \mathrm{C}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0 \mathrm{~V}<\mathrm{V}_{\mathrm{IN}}<\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V}<\mathrm{V}_{\mathrm{OUT}}<\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{CLO}}$ | Clock Output Low |  | 0.6 | V | $\mathrm{I}_{\mathrm{a}}=4.0 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{CHO}}$ | Clock Output High | 4.0 |  | V | $\mathrm{I}_{\mathrm{Oa}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF |  |
| $\mathrm{C}_{\mathrm{IO}}$ | I/O Capacitance |  | 20 | pF |  |

[^10]80188

PIN TIMINGS
A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

80188 Timing Requirements All Timings Measured At 1.5 Volts Unless Otherwise Noted

| Symbol | Parameter | $\begin{gathered} 80188 \\ (8 \mathrm{MHz}) \\ \hline \end{gathered}$ |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| TDVCL | Data in Setup (A/D) | 20 |  | ns |  |
| TCLDX | Data in Hold (A/D) | 10 |  | ns |  |
| T ${ }_{\text {ARYHCH }}$ | Asynchronous Ready (ARDY) active setup time ${ }^{(1)}$ | 20 |  | ns |  |
| TARYLCL | ARDY inactive setup time | 35 |  | ns |  |
| TCLARX | ARDY hold time | 15 |  | ns |  |
| T ARYCHL | Asynchronous Ready inactive hold time | 15 |  | ns |  |
| TSRYCL | Synchronous Ready (SRDY) Transition Setup Time ${ }^{(2)}$ | 20 |  | ns |  |
| TCLSRY | SRDY Transition Hold Time ${ }^{(2)}$ | 15 |  | ns |  |
| THVCL | HOLD Setup ${ }^{(1)}$ | 25 |  | ns |  |
| TINVCH | INTR, NMI, TEST, TMR IN, Setup(1) | 25 |  | ns |  |
| TINVCL | DRQ0, DRQ1, Setup(1) | 25 |  | ns |  |

80188 Master Interface Timing Responses

| TCLAV | Address Valid Delay | 5 | 55 | ns | $C_{L}=20-200 \mathrm{pF}$ <br> all outputs (except TCLTMV) <br> @ 8 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLAX | Address Hold | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 35 | ns |  |
| TCHCZ | Command Lines Float Delay |  | 45 | ns |  |
| $\mathrm{T}_{\mathrm{CHCV}}$ | Command Lines Valid Delay (after float) |  | 55 | ns |  |
| TLHLL | ALE Width | TCLCL-35 |  | ns |  |
| $\mathrm{T}_{\mathrm{CHLH}}$ | ALE Active Delay |  | 35 | ns |  |
| TCHLL | ALE Inactive Delay |  | 35 | ns |  |
| TLLAX | Address Hold to ALE Inactive | $\mathrm{T}_{\text {CHCL }}-25$ |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 44 | ns |  |
| TCLDOX | Data Hold Time | 10 |  | ns |  |
| TwHDX | Data Hold after WR | TCLCL-40 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 5 | 50 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 55 | ns |  |
| T CVCTX | Control Inactive Delay | 5 | 55 | ns |  |
| TCVDEX | $\overline{\mathrm{DEN}}$ Inactive Delay (Non-Write Cycle) | 10 | 70 | ns |  |

1. To guarantee recognition at next clock.
2. To guarantee proper operation.

PIN TIMINGS (Continued)

## A.C. CHARACTERISTICS

( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$ ) (Continued)
80188 Master Interface Timing Responses (Continued)

| Symbol | Parameter | $\begin{gathered} 80188 \\ (8 \mathrm{MHz}) \\ \hline \end{gathered}$ |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| $\mathrm{T}_{\text {AZRL }}$ | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 70 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 55 | ns |  |
| TrHav | $\overline{\mathrm{RD}}$ Inactive to Address Active | TCLCL-40 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 5 | 50 | ns |  |
| TRLRH | $\overline{\text { RD Width }}$ | $2 \mathrm{~T}_{\text {CLCL }}-50$ |  | ns |  |
| TWLWH | WR Width | $2 \mathrm{~T}_{\text {CLCL }}-40$ |  | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | T $\mathrm{CLCH}^{-25}$ |  | ns |  |
| TCHSV | Status Active Delay | 10 | 55 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 65 | ns |  |
| TCLTMV | Timer Output Delay |  | 60 | ns | 100 pF max |
| TCLRO | Reset Delay |  | 60 | ns |  |
| TCHQSV | Queue Status Delay |  | 35 | ns |  |
| TCHDX | Status Hold Time | 10 |  | ns |  |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 10 |  | ns |  |
| TCLLV | LOCK Valid/Invalid Delay | 5 | 65 | ns |  |

80188 Chip-Select Timing Responses

| TCLCSV | Chip-Select <br> Active Delay | 66 | ns |  |  |
| :---: | :--- | :---: | :---: | :---: | :---: |
| TCXCSX | Chip-Select Hold from <br> Command Inactive | 35 | ns |  |  |
| $T_{\text {CHCSX }}$ | Chip-Select <br> Inactive Delay | 5 | 35 | ns |  |

80188 CLKIN Requirements

| $T_{\text {CKIN }}$ | CLKIN Period | 62.5 | 250 | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $T_{\text {CKHL }}$ | CLKIN Fall Time |  | 10 | ns | 3.5 to 1.0 V |
| $T_{\text {CKLH }}$ | CLKIN Rise Time |  | 10 | ns | 1.0 to 3.5 V |
| $T_{\text {CLCK }}$ | CLKIN Low Time | 25 |  | ns | 1.5 V |
| $T_{\text {CHCK }}$ | CLKIN High Time | 25 |  | ns | 1.5 V |

PIN TIMINGS (Continued)
A.C. CHARACTERISTICS (Continued)
( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ ) (Continued)
$\mathbf{8 0 1 8 8}$ CLKOUT Timing ( $\mathbf{2 0 0}$ pF load)

| Symbol | Parameter | $\begin{gathered} 80188 \\ (8 \mathrm{MHz}) \end{gathered}$ |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| TCICO | CLKIN to CLKOUT Skew |  | 50 | ns |  |
| TCLCL | CLKOUT Period | 125 | 500 | ns |  |
| TCLCH | CLKOUT Low Time | $1 / 2 T_{\text {CLCL }}-7.5$ |  | ns | 1.5 V |
| TCHCL | CLKOUT High Time | $1 / 2 T_{\text {CLCL }}-7.5$ |  | ns | 1.5 V |
| $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLKOUT Rise Time |  | 15 | ns | 1.0 to 3.5 V |
| TCL2CL1 | CLKOUT Fall Time |  | 15 | ns | 3.5 to 1.0 V |

## Explanation of the AC Symbols

Each timing symbol has from 5 to 7 characters. The first character is always a "T" (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.
A: Address
ARY: Asynchronous Ready Input
C: Clock Output
CK: Clock Input
CS: Chip Select
CT: Control (DT/R, $\overline{\mathrm{DEN}}, \ldots$ )
D: Data Input
DE: DEN
H: Logic Level High
IN: Input (DRQO, TIMO, ...)

L: Logic Level Low or ALE
O: Output
QS: Queue Status (QS1, QS2)
R: $\overline{R D}$ Signal, RESET Signal
$\mathrm{S}: \quad$ Status ( $\overline{\mathbf{S 0}}, \overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2}$ )
SRY: Synchronous Ready Input
V: Valid
W: WR Signal
X: No Longer a Valid Logic Level
Z: Float
Examples:
TCLAV - Time from Clock Low to Address Valid
$\mathrm{T}_{\mathrm{CH}} \mathrm{H}$ - Time from Clock High to ALE High
TcLCSV- Time from Clock LOW to Chp Select Valid

## WAVEFORMS

## Major Cycle Timing



## WAVEFORMS (Continued)

## Major Cycle Timing (Continued)



## NOTES:

1. INTA occurs one clock later in Slave Mode.
2. Status inactive just prior to $T_{4}$.
3. If latched A1 and A2 are selected instead of $\overline{\text { PCS5 }}$ and $\overline{P C S 6}$, only TCLCSv is applicable.

WAVEFORMS (Continued)


WAVEFORMS (Continued)
READY TIMING


## WAVEFORMS (Continued)

HOLD/HLDA TIMING (Entering Hold)


HOLD/HLDA TIMING (Leaving Hold)


## WAVEFORMS (Continued)

Timer On 80188


## 80188 EXPRESS

The Intel EXPRESS system offers enhancements to the operational specifications of the 80188 microprocessor. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

The EXPRESS program includes the commercial standard temperature range with burn-in and an extended temperature range without burn-in.

With the commercial standard temperature range, operational characteristics are guaranteed over the temperature range of $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$. With the extended temperature range option, operational characteristics are guaranteed over the range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

The optional burn-in is dynamic, for a minimum time of 160 hours at $125^{\circ} \mathrm{C}$ with $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 0.25 \mathrm{~V}$, following guidelines in MIL-STD-883, Method 1015.

Package types and EXPRESS versions are identified by a one or two-letter prefix to the part number. The prefixes are listed in Table 16. All AC and DC specifications not mentioned in this section are the same for both commercial and EXPRESS parts.

Table 16. Prefix Identification

| Prefix | Package <br> Type | Temperature <br> Range | Burn-In |
| :---: | :---: | :---: | :---: |
| A | PGA | Commercial | No |
| N | PLCC | Commercial | No |
| R | LCC | Commercial | No |
| TA | PGA | Extended | No |
| QR | LCC | Commercial | Yes |

NOTE:
Not all package/temperature range combinations are available.

## 80188 EXECUTION TIMINGS

A determination of 80188 program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.

All instructions which involve memory accesses can also require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the Bus Interface Unit (BIU) and execution unit.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

The 80188 8-bit BIU is noticeably limited in its performance relative to the execution unit. A sufficient number of prefetched bytes may not reside in the prefetch queue much of the time. Therefore, actual program execution time may be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER MOV = Move: |  |  |  |  | $\begin{aligned} & 2 / 12^{*} \\ & 2 / 9^{*} \end{aligned}$ | 8/16-bit <br> 8/16-bit |
| Register to register/memory | 1000100 w | mod reg r/m |  |  |  |  |
| Register/memory to register | 1000101 w | mod reg r/m |  |  |  |  |
| Immediate to register/memory | 1100011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 12/13* |  |
| Immediate to register | 1011 w reg | data | data if $w=1$ |  | 3/4 |  |
| Memory to accumulator | 1010000 w | addr-low | addr-high |  | 8* |  |
| Accumulator to memory | 1010001 w | addr-low | addr-high |  | 9* |  |
| Register/memory to segment register | 10001110 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2/13 |  |
| Segment register to register/memory | 10001100 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2/15 |  |
| PUSH = Push: |  |  |  |  |  |  |
| Memory | 11111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  | 20 |  |
| Register | 01010 reg |  |  |  | 14 |  |
| Segment register | 000 reg 110 |  |  |  | 13 |  |
| Immediate | 01101080 | diata | data If $\mathrm{s}=0$ |  | 14 |  |
| Puswi = Push Al ./. | 011100000 |  |  |  | 68 |  |
| $\mathbf{P O P}=\mathbf{P o p}:$ |  |  |  |  |  |  |
| Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 24 |  |
| Register | 01011 reg |  |  |  | 14 |  |
| Segment register | 000 reg 111 | $(\mathrm{reg}=01)$ |  |  | 12 |  |
| Pordi = Pop All. . | 01100001 |  |  |  | 88 |  |
| XCHG = Exchange: |  |  |  |  |  |  |
| Register/memory with register | 1000011 w | mod reg r/m |  |  | 4/17* |  |
| Register with accumulator | 10010 reg |  |  |  | 3 |  |
| $\underline{N}=$ Input from: |  |  |  |  |  |  |
| Fixed port | 1110010 w | port |  |  | 10* |  |
| Variable port | 1110110 w |  |  |  | 8* |  |
| OUT = Output to: |  |  |  |  |  |  |
| Fixed port | 1110011 w | port |  |  | 9* |  |
| Variable port | 1110111 w |  |  |  | 7* | , |
| XLAT $=$ Translate byte to AL | 11010111 |  |  |  | 15 |  |
| LEA = Load EA to register | 10001101 | mod reg r/m |  |  | 6 |  |
| LDS = Load pointer to DS | 11000101 | mod reg r/m | $(\bmod =11)$ |  | 26 |  |
| LES = Load pointer to ES | 11000100 | mod reg r/m | $(\bmod \neq 11)$ |  | 26 |  |
| LAHF = Load AH with flags | 10011111 |  |  |  | 2 |  |
| SAHF $=$ Store AH into flags | 10011110 |  |  |  | 3 |  |
| PUSHF = Push flags | 10011100 |  |  |  | 13 |  |

Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086,8088 microsystems.
*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format |  | Clock <br> Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CONTROL TRANSFER (Continued) |  |  |  |  |  |
| JNO = Jump on not overflow | 01110001 | disp |  | 4/13 |  |
| JNS = Jump on not sign | 01111001 | disp |  | 4/13 |  |
| JCXZ $=$ Jump on CX zero | 11100011 | disp |  | 5/15 |  |
| LOOP = Loop CX times | 11100010 | disp |  | 6/16 | LOOP not |
| LOOPZ/LOOPE = Loop while zero/equal | 11100001 | disp |  | 6/16 | taken/LOOP |
| LOOPNZ/LOOPNE = Loop while not zero/equal | 11100000 | disp |  | 6/16 |  |
|  | $11001000$ $11001001$ | datarlow | data high |  |  |
| INT = Interrupt: |  |  |  |  |  |
| Type specified | 11001101 | type |  | 47 |  |
| Type 3 | 11001100 |  |  | 45 | if INT. taken/ |
| INTO = Interrupt on overflow | 11001110 |  |  | 48/4 | if INT. not taken |
| IRET $=$ Interrupt return | 11001111 |  |  | 28 |  |
| Bound = Detect valise out of range | 01100010 | modreg IIm |  | 33-35 |  |
| PROCESSOR CONTROL |  |  |  |  |  |
| CLC = Clear carry | 11111000 |  |  | 2 |  |
| CMC = Complement carry | 11110101 |  |  | 2 |  |
| STC = Set carry | 11111001 |  |  | 2 |  |
| CLD = Clear direction | 11111100 |  |  | 2 |  |
| STD $=$ Set direction | 11111101 |  |  | 2 |  |
| CLI = Clear interrupt | 11111010 |  |  | 2 |  |
| STI $=$ Set interrupt | 11111011 |  |  | 2 |  |
| HLT $=$ Halt | 11110100 |  |  | 2 |  |
| WAIT = Wait | 10011011 |  |  | 6 | if $\overline{\text { TEST }}=0$ |
| LOCK = Bus lock prefix | 11110000 |  |  | 2 |  |
| ESC $=$ Processor Extension Escape | 11011 TTT | mod LLL r/m |  | 6 |  |
|  | (TTT LLL are opcode to processor extension) |  |  |  |  |
| NOP = No Operation | 10010000 |  |  | 3 |  |

Shaded areas indicate instructions not available in 8086,8088 microsystems.
*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
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 $\bmod =01$ then DISP $=$ disp-low sign-extended to
16-bits, disp-high is absent
if $\bmod =10$ then DISP $=$ disp-high: disp-low
if $r / 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)+(S I)+$ DISP
if $r / m=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then $E A=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+D I S P^{*}$
if $r / m=111$ then $E A=(B X)+$ DISP
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

## Segment Override Prefix

$$
\begin{array}{|llllllll|}
\hline 0 & 0 & 1 & \text { reg } & 1 & 1 & 0 \\
\hline
\end{array}
$$

reg is assigned according to the following:

| reg | Segment <br> Register |
| :---: | :---: |
| 00 | ES |
| 01 | CS |
| 10 | SS |
| 11 | DS |

REG is assigned according to the following table:

| $\mathbf{1 6 - B i t}(\mathbf{w}=\mathbf{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.

## REVISION HISTORY

The sections significantly revised since version -010 are:

| Pin Description Table | Added note to $\overline{T E S T}$ pin requiring proper RESET at power-up to configure pin as input. |
| :---: | :---: |
|  | Renamed pin 44 to INT1/SELECT and pin 41 to INT3//(MTA1/IRQ to better describe their functions in Slave Mode. |
| Initialization and Processor Reset | Added reminder to drive $\overline{\mathrm{RES}}$ pin LOW during power-up. |
| Major Cycle Timing Waveform | Clarified applicability of TCLCSV to latched A1 and A2 in footnote. |
| HOLD/HLDA Timing Waveforms | Redrawn to indicate correct relationship of HOLD inactive to HLDA inactive. |
| Instruction Set Summary | Corrected clock count for ENTER instruction. |
| Slave Mode Operation | The three low order bits associated with vector generation and performing EOI are not alterable; however, the priority levels are programmable. This information is a clarification only. |

The sections significantly revised since version -009 are:
Pin Description Table Various descriptions rewritten for clarity.
Interrupt Vector Table Redrawn for clarity.
A.C. Characteristics

Added reminder that $\mathrm{T}_{\text {SRYCL }}$ and $\mathrm{T}_{\text {CLSRY }}$ must be met.
Explanation of the A.C. Symbols New section.
Major Cycle Timing Waveforms TCLRO indicated.
The sections significantly revised since version -008 are:

| Pin Description Table | Noted $\overline{\text { RES }}$ to be low more than 4 clocks. Connèctions to X1 and X2 <br> clarified. <br> Moved and clarified note concerning TC condition for ST//STOP clearing <br> during unsynchronized transfers. |
| :--- | :--- |
| DMA Control Bit Descriptions | Renamed iRMX Mode to Slave Mode. |
| Interrupt Controller, etc. | Noted that DO and D1 are read/write, others read-only. <br> Interrupt Request Register <br> Execution Timings |
| A.C. Characteristics | 10 MHz 80188 no longer offered. |

The sections significantly revised since version -007 are:

[^11]
## CHMOS HIGH INTEGRATION 16-BIT MICROPROCESSOR

- Operation Modes Include:
- Enhanced Mode Which Has
- DRAM Refresh Control Unit
- Power-Save Mode
- Compatible Mode
— NMOS 80188 Pin for Pin Replacement for Non-Numerics Applications
- Integrated Feature Set
— Enhanced 80C86/C88 CPU
- Clock Generator
- 2 Independent DMA Channels
- Programmable Interrupt Controller
- 3 Programmable 16-Bit Timers
- Dynamic RAM Refresh Control Unit
- Programmable Memory and Peripheral Chip Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- Power Save Mode
- System-Level Testing Support (High Impedance Test Mode)
- Available in 16 MHz (80C188-16), 12.5 MHz (80C188-12) and 10 MHz (80C188) Versions
- Direct Addressing Capability to 1 MByte Memory and 64 KByte I/O
- Completely Object Code Compatible with All Existing 8086/8088 Software and Also Has 10 Additional Instructions over 8086/8088
- Complete System Development Support
- All 8088 and NMOS 80188 Software Development Tools Can Be Used for 80C186 System Development
- ASM86 Assembler, PL/M-86, Pascal-86, Fortran-86, C-86 and System Utilities - In-Circuit-Emulator (ICETM-188)
- Available in 68 Pin:
— Plastic Leaded Chip Carrier (PLCC)
- Ceramic Pin Grid Array (PGA)
- Ceramic Leadless Chip Carrier (JEDEC A Package)
(See Packaging Outlines and Dimensions, Order Number 231369)
- Available in EXPRESS Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

The Intel 80C188 is a CHMOS high integration microprocessor. It has features which are new to the 80186 family which include a DRAM refresh control unit and power-save mode. When used in "compatible" mode, the 80 C 188 is $100 \%$ pin-for-pin compatible with the NMOS 80188 (except for 8087 applications). The "enhanced" mode of operation allows the full feature set of the 80 C 188 to be used. The 80 C 188 is upward compatible with 8086 and 8088 software and fully compatible with 80186 and 80188 software, except for numerics applications.


Figure 1. 80C188 Block Diagram


Figure 2. 80C188 Pinout Diagrams

Table 1. 80C188 Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ | $\begin{gathered} 9 \\ 43 \end{gathered}$ | $1$ | System Power: +5 volt power supply. |
| $\mathrm{V}_{\text {SS }}$ | $\begin{aligned} & 26 \\ & 60 \end{aligned}$ | $1$ | System Ground. |
| RESET | 57 | 0 | RESET Output indicates that the 80 C 188 CPU is being reset, and can be used as a system reset. It is active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods corresponding to the length of the RES signal. Reset goes inactive 2 clockout periods after RES goes inactive. When tied to the TEST pin, RESET forces the 80 C 188 into enhanced mode. RESET is not floated during bus hold. |
| $\begin{aligned} & \hline \mathrm{X} 1 \\ & \mathrm{X} 2 \end{aligned}$ | $\begin{aligned} & 59 \\ & 58 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Crystal Inputs X1 and X2 provide external connections for a fundamental mode or third overtone parallel resonant crystal for the internal oscillator. X1 can connect to an external clock instead of a crystal. In this case, minimize the capacitance on X2. The input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). |
| CLKOUT | 56 | 0 | Clock Output provides the system with a $50 \%$ duty cycle waveform. All device pin timings are specified relative to CLKOUT. CLKOUT is active during reset and bus hold. |
| RES | 24 | 1 | An active $\overline{\operatorname{RES}}$ causes the 80C188 to immediately terminate its present activity, clear the internal logic, and enter a dormant state. This signal may be asynchronous to the 80 C 188 clock. The 80C188 begins fetching instructions approximately $61 / 2$ clock cycles after RES is returned HIGH. For proper initialization, $\mathrm{V}_{\mathrm{CC}}$ must be within specifications and the clock signal must be stable for more than 4 clocks with $\overline{\text { RES }}$ held LOW. $\overline{\text { RES }}$ is internally synchronized. This input is provided with a Schmitt-trigger to facilitate power-on RES generation via an RC network. |
| TEST | 47 | 1/0 | The TEST pin is sampled during and after reset to determine whether the 80C188 is to enter Compatible or Enhanced Mode. Enhanced Mode requires TEST to be HIGH on the rising edge of $\overline{\text { RES }}$ and LOW four CLKOUT cycles later. Any other combination will place the 80C188 in Compatible Mode. A weak internal pullup ensures a HIGH state when the pin is not driven. This pin is examined by the WAIT instruction. If the TEST input is HIGH when WAIT execution begins, instruction execution will suspend. TEST will be resampled every five clocks until it goes LOW, at which time execution will resume. If interrupts are enabled while the 80 C 188 is waiting for TEST, interrupts will be serviced. During power-up, active $\overline{\operatorname{RES}}$ is required to configure TEST as an input. |
| TMR IN 0 TMR IN 1 | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | $1$ | Timer Inputs are used either as clock or control signals, depending upon the programmed timer mode. These inputs are active HIGH (or LOW-to-HIGH transitions are counted) and internally synchronized. Timer Inputs must be tied HIGH when not being used as clock or retrigger inputs. |
| TMR OUT 0 TMR OUT 1 | $\begin{aligned} & 22 \\ & 23 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Timer outputs are used to provide single pulse or continous waveform generation, depending upon the timer mode selected. These outputs are not floated during a bus hold. |

Table 1. 80C188 Pin Description (Continued)

| Symbol | Pin No. | Type | $\quad$ Name and Function |
| :--- | :---: | :---: | :--- |
| DRQ0 | 18 | 1 | DMA Request is asserted HIGH by an external device when it is <br> DRQ1 <br> ready for DMA Channel 0 or 1 to perform a transfer. These signals <br> are level-triggered and internally synchronized. |
| NMI | 19 | 19 | 1 |
|  |  |  | The Non-Maskable Interrupt input causes a Type 2 interrupt. An <br> NMI transition from LOW to HIGH is latched and synchronized <br> internally, and initiates the interrupt at the next instruction <br> boundary. NMI must be asserted for at least one CLKOUT period. |
| The Non-Maskable Interrupt cannot be avoided by programming. |  |  |  |$|$

Table 1. 80C186 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ALE/QSO | 61 | 0 | Address Latch Enable/Queue Status 0 is provided by the 80C188 to latch the address. ALE is active HIGH, with addresses guaranteed valid on the trailing edge. |  |  |
| WR/QS1 | 63 | 0 | Write Strobe/Queue Status 1 indicates that the data on the bus is to be written into a memory or an I/O device. It is active LOW, and floats during bus hold or reset. When the 80C188 is in queue status mode, the ALE/QS0 and WR/QS1 pins provide information about processor/instruction queue interaction. |  |  |
|  |  |  | QS1 | QSO | Queue Operation |
|  |  |  | $\begin{aligned} & \hline 0 \\ & 0 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 0 \\ & \hline \end{aligned}$ | No queue operation <br> First opcode byte fetched from the queue <br> Subsequent byte fetched from the queue <br> Empty the queue |
| $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ | 62 | O/I | Read Strobe is an active LOW signal which indicates that the 80 C 188 is performing a memory or I/O read cycle. It is guaranteed not to go LOW before the A/D bus is floated. An internal pull-up ensures that RD/ $\overline{\text { QSMD }}$ is HIGH during RESET. Following RESET the pin is sampled to determine whether the 80 C 188 is to provide $A L E, \overline{R D}$ and $\overline{W R}$, or queue status information. To enable Queue Status Mode, $\overline{\mathrm{RD}}$ must be connected to GND. $\overline{\mathrm{RD}}$ will float during bus HOLD. |  |  |
| ARDY | 55 | 1 | Asynchronous Ready informs the 80C188 that the addressed memory space or I/O device will complete a data transfer. The ARDY pin accepts a rising edge that is asynchronous to CLKOUT and is active HIGH. The falling edge of ARDY must be synchronized to the 80C188 clock. Connecting ARDY HIGH will always assert the ready condition to the CPU. If this line is unused, it should be tied LOW to yield control to the SRDY pin. |  |  |
| SRDY | 49 | 1 | Synchronous Ready informs the 80C188 that the addressed memory space or I/O device will complete a data transfer. The SRDY pin accepts an active-HIGH input synchronized to CLKOUT. The use of SRDY allows a relaxed system timing over ARDY. This is accomplished by elimination of the one-half clock cycle required to internally synchronize the ARDY input signal. Connecting SRDY high will always assert the ready condition to the CPU. If this line is unused, it should be tied LOW to yield control to the ARDY pin. |  |  |

Table 1. 80C188 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LOCK | 48 | 0 | LOCK output indicates that other system bus masters are not to gain control of the system bus. LOCK is active LOW. The LOCK signal is requested by the LOCK prefix instruction and is activated at the beginning of the first data cycle associated with the instruction immediately following the LOCK prefix. It remains active until the completion of that instruction. No instruction prefetching will occur while LOCK is asserted. $\overline{\text { LOCK }}$ floats during bus hold or reset. |  |  |  |
| $\frac{\overline{S 0}}{\frac{S 1}{S 2}}$ | $\begin{aligned} & 52 \\ & 53 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Bus cycle status $\overline{\mathbf{S 0}}-\overline{\mathrm{S}} \mathbf{2}$ are encoded to provide bus-transaction information: |  |  |  |
|  |  |  | 80 C 188 Bus Cycle Status Information |  |  |  |
|  |  |  | $\overline{5} 2$ | $\overline{51}$ | $\overline{\mathbf{S o}}$ | Bus Cycle Initiated |
|  |  |  | 0 0 0 0 1 1 1 1 | 0 0 1 1 0 0 1 1 | $\begin{aligned} & \hline 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Interrupt Acknowledge <br> Read I/O <br> Write I/O <br> Halt <br> Instruction Fetch <br> Read Data from Memory <br> Write Data to Memory <br> Passive (no bus cycle) |
|  |  |  | The status pins float during HOLD. <br> $\overline{\mathrm{S} 2}$ may be used as a logical M/Iত indicator, and $\overline{\mathrm{S} 1}$ as a $\mathrm{DT} / \overline{\mathrm{R}}$ indicator. |  |  |  |
| HOLD <br> HLDA | $\begin{aligned} & 50 \\ & 51 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | HOLD indicates that another bus master is requesting the local bus. The HOLD input is active HIGH. The 80C188 generates HLDA (HIGH) in response to a HOLD request. Simultaneous with the issuance of HLDA, the 80C188 will float the local bus and control lines. After HOLD is detected as being LOW, the 80 C 188 will lower HLDA. When the 80 C 188 needs to run another bus cycle, it will again drive the local bus and control lines. <br> In Enhanced Mode, HLDA will go low when a DRAM refresh cycle is pending in the 80C188 and an external bus master has control of the bus. It will be up to the external master to relinquish the bus by lowering HOLD so that the 80C188 may execute the refresh cycle. |  |  |  |
| UCS | 34 | O/I | Upper Memory Chip Select is an active LOW output whenever a memory reference is made to the defined upper portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ block) of memory. UCS does not float during bus hold. The address range activating UCS is software programmable. <br> $\overline{U C S}$ and $\overline{L C S}$ are sampled upon the rising edge of $\overline{\text { RES }}$. If both pins are held low, the 80C188 will enter ONCE Mode. In ONCE Mode all pins assume a high impedance state and remain so until a subsequent RESET. UCS has a weak internal pullup that is active during RESET to ensure that the 80C188 does not enter the ONCE mode inadvertently. |  |  |  |

Table 1. 80C188 Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{\text { LCS }}$ | 33 | O/I | Lower Memory Chip Select is active LOW whenever a memory reference is made to the defined lower portion ( $1 \mathrm{~K}-$ 256K) of memory. $\overline{\text { LCS }}$ does not float during bus HOLD. The address range activating LCS is software programmable. <br> $\overline{U C S}$ and $\overline{L C S}$ are sampled upon the rising edge of $\overline{\text { RES }}$. If both pins are held low, the 80C186 will enter ONCE Mode. In ONCE Mode all pins assume a high impedance state and remain so until a subsequent RESET. LCS has a weak internal pullup that is active only during RESET to ensure that the 80C188 does not enter ONCE Mode inadvertently. |
| $\begin{aligned} & \overline{\mathrm{MCSO}} \\ & \overline{\mathrm{MCS} 1} \\ & \overline{\mathrm{MCS2}} \\ & \hline \mathrm{MCS3} \end{aligned}$ | $\begin{aligned} & 38 \\ & 37 \\ & 36 \\ & 35 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Mid-Range Memory Chip Select signals are active LOW when a memory reference is made to the defined mid-range portion of memory ( $8 \mathrm{~K}-512 \mathrm{~K}$ ). These lines do not float during bus HOLD. The address ranges activating $\overline{\text { MCSO }}-3$ are software programmable. |
| $\overline{\text { PCS0 }}$ <br> PCS1 <br> PCS2 <br> PCS3 <br> PCS4 | $\begin{aligned} & 25 \\ & 27 \\ & 28 \\ & 29 \\ & 30 \\ & \hline \end{aligned}$ | $\begin{aligned} & 10 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | Peripheral Chip Select signals 0-4 are active LOW when a reference is made to the defined peripheral area $(64 \mathrm{~K}$ I/O space or 1 Mbyte memory space). These lines do not float during bus HOLD. The address ranges activating $\overline{\mathrm{PCSO}}-4$ are software programmable. |
| $\overline{\text { PCS5/A1 }}$ | 31 | 0 | Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth peripheral chip select, or to provide an internally latched A1 signal. The address range activating $\overline{\text { PCS5 }}$ is software-programmable. PCS5/A1 does not float during bus HOLD. When programmed to provide latched A1, this pin will retain the previously latched value during HOLD. |
| $\overline{\text { PCS6/A2 }}$ | 32 | 0 | Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh peripheral chip select, or to provide an internally latched A2 signal. The address range activating $\overline{\text { PCS6 }}$ is software-programmable. $\overline{\text { PCS6 }}$ /A2 does not float during bus HOLD. When programmed to provide latched A2, this pin will retain the previously latched value during HOLD. |
| DT/ $\bar{R}$ | 40 | 0 | Data Transmit/Receive controls the direction of data flow through an external data bus transceiver. When LOW, data is transferred to the 80 C 188 . When HIGH the 80 C 188 places write data on the data bus. DT/ $\overline{\mathrm{R}}$ floats during a bus hold or RESET. |
| $\overline{\text { DEN }}$ | 39 | 0 | Data Enable is provided as a data bus transceiver output enable. $\overline{\mathrm{DEN}}$ is active LOW during each memory and I/O access. $\overline{D E N}$ is HIGH whenever DT/ $\bar{R}$ changes state. During RESET, DEN is driven HIGH for one clock, then floated. DEN also floats during HOLD. |

## FUNCTIONAL DESCRIPTION

## Introduction

The following Functional Description describes the base architecture of the 80C188. The 80 C 188 is a very high integration 16 -bit microprocessor. It combines 15-20 of the most common microprocessor system components onto one chip. The 80 C 188 is object code compatible with the 8086/8088 microprocessors and adds 10 new instruction types to the 8086/8088 instruction set.

The 80C188 has two major modes of operation, Compatible and Enhanced. In Compatible Mode the 80C188 is completely compatible with NMOS 80188, with the exception of 8087 support. The Enhanced mode adds two new features to the system design. These are Power-Save control and Dynamic RAM refresh.

## 80C188 BASE ARCHITECTURE

The 8086, 8088, 80186, and 80188 families all contain the same basic set of registers, instructions, and addressing modes. The 80 C 188 processor is upward compatible with the 8086 and 8088 CPUs.

## Register Set

The 80C188 base architecture has fourteen registers as shown in Figures 3a and 3b. These registers are grouped into the following categories.

## General Registers

Eight 16-bit general purpose registers may be used for arithmetic and logical operands. Four of
these ( $A X, B X, C X$, and $D X$ ) can be used as 16 -bit registers or split into pairs of separate 8 -bit registers.

## 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.)

## 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 selects the specific registers for operand and address calculations.

## Status and Control Registers

Two 16-bit special purpose registers record or alter certain aspects of the 80 C 188 processor state. These are the Instruction Pointer Register, which contains the offset address of the next sequential instruction to be executed, and the Status Word Register, which contains status and control flag bits (see Figures 3a and 3b).

## Status Word Description

The Status Word records specific characteristics of the result of logical and arithmetic instructions (bits $0,2,4,6,7$, and 11) and controls the operation of the 80C186 within a given operating mode (bits 8, 9 , and 10). The Status Word Register is 16 -bits wide. The function of the Status Word bits is shown in Table 2.


Figure 3a. 80C188 Register Set


Figure 3b. Status Word Format

Table 2. Status Word Bit Functions

| Bit <br> Position | Name | Function |
| :---: | :---: | :--- |
| 0 | CF | Carry Flag-Set on high-order <br> bit carry or borrow; cleared <br> otherwise |
| 2 | PF | Parity Flag-Set if low-order 8 <br> bits of result contain an even <br> number of 1-bits; cleared <br> otherwise |
| 4 | AF | Set on carry from or borrow to <br> the low order four bits of AL; <br> cleared otherwise |
| 6 | ZF | Zero Flag-Set if result is zero; <br> cleared otherwise |
| 7 | SF | Sign Flag-Set equal to high- <br> order bit of result (0 if positive, <br> 1 if negative) |
| 8 | TF | Single Step Flag-Once set, a <br> single step interrupt occurs <br> after the next instruction <br> executes. TF is cleared by the <br> single step interrupt. |
| 9 | IF | Interrupt-enable Flag-When <br> set, maskable interrupts will <br> cause the CPU to transfer <br> control to an interrupt vector <br> specified location. |
| 10 | DF | Direction Flag-Causes string <br> instructions to auto decrement <br> the appropriate index register <br> when set. Clearing DF causes <br> auto increment. |
| 11 | OF | Overflow Flag-Set if the <br> signed result cannot be <br> expressed within the number <br> of bits in the destination <br> operand; cleared otherwise |

## Instruction Set

The instruction set is divided into seven categories: data transfer, arithmetic, shift/rotate/logical, string manipulation, control transfer, high-level instructions, and processor control. These categories are summarized in Figure 4.

An 80 C 188 instruction can reference anywhere from zero to several operands. An operand can reside in a register, in the instruction itself, or in memory. Specific operand addressing modes are discussed later in this data sheet.

## Memory Organization

Memory is organized in sets of segments. Each segment is a linear contiguous sequence of up to 64 K (216) 8 -bit bytes. Memory is addressed using a twocomponent address (a pointer) that consists of a 16bit base segment and a 16-bit offset. The 16 -bit base values are contained in one of four internal segment register (code, data, stack, extra). The physical address is calculated by shifting the base value LEFT by four bits and adding the 16 -bit offset value to yield a 20 -bit physical address (see Figure 5). This allows for a 1 MByte physical address size.

All instructions that address operands in memory must specify the base segment and the 16 -bit offset value. For speed and compact instruction encoding, the segment register used for physical address generation is implied by the addressing mode used (see Table 3). These rules follow the way programs are written (see Figure 6) 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 overridden for special cases. The stack, data, and extra segments may coincide for simple programs.

| GENERAL PURPOSE |  | MOVS |  | Move byte or word string |
| :---: | :---: | :---: | :---: | :---: |
| MOV | Move byte or word | INS |  | Input bytes or word string |
| PUSH | Push word onto stack | OUTS |  | Output bytes or word string |
| POP | Pop word off stack | CMPS |  | Compare byte or word string |
| PUSHA | Push all registers on stack | SCAS |  | Scan byte or word string |
| POPA | Pop all registers from stack | LODS |  | Load byte or word string |
| XCHG | Exchange byte or word |  |  |  |
| XLAT | Translate byte | STOS |  | Store byte or word string |
| INPUT/OUTPUT |  | REP |  | Repeat |
| IN | Input byte or word | REPE/REPZ |  | Repeat while equal/zero |
| OUT | Output byte or word | REPNE/REPNZ |  | Repeat while not equal/not zero |
| ADDRESS OBJECT |  | LOGICALS |  |  |
| LEA | Load effective address | NOT | "Not" byte or word |  |
| LDS | Load pointer using DS | AND | "And" byte or word |  |
| LES | Load pointer using ES | OR | "Inclusive or"' byte or word |  |
| FLAG TRANSFER |  | XOR | "Exclusive or" byte or word |  |
| LAHF |  | TEST | "Test" byte or word |  |
|  | Load AH register from flags | SHIFTS |  |  |
| SAHF | Store AH register in flags | SHL/SAL | Shift logical/arithmetic left byte or word |  |
| PUSHF | Push flags onto stack | SHR | Shift logical right byte or word |  |
| POPF | Pop flags off stack | SAR $\quad$ Shift arithmetic right byte or word |  |  |
| ADDITION |  | ROTATES |  |  |
| ADD | Add byte or word | ROL | Rotate left byte or word |  |
| ADC | Add byte or word with carry | ROR | Rotate right byte or word |  |
| INC | Increment byte or word by 1 | RCL | Rotate through carry left byte or word |  |
| AAA | ASCII adjust for addition | RCR | Rotate through carry right byte or word |  |
| DAA | Decimal adjust for addition | FLAG OPERATIONS |  |  |
| SUBTRACTION |  | STC | Set carry flag |  |
| SUB | Subtract byte or word | CLC | Clear carry flag |  |
| SBB | Subtract byte or word with borrow | CMC | Complement carry flag |  |
| DEC | Decrement byte or word by 1 | STD | Set direction flag |  |
| NEG | Negate byte or word | CLD | Clear direction flag |  |
| CMP | Compare byte or word | STI | Set interrupt enable flag |  |
| AAS | ASCII adjust for subtraction | CLI | Clear interrupt enable flag |  |
| DAS | Decimal adjust for subtraction | EXTERNAL SYNCHRONIZATION |  |  |
| MULTIPLICATION |  | HLT | Halt until interrupt or reset |  |
| MUL | Multiply byte or word unsigned | WAIT | Wait for TEST pin active |  |
| IMUL | Integer multiply byte or word | LOCK Lock bus during next instruction |  |  |
| AAM | ASCII adjust for multiply | NO OPERATION |  |  |
| DIVISION |  | NOP | No operation |  |
| DIV | Divide byte or word unsigned | HIGH LEVEL INSTRUCTIONS |  |  |
| IDIV | Integer divide byte or word | ENTER | Format stack for procedure entry |  |
| AAD | ASCII adjust for division | LEAVE | Restore stack for procedure exit |  |
| CBW | Convert byte to word | BOUND | Detects values outside prescribed range |  |
| CWD | Convert word to doubleword |  |  |  |

Figure 4. 80C188 Instruction Set

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

Figure 4. 80C188 Instruction Set (Continued)

To access operands that do not reside in one of the four immediately available segments, a full 32-bit pointer can be used to reload both the base (segment) and offset values.


Figure 5. Two Component Address
Table 3. Segment Register Selection Rules

| Memory <br> Reference <br> Needed | Segment <br> Register <br> Used | Implicit Segment <br> Selection Rule |
| :--- | :--- | :--- |
| Instructions | Code (CS) | Instruction prefetch and <br> immediate data. |
| Stack | Stack (SS) | All stack pushes and <br> pops; any memory <br> references which use BP <br> Register as a base <br> register. <br> All string instruction <br> references which use <br> the DI register as an <br> index. <br> All other data references. |
| External <br> Data <br> (Global) | Extra (ES) |  |
| Local Data | Data (DS) |  |



Figure 6. Segmented Memory Helps Structure Software

## Addressing Modes

The 80C188 provides eight categories of addressing modes to specify operands. Two addressing modes are provided for instructions that operate on register or immediate 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: a segment base and an offset. The segment base is supplied by a 16 -bit segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset, also called the effective address, is calculated by summing any combination of the following three address elements:

- the displacement (an 8- or 16-bit immediate value contained in the instruction);
- the base (contents of either the BX or BP base registers); and
- the index (contents of either the SI or DI index registers).

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 SI, DI, 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 80 C 188 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.
- Ordinal: An unsigned binary numeric value contained in an 8 -bit byte or a 16 -bit word.
- Pointer: A 16- or 32-bit quantity, composed of a 16 -bit offset component or a 16 -bit segment base component in addition to a 16 -bit offset component.
- String: A contiguous sequence of bytes or words. A string may contain from 1 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 BCD: A byte (packed) representation of two decimal digits $(0-9)$. One digit is stored in each nibble (4-bits) of the byte.

In general, individual data elements must fit within defined segment limits. Figure 7 graphically represents the data types supported by the 80 C 188 .

## I/O Space

The I/O space consists of 64 K 8 -bit or 32 K 16 -bit ports. Separate 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 $00 F F(H)$ are reserved.

## Interrupts

An interrupt transfers execution to a new program location. The old program address (CS:IP) and machine state (Status Word) 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. If the exception was caused by attempted execution of an ESC instruction, the return instruction will point to the ESC instruction, or to the segment override prefix immediately preceding
the ESC instruction if the prefix was present. In all other cases, the return address from an exception will point at the instruction immediately following the instruction causing the exception.


Figure 7. 80C188 Supported Data Types

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. Table 4 shows the 80 C 188 predefined types and default priority levels. For each interrupt, an 8 -bit vector must be supplied to the 80C186 which identifies the appropriate table entry. Exceptions supply the interrupt vector internally. In addition, internal peripherals and noncascaded external interrupts will generate their own vectors through the internal interrupt controller. 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. Non-maskable hardware interrupts use a predefined internally supplied vector.

## Interrupt Sources

The 80C188 can service interrupts generated by software or hardware. The software interrupts are generated by specific instructions (INT, ESC, unused OP, etc.) or the results of conditions specified by instructions (array bounds check, INTO, DIV, IDIV, etc.). All interrupt sources are serviced by an indirect call through an element of a vector table. This vector table is indexed by using the interrupt vector type (Table 4), multiplied by four. All hardware-generated interrupts are sampled at the end of each instruction. Thus, the software interrupts will begin service first. Once the service routine is entered and interrupts are enabled, any hardware source of sufficient priority can interrupt the service routine in progress.

Those pre-defined 80C188 interrupts which cannot be masked by programming are described below.

## DIVIDE ERROR EXCEPTION (TYPE 0)

Generated when a DIV or IDIV instruction quotient cannot be expressed in the number of bits in the destination.

## SINGLE-STEP INTERRUPT (TYPE 1)

Generated after most instructions if the TF flag in the status word is set. This interrupt allows programs to execute one instruction at a time. Interrupts will not be generated after prefix instructions (e.g., REP), instructions which modify segment registers (e.g., POP DS), or the WAIT instruction. Vectoring to the single-step interrupt service routine clears the TF bit. An IRET instruction in the interrupt service routine restores the TF bit to logic " 1 " and transfers control to the next instruction to be single-stepped.

## NON-MASKABLE INTERRUPT-NMI (TYPE 2)

An external interrupt source which is serviced regardless of the state of the IF bit. No external acknowledge sequence is performed. The IF bit is
cleared at the beginning of an NMI interrupt to prevent maskable interrupts from being serviced. A typical use of NMI would be to activate a power failure routine.

Table 4. 80C188 Interrupt Vectors

| Interrupt <br> Name | Vector <br> Type | Vector <br> Address | Default <br> Priority | Related <br> Instructions | Applicable <br> Notes |
| :---: | :---: | :---: | :---: | :--- | :---: |
| Divide Error <br> Exception | 0 | 00 H | 1 | DIV, IDIV | 1 |
| Single Step <br> Interrupt | 1 | 04 H | 1 A | All | 2 |
| Non-Maskable <br> Interrupt (NMI) | 2 | 08 H | 1 | All |  |
| Breakpoint <br> Interrupt | 3 | 0 CH | 1 | INT | 1 |
| INTO Detected <br> Overflow <br> Exception | 4 | 10 H | 1 | INTO | 1 |
| Array Bounds <br> Exception | 5 | 14 H | 1 | BOUND | 1 |
| Unused-Opcode <br> Exception | 6 | 18 H | 1 | Undefined <br> Opcodes | 1 |
| ESC Opcode <br> Exception | 7 | 1 CH | 1 | ESC Opcodes | 1,3 |
| Timer 0 Interrupt | 8 | 20 H | 2 A |  | 4,5 |
| Timer 1 Interrupt | 18 | 48 H | 2 B |  | 4,5 |
| Timer 2 Interrupt | 19 | 4 CH | 2 C |  | 4,5 |
| Reserved | 9 | 24 H | 3 |  | 5 |
| DMA 0 Interrupt | 10 | 28 H | 5 |  | 5 |
| DMA 1 Interrupt | 11 | 2 CH | 5 |  |  |
| INT0 Interrupt | 12 | 30 H | 6 |  |  |
| INT1 Interrupt | 13 | 34 H | 7 |  | 8 |
| INT2 Interrupt | 14 | 38 H | 8 |  |  |
| INT3 Interrupt | 15 | 3 CH | 9 |  |  |
| Reserved | 16,17 | $40 \mathrm{H}, 44 \mathrm{H}$ |  |  |  |
| Reserved | $20-31$ | $50 \mathrm{H} \ldots 7 \mathrm{CH}$ |  |  |  |
|  |  |  |  |  |  |

## NOTES:

Default priorities for the interrupt sources are used only if the user does not program each source to a unique priority level.

1. Generated as a result of an instruction execution.
2. Performed in same manner as 8088.
3. An ESC opcode will cause a trap regardless of the 80 C 188 operating mode. The 80 C 188 is not directly compatible with the 80188 in this respect. The instruction set of a numerics coprocessor cannot be executed.
4. All three timers constitute one source of request to the interrupt controller. As such, they share the same priority level with respect to other interrupt sources. However, the timers have a defined priority order among themselves ( $2 A>2 B>2 C$ ).
5. The vector type numbers for these sources are programmable in Slave Mode.

## BREAKPOINT INTERRUPT (TYPE 3)

A one-byte version of the INT instruction. It uses 12 as an index into the service routine address table (because it is a type 3 interrupt).

## INTO DETECTED OVERFLOW EXCEPTION (TYPE 4)

Generated during an INTO instruction if the OF bit is set:

## ARRAY BOUNDS EXCEPTION (TYPE 5)

Generated during a BOUND instruction if the array index is outside the array bounds. The array bounds are located in memory at a location indicated by one of the instruction operands. The other operand indicates the value of the index to be checked.

## UNUSED OPCODE EXCEPTION (TYPE 6)

Generated if execution is attempted on undefined opcodes.

## ESCAPE OPCODE EXCEPTION (TYPE 7)

Generated if execution is attempted of ESC opcodes (D8H-DFH). The 80C188 does not check an escape opcode trap bit as does the 80C186. On the 80C188, ESC traps occcur in both compatible and enhanced operating modes. The return address of
this exception will point to the ESC instruction causing the exception. If a segment override prefix preceded the ESC instruction, the return address will point to the segment override prefix.

## NOTE:

Unlike the 80188, all numerics coprocessor opcodes cause a trap. The 80 C 188 does not support the numerics interface.

Hardware-generated interrupts are divided into two groups: maskable interrupts and non-maskable interrupts. The 80 C 188 provides maskable hardware interrupt request pins INTO-INT3. In addition, maskable interrupts may be generated by the 80 C 188 integrated DMA controller and the integrated timer unit. The vector types for these interrupts is shown in Table 4. Software enables these inputs by setting the interrupt flag bit (IF) in the Status Word. The interrupt controller is discussed in the peripheral section of this data sheet.

Further maskable interrupts are disabled while servicing an interrupt because the IF bit is reset as part of the response to an interrupt or exception. The saved Status Word will reflect the enable status of the processor prior to the interrupt. The interrupt flag will remain zero unless specifically set. The interrupt return instruction restores the Status Word, thereby restoring the original status of IF bit. If the interrupt return re-enables interrupts, and another interrupt is pending, the 80C188 will immediately service the highest-priority interrupt pending, i.e., no instructions of the main line program will be executed.

## Initialization and Processor Reset

Processor initialization is accomplished by driving the RES input pin LOW. RES must be LOW during power-up to ensure proper device initialization. RES forces the 80 C 188 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as RES is active. After RES becomes inactive and an internal processing interval elapses, the 80C188 begins execution with the instruction at physical location FFFFO(H). $\overline{\text { RES }}$ also sets some registers to predefined values as shown in Table 5.

Table 5. 80C188 Initial Register State after RESET

| Status Word | FOO2(H) |
| :--- | :--- |
| Instruction Pointer | $0000(\mathrm{H})$ |
| Code Segment | FFFF(H) |
| Data Segment | $0000(\mathrm{H})$ |
| Extra Segment | $0000(\mathrm{H})$ |
| Stack Segment | $0000(\mathrm{H})$ |
| Relocation Register | $20 \mathrm{FF}(\mathrm{H})$ |
| UMCS | FFFB(H) |

## THE 80C188 COMPARED TO THE 80C186

The 80 C 188 is an 8 -bit processor designed based on the 80 C 186 internal structure. Most internal functions of the 80 C 188 are identical to the equivalent 80 C 186 functions. The 80C188 handles the external bus the same way the 80C186 does with the distinction of handling only 8 bits at a time. Sixteen-bit operands are fetched or written in two consecutive bus cycles. The processors will look the same to the software engineer, with the exception of execution time. The internal register structure is identical and all instructions except numerics instructions have the same end result. Internally, there are four differences between the 80C188 and the 80C186. All changes are related to the 8 -bit bus interface.

- The queue length is 4 bytes in the 80 C 188 , whereas the 80 C 186 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 necessary to fetch instructions 8 bits at a time.
- To further optimize the queue, the prefetching algorithm was changed. The 80 C 188 BIU will fetch a new instruction to load into the queue each time there is a 1 -byte hole (space available) in the queue. The 80 C 186 waits until a 2-byte space is available.
- The internal execution time of an instruction is affected by the 8 -bit interface. All 16 -bit fetches and writes from/to memory take an additional four clock cycles. The CPU may also be limited by the rate of instruction fetches when a series of simple operations occur. When the more sophisticated instructions of the 80 C 188 are being used, the queue has more time to fill and the execution proceeds more closely to the speed at which the execution unit will allow.
- The 80 C 188 does not have a numerics interface, since the 80C186 numerics interface inherently requires 16 -bit communication with the numerics coprocessor.

The 80C188 and 80C186 are completely software compatible (except for numerics instructions) by virtue of their identical execution units. However, software that is system dependent may not be completely transferable.

The bus interface and associated control signals vary somewhat between the two processors. The pin assignments are nearly identical, with the following functional changes:

- A8-A15-These pins are only address outputs on the 80C188. These address lines are latched internally and remain valid throughout the bus cycle.
- $\overline{B H E}$ has no meaning on the 80C188. However, it was necessary to designate this pin the $\overline{\text { FFSH }}$ pin in order to provide an indication of DRAM refresh bus cycles.


## 80C188 CLOCK GENERATOR

The 80C188 provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, synchronous and asynchronous ready inputs, and reset circuitry.

## Oscillator

The 80C188 oscillator circuit is designed to be used either with a parallel resonant fundamental or thirdovertone mode crystal, depending upon the frequency range of the application as shown in Figure 8c. This is used as the time base for the 80 C 188 . The crystal frequency chosen should be twice the required processor frequency. Use of an LC or RC circuit is not recommended.

The output of the oscillator is not directly available outside the 80 C 188 . The two recommended crystal configurations are shown in Figures 8a and 8b. When used in third-overtone mode the tank circuit shown in Figure 8b is recommended for stable operation. The sum of the stray capacitances and loading capacitors should equal the values shown. It is advisable to limit stray capacitance between the X1 and X 2 pins to less than 10 pF . While a fundamen-tal-mode circuit will require approximately 1 ms for start-up, the third-overtone arrangement may require 1 ms to 3 ms to stabilize.

Alternately, the oscillator may be driven from an external source as shown in Figure 8d. The configuration shown in Figure 8 e is not recommended.

Intel recommends the following values for crystal selection parameters:
Temperature Range: $\quad 0$ to $70^{\circ} \mathrm{C}$
ESR (Equivalent Series Resistance): $\quad 40 \Omega$ max $\mathrm{C}_{0}$ (Shunt Capacitance of Crystal): $\quad 7.0 \mathrm{pF}$ max $\mathrm{C}_{1}$ (Load Capacitance):
$20 \mathrm{pF} \pm 2 \mathrm{pF}$
Drive Level: 1 mW max

## Clock Generator

The 80C188 clock generator provides the $50 \%$ duty cycle processor clock for the 80 C 188 . It does this by
dividing the oscillator output by 2 forming the symmetrical clock. If an external oscillator is used, the state of the clock generator will change on the falling edge of the oscillator signal. The CLKOUT pin provides the processor clock signal for use outside the 80C188. This may be used to drive other system components. All timings are referenced to the output clock.

## READY Synchronization

The 80 C 188 provides both synchronous and asynchronous ready inputs. Asynchronous ready synchronization is accomplished by circuitry which samples ARDY in the middle of $T_{2}, T_{3}$ and again in the middle of each $T_{W}$ until ARDY is sampled HIGH. One-half CLKOUT cycle of resolution time is used for full synchronization of a rising ARDY signal. A high-to-low transition on ARDY may be used as an indication of the not ready condition but it must be performed synchronously to CLKOUT either in the middle of $T_{2}, T_{3}$ or $T_{W}$, or at the falling edge of $T_{3}$ or Tw.

A second ready input (SRDY) is provided to interface with externally synchronized ready signals. This input is sampled at the end of $T_{2}, T_{3}$ and again at the end of each $T_{w}$ until it is sampled HIGH. By using this input rather than the asynchronous ready input, the half-clock cycle resolution time penalty is eliminated. This input must satisfy set-up and hold times to guarantee proper operation of the circuit.

In addition, the 80 C 188 , as part of the integrated chip-select logic, has the capability to program WAIT states for memory and peripheral blocks. This is discussed in the Chip Select/Ready Logic description.


Figure 8. 80C188 Oscillator Configurations (see text)

## RESET Logic

The 80C188 provides both a $\overline{\text { RES }}$ input pin and a synchronized RESET output pin for use with other system components. The $\overline{\operatorname{RES}}$ input pin on the 80 C 188 is provided with hysteresis in order to facilitate power-on Reset generation via an RC network. RESET output is guaranteed to remain active for at least five clocks given a $\overline{R E S}$ input of at least six clocks. RESET may be delayed up to approximately two and one-half clocks behind RES.

## LOCAL BUS CONTROLLER

The 80C188 provides a local bus controller to generate the local bus control signals. In addition, it employs a HOLD/HLDA protocol for relinquishing the local bus to other bus masters. It also provides outputs that can be used to enable external buffers and to direct the flow of data on and off the local bus.

## Memory/Peripheral Control

The 80C188 provides ALE, $\overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ bus control signals. The RD and WR signals are used to strobe data from memory or I/O to the 80 C 188 or to strobe data from the 80C188 to memory or I/O. The ALE line provides a strobe to latch the address when it is valid. The 80 C 188 local bus controller does not provide a memory///O signal. If this is required, use the $\overline{\mathrm{S}}$ signal (which will require external latching), make the memory and I/O spaces nonoverlapping, or use only the integrated chip-select circuitry.

## Transceiver Control

The 80C188 generates two control signals for external transceiver chips. This capability allows the addition of transceivers for extra buffering without adding external logic. These control lines, DT/R and DEN, are generated to control the flow of data through the transceivers. The operation of these signals is shown in Table 6.

Table 6. Transceiver Control Signals Description

| Pin Name | Function |
| :---: | :---: |
| $\overline{\text { DEN ( }}$ (Data Enable) | Enables the output drivers of the transceivers. It is active LOW during memory, I/O, or INTA cycles. |
| DT//̄ (Data Transmit/ Receive) | Determines the direction of travel through the transceivers. A HIGH level directs data away from the processor during write operations, while a LOW level directs data toward the processor during a read operation. |

## Local Bus Arbitration

The 80C188 uses a HOLD/HLDA system of local bus exchange. This provides an asynchronous bus exchange mechanism. This means multiple masters utilizing the same bus can operate at separate clock frequencies. The 80C188 provides a single HOLD/ HLDA pair through which all other bus masters may gain control of the local bus. External circuitry must arbitrate which external device will gain control of the bus when there is more than one alternate local bus master. When the 80 C 188 relinquishes control of the local bus, it floats $\overline{D E N}, \overline{R D}, \overline{W R}, \overline{S 0}-\overline{S 2}$, LOCK, AD0-AD7, A8-A19, S7/RFSH, and DT//̄ to allow another master to drive these lines directly.

The 80 C 188 HOLD latency time, i.e., the time between HOLD request and HOLD acknowledge, is a function of the activity occurring in the processor when the HOLD request is received. A HOLD request is second only to DRAM refresh requests in priority of activity requests the processor may receive. Any bus cycle in progress will be completed before the 80 C 188 relinquishes the bus. This implies that if a HOLD request is received just as a DMA transfer begins, the HOLD latency can be as great as 4 bus cycles. This will occur if a DMA word transfer operation is taking place from an odd address to an odd address. This is a total of 16 clock cycles or more if WAIT states are required. In addition, if locked transfers are performed, the HOLD latency time will be increased by the length of the locked transfer.

If the 80 C 188 has relinquished the bus and a refresh request is pending, HLDA is removed (driven LOW) to signal the remote processor that the 80 C 188 wishes to regain control of the bus. The 80 C 188 will wait until HOLD is removed before taking control of the bus to run the refresh cycle.

## Local Bus Controller and Reset

During RESET, the local bus controller will perform the following action:

- Drive $\overline{\mathrm{DEN}}, \overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ HIGH for one clock cycle, then float them.
- Drive $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ to the inactive state (all HIGH) and then float.
- Drive $\overline{\text { LOCK }}$ HIGH and then float.
- Float AD0-AD7, A8-A19, S7/ $\overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$.
- Drive ALE LOW.
- Drive HLDA LOW.
$\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}$, and $\overline{\text { TEST }}$ pins have internal pullup devices which are active while RES is applied. Excessive loading or grounding certain of these pins causes the 80C188 to enter an alternative mode of operation:
- $\overline{R D} / \overline{\text { QSMD LOW }}$ results in Queue Status Mode.
- $\overline{U C S}$ and $\overline{\text { LCS }}$ LOW results in ONCE Mode.
- TEST LOW (and HIGH later) results in Enhanced Mode.


## INTERNAL PERIPHERAL INTERFACE

All the 80 C 188 integrated peripherals are controlled by 16 -bit registers contained within an internal 256 -byte control block. The control block may be mapped into either memory or I/O space. Internal logic will recognize control block addresses and respond to bus cycles. During bus cycles to internal registers, the bus controller will signal the operation externally (i.e., the $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, status, address, data, etc., lines will be driven as in a normal bus cycle), but $D_{15-0}$, SRDY, and ARDY will be ignored. The base address of the control block must be on an even 256 -byte boundary (i.e., the lower 8 bits of the base address are all zeros). All of the defined registers within this control block may be read or written by the 80C188 CPU at any time.

The control block base address is programmed by a 16-bit relocation register contained within the control block at offset FEH from the base address of the control block (see Figure 9). It provides the upper 12 bits of the base address of the control block. The control block is effectively an internal chip select range and must abide by all the rules concerning chip selects (the chip select circuitry is discussed later in this data sheet). Any access to the 256 bytes of the control block activates an internal chip select.

Other chip selects may overlap the control block only if they are programmed to zero wait states and ignore external ready. In addition, bit 12 of this register determines whether the control block will be mapped into I/O or memory space. If this bit is 1 , the control block will be located in memory space. If the bit is 0 , the control block will be located in I/O space. If the control register block is mapped into I/O space, the upper 4 bits of the base address must be programmed as 0 (since I/O addresses are only 16 bits wide).

In addition to providing relocation information for the control block, the relocation register contains bits which place the interrupt controller into Slave Mode. At RESET, the relocation register is set to 20FFH, which maps the control block to start at FFOOH in I/O space. An offset map of the 256 -byte control register block is shown in Figure 10.

## CHIP-SELECT/READY GENERATION LOGIC

The 80C188 contains logic which provides programmable chip-select generation for both memories and peripherals. In addition, it can be programmed to provide READY (or WAIT state) generation. It can also provide latched address bits A1 and A2. The chip-select lines are active for all memory and I/O cycles in their programmed areas, whether they be generated by the CPU or by the integrated DMA unit.

## Memory Chip Selects

The 80C188 provides 6 memory chip select outputs for 3 address areas; upper memory, lower memory, and midrange memory. One each is provided for upper memory and lower memory, while four are provided for midrange memory.

The range for each chip select is user-programmable and can be set to $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}, 16 \mathrm{~K}, 32 \mathrm{~K}, 64 \mathrm{~K}$, 128K (plus 1 K and 256 K for upper and lower chip selects). In addition, the beginning or base address of the midrange memory chip select may also be selected. Only one chip select may be programmed to be active for any memory location at a time. All chip select sizes are in bytes.


```
    M/IO = Register block located in Memory / I/O Space (1/0)
    SLAVE/MASTER = Configures interrupt controller for Slave/Master Mode (1/0)
```

Figure 9. Relocation Register

|  | OFFSET |
| :---: | :---: |
| Relocation Register | FEH |
|  | DAH |
|  | DOH |
| DMA Descriptors Channel 0 |  |
|  | COH |
| Chip-Select Control Registers | A8H |
|  | AOH |
|  | 66 H |
| Time 2 Control Registers | 60 H |
| Time 1 Control Registers | 5EH |
|  | 58H |
|  | 56 H |
| Time 0 Control Registers | 50H |
| Interrupt Controller Registers | 3EH |
|  | 20 H |

Figure 10. Internal Register Map

## Upper Memory $\overline{\mathbf{C S}}$

The 80C188 provides a chip select, called $\overline{U C S}$, for the top of memory. The top of memory is usually used as the system memory because after reset the 80 C 188 begins executing at memory location FFFFOH.

The upper limit of memory defined by this chip select is always FFFFFFH, while the lower limit is programmable. By programming the lower limit, the size of the select block is also defined. Table 7 shows the
relationship between the base address selected and the size of the memory block obtained.

Table 7. UMCS Programming Values

| Starting <br> Address <br> (Base <br> Address) | Memory <br> Block <br> Size | UMCS Value <br> (Assuming <br> R0=R1= R2 = 0) |
| :---: | :---: | :---: |
| FFC00 | 1 K | FFF8H |
| FF800 | 2 K | FFB8H |
| FF000 | 4 K | FF38H |
| FE000 | 8 K | FE38H |
| FC000 | 16 K | FC38H |
| F8000 | 32 K | F838H |
| F0000 | 64 K | F038H |
| E0000 | 128 K | E038H |
| C0000 | 256 K | C 038 H |

The lower limit of this memory block is defined in the UMCS register (see Figure 11). This register is at offset $A O H$ in the internal control block. The legal values for bits 6-13 and the resulting starting address and memory block sizes are given in Table 7. Any combination of bits 6-13 not shown in Table 7 will result in undefined operation. After reset, the UMCS register is programmed for a 1 K area. It must be reprogrammed if a larger upper memory area is desired.

The internal generation of any 20-bit address whose upper 16 bits are equal to or greater than the UMCS value (with bits 0-5 as " 0 ") asserts UCS. UMCS bits R2-R0 specify the ready mode for the area of memory defined by the chip select register, as explained later.

## Lower Memory CS

The 80C188 provides a chip select for low memory called $\overline{\mathrm{LCS}}$. The bottom of memory contains the interrupt vector table, starting at location 00000 H .

The lower limit of memory defined by this chip select is always OH , while the upper limit is programmable. By programming the upper limit, the size of the memory block is defined. Table 8 shows the relationship between the upper address selected and the size of the memory block obtained.

Table 8. LMCS Programming Values

| Upper Address | Memory Block Size | $\begin{gathered} \text { LMCS Value } \\ \text { (Assuming } \\ \mathbf{R 0}=\mathbf{R 1}=\mathbf{R 2}=\mathbf{0} \text { ) } \end{gathered}$ |
| :---: | :---: | :---: |
| 003FFH | 1K | 0038H |
| 007FFH | 2K | 0078H |
| 00FFFH | 4K | $00 \mathrm{F8H}$ |
| 01FFFH | 8 K | $01 \mathrm{F8H}$ |
| 03FFFH | 16K | 03 F 8 H |
| 07FFFH | 32K | 07F8H |
| OFFFFH | 64K | OFF8H |
| 1FFFFH | 128K | 1FF8H |
| 3FFFFH | 256K | 3FF8H |

The upper limit of this memory block is defined in the LMCS register (see Figure 12) at offset A2H in the internal control block. The legal values for bits 6-15 and the resulting upper address and memory block sizes are given in Table 8. Any combination of bits 6-15 not shown in Table 8 will result in undefined operation. After RESET, the LMCS register value is undefined. However, the LCS chip-select line will not become active until the LMCS register is accessed.

Any internally generated 20 -bit address whose upper 16 bits are less than or equal to LMCS (with bits 0-5 " 1 ") will assert LCS. LMCS register bits R2-R0 specify the READY mode for the area of memory defined by this chip-select register.

## Mid-Range Memory $\overline{\mathbf{C S}}$

The 80C188 provides four $\overline{\text { MCS }}$ lines which are active within a user-locatable memory block. This block can be located within the 80C188 1M byte memory address space exclusive of the areas defined by UCS and LCS. Both the base ad-
dress and size of this memory block are programmable.

The size of the memory block defined by the midrange select lines, as shown in Table 9, is determined by bits 8-14 of the MPCS register (see Figure 13). This register is at location ABH in the internal control block. One and only one of bits 8-14 must be set at a time. Unpredictable operation of the MCS lines will otherwise occur. Each of the four chip-select lines is active for one of the four equal contiguous divisions of the mid-range block. If the total block size is 32 K , each chip select is active for 8 K of memory with MCSO being active for the first range and $\overline{M C S 3}$ being active for the last range.

The EX and MS in MPCS relate to peripheral functionality as described in a later section.

Table 9. MPCS Programming Values

| Total Block <br> Size | Individual <br> Select Size | MPCS Bits <br> $14-8$ |
| :---: | :---: | :---: |
| 8 K | 2 K | 0000001 B |
| 16 K | 4 K | 0000010 B |
| 32 K | 8 K | 0000100 B |
| 64 K | 16 K | 0001000 B |
| 128 K | 32 K | 0010000 B |
| 256 K | 64 K | 010000 B |
| 512 K | 128 K | 1000000 B |

The base address of the mid-range memory block is defined by bits 15-9 of the MMCS register (see Figure 14). This register is at offset A 6 H in the internal control block. These bits correspond to bits A19-A13 of the 20 -bit memory address. Bits A12-A0 of the base address are always 0 . The base address may be set at any integer multiple of the size of the total memory block selected. For example, if the mid-range block size is 32 K (or the size of the block for which each MCS line is active is 8 K ), the block could be located at 10000 H or 18000 H , but not at 14000 H , since the first few integer multiples of a 32 K memory block are $0 \mathrm{H}, 8000 \mathrm{H}$, $10000 \mathrm{H}, 18000 \mathrm{H}$, etc. After RESET, the contents of both registers are undefined. However, none of the $\overline{M C S}$ lines will be active until both the MMCS and MPCS registers are accessed.


Figure 11. UMCS Register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OFFSET: A2H | 0 | 0 | U | U | U | U | U | U | $U$ | U | 1 | 1 | 1 | R2 | R1 | R0 |
| A19 A10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 12. LMCS Register


Figure 13. MPCS Register

OFFSET: A6H

| 15 | 9 | R |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| U | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | 1 | 1 | 1 | 1 | 1 | 1 | $R 2$ | $R 1$ | $R 0$ |
| A19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 14. MMCS Register

MMCS bits R2-R0 specify READY mode of operation for all four mid-range chip selects.

The 512K block size for the mid-range memory chip selects is a special case. When using 512 K , the base address would have to be at either locations 00000 H or 80000 H . If it were to be programmed at 00000 H when the LCS line was programmed, there would be an internal conflict between the LCS ready generation logic and the MCS ready generation logic. Likewise, if the base address were programmed at 80000 H , there would be a conflict with the UCS ready generation logic. Since the LCS chip-select line does not become active until programmed, while the UCS line is active at reset, the memory base can be set only at 00000 H . If this base address is selected, however, the LCS range must not be programmed.

## Peripheral Chip Selects

The 80C188 can generate chip selects for up to seven peripheral devices. These chip selects are active for seven contiguous blocks of 128 bytes above a programmable base address. The base address may be located in either memory or I/O space.

Seven CS lines called $\overline{\text { PCSO }}-6$ are generated by the 80C188. The base address is user-programmable; however it can only be a multiple of 1 K bytes, i.e., the least significant 10 bits of the starting address are always 0 .
$\overline{\text { PCS5 }}$ and $\overline{\text { PCS6 }}$ can also be programmed to provide latched address bits A1 and A2. If so programmed, they cannot be used as peripheral selects. These outputs can be connected directly to the A0 and A1 pins used for selecting internal registers of 8 -bit peripheral chips.

The starting address of the peripheral chip-select block is defined by the PACS register (see Figure 15). The register is located at offset A4H in the internal control block. Bits 15-6 of this register correspond to bits $19-10$ of the 20 -bit Programmable Base Address (PBA) of the peripheral chip-select block. Bits 9-0 of the PBA of the peripheral chip-select block are all zeros. If the chip-select block is located in I/O space, bits 12-15 must be programmed zero, since the I/O address is only 16 bits wide. Table 10 shows the address range of each peripheral chip select with respect to the PBA contained in PACS register.

OFFSET:


Figure 15. PACS Register

The user should program bits 15-6 to correspond to the desired peripheral base location. PACS bits 0-2 are used to specify READY mode for $\overline{\mathrm{PCSO}}-\overline{\mathrm{PCS3}}$.

Table 10. PCS Address Ranges

| $\overline{\text { PCS Line }}$ | Active between Locations |
| :--- | :--- |
| $\overline{\text { PCSO }}$ | PBA $-\mathrm{PBA}+127$ |
| $\overline{\mathrm{PCS1}}$ | PBA $+128-\mathrm{PBA}+255$ |
| $\overline{\mathrm{PCS2}}$ | PBA $+256-\mathrm{PBA}+383$ |
| $\overline{\mathrm{PCS3}}$ | PBA $+384-\mathrm{PBA}+511$ |
| $\overline{\mathrm{PCS4}}$ | PBA $+512-\mathrm{PBA}+639$ |
| $\overline{\mathrm{PCS5}}$ | PBA $+640-\mathrm{PBA}+767$ |
| $\overline{\mathrm{PCS6}}$ | PBA $+768-\mathrm{PBA}+895$ |

The mode of operation of the peripheral chip selects is defined by the MPCS register (which is also used to set the size of the mid-range memory chip-select block, see Figure 13). The register is located at offset A 8 H in the internal control block. Bit 7 is used to select the function of PCS5 and PCS6, while bit 6 is used to select whether the peripheral chip selects are mapped into memory or I/O space. Table 11 describes the programming of these bits. After RESET, the contents of both the MPCS and the PACS registers are undefined, however none of the PCS lines will be active until both of the MPCS and PACS registers are accessed.

Table 11. MS, EX Programming Values

| Bit | Description |
| :--- | :--- |
| MS | $1=$ Peripherals mapped into memory space. |
|  | $0=$ Peripherals mapped into I/O space. |
| EX | $0=5 \overline{\text { PCS }}$ lines. A1, A2 provided. |
|  | $1=7 \overline{\text { PCS lines. A1, A2 are not provided. }}$ |

MPCS bits 0-2 specify the READY mode for $\overline{\text { PCS4 }}-$ $\overline{\text { PCS6 }}$ as outlined below.

## READY Generation Logic

The 80C188 can generate a READY signal internally for each of the memory or peripheral CS lines. The number of WAIT states to be inserted for each peripheral or memory is programmable to provide 0-3 wait states for all accesses to the area for which the chip select is active. In addition, the 80C188 may be programmed to either ignore external READY for each chip-select range individually or to factor external READY with the integrated ready generator.

READY control consists of 3 bits for each $\overline{\mathrm{CS}}$ line or group of lines generated by the 80 C 188 . The interpretation of the READY bits is shown in Table 12.

Table 12. READY Bits Programming

| R2 | R1 | R0 | Number of WAIT States Generated |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 wait states, external RDY also used. |
| 0 | 0 | 1 | 1 wait state inserted, external RDY also used. |
| 0 | 1 | 0 | 2 wait states inserted, external RDY also used. |
| 0 | 1 | 1 | 3 wait states inserted, external RDY also used. |
| 1 | 0 | 0 | 0 wait states, external RDY ignored. |
| 1 | 0 | 1 | 1 wait state inserted, external RDY ignored. |
| 1 | 1 | 0 | 2 wait states inserted, external RDY ignored. |
| 1 | 1 | 1 | 3 wait states inserted, external RDY ignored. |

The internal READY generator operates in parallel with external READY, not in series, if the external READY is used $(R 2=0)$. For example, if the internal generator is set to insert two wait states, but activity on the external READY lines will insert four wait states, the processor will only insert four wait states, not six. This is because the two wait states generated by the internal generator overlapped the first two wait states generated by the external ready signal. Note that the external ARDY and SRDY lines are always ignored during cycles accessing internal peripherals.

R2-R0 of each control word specifies the READY mode for the corresponding block, with the exception of the peripheral chip selects: R2-R0 of PACS set the PCSO-3 READY mode, R2-RO of MPCS set the $\overline{\text { PCS4-6 READY mode. }}$

## Chip Select/Ready Logic and Reset

Upon RESET, the Chip-Select/Ready Logic will perform the following actions:

- All chip-select outputs will be driven HIGH.
- Upon leaving RESET, the UCS line will be programmed to provide chip selects to a 1 K block with the accompanying READY control bits set at 011 to insert 3 wait states in conjunction with external READY (i.e., UMCS resets to FFFBH).
- No other chip select or READY control registers have any predefined values after RESET. They will not become active until the CPU accesses their control registers. Both the PACS and MPCS registers must be accessed before the $\overline{\mathrm{PCS}}$ lines will become active.


## DMA CHANNELS

The 80C188 DMA controller provides two independent DMA channels. Data transfers can occur between memory and I/O spaces (e.g., Memory to I/O) or within the same space (e.g., Memory to Memory or I/O to I/O). Each DMA channel maintains both a 20-bit source and destination pointer which can be optionally incremented or decremented after each data transfer. Each data transfer consumes 2 bus cycles (a minimum of 8 clocks), one cycle to fetch data and the other to store data.

## DMA Operation

Each channel has six registers in the control block which define each channel's operation. The control registers consist of a 20 -bit Source pointer (2 words), a 20 -bit destination pointer ( 2 words), a 16-bit Transfer Count Register, and a 16 -bit Control Word. The format of the DMA Control Blocks is shown in Table 13. The Transfer Count Register
(TC) specifies the number of DMA transfers to be performed. Up to 64 K byte transfers can be performed with automatic termination. The Control Word defines the channel's operation (see Figure 17). All registers may be modified or altered during any DMA activity. Any changes made to these registers will be reflected immediately in DMA operation.

Table 13. DMA Control Block Format

| Register Name | Register Address |  |
| :--- | :---: | :---: |
|  | Ch. 0 | Ch. 1 |
| Control Word | CAH | DAH |
| Transfer Count | C8H | D8H |
| Destination Pointer (upper 4 | C6H | D6H |
| bits) |  |  |
| Destination Pointer | C4H | D4H |
| Source Pointer (upper 4 bits) | C2H | D2H |
| Source Pointer | C0H | DOH |



Figure 16. DMA Unit Block Diagram


Figure 17. DMA Control Register

## DMA Channel Control Word Register

Each DMA Channel Control Word determines the mode of operation for the particular 80C188 DMA channel. This register specifies:

- the mode of synchronization;
- whether interrupts will be generated after the last transfer;
- whether DMA activity will cease after a programmed number of DMA cycles;
- the relative priority of the DMA channel with respect to the other DMA channel;
- whether the source pointer will be incremented, decremented, or maintained constant after each transfer;
- whether the source pointer addresses memory or I/O space;
- whether the destination pointer will be incremented, decremented, or maintained constant after each transfer; and
- whether the destination pointer will address memory or I/O space.

The DMA channel control registers may be changed while the channel is operating. However, any changes made during operation will affect the current DMA transfer.

## DMA Control Word Bit Descriptions

DEST: $\quad \mathrm{M} / \overline{\mathrm{OO}}$ Destination pointer is in memory (1) or $1 / O(0)$ space.

DEC Decrement destination pointer by 1 after each transfer.
INC Increment destination pointer by 1 after each transfer.
If both INC and DEC are specified, the pointer will remain constant after each cycle.
SOURCE: $M / \overline{\mathrm{O}}$ Source pointer is in memory (1) or I/O (0) space.
DEC Decrement source pointer by 1 after each transfer.
INC Increment source pointer by 1 after each transfer.
If both INC and DEC are specified, the pointer will remain constant after each cycle.

TC:

INT:
SYN:
$\mathrm{P}: \quad$ Channel priority relative to other channel during simultaneous requests.
0 Low priority.
1 High priority.
Channels will alternate cycles if both are set at the same priority level.
TDRQ: Enable/Disable (1/0) DMA requests from timer 2.
CHG/NOCHG: Change/Do not change (1/0) the $\mathrm{ST} / \overline{\mathrm{STOP}}$ bit. If this bit is set when writing the control word, the ST/STOP bit will be programmed by the write to the control word. If this bit is cleared when writing the control word, the ST/STOP bit will not be altered. This bit is not stored; it will always be read as 0 .
ST/STOP: $\quad$ Start/Stop ( $1 / 0$ ) channel.

## DMA Destination and Source Pointer Registers

Each DMA channel maintains a 20-bit source and a 20-bit destination pointer. Each of these pointers takes up two full 16-bit registers in the peripheral control block. For each DMA Channel to be used, all four pointer registers must be initialized. The lower four bits of the upper register contain the upper four bits of the 20-bit physical address (see Figure 18). These pointers may be individually incremented or decremented after each transfer.

Each pointer may point into either memory or 1/O space. Since the upper four bits of the address are not automatically programmed to zero, the user must program them in order to address the normal 64 K I/O space. There is no restriction on values for the pointer registers.

## DMA Transfer Count Register

Each DMA channel maintains a 16-bit transfer count register (TC). The register is decremented after every DMA cycle, regardless of the state of the TC bit in the DMA Control Register. If the TC bit in the DMA control word is set or if unsynchronized transfers are programmed, however, DMA activity will terminate when the transfer count register reaches zero.

## DMA Requests

Data transfers may be either source or destination synchronized, that is either the source of the data or the destination of the data may request the data transfer. In addition, DMA transfers may be unsynchronized; that is, the transfer will take place continually until the correct number of transfers has occurred. When source or unsynchronized transfers are performed, the DMA channel may begin another transfer immediately after the end of a previous DMA transfer. This allows a complete transfer to take place every 2 bus cycles or eight clock cycles (assuming no wait states). When destination synchronization is performed, data will not be fetched from the source address until the destination device signals that it is ready to receive it. Also, the DMA controller will relinquish control of the bus after every transfer. If no other bus activity is initiated, another destination synchronized DMA cycle will begin after two processor clocks. This allows the destination device time to remove its request if another transfer is not desired. Since the DMA controller will relinquish the bus, the CPU can initiate a bus cycle. As a result, a complete bus cycle will often be inserted between destination synchronized transfers. Table 14 shows the maximum DMA transfer rates.

Table 14. Maximum DMA Transfer Rates at CLKOUT $=16 \mathbf{~ M H z}$

| Type of <br> Synchronization <br> Selected | CPU Running | CPU Halted |
| :--- | :---: | :---: |
| Unsynchronized <br> Source Synch <br> Destination Synch | 2.0 MBytes $/ \mathrm{sec}$ <br> 2.0 MBytes $/ \mathrm{sec}$ | $2.0 \mathrm{MBytes} / \mathrm{sec}$ |
| 1.3 MBytes $/ \mathrm{sec}$ | $1.6 \mathrm{MByytes} / \mathrm{sec}$ |  |



Figure 18. DMA Pointer Register Format

## DMA Acknowledge

No explicit DMA acknowledge pulse is provided. Since both source and destination pointers are maintained, a read from a requesting source, or a write to a requesting destination, should be used as the DMA acknowledge signal. Since the chip-select lines can be programmed to be active for a given block of memory or I/O space, and the DMA pointers can be programmed to point to the same given block, a chip-select line could be used to indicate a DMA acknowledge.

## DMA Priority

The DMA channels may be programmed to give one channel priority over the other, or they may be programmed to alternate cycles when both have DMA requests pending. DMA cycles always have priority over internal CPU cycles except between locked memory accesses; also, an external bus hold takes priority over an internal DMA cycle. Because an interrupt request cannot suspend a DMA operation and the CPU cannot access memory during a DMA cycle, interrupt latency time will suffer during sequences of continuous DMA cycles. An NMI request, however, will cause all internal DMA activity to halt. This allows the CPU to quickly respond to the NMI request.

## DMA Programming

DMA cycles will occur whenever the ST/ $\overline{\text { STOP }}$ bit of the Control Register is set. If synchronized transfers are programmed, a DRQ must also be generated. Therefore the source and destination transfer point-
ers, and the transfer count register (if used) must be programmed before the ST/STOP bit is set.

Each DMA register may be modified while the channel is operating. If the CHG/NOCHG bit is cleared when the control register is written, the ST/STOP bit of the control register will not be modified by the write. If multiple channel registers are modified, it is recommended that a LOCKED string transfer be used to prevent a DMA transfer from occurring between updates to the channel registers.

## DMA Channels and Reset

Upon RESET, the state of the DMA channels will be as follows:

- The ST/STOP bit for each channel will be reset to STOP.
- Any transfer in progress is aborted.
- The values of the transfer count registers, source pointers and destination pointers are indeterminate.


## TIMERS

The 80C188 provides three internal 16-bit programmable timers (see Figure 19). Two of these are highly flexible and are connected to four external pins (2 per timer). They can be used to count external events, time external events, generate nonrepetitive waveforms, etc. The third timer is not connected to any external pins, and is useful for real-time coding and time delay applications. In addition, the third timer can be used as a prescaler to the other two, or as a DMA request source.


Figure 19. Timer Block Diagram

## Timer Operation

The timers are controlled by 11 16-bit registers in the peripheral control block. The configuration of these registers is shown in Table 15. The count register contains the current value of the timer. It can be read or written at any time independent of whether the timer is running or not. The value of this register will be incremented for each timer event. Each of the timers is equipped with a MAX COUNT register, which defines the maximum count the timer will reach. After reaching the MAX COUNT register value, the timer count value will reset to zero during that same clock, i.e., the maximum count value is never stored in the count register itself. Timers 0 and 1 are, in addition, equipped with a second MAX COUNT register, which enables the timers to alternate their count between two different MAX COUNT values. If a single MAX COUNT register is used, the timer output pin will switch LOW for a single clock, 1 clock after the maximum count value has been reached. In the dual MAX COUNT register mode, the output pin will indicate which MAX COUNT register is currently in use, thus allowing nearly complete freedom in selecting waveform duty cycles. For the timers with two MAX COUNT registers, the RIU bit in the control register determines which is used for the comparison.

Each timer gets serviced every fourth CPU-clock cycle, and thus can operate at speeds up to one-quarter the internal clock frequency (one-eighth the crystal rate). External clocking of the timers may be done at up to a rate of one-quarter of the internal CPUclock rate. Due to internal synchronization and pipelining of the timer circuitry, a timer output may take up to 6 clocks to respond to any individual clock or gate input.

Since the count registers and the maximum count registers are all 16 bits wide, 16 bits of resolution are provided. Any Read or Write access to the timers will add one wait state to the minimum four-clock bus cycle, however. This is needed to synchronize and coordinate the internal data flows between the internal timers and the internal bus.

The timers have several programmable options.

- All three timers can be set to halt or continue on a terminal count.
- Timers 0 and 1 can select between internal and external clocks, alternate between MAX COUNT registers and be set to retrigger on external events.
- The timers may be programmed to cause an interrupt on terminal count.

These options are selectable via the timer mode/ control word.

## Timer Mode/Control Register

The mode/control register (see Figure 20) allows the user to program the specific mode of operation or check the current programmed status for any of the three integrated timers.

Table 15. Timer Control Block Format

| Register Name | Register Offset |  |  |
| :--- | :---: | :---: | :---: |
|  | Tmr. 0 | Tmr. 1 | Tmr. 2 |
| Mode/Control Word | 56 H | 5 EH | 66 H |
| Max Count B | 54 H | 5 CH | not present |
| Max Count A | 52 H | 5 AH | 62 H |
| Count Register | 50 H | 58 H | 60 H |


| 15 | 14 | 13 | $\mathbf{1 2}$ | $\mathbf{1 1}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | 1 | 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EN | $\overline{\mathrm{NH}}$ | INT | RIU | 0 | $\ldots$ | MC | RTG | P | EXT | ALT | CONT |

Figure 20. Timer Mode/Control Register

## EN:

The enable bit provides programmer control over the timer's RUN/HALT status. When set, the timer is enabled to increment subject to the input pin constraints in the internal clock mode (discussed previously). When cleared, the timer will be inhibited from counting. All input pin transistions during the time EN is zero will be ignored. If CONT is zero, the EN bit is automatically cleared upon maximum count.

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

The inhibit bit allows for selective updating of the enable (EN) bit. If INH is a one during the write to the mode/control word, then the state of the EN bit will be modified by the write. If $\overline{\mathrm{INH}}$ is a zero during the write, the EN bit will be unaffected by the operation. This bit is not stored; it will always be a 0 on a read.

## INT:

When set, the INT bit enables interrupts from the timer, which will be generated on every terminal count. If the timer is configured in dual MAX CONT register mode, an interrupt will be generated each time the value in MAX COUNT register $A$ is reached, and each time the value in MAX COUNT register B is reached. If this enable bit is cleared after the interrupt request has been generated, but before a pending interrupt is serviced, the interrupt request will still be in force. (The request is latched in the Interrupt Controller).

## RIU:

The Register In Use bit indicates which MAX COUNT register is currently being used for comparison to the timer count value. A zero value indicates register A. The RIU bit cannot be written, i.e., its value is not affected when the control register is written. It is always cleared when the ALT bit is zero.

## MC:

The Maximum Count bit is set whenever the timer reaches its final maximum count value. If the timer is configured in dual MAX COUNT register mode, this bit will be set each time the value in MAX COUNT register $A$ is reached, and each time the value in MAX COUNT register B is reached. This bit is set regardless of the timer's interrupt-enable bit. The MC bit gives the user the ability to monitor timer status through software instead of through interrupts.

Programmer intervention is required to clear this bit.

## RTG:

Retrigger bit is only active for internal clocking (EXT $=0$ ). In this case it determines the control function provided by the input pin.

If RTG $=0$, the input level gates the internal clock on and off. If the input pin is HIGH, the timer will count; if the input pin is LOW, the timer will hold its value. As indicated previously, the input signal may be asynchronous with respect to the 80C188 clock.

When RTG $=1$, the input pin detects LOW-to-HIGH transitions. The first such transition starts the timer running, clearing the timer value to zero on the first clock, and then incrementing thereafter. Further transitions on the input pin will again reset the timer to zero, from which it will start counting up again. If CONT $=0$, when the timer has reached maximum count, the EN bit will be cleared, inhibiting further timer activity.

## P:

The prescaler bit is ignored unless internal clocking has been selected (EXT $=0$ ). If the $P$ bit is a zero, the timer will count at one-fourth the internal CPU clock rate. If the P bit is a one, the output of timer 2 will be used as a clock for the timer. Note that the user must initialize and start timer 2 to obtain the prescaled clock.

## EXT:

The external bit selects between internal and external clocking for the timer. The external signal may be asynchronous with respect to the 80 C 188 clock. If this bit is set, the timer will count LOW-to-HIGH transitions on the input pin. If cleared, it will count an internal clock while using the input pin for control. In this mode, the function of the external pin is defined by the RTG bit. The maximum input to output transition latency time may be as much as 6 clocks. However, clock inputs may be pipelined as closely together as every 4 clocks without losing clock pulses.

## ALT:

The ALT bit determines which of two MAX COUNT registers is used for count comparison. If ALT $=0$, register A for that timer is always used, while if ALT $=1$, the comparison will alternate between register A and register B when each maximum count is reached. This alternation allows the user to change one MAX COUNT register while the other is being used, and thus provides a method of generating non-repetitive waveforms. Square waves and pulse outputs of any duty cycle are a subset of available signals obtained by not changing the final count registers. The ALT bit also determines the function of the timer output pin. If ALT is zero, the output pin will go LOW for one clock, the clock after the maximum count is reached. If ALT is one, the output pin will reflect the current MAX COUNT register being used ( $0 / 1$ for $B / A$ ).

## CONT:

Setting the CONT bit causes the associated timer to run continuously, while resetting it causes the timer to halt upon maximum count. If CONT $=0$ and ALT = 1 , the timer will count to the MAX COUNT register A value, reset, count to the register B value, reset, and halt.

Not all mode bits are provided for timer 2. Certain bits are hardwired as indicated below:

$$
A L T=0, E X T=0, P=0, R T G=0, R I U=0
$$

## Count Registers

Each of the three timers has a 16 -bit count register. The contents of this register may be read or written by the processor at any time. If the register is written while the timer is counting, the new value will take effect in the current count cycle.

The count registers should be programmed before attempting to use the timers since they are not automatically initialized to zero.

## Max Count Registers

Timers 0 and 1 have two MAX COUNT registers, while timer 2 has a single MAX COUNT register. These contain the number of events the timer will count. In timers 0 and 1, the MAX COUNT register used can alternate between the two max count values whenever the current maximum count is reached.

A timer resets when the timer count register equals the max count value being used. If the timer count register or the max count register is changed so that the max count is less than the timer count, the timer does not immediately reset. Instead, the timer counts up to OFFFFH, "wraps around" to zero, counts up to the max count value, and then resets.

## Timers and Reset

Upon RESET, the state of the timers will be as follows:

- All EN (Enable) bits are reset preventing timer counting.
- For Timers 0 and 1 , the RIU bits are reset to zero and the ALT bits are set to one. This results in the Timer Out pins going HIGH.
- The contents of the count registers are indeterminate.


## INTERRUPT CONTROLLER

The 80C188 can receive interrupts from a number of sources, both internal and external. The internal interrupt controller serves to merge these requests on a priority basis, for individual service by the CPU.

Internal interrupt sources (Timers and DMA channels) can be disabled by their own control registers or by mask bits within the interrupt controller. The 80 C 188 interrupt controller has its own control register that sets the mode of operation for the controller.

The interrupt controller will resolve priority among requests that are pending simultaneously. Nesting is provided so interrupt service routines for lower priority interrupts may be interrupted by higher priority interrupts. A block diagram of the interrupt controller is shown in Figure 21.

The 80C188 has a special Slave Mode in which the internal interrupt controller acts as a slave to an external master. The controller is programmed into this mode by setting bit 14 in the peripheral control block relocation register. (See Slave Mode section.)

## MASTER MODE OPERATION

## Interrupt Controller External Interface

Five pins are provided for external interrupt sources. One of these pins is NMI, the non-maskable interrupt. NMI is generally used for unusual events such as power-fail interrupts. The other four pins may be configured in any of the following ways:

- As four interrupt input lines with internally generated interrupt vectors.
- As an interrupt line and interrupt acknowledge line pair (cascade mode) with externally generated interrupt vectors plus two interrupt input lines with internally generated vectors.
- As two pairs of interrupt/interrupt acknowledge lines (Cascade Mode) with externally generated interrupt vectors.

External sources in the Cascade Mode use externally generated interrupt vectors. When an interrupt is acknowledged, two INTA cycles are initiated and the vector is read into the 80 C 188 on the second cycle. The capability to interface to external 82C59A programmable interrupt controllers is provided when the inputs are configured in Cascade Mode.

## Interrupt Controller Modes of Operation

The basic modes of operation of the interrupt controller in master mode are similar to the 82C59A. The interrupt controller responds identically to internal interrupts in all three modes: the difference is only in the interpretation of function of the four external interrupt pins. The interrupt controller is set into one of these three modes by programming the correct bits in the INTO and INT1 control registers. The modes of interrupt controller operation are as follows:

## Fully Nested Mode

When in the fully nested mode four pins are used as direct interrupt requests as in Figure 22. The vectors for these four inputs are generated internally. An inservice bit is provided for every interrupt source. If a lower-priority device requests an interrupt while the in service bit (IS) is set, no interrupt will be generated by the interrupt controller. In addition, if another interrupt request occurs from the same interrupt source while the in-service bit is set, no interrupt will be generated by the interrupt controller. This allows interrupt service routines to operate with interrupts enabled, yet be suspended only by interrupts of higher priority than the in-service interrupt.

When a service routine is completed, the proper is bit must be reset by writing the proper pattern to the EOI register. This is required to allow subsequent interrupts from this interrupt source and to allow servicing of lower-priority interrupts. An EOI com-
mand is executed at the end of the service routine just before the return from interrupt instruction. If the fully nested structure has been upheld, the next highest-priority source with its IS bit set is then serviced.

## Cascade Mode

The 80C188 has four interrupt pins and two of them have dual functions. In the fully nested mode the four pins are used as direct interrupt inputs and the corresponding vectors are generated internally. In the Cascade Mode, the four pins are configured into interrupt input-dedicated acknowledge signal pairs. The interconnection is shown in Figure 23. INTO is an interrupt input interfaced to an 82C59A, while INT2//ָNTAO serves as the dedicated interrupt acknowledge signal to that peripheral. The same is true for INT1 and INT3/INTA1. Each pair can selectively be placed in the Cascade or non-Cascade Mode by programming the proper value into INTO and INT1 control registers. The use of the dedicated acknowledge signals eliminates the need for the use of external logic to generate $\overline{\text { NTA }}$ and device select signals.

The primary Cascade Mode allows the capability to serve up to 128 external interrupt sources through the use of external master and slave 82C59As. Three levels of priority are created, requiring priority resolution in the 80 C 188 interrupt controller, the master 82C59As, and the slave 82C59As. If an external interrupt is serviced, one IS bit is set at each of these levels. When the interrupt service routine is completed, up to three end-of-interrupt commands must be issued by the programmer.


Figure 21. Interrupt Controller Block Diagram


Figure 22. Fully Nested (Direct) Mode Interrupt Controller Connections

## Special Fully Nested Mode

This mode is entered by setting the SFNM bit in INT0 or INT1 control register. It enables complete nestability with external 82C59A masters. Normally, an interrupt request from an interrupt source will not be recognized unless the in-service bit for that source is reset. If more than one interrupt source is connected to an external interrupt controller, all of the interrupts will be funneled through the same 80C188 interrupt request pin. As a result, if the external interrupt controller receives a higher-priority interrupt, its interrupt will not be recognized by the 80C188 controller until the 80C188 in-service bit is reset. In Special Fully Nested Mode, the 80C188 interrupt controller will allow interrupts from an external pin regardless of the state of the in-service bit for an interrupt source in order to allow multiple interrupts from a single pin. An in-service bit will continue to be set, however, to inhibit interrupts from other lower-priority 80C188 interrupt sources.

Special procedures should be followed when resetting IS bits at the end of interrupt service routines. Software polling of the IS register in the external master 82C59A is required to determine if there is more than one bit set. If so, the IS bit in the 80C188 remains active and the next interrupt service routine is entered.

## Operation in a Polled Environment

The controller may be used in a polled mode if interrupts are undesirable. When polling, the processor disables interrupts and then polls the interrupt controller whenever it is convenient. Polling the interrupt controller is accomplished by reading the Poll Word (Figure 32). Bit 15 in the poll word indicates to the processor that an interrupt of high enough priority is requesting service. Bits $0-4$ indicate to the processor the type vector of the highest-priority source requesting service. Reading the Poll Word causes the In-Service bit of the highest priority source to be set.

It is desirable to be able to read the Poll Word information without guaranteeing service of any pending
interrupt, i.e., not set the indicated in-service bit. The 80C188 provides a Poll Status Word in addition to the conventional Poll Word to allow this to be done. Poll Word information is duplicated in the Poll Status Word, but reading the Poll Status Word does not set the associated in-service bit. These words are located in two adjacent memory locations in the register file.

## Master Mode Features

## Programmable Priority

The user can program the interrupt sources into any of eight different priority levels. The programming is done by placing a 3 -bit priority level $(0-7)$ in the control register of each interrupt source. (A source with a priority level of 4 has higher priority over all priority levels from 5 to 7 . Priority registers containing values lower than 4 have greater priority). All interrupt sources have preprogrammed default priority levels (see Table 4).

If two requests with the same programmed priority level are pending at once, the priority ordering scheme shown in Table 4 is used. If the serviced interrupt routine reenables interrupts, other interrupt requests can be serviced.

## End-of-Interrupt Command

The end-of-interrupt (EOI) command is used by the programmer to reset the In-Service (IS) bit when an interrupt service routine is completed. The EOI command is issued by writing the proper pattern to the EOI register. There are two types of EOI commands, specific and nonspecific. The nonspecific command does not specify which IS bit is reset. When issued, the interrupt controller automatically resets the IS bit of the highest priority source with an active service routine. A specific EOI command requires that the programmer send the interrupt vector type to the interrupt controller indicating which source's IS bit is to be reset. This command is used when the fully nested structure has been disturbed or the highest priority IS bit that was set does not belong to the service routine in progress.

## Trigger Mode

The four external interrupt pins can be programmed in either edge- or level-trigger mode. The control register for each external source has a level-trigger mode (LTM) bit. All interrupt inputs are active HIGH. In the edge sense mode or the level-trigger mode, the interrupt request must remain active (HIGH) until the interrupt request is acknowledged by the

80C188 CPU. In the edge-sense mode, if the level remains high after the interrupt is acknowledged, the input is disabled and no further requests will be generated. The input level must go LOW for at least one clock cycle to re-enable the input. In the level-trigger mode, no such provision is made: holding the interrupt input HIGH will cause continuous interrupt requests.

## Interrupt Vectoring

The 80C186 Interrupt Controller will generate interrupt vectors for the integrated DMA channels and the integrated Timers. In addition, the Interrupt Controller will generate interrupt vectors for the external interrupt lines if they are not configured in Cascade or Special Fully Nested Mode. The interrupt vectors generated are fixed and cannot be changed (see Table 4).

## Interrupt Controller Registers

The Interrupt Controller register model is shown in Figure 24. It contains 15 registers. All registers can both be read or written unless specified otherwise.

## In-Service Register

This register can be read from or written into. The format is shown in Figure 25. It contains the In-Service bit for each of the interrupt sources. The In-Service bit is set to indicate that a source's service routine is in progress. When an In-Service bit is set, the interrupt controller will not generate interrupts to the CPU when it receives interrupt requests from devices with a lower programmed priority level. The TMR bit is the In-Service bit for all three timers; the D0 and D1 bits are the In-Service bits for the two DMA channels; the $10-13$ are the In -Service bits for the
external interrupt pins. The IS bit is set when the processor acknowledges an interrupt request either by an interrupt acknowledge or by reading the poll register. The IS bit is reset at the end of the interrupt service routine by an end-of-interrupt command.

## Interrupt Request Register

The internal interrupt sources have interrupt request bits inside the interrupt controller. The format of this register is shown in Figure 25. A read from this register yields the status of these bits. The TMR bit is the logical OR of all timer interrupt requests. D0 and D1 are the interrupt request bits for the DMA channels.

The state of the external interrupt input pins is also indicated. The state of the external interrupt pins is not a stored condition inside the interrupt controller, therefore the external interrupt bits cannot be written. The external interrupt request bits are set when an interrupt request is given to the interrupt controller, so if edge-triggered mode is selected, the bit in the register will be HIGH only after an inactive-to-active transition. For internal interrupt sources, the register bits are set when a request arrives and are reset when the processor acknowledges the requests.

Writes to the interrupt request register will affect the D0 and D1 interrupt request bits. Setting either bit will cause the corresponding interrupt request while clearing either bit will remove the corresponding interrupt request. All other bits in the register are readonly.

## Mask Register

This is a 16-bit register that contains a mask bit for each interrupt source. The format for this register is shown in Figure 25. A one in a bit position corre-


Figure 23. Cascade and Special Fully Nested Mode Interrupt Controller Connections
sponding to a particular source masks the source from generating interrupts. These mask bits are the exact same bits which are used in the individual control registers; programming a mask bit using the mask register will also change this bit in the individual control registers, and vice versa.


## Priority Mask Register

This register masks all interrupts below a particular interrupt priority level. The format of this register is shown in Figure 26. The code in the lower three bits of this register inhibits interrupts of priority lower (a higher priority number) than the code specified. For example, 100 written into this register masks interrupts of level five (101), six (110), and seven (111). The register is reset to seven (111) upon RESET so no interrupts are masked due to priority number.

## Interrupt Status Register

This register contains general interrupt controller status information. The format of this register is shown in Figure 27. The bits in the status register have the following functions:
DHLT: DMA Halt Transfer; setting this bit halts all DMA transfers. It is automatically set whenever a non-maskable interrupt occurs, and it is reset when an IRET instruction is executed. This bit allows prompt service of all nonmaskable interrupts. This bit may also be set by the programmer.
IRTx: These three bits represent the individual timer interrupt request bits. These bits differentiate between timer interrupts, since the timer IR bit in the interrupt request register is the "OR" function of all timer interrupt request. Note that setting any one of these three bits initiates an interrupt request to the interrupt controller.

Figure 24. Interrupt Controller Registers
(Master Mode)


Figure 25. In-Service, Interrupt Request, and Mask Register Formats


Figure 26. Priority Mask Register Format


Figure 27. Interrupt Status Register Format (Master Mode)

Timer, DMA 0, 1; Control Register

These registers are the control words for all the internal interrupt sources. The format for these registers is shown in Figure 28. The three bit positions PRO, PR1, and PR2 represent the programmable priority level of the interrupt source. The MSK bit inhibits interrupt requests from the interrupt source. The MSK bits in the individual control registers are the exact same bits as are in the Mask Register; modifying them in the individual control registers will also modify them in the Mask Register, and vice versa.

## INTO-INT3 Control Registers

These registers are the control words for the four external input pins. Figure 29 shows the format of the INTO and INT1 Control registers; Figure 30 shows the format of the INT2 and INT3 Control registers. In Cascade Mode or Special Fully Nested Mode, the control words for INT2 and INT3 are not used.

The bits in the various control registers are encoded as follows:
PRO-2: Priority programming information. Highest Priority $=000$, Lowest Priority $=111$
LTM: Level-trigger mode bit. $1=$ level-triggered; $0=$ edge-triggered. Interrupt Input levels are active high. In level-triggered mode, an interrupt is generated whenever the external line is high. In edge-triggered mode, an interrupt will be generated only when this
level is preceded by an inactive-to-active transition on the line. In both cases, the level must remain active until the interrupt is acknowledged.
MSK: Mask bit, $1=$ mask; $0=$ non-mask.
C: $\quad$ Cascade mode bit, $1=$ cascade; $0=$ direct
SFNM: Special Fully Nested Mode bit, 1 = SFNM

## EOI Register

The end of the interrupt register is a command register which can only be written into. The format of this register is shown in Figure 31. It initiates an EOI command when written to by the 80C188 CPU.

The bits in the EOI register are encoded as follows:
$S_{x}$ : Encoded information that specifies an interrupt source vector type as shown in Table 4. For example, to reset the In-Service bit for DMA channel 0 , these bits should be set to 01010, since the vector type for DMA channel 0 is 10 .

## NOTE:

To reset the single In-Service bit for any of the three timers, the vector type for timer 0 (8) should be written in this register.

NSPEC/: A bit that determines the type of EOI comSPEC mand. Nonspecific $=1$, Specific $=0$.

Figure 28. Timer/DMA Control Registers Formats

| 15 | 14 |  |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | - | - | - | $\bullet$ | $\bullet$ | 0 | SFNM | C | LTM | MSK | PR2 | PR1 | PRO |

Figure 29. INTO/INT1 Control Register Formats


Figure 30. INT2/INT3 Control Register Formats

## Poll and Poll Status Registers

These registers contain polling information. The format of these registers is shown in Figure 32. They can only be read. Reading the Poll register constitutes a software poll. This will set the IS bit of the highest priority pending interrupt. Reading the poll status register will not set the IS bit of the highest priority pending interrupt; only the status of pending interrupts will be provided.

Encoding of the Poll and Poll Status register bits are as follows:
Sx: Encoded information that indicates the vector type of the highest priority interrupting source. Valid only when INTREQ $=1$.

INTREQ: This bit determines if an interrupt request is present. Interrupt Request = 1; no Interrupt Request $=0$.

## SLAVE MODE OPERATION

When Slave Mode is used, the internal 80 C 188 interrupt controller will be used as a slave controller to an external master interrupt controller. The internal 80C188 resources will be monitored by the internal interrupt controller, while the external controller functions as the system master interrupt controller.

Upon reset, the 80 C 188 will be in master mode. To provide for slave mode operation bit 14 of the relocation register should be set.

Because of pin limitations caused by the need to interface to an external 82C59A master, the internal interrupt controller will no longer accept external inputs. There are however, enough 80 C 188 interrupt controller inputs (internally) to dedicate one to each timer. In this mode, each timer interrupt source has its own mask bit, IS bit, and control word.

In Slave Mode each peripheral must be assigned a unique priority to ensure proper interrupt controller operation. Therefore, it is the programmer's responsibility to assign correct priorities and initialize interrupt control registers before enabling interrupts.

## Slave Mode External Interface

The configuration of the 80C188 with respect to an external 82C59A master is shown in Figure 33. The INTO (Pin 45) input is used as the 80C188 CPU interrupt input. IRQ (Pin 41) functions as an output to send the 80C188 slave-interrupt-request to one of the 8 master-PIC-inputs.

| 15 | 14 | 13 |  |  |  |  |  |  |  | 5 | 4 | 3 | 2 | 10 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SPEC/ NSPEC | 0 | 0 | $\bullet$ | $\bullet$ | - | - | - | - | $\bullet$ | 0 | S4 | S3 | S2 | S1 | S0 |

Figure 31. EOI Register Format


Figure 32. Poll and Poll Status Register Format


270432-20
Figure 33. Slave Mode Interrupt Controller Connections

Correct master-slave interface requires decoding of the slave addresses (CASO-2). Slave 82C59As do this internally. Because of pin limitations, the 80C188 slave address will have to be decoded externally. SELECT (Pin 44) is used as a slave-select input. Note that the slave vector address is transferred internally, but the READY input must be supplied externally.
$\overline{\text { INTAO }}$ (Pin 42) is used as an acknowledge output, suitable to drive the INTA input of an 82C59A.

## Interrupt Nesting

Slave Mode operation allows nesting of interrupt requests. When an interrupt is acknowledged, the priority logic masks off all priority levels except those with equal or higher priority.

## Vector Generation in the Slave Mode

Vector generation in Slave Mode is exactly like that of an 8259A or 82C59A slave. The interrupt controller generates an 8 -bit vector type number which the CPU multiplies by four to use as andress into the vector table. The five most significant bits of this type number are user-programmable while the three least significant bits are defined according to Figure 34. The significant five bits of the vector are programmed by writing to the Interrupt Vector register at offset 20 H .

## Specific End-of-Interrupt

In Slave Mode the specific EOI command operates to reset an in-service bit of a specific priority. The user supplies a 3-bit priority-level value that points to an in-service bit to be reset. The command is executed by writing the correct value in the Specific EOI register at offset 22 H .

## Interrupt Controller Registers in the Slave Mode

All control and command registers are located inside the internal peripheral control block. Figure 34 shows the offsets of these registers.

## End-of-Interrupt Register

The end-of-interrupt register is a command register which can only be written. The format of this register is shown in Figure 35. It initiates an EOI command when written by the 80C188 CPU.

The bits in the EOI register are encoded as follows:
$V T_{x}$ : Three least-significant vector type bits corresponding to the source for which the IS bit is to be reset. Figure 34 indicates these bits.

## In-Service Register

This register can be read from or written into. It contains the in-service bit for each of the internal interrupt sources. The format for this register is shown in Figure 36. Bit positions 2 and 3 correspond to the DMA channels; positions 0,4 , and 5 correspond to the integral timers. The source's IS bit is set when the processor acknowledges its interrupt request.

## Interrupt Request Register

This register indicates which internal peripherals have interrupt requests pending. The format of this register is shown in Figure 36. The interrupt request bits are set when a request arrives from an internal source, and are reset when the processor acknowledges the request. As in Master Mode, D0 and D1 are read/write; all other bits are read only.

## Mask Register

This register contains a mask bit for each interrupt source. The format for this register is shown in Figure 36. If the bit in this register corresponding to a particular interrupt source is set, any interrupts from that source will be masked. These mask bits are exactly the same bits which are used in the individual control registers, i.e., changing the state of a mask bit in this register will also change the state of the mask bit in the individual interrupt control register corresponding to the bit.

## Control Registers

These registers are the control words for all the internal interrupt sources. The format of these registers is shown in Figure 37. Each of the timers and both of the DMA channels have their own Control Register.

The bits of the Control Registers are encoded as follows:
prx: 3-bit encoded field indicating a priority level for the source.
msk: mask bit for the priority level indicated by $\mathrm{pr}_{\mathrm{x}}$ bits.

| TIMER 2 CONTROL REGISTER | offset <br> ЗАН |
| :---: | :---: |
| (VECTOR TYPE $\times \times \times \times \times 101$ ) |  |
| TIMER 1 CONTROL REGISTER (VECTOR TYPE xxxxx100) | 38 H |
| DMA 1 CONTROL REGISTER (VECTOR TYPE xxxxx011) | 36H |
| DMA O CONTROL REGISTER (VECTOR TYPE $\times x x x \times 010$ ) | 34 H |
| TIMER O CONTROL REGISTER (VECTOR TYPE xxxxx000) | 32 H |
| INTERRUPT STATUS REGISTER | 30 H |
| Interrupt-request register | 2 EH |
| IN-SERVICE REGISTER | 2 CH |
| PRIORITY-LEVEL MASK REGISTER | 2 AH |
| MASK REGISTER | 28 H |
| SPECIFIC EOI REGISTER | ${ }^{22 \mathrm{H}}$ |
| Interrupt vector register | 20 H |

Figure 34. Interrupt Controller Registers (Slave Mode)

| 15 | 14 | 13 |  |  |  |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | - | - | - | - | 0 | 0 | 0 | 0 | 0 | 0 | VT2 | VT1 | VT0 |

Figure 35. Specific EOI Register Format

| 15 | 14 | $\mathbf{1 3}$ | $\mathbf{8}$ | $\mathbf{7}$ | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | 0 | 0 | 0 | TMR2 | TMR1 | D1 | D0 | 0 |

Figure 36. In-Service, Interrupt Request, and Mask Register Format

## Interrupt Vector Register

This register provides the upper five bits of the interrupt vector address. The format of this register is shown in Figure 38. The interrupt controller itself provides the lower three bits of the interrupt vector as determined by the priority level of the interrupt request.

The format of the bits in this register is:
$\mathrm{t}_{\mathrm{x}}$ : 5 -bit field indicating the upper five bits of the vector address.

## Priority-Level Mask Register

This register indicates the lowest priority-level interrupt which will be serviced.

The encoding of the bits in this register is:
$m_{x}$ : 3-bit encoded field indication priority-level value. All levels of lower priority will be masked.

## Interrupt Controller and Reset

Upon RESET, the interrupt controller will perform the following actions:

- All SFNM bits reset to 0 , implying Fully Nested Mode.
- All PR bits in the various control registers set to 1. This places all sources at lowest priority (level 111).
- All LTM bits reset to 0 , resulting in edge-sense mode.
- All Interrupt Service bits reset to 0.
- All interrupt Request bits reset to 0 .
- All MSK (Interrupt Mask) bits set to 1 (mask).
- All C (Cascade) bits reset to 0 (non-Cascade).
- All PRM (Priority Mask) bits set to 1 , implying no levels masked.
- Initialized to Master Mode.


## Interrupt Status Register

This register is defined as in Master Mode except that DHLT is not implemented (see Figure 27).

## Enhanced Mode Operation

In Compatible Mode the 80C188 operates with all the features of the NMOS 80188, with the exception of 8087 support (i.e. no numeric coprocessing is possible). Queue-Status information is still available for design purposes other than 8087 support.

All the Enhanced Mode features are completely masked when in Compatible Mode. A write to any of the Enhanced Mode registers will have no effect, while a read will not return any valid data.

In Enhanced Mode, the 80C188 will operate with Power-Save and DRAM refresh, in addition to all the Compatible Mode features.

## Entering Enhanced Mode

Enhanced mode can be entered by tying the RESET output signal from the 80C188 to the TEST/BUSY input.

## Queue-Status Mode

The queue-status mode is entered by strapping the $\overline{R D}$ pin low. $\overline{R D}$ is sampled at RESET and if LOW, the 80C188 will reconfigure the ALE and WR pins to be QS0 and QS1 respectively. This mode is available on the 80 C 188 in both Compatible and Enhanced Modes.

## DRAM Refresh Control Unit Description

The Refresh Control Unit (RCU) automatically generates DRAM refresh bus cycles. The RCU operates only in Enhanced Mode. After a programmable period of time, the RCU generates a memory read request to the BIU. If the address generated during a refresh bus cycle is within the range of a properly programmed chip select, that chip select will be activated when the BIU executes the refresh bus cycle. The ready logic and wait states programmed for that region will also be in force. If no chip select is activated, then external ready is automatically required to terminate the refresh bus cycle.

If the HLDA pin is active when a DRAM refresh request is generated (indicating a bus hold condition), then the 80 C 188 will deactivate the HLDA pin in order to perform a refresh cycle. The circuit external to the 80C188 must remove the HOLD signal for at least one clock in order to execute the refresh cycle. The sequence of HLDA going inactive while HOLD is being held active can be used to signal a pending refresh request.

All registers controlling DRAM refresh may be read and written in Enhanced Mode. When the processor is operating in Compatible Mode, they are deselected and are therefore inaccessible. Some fields of these registers cannot be written and are always read as zeros.

## DRAM Refresh Addresses

The address generated during a refresh cycle is determined by the contents of the MDRAM register (see Figure 40) and the contents of a 9 -bit counter. Figure 41 illustrates the origin of each bit.

Bits 0-8: Reserved, read back as 0.
Bits 9-15: M0-M6, are address bits A13-A19 of the 20-bit memory refresh address. These bits should correspond to any chip select address to be activated for the DRAM partition. These bits are cleared to 0 on RESET.

Figure 40. Memory Partition Register

| A19 | A18 | A17 | A16 | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M6 | M5 | M4 | M3 | M2 | M1 | M0 | 0 | 0 | 0 | CAB | CA7 | CA6 | CA5 | CA4 | CA3 | CA2 | CA1 | CAO | 1 |

M6-M0: Bits defined by MDRAM Register
CA8-CAO: Bits defined by refresh address counter. These bits change according to a linear/feedback shift register; they do not directly follow a binary count.

Figure 41. Addresses Generated by RCU

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CDRAM: Offset E2H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C8 | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 |

Bits 0-8: C0-C8, clock divisor register, holds the number of CLKOUT cycles between each refresh request.
Bits 9-15: Reserved, read back as 0.
Figure 42. Clock Pre-Scaler Register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EDRAM: <br> Offset E4H | E | 0 | 0 | 0 | 0 | 0 | 0 | T8 | T7 | T6 | T5 | T4 | T3 | T2 | T1 | T0 |

Bits 0-8: T0-T8, refresh clock counter outputs. Read only.
Bits 9-14: Reserved, read back as 0 .
Bit 15: Enable RCU, set to 0 on RESET.
Figure 43. Enable RCU Register

## Refresh Control Unit Programming and Operation

After programming the MDRAM and the CDRAM registers (Figures 40 and 42), the RCU is enabled by setting the " $E$ " bit in the EDRAM register (Figure 43). The clock counter (T0-T8 of EDRAM) will be loaded from $\mathrm{CO}-\mathrm{C8}$ of CDRAM during $\mathrm{T}_{3}$ of instruction cycle that sets the " $E$ " bit. The clock counter is then decremented at each subsequent CLKOUT.

A refresh is requested when the value of the counter has reached 1 and the counter is reloaded from CDRAM. In order to avoid missing refresh requests, the value in the CDRAM register should always be at least 18 ( 12 H ). Clearing the "E" bit at anytime will clear the counter and stop refresh requests, but will not reset the refresh address counter.

## POWER-SAVE CONTROL

## Power Save Operation

The 80C188, when in Enhanced Mode, can enter a power saving state by internally dividing the processor clock frequency by a programmable factor. This divided frequency is also available at the CLKOUT
pin. The PDCON register contains the two-bit fields for selecting the clock division factor and the enable bit.

All internal logic, including the Refresh Control Unit and the timers, will have their clocks slowed down by the division factor. To maintain a real time count or a fixed DRAM refresh rate, these peripherals must be re-programmed when entering and leaving the power-save mode.

The power-save mode is exited whenever an interrupt is processed by automatically resetting the enable bit. If the power-save mode is to be re-entered after serving the interrupt, the enable bit will need to be set in software before returning from the interrupt routine.

The internal clocks of the 80 C 188 will begin to be divided during the $T_{3}$ state of the instruction cycle that sets the enable bit. Clearing the enable bit will restore full speed in the $T_{3}$ state of that instruction.

At no time should the internal clock frequency be allowed to fall below 0.5 MHz . This is the minimum operational frequency of the 80 C 188 . For example, an 80 C 188 running with a 12 MHz crystal ( 6 MHz CLOCKOUT) should never have a clock divisor greater than eight.

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PDCON: | E | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | F1 | F0 |

Bits 0-1: Clock Divisor Select

| F1 | F0 | Division Factor |
| ---: | :---: | :--- |
| 0 | 0 | divide by 1 |
| 0 | 1 | divide by 4 |
| 1 | 0 | divide by 8 |
| 1 | 1 | divide by 16 |

Bits 2-14: Reserved, read back as zero.
Bit 15: Enable Power Save Mode. Set to zero on RESET.
Figure 44. Power-Save Control Register

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80 C 188 has a test mode available which allows all pins to be placed in a high-impedance state. ONCE stands for "ON Circuit Emulation". When placed in this mode, the 80C188 will put all pins in the high-impedance state until RESET.

The ONCE mode is selected by tying the $\overline{U C S}$ and the LCS LOW during RESET. These pins are sampled on the low-to-high transition of the RES pin. The UCS and the LCS pins have weak internal pullup resistors similar to the $\overline{R D}$ and TEST pins to guarantee normal operation.


Figure 45. Typical 80C188 Computer

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias $\ldots .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground -1.0 V to +7.0 V
Package Power Dissipation $\qquad$
Not to exceed the maximum allowable die temperature based on thermal resistance of the package.

NOTICE: This data sheet contains preliminary information on new products in production. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## D.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (Except X1) | -0.5 | $0.2 \mathrm{~V}_{C C}-0.3$ | V |  |
| $\mathrm{V}_{\text {IL2 }}$ | Clock Input Low Voltage (X1) | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{1 \text { H }}$ | Input High Voltage (All except X1, RES, ARDY and SRDY) | 0.2 $\mathrm{V}_{\mathrm{CC}}+0.9$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{1+1}$ | Input High Voltage ( $\overline{\text { RES }}$ ) | 3.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{H} 2}$ | Input High Voltage (SRDY, ARDY) | $0.2 \mathrm{~V}_{\mathrm{CC}}+1.1$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{H} 3}$ | Clock Input High Voltage (X1) | 3.9 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\begin{aligned} & \mathrm{lOL}=2.5 \mathrm{~mA}(\mathrm{SO}, 1,2) \\ & \mathrm{loL}=2.0 \mathrm{~mA} \text { (others) } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{l}^{\mathrm{OH}}=-2.4 \mathrm{~mA} @ 2.4 \mathrm{~V}(4)$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}-0.5$ | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{l}_{\mathrm{OH}}=-200 \mu \mathrm{~A} @ \mathrm{~V}_{\mathrm{CC}}-0.5$ |
| ICC | Power Supply Current |  | 150 | mA | $\begin{aligned} & @ 16 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}(3) \end{aligned}$ |
|  |  |  | 120 | mA | $\begin{aligned} & @ 12.5 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3) \end{aligned}$ |
|  |  |  | 100 | mA | @10 MHz, $0^{\circ} \mathrm{C}$ $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3)$ |
| LII | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & @ 0.5 \mathrm{MHz} \\ & 0.45 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| Lio | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & @ 0.5 \mathrm{MHz} \\ & 0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}}{ }^{(1)} \end{aligned}$ |
| $\mathrm{V}_{\text {CLO }}$ | Clock Output Low |  | 0.45 | V | $\mathrm{ICLO}=4.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{CHO}}$ | Clock Output High | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{I}_{\mathrm{CHO}}=-500 \mu \mathrm{~A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 10 | pF | @ $1 \mathrm{MHz}{ }^{(2)}$ |
| $\mathrm{ClO}_{10}$ | Output or I/O Capacitance |  | 20 | pF | @ 1 MHz ${ }^{(2)}$ |

## NOTES:

1. Pins being floated during HOLD or by invoking the ONCE Mode.
2. Characterization conditions are a) Frequency $=1 \mathrm{MHz}$; b) Unmeasured pins at GND; c) $\mathrm{V}_{\mathbb{I N}}$ at +5.0 V or 0.45 V . This parameter is not tested.
3. Current is measured with the device in RESET with X1 and X2 driven and all other non-power pins open.
4. $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{T E S T}$ pins have internal pullup devices. Loading some of these pins above $\mathrm{l}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ can cause the 80 C 188 to go into alternative modes of operation. See the section on Local Bus Controller and Reset for details.

## POWER SUPPLY CURRENT

Current is linearly proportional to clock frequency and is measured with the device in RESET with X1 and X2 driven and all other non-power pins open.

Maximum current is given by $\mathrm{I}_{\mathrm{CC}}=8.4 \mathrm{~mA} \times$ freq. $(\mathrm{MHz})+15 \mathrm{~mA}$.

Typical current is given by $\mathrm{I}_{\mathrm{CC}}$ (typ.) $=6.4 \mathrm{~mA} \mathrm{X}$ freq. (MHz) +4.0 mA . "Typicals" are based on a limited number of samples taken from early manufacturing lots measured at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and room temperature. "Typicals" are not guaranteed.


Figure 46. Icc vs Frequency

## A. C. CHARACTERISTICS

## MAJOR CYCLE TIMINGS (READ CYCLE)

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $C_{L}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $C_{L}=50-100 \mathrm{pF}$ (12.5-16 MHz).
For A.C. tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at XI where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | $80 \mathrm{C188}$ |  | 80C188-12 |  | 80C188-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |


80C188 GENERAL TIMING RESPONSES (Listed More Than Once)

| $\mathrm{T}_{\text {CHSV }}$ | Status Active Delay | 5 | 45 | 5 | 35 | 5 | 31 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 5 | 46 | 5 | 35 | 5 | 30 | ns |  |
| TCLAV | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 5 | 40 | 5 | 36 | 5 | 33 | ns |  |
| $\mathrm{T}_{\text {CHDX }}$ | Status Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 30 |  | 25 |  | 20 | ns |  |
| $\mathrm{T}_{\text {LHLL }}$ | ALE Width | $\mathrm{T}_{\mathrm{CLCL}}$ - 15 |  | ${ }^{T}$ CLCL - 15 |  | ${ }^{\text {CLLCL }} 15$ |  | ns |  |
| $\mathrm{T}_{\text {CHLL }}$ | ALE Inactive Delay |  | 30 |  | 25 |  | 20 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | $\mathrm{T}_{\text {CLCH }}-18$ |  | $\mathrm{T}_{\text {CLCH }}-15$ |  | T ${ }_{\text {CLCH - }} 15$ |  | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | ${ }^{\text {CHCL - } 15}$ |  | $\mathrm{T}_{\text {CHCL }-15}$ |  | TCHCL - 15 |  | ns | $\begin{aligned} & \text { Equal } \\ & \text { Loading } \\ & \hline \end{aligned}$ |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | 0 |  | ns |  |
| TCLAZ | Address Float Delay | $\mathrm{T}_{\text {CLAX }}$ | 30 | $\mathrm{T}_{\text {CLAX }}$ | 25 | ${ }^{\text {CLLAX }}$ | 20 | ns |  |
| TCLCSV | Chip-Select Active Delay | 3 | 42 | 3 | 33 | 3 | 30 | ns |  |
| TCxcsx | Chip-Select Hold from Command Inactive | TCLCH-10 |  | TCLCH - 10 |  | $\mathrm{T}_{\text {CLCH }}-10$ |  | ns | Equal Loading |
| $\mathrm{T}_{\text {CHCSX }}$ | Chip-Select Inactive Delay | 5 | 35 | 5 | 30 | 5 | 25 | ns |  |
| ${ }^{\text {T DXDL }}$ | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 |  | 0 |  | ns | Equal Loading |
| T CVCTV | Control Active Delay 1 | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| $\mathrm{T}_{\text {CVDEX }}$ | $\overline{\mathrm{DEN}}$ Inctive Delay | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| ${ }^{T}$ CHCTV | Control Active Delay 2 | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| ${ }^{T}$ CLLV | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | 3 | 35 | ns |  |
| $80 C 188$ TIMMNG RESPONSES (Read Cycle) |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {AZRL }}$ | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {CLRL }}$ | $\overline{\mathrm{RD}}$ Active Delay | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| TRLRH | $\overline{R D}$ Puise Width | $2 \mathrm{C}_{\text {CLCL }}-30$ |  | $2 \mathrm{CLLCL}^{-25}$ |  | $2 \mathrm{CLCLL}^{-25}$ |  | ns |  |
| TCLRH | $\overline{\text { RD Inactive Delay }}$ | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| $\mathrm{T}_{\text {RHLH }}$ | $\overline{\mathrm{RD}}$ Inactive to ALE High | $\mathrm{T}_{\text {CLCH }}$-14 |  | $\mathrm{T}_{\mathrm{CLCH}}$ - 14 |  | TCLCH - 14 |  | ns | Equal Loading |
| TrHAV | $\overline{\mathrm{RD}}$ Inactive to Address Active | TCLCL - 15 |  | $\mathrm{T}_{\text {CLCL }}$ - 15 |  | TCLCL - 15 |  | ns | Equal Loading |

## A.C. CHARACTERISTICS

## READ CYCLE WAVEFORMS



## NOTES:

1. Status inactive in state preceding $T_{4}$.
2. If latched $A_{1}$ and $A_{2}$ are selected instead of $\overline{P C S 5}$ and $\overline{P C S 6}$, only $T_{C L C S V}$ is applicable.
3. For write cycle followed by read cycle.
4. $T_{1}$ of next bus cycle.
5. Changes in T-state preceding next bus cycle if followed by write.

## A. C. CHARACTERISTICS

## MAJOR CYCLE TIMINGS (WRITE CYCLE)

$T_{A}=0{ }^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}_{ \pm} 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}$ ( $12.5-16 \mathrm{MHz}$ ).
For A.C. tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at XI where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}{ }^{-0.5 \mathrm{~V}}$.

| Symbol | Parameter | 80C188 |  | 80C188-12 |  | 80C188-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 80C188 GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {CHSV }}$ | Status Active Delay | 5 | 45 | 5 | 35 | 5 | 31 | ns |  |
| $\mathrm{T}_{\text {CLSH }}$ | Status Inactive Delay | 5 | 46 | 5 | 35 | 5 | 30 | ns |  |
| TCLAV | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| ${ }^{\text {C CLAX }}$ | Address Hold | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {CLDV }}$ | Data Valid Delay | 5 | 40 | 5 | 36 | 5 | 33 | ns |  |
| $\mathrm{T}_{\text {CHDX }}$ | Status Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 30 |  | 25 |  | 20 | ns |  |
| $\mathrm{T}_{\text {LHLL }}$ | ALE Width | $\mathrm{T}_{\text {CLCL - }} 15$ |  | ${ }^{\text {CLLCL }}$ - 15 |  | ${ }^{T}$ CLCL - 15 |  | ns |  |
| $T_{\text {CHLL }}$ | ALE Inactive Delay |  | 30 |  | 25 | . | 20 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 18 |  | TCLCH-15 |  | TCLCH - 15 |  | ns | $\begin{aligned} & \text { Equal } \\ & \text { Loading } \end{aligned}$ |
| Tllax | Address Hold from ALE Inactive | $\mathrm{T}_{\text {CHCL }}-15$ |  | $\mathrm{T}_{\text {CHCL }}-15$ |  | $\mathrm{T}_{\text {CHCL }}-15$ |  | ns | Equal Loading |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {CLDOX }}$ | Data Hold Time | 3 |  | 3 |  | 3 |  | ns |  |
| $\mathrm{T}_{\text {cVatv }}$ | Control Active Delay 1 | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| $T_{\text {cVatx }}$ | Control Inactive Delay | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| $\mathrm{T}_{\text {CLCSV }}$ | Chip-Select Active Delay | 3 | 42 | 3 | 33 | 3 | 30 | ns |  |
| T Cxcsx | Chip-Select Hold from Command Inactive | TCLCH - 10 |  | TCLCH-10 |  | ${ }^{\text {CLCH - }} 10$ |  | ns | Equal Loading |
| TCHCSX | Chip-Select Inactive Delay | 5 | 35 | 5 | 30 | 5 | 25 | ns |  |
| TDXDL | $\overline{\text { DEN }}$ Inactive to DT/R Low | 0 |  | 0 |  | 0 |  | ns | Equal Loading |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | 3 | 35 | ns |  |

80C188 TIMING RESPONSES (Write Cycle)

| ${ }^{\text {T WLWH }}$ | WR Pulse Width | ${ }^{2 T}$ CLCL - 30 | ${ }^{2} \mathrm{CLLCL}$ - 25 | ${ }^{2} \mathrm{C}_{\text {clCL }}-25$ | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {W WHLLH }}$ | $\overline{\text { WR }}$ Inactive to ALE High | ${ }^{T}$ CLCH - 14 | TCLCH - 14 | ${ }^{T}$ CLCH - 14 | ns | Equal Loading |
| $T_{\text {Whidx }}$ | Data Hold After WR | TCLCL - 34 | TCLCL - 20 | T CLCL - 20 | ns | Equal Loading |
| ${ }^{\text {T Whidex }}$ | $\overline{\text { WR }}$ Inactive to $\overline{\text { DEN }}$ Inactive | TCLCH - 10 | ${ }^{\text {CLLCH }}$ - 10 | $\mathrm{T}_{\text {CLCH - }} 10$ | ns | Equal Loading |

## A.C. CHARACTERISTICS

## WRITE CYCLE WAVEFORMS



NOTES:

1. Status inactive in state preceding $\mathrm{T}_{4}$.
2. If latched $A_{1}$ and $A_{2}$ are selected instead of $\overline{\mathrm{PCS5}}$ and $\overline{\mathrm{PCS}}$, only $\mathrm{T}_{\text {CLCSV }}$ is applicable.
3. For write cycle followed by read cycle.
4. $T_{1}$ of next bus cycle.
5. Changes in T-state preceding next bus cycle if followed by read, INTA, or halt.

## A. C. CHARACTERISTICS

## MAJOR CYCLE TIMINGS (INTERRUPT ACKNOWLEDGE CYCLE)

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}_{ \pm} 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}_{ \pm} 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | 80 C 188 |  | 80C188-12 |  | 80C188-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | M |  |  |

80C188 GENERAL TIMING REQUIREMENTS (Listed More Than Once)

| $T_{\text {DVCL }}$ | Data in Setup (AD) | 15 |  | 15 |  | 15 |  | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLDX | Data in Hold (ADD) | 3 |  | 3 |  | 3 |  | ns |

80C188 GENERAL TIMING RESPONSES (Listed More Than Once)

| ${ }^{\text {CHCHS }}$ | Status Active Delay | 5 | 45 | 5 | 35 | 5 | 31 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\text {CLSH }}$ | Status Inactive Delay | 5 | 46 | 5 | 35 | 5 | 30 | ns |  |
| ${ }^{\text {T CLAV }}$ | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| TAVCH | Address Valid to Clock High | 0 |  | 0 |  | 0 |  | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {CLDV }}$ | Data Valid Delay | 5 | 40 | 5 | 36 | 5 | 33 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 30 |  | 25 |  | 20 | ns |  |
| $\mathrm{T}_{\text {LHLL }}$ | ALE Width | $\mathrm{T}_{\text {CLCL }}-15$ |  | ${ }^{\text {CLLCL - } 15}$ |  | $\mathrm{T}_{\text {CLCL - }} 15$ |  | ns |  |
| $\mathrm{T}_{\text {CHLL }}$ | ALE Inactive Delay |  | 30 | $\cdots$ | 25 |  | 20 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 18 |  | TCLCH - 15 |  | $\mathrm{T}_{\text {CLCH }}-15$ |  | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | $\mathrm{T}_{\text {CHCL }}-15$ |  | $\mathrm{T}_{\text {ChCL }}$ - 15 |  | $\mathrm{T}_{\text {CHCL }}-15$ |  | ns | Equal Loading |
| TCLAZ | Address Float Delay | $\mathrm{T}_{\text {CLAX }}$ | 30 | $\mathrm{T}_{\text {CLAX }}$ | 25 | ${ }^{\text {CCLAX }}$ | 20 | ns |  |
| T CVCtV | Control Active Delay 1 | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| $T_{\text {cVCTX }}$ | Control Inactive Delay | 3 | 44 | 3 | 37 | 3 | 31 | ns |  |
| TDXDL | $\overline{\text { DEN }}$ Inactive to DT/R Low | 0 |  | 0 |  | 0 |  | ns | Equal Loading |
| $\mathrm{T}_{\text {CHCTV }}$ | Control Active Delay 2 | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| TCVDEX | $\overline{\mathrm{DEN}}$ Inctive Delay (Non-Write Cycles) | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |
| $\mathrm{T}_{\text {CLLV }}$ | [OCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | 3 | 35 | ns |  |

270432-37
A. C. CHARACTERISTICS

INTERRUPT ACKNOWLEDGE CYCLE WAVEFORMS


## A. C. CHARACTERISTICS

## SOFTWARE HALT CYCLE TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $C_{L}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathbb{I}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | 80C188 |  | 80C188-12 |  | 80C188-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 80C188 GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {CHSV }}$ | Status Active Delay | 5 | 45 | 5 | 35 | 5 | 31 | ns |  |
| ${ }^{\text {ClSH }}$ | Status Inactive Delay | 5 | 46 | 5 | 35 | 5 | 30 | ns |  |
| TCLAV | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 30 |  | 25 |  | 20 | ns |  |
| $\mathrm{T}_{\text {LHLL }}$ | ALE Width | $\mathrm{T}_{\text {CLCL }}-15$ |  | $\mathrm{T}_{\text {CLCL }}-15$ |  | $\mathrm{T}_{\text {CLCL }}-15$ |  | ns |  |
| ${ }^{\text {CHLLL }}$ | ALE Inactive Delay |  | 30 |  | 25 | 1 | 20 | ns |  |
| T DXDL | $\overline{\text { DEN }}$ Inactive to DT/R Low |  | 0 |  | 0 |  | 0 | ns | Equal Loading |
| $\mathrm{T}_{\text {CHCTV }}$ | Control Active Delay 2 | 5 | 44 | 5 | 37 | 5 | 31 | ns |  |

## SOFTWARE HALT CYCLE WAVEFORMS



## A. C. CHARACTERISTICS

## CLOCK TIMINGS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{I H}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | $80 C 188$ |  | 80C188-12 |  | 80C188-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 80C188 CLKIN REQUIREMENTS Measurements taken with following conditions: External clock input to X 1 and X2 not connected (float) |  |  |  |  |  |  |  |  |  |
| TCKIN | CLKIN Period | 50 | 1000 | 40 | 1000 | 31.25 | 1000 | ns |  |
| $\mathrm{T}_{\text {CLCK }}$ | CLKIN Low Time | 20 |  | 16 |  | 13 |  | ns | $1.5 \mathrm{~V}^{(2)}$ |
| T ${ }_{\text {CHCK }}$ | CLKIN High Time | 20 |  | 16 |  | 13 |  | ns | $1.5 \mathrm{~V}^{(2)}$ |
| $\mathrm{T}_{\text {CKHL }}$ | CLKIN Fall Time |  | 5 |  | 5 |  | 5 | ns | 3.5 to 1.0 V |
| $\mathrm{T}_{\text {CKLH }}$ | CLKIN Rise Time |  | 5 |  | 5 |  | 5 | ns | 1.0 to 3.5 V |
| 80C188 CLKKOUT TIMING |  |  |  |  |  |  |  |  |  |
| $\mathrm{T}_{\text {cico }}$ | CLKIN to CLKOUT Skew |  | 25 |  | 21 |  | 17 | ns |  |
| $\mathrm{T}_{\text {CLCL }}$ | CLKOUT Period | 100 | 2000 | 80 | 2000 | 62.5 | 2000 | ns |  |
| $\mathrm{T}_{\mathrm{CLCH}}$ | CLKOUT Low Time | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-8}$ |  | $0.5 \mathrm{TCLCL}^{-7}$ |  | 0.5 TCLCL ${ }^{-7}$ |  | ns | $\mathrm{C}_{\mathrm{E}}=100 \mathrm{pF}$ (2) |
|  |  | $0.5 \mathrm{TCLCL}^{-6}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-5}$ |  | $0.5 \mathrm{CLCL}^{-5}$ |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}(3)$ |
| $\mathrm{T}_{\mathrm{CHCL}}$ | CLKOUT High Time | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-8}$ |  | $0.5 \mathrm{TCLCL}^{-7}$ |  | $0.5 \mathrm{CLCLL}^{-7}$ |  | ns | $\mathrm{C}_{[ }=100 \mathrm{pF}(4)$ |
|  |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-6}$ |  | $0.5 \mathrm{~T}_{\text {CLCL }}{ }^{-5}$ |  | 0.5 TCLCL ${ }^{-5}$ |  | ns | $\mathrm{C}_{L}=50 \mathrm{pF}$ (3) |
| $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLKOUT Rise Time |  | 10 |  | 10 |  | 10 | ns | 1.0 to 3.5 V |
| TCL2CL1 | CLKOUT Fall Time |  | 10 |  | 10 |  | 10 | ns | 3.5 to 1.0 V |

## NOTES:

1. $T_{\text {CLCK }}$ and $T_{\text {CHCK }}$ (CLKIN Low and High times) should not have a duration less than $40 \%$ of $T_{\text {CKIN }}$
2. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}(5.25 \mathrm{~V} @ 16 \mathrm{MHz}) . \mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$.
3. Not Tested.
4. Tested under worst case conditions: $V_{C C}=4.5 \mathrm{~V}(4.75 \mathrm{~V} @ 16 \mathrm{MHz}) . \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$.

## CLOCK WAVEFORMS



## A. C. CHARACTERISTICS

READY, PERIPHERAL, AND QUEUE STATUS TIMINGS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}_{ \pm} 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}_{ \pm} 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50-200 \mathrm{pF}$ ( 10 MHz ) and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | 80 C 188 |  | 80C188-12 |  | 80C188-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |

80C188 READY AND PERIPHERAL TIMING REQUIREMENTS


## 80C188 PERIPHERAL AND QUEUE STATUS TIMING RESPONSES

| $T_{\text {CLTMV }}$ | Timer Output Delay |  | 40 |  | 33 |  | 27 | $n s$ |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $T_{\text {CHOSV }}$ | Queue Status Delay |  | 37 |  | 32 |  |  | 30 | $n s$ |

## NOTES:

1. To guarantee proper operation.
2. To guarantee recognition at clock edge.

## SYNCHRONOUS READY (SRDY) WAVEFORMS



270432-41

## A. C. CHARACTERISTICS

## ASYNCHRONOUS READY (ARDY) WAVEFORMS



## PERIPHERAL AND QUEUE STATUS WAVEFORMS



## A. C. CHARACTERISTICS

## RESET AND HOLD/HLDA TIMINGS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ except $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ at $\mathrm{f}>12.5 \mathrm{MHz}$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $C_{L}=50-200 \mathrm{pF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-16 \mathrm{MHz})$.
For A.C. tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}{ }^{-0.5 \mathrm{~V}}$.

| Symbol | Parameter | 80 C 188 |  | 80C188-12 |  | 80C188-16 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |

## 80C188 RESET AND HOLD/HLDA TIMING REQUIREMENTS

| $T_{\text {RESIN }}$ | $\overline{\text { RES Setup }}$ HOLD Setup (1) | 15 |  | 15 |  | 15 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {HVCL }}$ | HOLD | 15 |  | 15 |  | 15 |  | ns |  |

80C188 GENERAL TIMING RESPONSES (Listed More Than Once)

| $T_{C L A Z}$ | Address Float Delay | $T_{\text {CLAX }}$ | 30 | $T_{C L A X}$ | 25 | $T_{\text {CLAX }}$ | 20 | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {CLAV }}$ | Address Valid Delay | 5 | 44 | 5 | 36 | 5 | 33 | ns |  |

80C188 RESET AND HOLD/HLDA TIMING RESPONSES

| $T_{\text {CLRO }}$ | Reset Delay |  | 40 |  | 33 |  | 27 | ns |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $T_{\text {CLHAV }}$ | HLDA Valid Delay | 3 | 40 | 3 | 33 | 3 | 25 | ns |  |
| $T_{\text {CHCZ }}$ | Command Lines Float <br> Delay |  | 40 |  | 33 |  | 28 | ns |  |
| $T_{\text {CHCV }}$ | Command Lines Valid Delay <br> (after Float) |  | 44 |  | 36 |  | 32 | ns |  |

## NOTE:

1. To guarantee recognition at next clock.

## RESET WAVEFORMS



## A. C. CHARACTERISTICS

HOLD/HLDA WAVEFORMS (Entering Hold)


HOLD/HLDA WAVEFORMS (Leaving Hold)


## EXPLANATION OF THE AC SYMBOLS

Each timing symbol has from 5 to 7 characters. The first character is always a " $T$ " (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.
A: Address
ARY: Asynchronous Ready Input
C: Clock Output
CK: Clock Input
CS: Chip Select
CT: Control (DT/信, $\overline{\mathrm{DEN}}, \ldots$. .
D: Data Input
DE: $\overline{\mathrm{DEN}}$
H: Logic Level High
IN: Input (DRQ0, TIM0, . . .)
L: Logic Level Low or ALE
O: Output
QS: Queue Status (QS1, QS2)
R: $\overline{R D}$ Signal, RESET Signal
S : Status ( $\overline{\mathbf{S} 0}, \overline{\mathbf{S} 1}, \overline{\mathbf{S} 2})$
SRY: Synchronous Ready Input
V: Valid
W: WR Signal
X: No Longer a Valid Logic Level
Z: Float
Examples:
TCLAV - Time from Clock Low to Address Valid
TCHLH- Time from Clock High to ALE High
TCLCSV- Time from Clock Low to Chip Select Valid

## Typical Output Delay Capacitive Derating



Figure 47. Capacitive Derating Curve

## Typical Rise and Fall Times for TTL Voltage Levels



Figure 48. TTL Level Slew Rates for Output Buffers

Typical Rise and Fall Times for CMOS Voltage Levels


Figure 49. CMOS Level Slew Rates for Output Buffers

## 80C188 EXPRESS

The Intel EXPRESS system offers enhancements to the operational specifications of the 80 C 188 microprocessor. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

The 80C188 EXPRESS program includes an extended temperature range. With the commercial standard temperature range operational characteristics are guaranteed over the temperature range of $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$. With the extended temperature range option, operational characteristics are guaranteed over the range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

Package types and EXPRESS versions are identified by a one or two-letter prefix to the part number. The prefixes are listed in Table 16. All AC and DC specifications not mentioned in this section are the same for both commercial and EXPRESS parts.

Table 16. Prefix Identification

| Prefix | Package Type | Temperature Range |
| :---: | :---: | :---: |
| A | PGA | commercial |
| N | PLCC | commercial |
| R | LCC | commercial |
| TA | PGA | extended |
| TN | PLCC | extended |
| TR | LCC | extended |

## NOTE:

Extended temperature versions of the 80 C 188 are not available at 16 MHz .

## 80C188 EXECUTION TIMINGS

A determination of 80 C 188 program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

The 80C188 8-bit BIU is noticeably limited in its performance relative to the execution unit. A sufficient number of prefetched bytes may not reside in the prefetch queue much of the time. Therefore, actual program execution time will be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY


Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*NOTE:
Clock cycles show: 'or byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086,8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: |
| CONTROL TRANSFER (Continued) INT = Interrupt: |  |  |  | if INT. taken/ if INT. not taken |
| Type specified | 11001101 | type | 47 |  |
| Type 3 | 11001100 |  | 45 |  |
| INTO = Interrupt on overflow | 11001110 |  | 48/4 |  |
| IRET $=$ Interrupt return | 11001111 |  | 28 |  |
| Bound - Detect value out of range | * 010100010 | mod reg IIm. | 33-35 |  |
| PROCESSOR CONTROL |  |  |  |  |
| CLC = Clear carry | 11111000 |  | 2 |  |
| CMC = Complement carry | 11110101 |  | 2 |  |
| STC = Set carry | 11111001 |  | 2 |  |
| CLD = Clear direction | 11111100 |  | 2 |  |
| STD = Set direction | 11111101 |  | 2 |  |
| CLI = Clear interrupt | 11111010 |  | 2 |  |
| STI = Set interrupt | 11111011 |  | 2 |  |
| HLT = Halt | 11110100 |  | 2 |  |
| WAIT $=$ Wait | 10011011 |  | 6 | if $\overline{\text { TEST }}=0$ |
| LOCK = Bus lock prefix | 11110000 | - | 2 |  |
| NOP = No Operation | 10010000 |  | 3 |  |

Shaded areas indicate instructions not available in 8086,8088 microsystems.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if mod $=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field if mod $=00$ then DISP $=0^{*}$, disp-low and disphigh 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)+D I S P$
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)+D I S P$
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(S I)+$ 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 EA $=(B X)+$ DISP
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

## Segment Override Prefix

$\begin{array}{lllllll}0 & 0 & 1 & \mathrm{reg} & 1 & 1 & 0\end{array}$
reg is assigned according to the following:

REG is assigned according to the following table:

| 16-Bit $(w=1)$ | 8-Bit $(w=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.

## REVISION HISTORY

The sections significantly revised since version -003 are:
Pin Description Table Added note to TEST pin requiring proper RESET at power-up to configure pin as input.
Renamed pin 44 to INT1/SELECT and pin 41 to INT3/INTA1/IRQ to better describe their functions in Slave Mode.
Initialization and Added reminder to drive RES pin LOW during power-up.
Processor Reset
Read and Write Cycle
Clarified applicability of TCLCSv to latched A1 and A2 in footnotes.
Waveforms
Instruction Set
Corrected clock count for ENTER instruction.
Summary
Slave Mode Operation The three low order bits associated with vector generation and performing EOI are not alterable; however, the priority levels are programmable. This information is a clarification only.
The sections significantly revised since version -002 are:

Front Page
Local Bus Controller and Reset
D.C. Characteristics

Power Supply Current
A.C. Characteristics

Deleted references to burn-in devices.
Clarified effects of excessive loading on pins with internal pullup devices. Equivalent resistance no longer shown.
Renamed $\mathrm{V}_{\mathrm{CLI}}$ to $\mathrm{V}_{\mathrm{IL1}}$. Renamed $\mathrm{V}_{\mathrm{CHI}}$ to $\mathrm{V}_{\mathrm{IH3}}$. Changed $\mathrm{V}_{\mathrm{OH}}(\mathrm{min})$ from $0.8 \mathrm{~V}_{\mathrm{CC}}$ to $V_{C C}-0.5 \mathrm{~V}$. Changed ICc (max) from 180 mA to 150 mA at $16 \mathrm{MHz}, 150 \mathrm{~mA}$ to 120 mA at 12.5 MHz , and 120 mA to 100 mA at 10 MHz . Changed $\mathrm{V}_{\mathrm{CLO}}$ (max) from 0.5 V to 0.45 V . Changed $\mathrm{V}_{\mathrm{CHO}}(\mathrm{min})$ from $0.8 \mathrm{~V}_{\mathrm{CC}}$ to $\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$. Clarified effect of excessive loading on pins with internal pullup devices.
Added equation and graph for maximum current.
Many timings changed (all listed in ns): TDVCL (min) at 16 MHz from 10 to 15; TCLDX
(min) from 5 to 3; TCLAV (max) at 10 MHz from 50 to 44; TCHCV (max) from 45 to 44 at 10 MHz and from 37 to 36 at 12.5 MHz ; $\mathrm{T}_{\text {LHLL }}(\min )$ from $\mathrm{T}_{\mathrm{CLCL}}-30$ to $\mathrm{T}_{\mathrm{CLCL}}$ - 15; $T_{\text {LLAX }}(\min )$ at 10 MHz from $T_{C H C L}-20$ to $T_{C H C L}-15 ; T_{C V C T V}$ (max) from 56 to 44 at 10 MHz , and from 47 to 37 at 12.5 MHz ; TCVDEX (max) from 56 to 44 at $10 \mathrm{MHz}, 47$ to 37 at 12.5 MHz , and from 35 to 31 at 16 MHz ; $T_{\text {RHAV }}(\mathrm{min})$ from $T_{C L C L}-40$ at 10 MHz and $\mathrm{T}_{\mathrm{CLCL}}-20$ at 12.5 MHz and 16 MHz to $\mathrm{T}_{\mathrm{CLCL}}-15$ at all frequencies; $T_{\text {RLRH }}(\mathrm{min})$ from $2 \mathrm{~T}_{\mathrm{CLCL}}-46$ to $2 \mathrm{~T}_{\mathrm{CLCL}}-30$ at 10 MHz , from $2 \mathrm{~T}_{\mathrm{CLCL}}-40$ to 2 $T_{C L C L}-25$ at 12.5 MHz , and $T_{C L C L}-30$ to $2 \mathrm{~T}_{\mathrm{CLCL}}-25$ at 16 MHz ; TWLWH (min) from $2 T_{C L C L}-34$ to $2 T_{C L C L}-30$ at 10 MHz , and $2 \mathrm{~T}_{\mathrm{CLCL}}-30$ to $2 \mathrm{~T}_{\mathrm{CLCL}}-25$ at $12.5 \mathrm{MHz}, \mathrm{T}_{\mathrm{AVLL}}(\mathrm{min})$ from $\mathrm{T}_{\mathrm{CLCH}}-19$ to $\mathrm{T}_{\mathrm{CLCH}}-18$ at 10 MHz ; $\mathrm{T}_{\mathrm{CLSH}}$ (max) at 10 MHz from 50 to 46 ; TCLTMV (max) from 48 to 40 at $10 \mathrm{MHz} ; 40$ to 33 at 12.5 MHz , and 30 to 27 at 16 MHz ; TCLRO (max) from 48 to 40 at 10 MHz , 40 to 33 at 12.5 MHz , and 37 to 27 at 16 MHz ; TCHQSV (max) from 28 to 37 at $10 \mathrm{MHz}, 28$ to 32 at 12.5 MHz , and 25 to 30 at 16 MHz ; $\mathrm{T}_{\mathrm{CHDX}}(\min )$ from 5 to 10 ; $\mathrm{T}_{\mathrm{CLLV}}(\max )$ at 10 MHz from 45 to 40 and at 12.5 MHz from 40 to 37 ; TCLCSV (max) from 45 to 42 at 10 MHz ; $\mathrm{T}_{\mathrm{CHCSX}}(\max$ ) from 32 to 35 at $10 \mathrm{MHz}, 28$ to 30 at 12.5 MHz , and 23 to 25 at 16 MHz ; and $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL} 2 \mathrm{CL} 1}(\max )$ at 16 MHz from 8 to 10 . Added new timings for TWHDEX, $T_{\text {RHLH }}$, and TWHLH. Established minimum timing for TCLCSV.

Timing Waveforms

Specification Level Markings

Section rearranged to show waveforms on same or facing page relative to corresponding tabular data. TCLSRY drawn to same clock edge as TSRYCL. Drawing changed to indicate one less clock between HOLD inactive and HLDA inactive.
New section.

The sections significantly revised since version -001 are:

LCC Contact Diagram
Pin Description Table
Interrupt Vector Table
ESC Opcode Exception Description

Oscillator Configurations
RESET Logic

Local Bus Arbitration
Local Bus Controller
and Reset
DMA Controller
Timers
DRAM Refresh Addresses
D.C. Characteristics

Power Supply Current
A.C. Characteristics

Explanation of
the A.C. Symbols
Major Cycle Timing Waveforms TDXDL indicated in Read Cycle. TCLRO indicated.
Rise/Fall Times and Capacitive New Figures added.
Derating Curves
Instruction Set Summary ESC deleted.

## SPECIFICATION LEVEL MARKINGS

Current 80C188 devices bear backside lot code information consisting of seven digits followed by letters. The second, third, and fourth digits comprise a manufacturing data code. This preliminary data sheet applies only to 80 C 188 devices with a date code corresponding to week 25 of 1989 (backside markings x925xxx XXX) or later.

## 80C188XL20, 16, 12, 10 16-BIT HIGH INTEGRATION EMBEDDED PROCESSOR

Low Power, Full Static Version of the 80C188

■ Operation Modes Include:

- Enhanced Mode
- DRAM Refresh Control Unit
- Power-Save Mode
- Compatible Mode
— NMOS 80C188 Pin-for-Pin
Replacement for Non-Numerics Applications

Integrated Feature Set

- Static, Modular CPU
- Clock Generator
- 2 Independent DMA Channels
- Programmable Interrupt Controller
- 3 Programmable 16-Bit Timers
- Dynamic RAM Refresh Control Unit
- Programmable Memory and Peripheral Chip Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- Power-Save Mode
- System-Level Testing Support (High Impedance Test Mode)

Speed Versions Available

- 20 MHz (80C188XL20)
- 16 MHz (80C188XL16)
- 12.5 MHz (80C188XL12)
- 10 MHz (80C188XL)
- Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Completely Object Code Compatible with Existing 8086/8088 Software and Has 10 Additional Instructions over 8086/8088
- Complete System Development Support
- All 8086 and 80C186 Software

Development Tools Can Be Used for 80C188XL System Development

- ASM 86 Assembler, PL/M-86, Pascal-86, Fortran-86 iC-86 and System Utilities
- In-Circuit-Emulator (ICETM-186)
- Available in 68-Pin:
— Plastic Leaded Chip Carrier (PLCC)
- Ceramic Pin Grid Array (PGA)
- Ceramic Leadless Chip Carrier (JEDEC A Package)
■ Available in 80-Pin Quad Flat Pack (EIAJ)
- Available in EXPRESS Extended Temperature Range
$\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

The Intel 80 C 188 XL is a Modular Core re-implementation of the 80 C 188 Microprocessor. It offers higher speed and lower power consumption than the standard 80C188 but maintains $100 \%$ clock-for-clock functional compatibility. Packaging and pinout are also identical.

80C188XL20, 16, 12, 10 16-BIT HIGH INTEGRATION EMBEDDED PROCESSOR
CONTENTS page CONTENTS PAGE
INTRODUCTION ..... 24-561
AC CHARACTERISTICS ..... 24-567
Major Cycle Timings (Read Cycle) ..... 24-567
80C188XL BASE ARCHITECTURE ..... 24-561
80C188XL Clock Generator
80C188XL Clock Generator ..... 24-561 ..... 24-561
Major Cycle Timings (Write Cycle) ..... 24-569
Bus Interface Unit ..... 24-562
80C188XL PERIPHERAL ARCHITECTURE ..... 24-562
Chip-Select/Ready Generation Logic ..... 24-562
DMA Unit ..... 24-563
Timer/Counter Unit ..... 24-563
Interrupt Control Unit ..... 24-564
Enhanced Mode Operation ..... 24-564
Queue-Status Mode ..... 24-564
DRAM Refresh Control Unit ..... 24-564
Power-Save Control ..... 24-564
ONCETM Test Mode ..... 24-564
ABSOLUTE MAXIMUM RATINGS ..... 24-565
DC CHARACTERISTICS ..... 24-565
POWER SUPPLY CURRENT ..... 24-566
Major Cycle Timings (Interrupt Acknowledge Cycle) ..... 24-571
Software Halt Cycle Timings ..... 24-573
Clock Timings ..... 24-574
Ready, Peripheral and Queue Status Timings ..... 24-576
Reset and Hold/HLDA Timings ..... 24-578
AC Timing Waveforms ..... 24-580
EXPLANATION OF THE AC SYMBOLS ..... 24-587
DERATING CURVES ..... 24-588
80C188XL EXPRESS ..... 24-589
80C188XL EXECUTION TIMINGS ..... 24-589
INSTRUCTION SET SUMMARY ..... 24-590
FOOTNOTES ..... 24-595
REVISION HISTORY ..... 24-596
ERRATA ..... 24-596
PRODUCT IDENTIFICATION ..... 24-596


Figure 1. 80C188XL Block Diagram


Figure 2. 80C188XL Pinout Diagrams


Figure 2. 80C188XL Pinout Diagrams (Continued)

Table 1. 80C188XL Pin Description

| Symbol | $\begin{array}{\|c} \text { LCC } \\ \text { PGA } \\ \text { PLCC } \\ \text { Pin No. } \end{array}$ | QFP <br> Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\begin{gathered} 9 \\ 43 \end{gathered}$ | $\begin{aligned} & 33,34 \\ & 72,73 \end{aligned}$ | I | System Power: + 5 volt power supply. |
| $\mathrm{V}_{S S}$ | $\begin{aligned} & 26 \\ & 60 \end{aligned}$ | $\begin{gathered} 12,13 \\ 53 \end{gathered}$ | $\begin{aligned} & \text { I } \\ & \hline \end{aligned}$ | System Ground. |
| RESET | 57 | 18 | 0 | RESET Output indicates that the 80C188XL CPU is being reset, and can be used as a system reset. It is active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods corresponding to the length of the RES signal. Reset goes inactive 2 clockout periods after RES goes inactive. When tied to the TEST pin, RESET forces the 80C188XL into enhanced mode. RESET is not floated during bus hold. |
| $\begin{aligned} & \text { X1 } \\ & \text { X2 } \end{aligned}$ | $\begin{aligned} & 59 \\ & 58 \end{aligned}$ | $\begin{aligned} & 16 \\ & 17 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Crystal Inputs X1 and X2 provide external connections for a fundamental mode or third overtone parallel resonant crystal for the internal oscillator. X1 can connect to an external clock instead of a crystal. In this case, minimize the capacitance on X2. The input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). |
| CLKOUT | 56 | 19 | 0 | Clock Output provides the system with a $50 \%$ duty cycle waveform. All device pin timings are specified relative to CLKOUT. CLKOUT is active during reset and bus hold. |
| $\overline{\mathrm{RES}}$ | 24 | 55 | 1 | An active $\overline{\text { RES }}$ causes the 80C188XL to immediately terminate its present activity, clear the internal logic, and enter a dormant state. This signal may be asynchronous to the 80C188XL clock. The 80C188XL begins fetching instructions approximately $61 / 2$ clock cycles after $\overline{\text { RES }}$ is returned HIGH. For proper initialization, $\mathrm{V}_{\mathrm{CC}}$ must be within specifications and the clock signal must be stable for more than 4 clocks with RES held LOW. RES is internally synchronized. This input is provided with a Schmitt-trigger to facilitate power-on RES generation via an RC network. |
| TEST | 47 | 29 | 1/0 | The TEST pin is sampled during and after reset to determine whether the 80C188XL is to enter Compatible or Enhanced Mode. Enhanced Mode requires TEST to be HIGH on the rising edge of $\overline{\mathrm{RES}}$ and LOW four CLKOUT cycles later. Any other combination will place the 80C188XL in Compatible Mode. A weak internal pullup ensures a HIGH state when the pin is not driven. This pin is examined by the WAIT instruction. If the TEST input is HIGH when WAIT execution begins, instruction execution will suspend. TEST will be resampled every five clocks until it goes LOW, at which time execution will resume. If interrupts are enabled while the 80C188XL is waiting for TEST, interrupts will be serviced. During power-up, active $\overline{\text { RES }}$ is required to configure TEST as an input. |
| TMR IN 0 TMR IN 1 | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | $\begin{aligned} & 59 \\ & 58 \end{aligned}$ | $1$ | Timer Inputs are used either as clock or control signals, depending upon the programmed timer mode. These inputs are active HIGH (or LOW-to-HIGH transitions are counted) and internally synchronized. Timer Inputs must be tied HIGH when not being used as clock or retrigger inputs. |

Table 1. 80C188XL Pin Description (Continued)

| Symbol | $\begin{gathered} \hline \text { LCC } \\ \text { PGA } \\ \text { PLCC } \\ \text { Pin No. } \end{gathered}$ | QFP Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| TMR OUT 0 TMR OUT 1 | $\begin{aligned} & 22 \\ & 23 \end{aligned}$ | $\begin{aligned} & 57 \\ & 56 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Timer outputs are used to provide single pulse or continous waveform generation, depending upon the timer mode selected. These outputs are not floated during a bus hold. |
| $\begin{aligned} & \text { DRQ0 } \\ & \text { DRQ1 } \end{aligned}$ | $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | $\begin{aligned} & \hline 61 \\ & 60 \end{aligned}$ | $1$ | DMA Request is asserted HIGH by an external device when it is ready for DMA Channel 0 or 1 to perform a transfer. These signals are level-triggered and internally synchronized. |
| NMI | 46 | 30 | 1 | The Non-Maskable Interrupt input causes a Type 2 interrupt. An NMI transition from LOW to HIGH is latched and synchronized internally, and initiates the interrupt at the next instruction boundary. NMI must be asserted for at least one CLKOUT period. The Non-Maskable Interrupt cannot be avoided by programming. |
| INTO <br> INT1/SELECT <br> INT2//NTAO <br> INT3//NTA1/IRQ | $\begin{aligned} & 45 \\ & 44 \\ & 42 \\ & 41 \end{aligned}$ | $\begin{aligned} & 31 \\ & 32 \\ & 35 \\ & 36 \end{aligned}$ | $\begin{gathered} 1 \\ 1 \\ 1 / 0 \\ 1 / 0 \end{gathered}$ | Maskable Interrupt Requests can be requested by activating one of these pins. When configured as inputs, these pins are active HIGH. Interrupt Requests are synchronized internally. INT2 and INT3 may be configured to provide active-LOW interrupt-acknowledge output signals. All interrupt inputs may be configured to be either edge- or level-triggered. To ensure recognition, all interrupt requests must remain active until the interrupt is acknowledged. When Slave Mode is selected, the function of these pins changes (see Interrupt Controller section of this data sheet). |
|  <br> A19/S6 <br> A18/S5 <br> A17/S4 <br> A16/S3 | $\begin{aligned} & 65 \\ & 66 \\ & 67 \\ & 68 \end{aligned}$ | $\begin{aligned} & 6 \\ & 5 \\ & 4 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Address Bus Outputs (16-19) and Bus Cycle Status (3-6) indicate the four most significant address bits during $T_{1}$. These signals are active HIGH. During $\mathrm{T}_{2}, \mathrm{~T}_{3}, \mathrm{~T}_{\mathrm{w}}$ and $\mathrm{T}_{4}$ status information is available on these lines as encoded below: <br> During $T_{2}, T_{3}, T_{W}$ and $T_{4}$, the $S 6$ pin is LOW to indicate a CPU-initiated bus cycle or HIGH to indicate a DMA-initiated or refresh bus cycle. During the same T-states, S3, S4 and S5 are always LOW. <br> These outputs are floated during a bus hold or reset. |
| A15 <br> A14 <br> A13 <br> A12 <br> A11 <br> A10 <br> A9 <br> A8 | $\begin{gathered} 1 \\ 3 \\ 5 \\ 7 \\ 7 \\ 10 \\ 12 \\ 14 \\ 16 \end{gathered}$ | $\begin{gathered} \hline 1 \\ 79 \\ 77 \\ 75 \\ 71 \\ 69 \\ 67 \\ 65 \\ \hline \end{gathered}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Address-Only Bus (15-8) contains valid addresses from $\mathrm{T}_{1}-\mathrm{T}_{4}$. The bus is active high. These outputs are floated during a bus hold or reset. |
| AD7 AD6 AD5 AD4 AD3 AD2 AD1 AD0 | $\begin{gathered} \hline 2 \\ 4 \\ 6 \\ 8 \\ 8 \\ 11 \\ 13 \\ 15 \\ 17 \end{gathered}$ | $\begin{aligned} & 80 \\ & 78 \\ & 76 \\ & 74 \\ & 70 \\ & 68 \\ & 66 \\ & 64 \end{aligned}$ | I/O <br> I/O <br> I/O <br> I/O <br> 1/O <br> I/O <br> 1/O <br> 1/O | Address/Data Bus (7-0) signals constitute the time multiplexed memory or I/O address ( $\mathrm{T}_{1}$ ) and data ( $\mathrm{T}_{2}, \mathrm{~T}_{3}$, $T_{W}$ and $T_{4}$ ) bus. The bus is active high. These pins are floated during a bus hold or reset. |

Table 1. 80C188XL Pin Description (Continued)

| Symbol | $\begin{gathered} \text { LCC } \\ \text { PGA } \\ \text { PLCC } \\ \text { Pin No. } \end{gathered}$ | QFP <br> Pin No. | Type | Name and Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { RFSH }}$ | 64 | 7 | 0 | In compatible mode, $\overline{\text { RFSH }}$ is HIGH. In enhanced mode, $\overline{\text { RFSH }}$ is asserted LOW to signify a refresh bus cycle. The RFSH output pin floats during bus hold or reset, regardless of operating mode. |  |  |
| ALE/QSO | 61 | 10 | 0 | Address Latch Enable/Queue Status 0 is provided by the 80C188XL to latch the address. ALE is active HIGH, with addresses guaranteed valid on the trailing edge. |  |  |
| WR/QS1 | 63 | 8 | 0 | Write Strobe/Queue Status 1 indicates that the data on the bus is to be written into a memory or an I/O device. It is active LOW, and floats during bus hold or reset. When the 80C188XL is in Queue Status Mode, the ALE/QSO and WR/QS1 pins provide information about processor/instruction queue interaction. |  |  |
|  |  |  |  | QS1 | QSo | Queue Operation |
|  |  |  |  | 0 0 1 1 | 0 1 1 0 | No queue operation <br> First opcode byte fetched from the queue Subsequent byte fetched from the queue Empty the queue |
| $\overline{\text { RD/ }} \overline{\text { QSMD }}$ | 62 | 9 | O/I | Read Strobe is an active LOW signal which indicates that the 80 C 188 XL is performing a memory or I/O read cycle. It is guaranteed not to go LOW before the A/D bus is floated. An internal pull-up ensures that $\overline{\text { RD }} / \overline{\text { QSMD }}$ is HIGH during RESET. Following RESET the pin is sampled to determine whether the 80C188XL is to provide ALE, $\overline{R D}$ and $\overline{W R}$, or queue status information. To enable Queue Status Mode, $\overline{\mathrm{RD}}$ must be connected to GND. $\overline{\text { RD }}$ will float during bus HOLD. |  |  |
| ARDY | 55 | 20 | 1 | Asynchronous Ready informs the 80C188XL that the addressed memory space or I/O device will complete a data transfer. The ARDY pin accepts a rising edge that is asynchronous to CLKOUT and is active HIGH. The falling edge of ARDY must be synchronized to the 80C188XL clock. Connecting ARDY HIGH will always assert the ready condition to the CPU. If this line is unused, it should be tied LOW to yield control to the SRDY pin. |  |  |
| SRDY | 49 | 27 | 1 | Synchronous Ready informs the 80C188XL that the addressed' memory space or I/O device will complete a data transfer. The SRDY pin accepts an active-HIGH input synchronized to CLKOUT. The use of SRDY allows a relaxed system timing over ARDY. This is accomplished by elimination of the one-half clock cycle required to internally synchronize the ARDY input signal. Connecting SRDY high will always assert the ready condition to the CPU. If this line is unused, it should be tied LOW to yield control to the ARDY pin. |  |  |

Table 1. 80C188XL Pin Description (Continued)

| Symbol | LCC <br> PGA <br> PLCC <br> Pin No. | QFP <br> Pin No. | Type | Name and Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { LOCK }}$ | 48 | 28 | 0 | LOCK output indicates that other system bus masters are not to gain control of the system bus. LOCK is active LOW. The LOCK signal is requested by the LOCK prefix instruction and is activated at the beginning of the first data cycle associated with the instruction immediately following the LOCK prefix. It remains active until the completion of that instruction. No instruction prefetching will occur while LOCK is asserted. LOCK floats during bus hold or reset. |  |  |  |
| $\overline{\mathrm{S} 0}$ | 52 | 23 |  | Bus cycle status $\overline{\mathbf{S 0}}-\overline{\mathbf{S 2}}$ are encoded to provide bus-transaction information: |  |  |  |
| S2 | 54 | 21 | 0 | 80C188XL Bus Cycle Status Information |  |  |  |
|  |  |  |  | $\overline{\mathbf{S 2}}$ | $\overline{\text { S1 }}$ | $\overline{\mathbf{S o}}$ | Bus Cycle Initiated |
|  |  |  |  | 0 0 0 0 1 1 1 1 | 0 0 1 1 0 0 1 1 | 0 1 0 1 0 1 0 1 | Interrupt Acknowledge <br> Read I/O <br> Write I/O <br> Halt <br> Instruction Fetch <br> Read Data from Memory <br> Write Data to Memory <br> Passive (no bus cycle) |
|  |  |  |  | The status pins float during HOLD. $\overline{\mathrm{S} 2}$ may be used as a logical $\mathrm{M} / / \overline{\mathrm{O}}$ indicator, and $\overline{\mathrm{S} 1}$ as a $D T / \bar{R}$ indicator. |  |  |  |
| $\begin{aligned} & \text { HOLD } \\ & \text { HLDA } \end{aligned}$ | $\begin{aligned} & 50 \\ & 51 \end{aligned}$ | $\begin{aligned} & 26 \\ & 25 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | HOLD indicates that another bus master is requesting the local bus. The HOLD input is active HIGH. The 80C188XL generates HLDA (HIGH) in response to a HOLD request. Simultaneous with the issuance of HLDA, the 80C188XL will float the local bus and control lines. After HOLD is detected as being LOW, the 80C188XL will lower HLDA. When the 80C188XL needs to run another bus cycle, it will again drive the local bus and control lines. <br> In Enhanced Mode, HLDA will go low when a DRAM refresh cycle is pending in the 80C188XL and an external bus master has control of the bus. It will be up to the external master to relinquish the bus by lowering HOLD so that the 80C188XL may execute the refresh cycle. |  |  |  |
| $\overline{\text { UCS }}$ | 34 | 45 | 0/I | Upper Memory Chip Select is an active LOW output whenever a memory reference is made to the defined upper portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ block) of memory. UCS does not float during bus hold. The address range activating UCS is software programmable. <br> $\overline{U C S}$ and $\overline{\mathrm{LCS}}$ are sampled upon the rising edge of $\overline{\mathrm{RES} \text {. If both pins }}$ are held low, the 80C188XL will enter ONCE Mode. In ONCE Mode all pins assume a high impedance state and remain so until a subsequent RESET. UCS has a weak internal pullup that is active during RESET to ensure that the 80C188XL does not enter the ONCE Mode inadvertently. |  |  |  |

Table 1. 80C188XL Pin Description (Continued)

| Symbol | $\begin{gathered} \text { LCC } \\ \text { PGA } \\ \text { PLCC } \\ \text { Pin No. } \end{gathered}$ | QFP <br> Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { LCS }}$ | 33 | 46 | O/I | Lower Memory Chip Select is active LOW whenever a memory reference is made to the defined lower portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ ) of memory. LCS does not float during bus HOLD. The address range activating $\overline{\text { LCS }}$ is software programmable. <br> $\overline{U C S}$ and $\overline{L C S}$ are sampled upon the rising edge of $\overline{\text { RES }}$. If both pins are held low, the 80C188XL will enter ONCE Mode. In ONCE Mode all pins assume a high impedance state and remain so until a subsequent RESET. $\overline{\text { LCS }}$ has a weak internal pullup that is active only during RESET to ensure that the 80C188XL does not enter ONCE Mode inadvertently. |
| $\begin{aligned} & \frac{\overline{M C S 0}}{\overline{M C S 1}} \overline{\overline{M C S 2}} \overline{M C S 3} \end{aligned}$ | $\begin{aligned} & 38 \\ & 37 \\ & 36 \\ & 35 \end{aligned}$ | $\begin{aligned} & 39 \\ & 40 \\ & 41 \\ & 42 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Mid-Range Memory Chip Select signals are active LOW when a memory reference is made to the defined mid-range portion of memory ( $8 \mathrm{~K}-512 \mathrm{~K}$ ). These lines do not float during bus HOLD. The address ranges activating $\overline{\mathrm{MCSO}-3}$ are software programmable. |
| PCS0 <br> PCS1 <br> PCS2 <br> PCS3 <br> PCS4 | $\begin{aligned} & 25 \\ & 27 \\ & 28 \\ & 29 \\ & 30 \end{aligned}$ | $\begin{aligned} & 54 \\ & 52 \\ & 51 \\ & 50 \\ & 49 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Peripheral Chip Select signals 0-4 are active LOW when a reference is made to the defined peripheral area $(64 \mathrm{~K}$ I/O space or 1 Mbyte memory space). These lines do not float during bus HOLD. The address ranges activating $\overline{\mathrm{PCSO}-4}$ are software programmable. |
| $\overline{\text { PCS5/A1 }}$ | 31 | 48 | 0 | Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth peripheral chip select, or to provide an internally latched A 1 signal. The address range activating $\overline{\text { PCS5 }}$ is software-programmable. PCS5/A1 does not float during bus HOLD. When programmed to provide latched A1, this pin will retain the previously latched value during HOLD. |
| $\overline{\mathrm{PCS6}} / \mathrm{A} 2$ | 32 | 47 | 0 | Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh peripheral chip select, or to provide an internally latched A2 signal. The address range activating $\overline{\text { PCS6 }}$ is software-programmable. $\overline{\text { PCS6/A2 does not float }}$ during bus HOLD. When programmed to provide latched A2, this pin will retain the previously latched value during HOLD. |
| DT/R | 40 | 37 | 0 | Data Transmit/Receive controls the direction of data flow through an external data bus transceiver. When LOW, data is transferred to the 80C188XL. When HIGH the 80C188XL places write data on the data bus. DT//̄ floats during a bus hold or RESET. |
| $\overline{\text { DEN }}$ | 39 | 38 | 0 | Data Enable is provided as a data bus transceiver output enable. $\overline{\text { DEN }}$ is active LOW during each memory and I/O access. $\overline{D E N}$ is HIGH whenever DT/ $\bar{R}$ changes state. During RESET, DEN is driven HIGH for one clock, then floated. DEN also floats during HOLD. |
| N.C. | - | $\begin{gathered} 2,11,14,15, \\ 24,43,44, \\ 62,63 \end{gathered}$ | - | Not Connected. To maintain compatibility with future products, do not connect these pins. |

## INTRODUCTION

The following Functional Description describes the base architecture of the 80 C 188 XL . The 80C188XL is a very high integration 16 -bit microprocessor. It combines 15-20 of the most common microprocessor system components onto one chip. The 80C188XL is object code compatible with the 8086/8088 microprocessors and adds 10 new instruction types to the 8086/8088 instruction set.

The 80C188XL has two major modes of operation, Compatible and Enhanced. In Compatible Mode the 80C188XL is completely compatible with NMOS 80188, with the exception of 8087 support. The Enhanced mode adds two new features to the system design. These are Power-Save control and Dynamic RAM refresh.

## 80C188XL BASE ARCHITECTURE

## 80C188XL Clock Generator

The 80C188XL provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, synchronous and asynchronous ready inputs and reset circuitry.

The 80C188XL oscillator circuit is designed to be used either with a parallel resonant fundamental or third-overtone mode crystal, depending upon the frequency range of the application. This is used as the time base for the 80C188XL.

The output of the oscillator is not directly available outside the 80 C 188 XL . The recommended crystal configuration is shown in Figure 3b. When used in third-overtone mode, the tank circuit is recommended for stable operation. Alternately, the oscillator may be driven from an external source as shown in Figure 3 a .

The crystal or clock frequency chosen must be twice the required processor operating frequency due to the internal divide by two counter. This counter is used to drive all internal phase clocks and the external CLKOUT signal. CLKOUT is a $50 \%$ duty cycle processor clock and can be used to drive other system components. All AC timings are referenced to CLKOUT.

Intel recommends the following values for crystal selection parameters:
Temperature Range: Application Specific ESR (Equivalent Series Resistance): $\quad 60 \Omega$ max $\mathrm{C}_{0}$ (Shunt Capacitance of Crystal): $\quad 7.0 \mathrm{pF}$ max $\mathrm{C}_{1}$ (Load Capacitance): $\quad 20 \mathrm{pF} \pm 5 \mathrm{pF}$ Drive Level:

2 mW max


Figure 3. 80C188XL Oscillator Configurations (see text)

## Bus Interface Unit

The 80C188XL provides a bus controller to generate the local bus control signals. In addition, it employs a HOLD/HLDA protocol for relinquishing the local bus to other bus masters. It also provides outputs that can be used to enable external buffers and to direct the flow of data on and off the local bus.

The bus controller is responsible for generating 20 bits of address, read and write strobes, bus cycle status information add data (for write operations) information. It is also responsible for reading data from the lcoal bus during a read operation. Synchronous and asynchronous ready input pins are provided to extend a bus cycle beyond the minimum four states (clocks).

The 80C188XL bus controller also generates two control signals ( $\overline{\mathrm{DEN}}$ and DT/ $\overline{\mathrm{R}}$ ) when interfacing to external transceiver chips. This capability allows the addition of transceivers for simple buffering of the multiplexed address/data bus.

During RESET, the local bus controller will perform the following action:

- Drive $\overline{\mathrm{DEN}}, \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ HIGH for one clock cycle, then float them.
- Drive $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ to the inactive state (all HIGH) and then float.
- Drive $\overline{\text { LOCK }}$ HIGH and then float.
- Float AD0-AD7, A8-A19, S7/RFSH, DT/주.
- Drive ALE LOW.
- Drive HLDA LOW.
$\overline{R D} / \overline{Q S M D}, \overline{U C S}, \overline{L C S}$ and $\overline{T E S T}$ pins have internal pullup devices which are active while $\overline{\mathrm{RES}}$ is applied. Excessive loading or grounding certain of these pins causes the 80C188XL to enter an alternative mode of operation:
- $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ LOW results in Queue Status Mode.
- UCS and $\overline{\text { LCS }}$ LOW results in ONCE Mode.
- TEST LOW (and HIGH later) results in Enhanced Mode.


## 80C188XL PERIPHERAL ARCHITECTURE

All the 80C188XL integrated peripherals are controlled by 16 -bit registers contained within an internal 256-byte control block. The control block may be mapped into either memory or 1/O space. Internal logic will recognize control block addresses and respond to bus cycles. An offset map of the 256-byte control register block is shown in Figure 3.

## Chip-Select/Ready Generation Logic

The 80C188XL contains logic which provides programmable chip-select generation for both memories and peripherals. In addition, it can be programmed to provide READY (or WAIT state) generation. It can also provide latched address bits A1 and A2. The chip-select lines are active for all memory and I/O cycles in their programmed areas; whether they be generated by the CPU or by the integrated DMA unit.

The 80C188XL provides 6 memory chip select outputs for 3 address areas; upper memory, lower memory, and midrange memory. One each is provided for upper memory and lower memory, while four are provided for midrange memory.


Figure 4. Internal Register Map
The 80C188XL provides a chip select, called UCS, for the top of memory. The top of memory is usually used as the system memory because after reset the 80C188XL begins executing at memory location FFFFOH.

The 80C188XL provides a chip select for low memory called LCS. The bottom of memory contains the interrupt vector table, starting at location 00000 H .

The 80C188XL provides four MCS lines which are active within a user-locatable memory block. This block can be located within the 80C188XL 1 Mbyte memory address space exclusive of the areas defined by $\overline{U C S}$ and $\overline{L C S}$. Both the base address and size of this memory block are programmable.

The 80C188XL can generate chip selects for up to seven peripheral devices. These chip selects are active for seven contiguous blocks of 128 bytes above a programmable base address. The base address may be located in either memory or I/O space.

The 80C188XL can generate a READY signal internally for each of the memory or peripheral $\overline{C S}$ lines. The number of WAIT states to be inserted for each peripheral or memory is programmable to provide $0-3$ wait states for all accesses to the area for which the chip select is active. In addition, the 80C188XL may be programmed to either ignore external READY for each chip-select range individually or to factor external READY with the integrated ready generator.

Upon RESET, the Chip-Select/Ready Logic will perform the following actions:

- All chip-select outputs will be driven HIGH.
- Upon leaving RESET, the UCS line will be programmed to provide chip selects to a 1 K block with the accompanying READY control bits set at 011 to insert 3 wait states in conjunction with external READY (i.e., UMCS resets to FFFBH).
- No other chip select or READY control registers have any predefined values after RESET. They will not become active until the CPU accesses their control registers.


## DMA Unit

The 80C188XL DMA controller provides two independent DMA channels. Data transfers can occur between memory and I/O spaces (e.g., Memory to I/O) or within the same space (e.g., Memory to Memory or I/O to I/O). Each DMA channel maintains both a 20 -bit source and destination pointer which can be optionally incremented or decremented after each data transfer. Each data transfer consumes 2 bus cycles (a minimum of 8 clocks), one cycle to fetch data and the other to store data.

## Timer/Counter Unit

The 80C188XL provides three internal 16 -bit programmable timers. Two of these are highly flexible and are connected to four external pins ( 2 per timer). They can be used to count external events, time external events, generate nonrepetitive waveforms, etc. The third timer is not connected to any external pins, and is useful for real-time coding and time delay applications. In addition, the third timer can be used as a prescaler to the other two, or as a DMA request source.

## Interrupt Control Unit

The 80C188XL can receive interrupts from a number of sources, both internal and external. The 80C188XL has 5 external and 2 internal interrupt sources (Timer/Counters and DMA). The internal interrupt controller serves to merge these requests on a priority basis, for individual service by the CPU.

## Enhanced Mode Operation

In Compatible Mode the 80C188XL operates with all the features of the NMOS 80188, with the exception of 8087 support (i.e. no numeric coprocessing is possible). Queue-Status information is still available for design purposes other than 8087 support.

All the Enhanced Mode features are completely masked when in Compatible Mode. A write to any of the Enhanced Mode registers will have no effect, while a read will not return any valid data.

In Enhanced Mode, the 80C188XL will operate with Power-Save and DRAM refresh, in addition to all the Compatible Mode features.

Enhanced mode can be entered by tying the RESET output signal from the 80C188XL to the TEST input.

## Queue-Status Mode

The queue-status mode is entered by strapping the $\overline{\mathrm{RD}}$ pin low. $\overline{\mathrm{RD}}$ is sampled at RESET and if LOW, the 80 C 188 XL will reconfigure the ALE and $\overline{\mathrm{WR}}$ pins to be QS0 and QS1 respectively. This mode is available on the 80C188XL in both Compatible and Enhanced Modes.

## DRAM Refresh Control Unit

The Refresh Control Unit (RCU) automatically generates DRAM refresh bus cycles. The RCU operates only in Enhanced Mode. After a programmable period of time, the RCU generates a memory read request to the BIU. If the address generated during a refresh bus cycle is within the range of a properly programmed chip select, that chip select will be activated when the BIU executes the refresh bus cycle.

## Power-Save Control

The 80C188XL, when in Enhanced Mode, can enter a power saving state by internally dividing the processor clock frequency by a programmable factor. This divided frequency is also available at the CLKOUT pin.

All internal logic, including the Refresh Control Unit and the timers, have their clocks slowed down by the division factor. To maintain a real time count or a fixed DRAM refresh rate, these peripherals must be re-programmed when entering and leaving the pow-er-save mode.

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80 C 188 XL has a test mode available which allows all pins to be placed in a high-impedance state. ONCE stands for "ON Circuit Emulation". When placed in this mode, the 80C188XL will put all pins in the high-impedance state until RESET.

The ONCE Mode is selected by tying the $\overline{U C S}$ and the LCS LOW during RESET. These pins are sampled on the low-to-high transition of the $\overline{\operatorname{RES}}$ pin. The UCS and the LCS pins have weak internal pullup resistors similar to the $\overline{\mathrm{RD}}$ and TEST pins to guarantee ONCE Mode is not entered inadvertently during normal operation. LCS and UCS must be held low at least one clock after RES goes high to guarantee entrance into ONCE Mode.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias $\ldots .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature $\ldots \ldots \ldots . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground ............. - 1.0V to +7.0 V
Package Power Dissipation . . . . . . . . . . . . . . . . . . . 1W
Not to exceed the maximum allowable die temperature based on thermal resistance of the package.

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

NOTICE: The specifications are subject to change without notice.

DC CHARACTERISTICS $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (Except X1) | -0.5 | 0.2 $\mathrm{V}_{\text {c }}-0.3$ | V |  |
| $\mathrm{V}_{\mathrm{IL} 1}$ | Clock Input Low Voltage (X1) | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{1+}$ | Input High Voltage (All except X1 and $\overline{\text { RES }}$ ) | $0.2 \mathrm{~V}_{\mathrm{CC}}+0.9$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{H} 1}$ | Input High Voltage ( $\overline{\mathrm{RES}}$ ) | 3.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{H} 2}$ | Clock Input High Voltage (X1) | 3.9 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}(\mathrm{SO}, 1,2) \\ & \mathrm{IOL}=2.0 \mathrm{~mA} \text { (others) } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{l}_{\mathrm{OH}}=-2.4 \mathrm{~mA}$ @ 2.4 V (4) |
|  |  | $\mathrm{V}_{\mathrm{CC}}-0.5$ | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{I}^{\circ} \mathrm{H}=-200 \mu \mathrm{~A} @ \mathrm{~V}_{\mathrm{CC}}-0.5(4)$ |
| Icc | Power Supply Current |  | 100 | mA | $@ 20 \mathrm{MHz}, 0^{\circ} \mathrm{C}$ $V_{C C}=5.5 \mathrm{~V}(3)$ |
|  |  |  | 80 | mA | $\begin{aligned} & @ 16 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3) \\ & \hline \end{aligned}$ |
|  |  |  | 65 | mA | $\begin{aligned} & @ 12.5 \mathrm{MHz}, 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(3) \\ & \hline \end{aligned}$ |
|  |  |  | 50 | mA | @ $10 \mathrm{MHz}, 0^{\circ} \mathrm{C}$ $V_{C C}=5.5 \mathrm{~V}{ }^{(3)}$ |
|  |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & @ D C 0^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ |
| LII | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.5 \mathrm{MHz}, \\ & 0.45 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| Lo | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & @ 0.5 \mathrm{MHz}, \\ & 0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}}{ }^{(1)} \end{aligned}$ |
| $\mathrm{V}_{\text {CLO }}$ | Clock Output Low |  | 0.45 | V | $\mathrm{I}_{\mathrm{CLO}}=4.0 \mathrm{~mA}$ |

DC CHARACTERISTICS (Continued) $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CHO}}$ | Clock Output High | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{I}_{\mathrm{CHO}}=-500 \mu \mathrm{~A}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $@ 1 \mathrm{MHz}^{(2)}$ |
| $\mathrm{C}_{\mathrm{IO}}$ | Output or I/O Capacitance |  | 20 | pF | $@ 1 \mathrm{MHz}^{(2)}$ |

## NOTES:

1. Pins being floated during HOLD or by invoking the ONCE Mode.
2. Characterization conditions are a) Frequency $=1 \mathrm{MHz}$; b) Unmeasured pins at $G N D$; c) $V_{I N}$ at +5.0 V or 0.45 V . This parameter is not tested.
3. Current is measured with the device in RESET with X1 and X2 driven and all other non-power pins open.
4. $\overline{R D} / \overline{Q S M D}, \overline{U C S}, \overline{L C S}$ and $\overline{T E S T}$ pins have internal pullup devices. Loading some of these pins above $I_{O H}=-200 \mu \mathrm{~A}$ can cause the 80 C 186 to go into alternative modes of operation. See the section on Local Bus Controller and Reset for details.

## POWER SUPPLY CURRENT

Current is linearly proportional to clock frequency and is measured with the device in RESET with X1 and X2 driven and all other non-power pins open.

Maximum current is given by $\mathrm{I}_{\mathrm{CC}}=5 \mathrm{~mA} \times$ freq. $(M H z)+l_{Q L}$.
$l_{Q L}$ is the quiescent leakage current when the clock is static. $\mathrm{l}_{\mathrm{QL}}$ is typically less than $100 \mu \mathrm{~A}$.


Figure 4. Icc vs Frequency

80C188XL

## AC CHARACTERISTICS

## MAJOR CYCLE TIMINGS (READ CYCLE)

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For AC tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL |  | 80C188XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |


| $T_{\text {DVCL }}$ | Data in Setup (A/D) | 15 |  | 15 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {CLDX }}$ | Data in Hold (A/D) | 3 |  | 3 |  | ns |  |

80C188XL GENERAL TIMING RESPONSES (Listed More Than Once)

| T ${ }_{\text {CHSV }}$ | Status Active Delay | 3 | 45 | 3 | 35 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 3 | 46 | 3 | 35 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 40 | 3 | 36 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TCHLH | ALE Active Delay |  | 30 |  | 25 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL - 15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 30 |  | 25 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 18 |  | TCLCH - 15 |  | ns | $\begin{gathered} \text { Equal } \\ \text { Loading } \end{gathered}$ |
| Tllax | Address Hold from ALE Inactive | TCHCL - 15 |  | TCHCL - 15 |  | ns | Equal Loading |
| T AVCH | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 30 | TCLAX | 25 | ns |  |
| TClcsv | Chip-Select Active Delay | 3 | 42 | 3 | 33 | ns |  |
| T cxcsx | Chip-Select Hold from Command Inactive | TCLCH - 10 |  | TCLCH - 10 |  | ns | Equal Loading |
| TCHCSX | Chip-Select Inactive Delay | 3 | 35 | 3 | 30 | ns |  |
| TDXDL | $\overline{\text { DEN }}$ Inactive to DT/何 Low | 0 |  | 0 |  | ns | Equal Loading |
| T CVCTV | Control Active Delay 1 | 3 | 44 | 3 | 37 | ns |  |
| TCVdex | $\overline{\mathrm{DEN}}$ Inactive Delay | 3 | 44 | 3 | 37 | ns |  |
| TCHCTV | Control Active Delay 2 | 3 | 44 | 3 | 37 | ns |  |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | ns |  |

80C188XL TIMING RESPONSES (Read Cycle)

| TAZRL | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | 0 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 3 | 44 | 3 | 37 | ns |  |
| TRLRH | $\overline{\text { RD Pulse Width }}$ | $2 \mathrm{~T}_{\text {CLCL }}-30$ |  | $2 \mathrm{~T}_{\text {CLCL }}-25$ |  | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 3 | 44 | 3 | 37 | ns |  |
| $\mathrm{T}_{\text {RHLH }}$ | $\overline{\mathrm{RD}}$ Inactive to ALE High | TCLCH - 14 |  | TCLCH - 14 |  | ns | Equal Loading |
| TrHAV | $\overline{\mathrm{RD}}$ Inactive to Address Active | TCLCL - 15 |  | TCLCL - 15 |  | ns | Equal Loading |

AC CHARACTERISTICS
MAJOR CYCLE TIMINGS (READ CYCLE)
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $C_{L}=50-200 \mathrm{PF}(10 \mathrm{MHz})$ and $\mathrm{C}_{\mathrm{L}}=50-100 \mathrm{pF}(12.5-20 \mathrm{MHz})$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL16 |  | 80C188XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C188XL GENERAL TIMING REQUIREMENTS (Listed More Than Once)

| $T_{\text {DVCL }}$ | Data in Setup (A/D) | 15 |  | 10 |  | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {CLDX }}$ | Data in Hold (A/D) | 3 |  | 3 |  | ns |

80C188XL GENERAL TIMING RESPONSES (Listed More Than Once)

| TCHSV | Status Active Delay | 3 | 31 | 3 | 25 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 3 | 30 | 3 | 25 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TCHLH | ALE Active Delay |  | 20 |  | 20 | ns |  |
| TLHLL | ALE Width | $\mathrm{T}_{\mathrm{CLCL}}-15$ |  | $\mathrm{T}_{\text {CLCL }}-15$ |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 20 |  | 20 | ns |  |
| TAVLL | Address Valid to ALE Low | $\mathrm{TCLCH}^{-15}$ |  | $\mathrm{T}_{\mathrm{CLCH}}-10$ | * | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | $\mathrm{T}_{\text {CHCL }}-15$ |  | $\mathrm{T}_{\text {CHCL }}-10$ |  | ns | Equal Loading |
| T ${ }_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 20 | TCLAX | 20 | ns |  |
| TCLCSV | Chip-Select Active Delay | 3 | 30 | 3 | 25 | ns |  |
| TCXCSX | Chip-Select Hold from Command Inactive | $\mathrm{t}_{\mathrm{CLCH}}-10$ |  | TCLCH - 10 |  | ns | Equal Loading |
| TCHCSX | Chip-Select Inactive Delay | 3 | 25 | 3 | 20 | ns |  |
| TDXDL | $\overline{\text { DEN }}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 |  | ns | Equal Loading |
| TCVCTV | Control Active Delay 1 | 3 | 31 | 3 | 25 | ns |  |
| TCVDEX | DEN Inactive Delay | 3 | 31 | 3 | 22 | ns |  |
| TCHCTV | Control Active Delay 2 | 3 | 31 | 3 | 22 | ns |  |
| TCLLV | $\overline{\text { LOCK }}$ Valid/Invalid Delay | 3 | 35 | 3 | 22 | ns |  |

80C188XL TIMING RESPONSES (Read Cycle)

| $T_{\text {AZRL }}$ | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | 0 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\text {CLRL }}$ | $\overline{\mathrm{RD}}$ Active Delay | 3 | 31 | 3 | 27 | ns |  |
| $\mathrm{~T}_{\text {RLRH }}$ | $\overline{\mathrm{RD}}$ Pulse Width | $2 \mathrm{~T}_{\mathrm{CLCL}}-25$ |  | $2 \mathrm{~T}_{\mathrm{CLCL}}-20$ |  | ns |  |
| $\mathrm{~T}_{\text {CLRH }}$ | $\overline{\mathrm{RD}}$ Inactive Delay | 3 | 31 | 3 | 27 | ns |  |
| $\mathrm{~T}_{\text {RHLH }}$ | $\overline{\mathrm{RD}}$ Inactive to ALE High | $\mathrm{T}_{\mathrm{CLCH}}-14$ |  | $\mathrm{~T}_{\mathrm{CLCH}}-14$ |  | ns | Equal <br> Loading |
| $\mathrm{T}_{\text {RHAV }}$ | $\overline{\mathrm{RD}}$ Inactive to Address <br> Active | $\mathrm{T}_{\mathrm{CLCL}}-15$ |  | $\mathrm{~T}_{\mathrm{CLCL}}-15$ |  | ns | Equal <br> Loading |

## AC CHARACTERISTICS

MAJOR CYCLE TIMINGS (WRITE CYCLE)
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{I H}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL |  | 80C188XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C188XL GENERAL TIMING RESPONSES (Listed More Than Once)

| TCHSV | Status Active Delay | 3 | 45 | 3 | 35 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 3 | 46 | 3 | 35 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 40 | 3 | 36 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TCHLH | ALE Active Delay |  | 30 |  | 25 | ns |  |
| TLHLL | ALE Width | $\mathrm{T}_{\text {CLCL }}-15$ |  | TCLCL - 15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 30 |  | 25 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 18 |  | TCLCH - 15 |  | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | TCHCL - 15 |  | TCHCL - 15 |  | ns | Equal Loading |
| $\mathrm{T}_{\mathrm{AVCH}}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLDOX | Data Hold Time | 3 |  | 3 |  | ns |  |
| Tevctv | Control Active Delay 1 | 3 | 44 | 3 | 37 | ns |  |
| T ${ }_{\text {cvictx }}$ | Control Inactive Delay | 3 | 44 | 3 | 37 | ns |  |
| TCLCSV | Chip-Select Active Delay | 3 | 42 | 3 | 33 | ns |  |
| Tcxcsx | Chip-Select Hold from Command Inactive | TCLCH -10 |  | TCLCH - 10 |  | ns | Equal Loading |
| TCHCSX | Chip-Select Inactive Delay | 3 | 35 | 3 | 30 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 |  | ns | Equal Loading |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | ns |  |

80C188XL TIMING RESPONSES (Write Cycle)

| $T_{\text {WLWH }}$ | $\overline{\text { WR }}$ Pulse Width | $2 T_{\text {CLCL }}-30$ |  | $2 T_{C L C L}-25$ |  | $n s$ |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $T_{\text {WHLH }}$ | $\overline{W R}$ Inactive to ALE High | $T_{\text {CLCH }}-14$ |  | $T_{C L C H}-14$ |  | $n s$ | Equal <br> Loading |
| $T_{\text {WHDX }}$ | Data Hold after $\overline{\text { WR }}$ | $T_{\text {CLCL }}-34$ |  | $T_{\text {CLCL }}-20$ |  | $n s$ | Equal <br> Loading |
| $T_{\text {WHDEX }}$ | $\overline{\text { WR }}$ Inactive to $\overline{\text { DEN }}$ Inactive | $T_{\text {CLCH }}-10$ |  | $T_{C L C H}-10$ |  | $n s$ | Equal <br> Loading |

## AC CHARACTERISTICS

## MAJOR CYCLE TIMINGS (WRITE CYCLE)

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $C_{L}=50 \mathrm{pF}$.
For $A C$ tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{I H}=\mathrm{V}_{\mathrm{C}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL16 |  | 80C188XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

## 80C188XL GENERAL TIMING RESPONSES (Listed More Than Once)

| TCHSV | Status Active Delay | 3 | 31 | 3 | 25 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 3 | 30 | 3 | 25 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 20 |  | 20 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL-15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 20 |  | 20 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 15 |  | TCLCH - 10 |  | ns | Equal Loading |
| TLLAX | Address Hold from ALE Inactive | TCHCL - 15 |  | TCHCL - 10 |  | ns | Equal Loading |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLDOX | Data Hold Time | 3 |  | 3 |  | ns |  |
| T CVCtV | Control Active Delay 1 | 3 | 31 | 3 | 25 | ns |  |
| T ${ }_{\text {cvictx }}$ | Control Inactive Delay | 3 | 31 | 3 | 25 | ns |  |
| T CLCSV | Chip-Select Active Delay | 3 | 30 | 3 | 25 | ns |  |
| Tcxcsx | Chip-Select Hold from Command Inactive | TCLCH - 10 |  | TCLCH - 10 |  | ns | Equal Loading |
| TCHCSX | Chip-Select Inactive Delay | 3 | 25 | 3 | 20 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/可 Low | 0 |  | 0 |  | ns | Equal Loading |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 35 | 3 | 22 | ns |  |

80C188XL TIMING RESPONSES (Write Cycie)

| TWLWH | $\overline{\text { WR Pulse Width }}$ | $2 \mathrm{~T}_{\text {CLCL }}-25$ | $2 \mathrm{~T}_{\text {CLCL }}-20$ | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TWHLH | $\overline{\text { WR }}$ Inactive to ALE High | T ${ }_{\text {CLCH }}-14$ | TCLCH - 14 | ns | Equal Loading |
| TWHDX | Data Hold after $\overline{\mathrm{WR}}$ | TCLCL - 20 | TCLCL - 15 | ns | Equal Loading |
| T WHDEX | $\overline{\text { WR }}$ Inactive to $\overline{\mathrm{DEN}}$ Inactive | TCLCH - 10 | TCLCH - 10 | ns | Equal Loading |

## AC CHARACTERISTICS

MAJOR CYCLE TIMINGS (INTERRUPT ACKNOWLEDGE CYCLE)
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $V_{I L}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL |  | 80C188XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C188XL GENERAL TIMING REQUIREMENTS (Listed More Than Once) |  |  |  |  |  |  |  |
| TDVCL | Data in Setup (A/D) | 15 |  | 15 |  | ns |  |
| TCLDX | Data in Hold (A/D) | 3 |  | 3 |  | ns |  |
| 80C188XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| TCHSV | Status Active Delay | 3 | 45 | 3 | 35 | ns |  |
| TCLSH | Status Inactive Delay | 3 | 46 | 3 | 35 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| TAVCH | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 40 | 3 | 36 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| $\mathrm{T}_{\text {CHLH }}$ | ALE Active Delay |  | 30 |  | 25 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL - 15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 30 |  | 25 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 18 |  | TCLCH - 15 |  | ns | Equal Loading |
| TLLAX | Address Hold to ALE Inactive | TCHCL - 15 |  | TCHCL -15 |  | ns | Equal Loading |
| TCLAZ | Address Float Delay | TCLAX | 30 | TCLAX | 25 | ns |  |
| Tcvctv | Control Active Delay 1 | 3 | 44 | 3 | 37 | ns |  |
| Tcvatx | Control Inactive Delay | 3 | 44 | 3 | 37 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 |  | ns | Equal Loading |
| TCHCTV | Control Active Delay 2 | 3 | 44 | 3 | 37 | ns |  |
| TCVDEX | $\overline{\text { DEN }}$ Inactive Delay (Non-Write Cycles) | 3 | 44 | 3 | 37 | ns |  |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 40 | 3 | 37 | ns |  |

AC CHARACTERISTICS

## MAJOR CYCLE TIMINGS (INTERRUPT ACKNOWLEDGE CYCLE)

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For AC tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL16 |  | 80C188XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C188XL GENERAL TIMING REQUIREMENTS (Listed More Than Once)

| $T_{\text {DVCL }}$ | Data in Setup (A/D) | 15 |  | 10 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {CLDX }}$ | Data in Hold (A/D) | 3 |  | 3 |  | ns |  |

80C188XL GENERAL TIMING RESPONSES (Listed More Than Once)

| TCHSV | Status Active Delay | 3 | 31 | 3 | 25 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLSH | Status Inactive Delay | 3 | 30 | 3 | 25 | ns |  |
| Tclav | Address Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| $\mathrm{T}_{\text {AVCH }}$ | Address Valid to Clock High | 0 |  | 0 |  | ns |  |
| TCLAX | Address Hold | 0 |  | 0 |  | ns |  |
| TCLDV | Data Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TCHLH | ALE Active Delay |  | 20 |  | 20 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL-15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 20 |  | 20 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low | TCLCH - 15 |  | TCLCH - 10 |  | ns | Equal Loading |
| TLLAX | Address Hold to ALE Inactive | TCHCL - 15 |  | TCHCL - 10 |  | ns | Equal Loading |
| TCLAZ | Address Float Delay | TCLAX | 20 | TCLAX | 20 | ns |  |
| T ${ }_{\text {cvetv }}$ | Control Active Delay 1 | 3 | 31 | 3 | 25 | ns |  |
| T ${ }_{\text {cvact }}$ | Control Inactive Delay | 3 | 31 | 3 | 25 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | 0 |  | ns | Equal Loading |
| TCHCTV | Control Active Delay 2 | 3 | 31 | 3 | 22 | ns |  |
| T CVDEX | $\overline{D E N}$ Inactive Delay (Non-Write Cycles) | 3 | 31 | 3 | 22 | ns |  |
| TCLLV | LOCK Valid/Invalid Delay | 3 | 35 | 3 | 22 | ns |  |

## AC CHARACTERISTICS

## SOFTWARE HALT CYCLE TIMINGS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL |  | 80C188XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C188XL GENERAL TIMING REQUIREMENTS (Listed More Than Once) |  |  |  |  |  |  |  |
| TCHSV | Status Active Delay | 3 | 45 | 3 | 35 | ns |  |
| TCLSH | Status Inactive Delay | 3 | 46 | 3 | 35 | ns |  |
| TCLAV | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| TCHLH | ALE Active Delay |  | 30 |  | 25 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL - 15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 30 |  | 25 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low |  | 0 |  | 0 | ns | Equal Loading |
| $\mathrm{T}_{\text {CHCTV }}$ | Control Active Delay 2 | 3 | 44 | 3 | 37 | ns |  |


| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL 16 |  | 80C188XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C188XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| TCHSV | Status Active Delay | 3 | 31 | 3 | 25 | ns |  |
| TCLSH | Status Inactive Delay | 3 | 30 | 3 | 25 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 27 | ns |  |
| TCHLH | ALE Active Delay |  | 20 |  | 20 | ns |  |
| TLHLL | ALE Width | TCLCL - 15 |  | TCLCL - 15 |  | ns |  |
| TCHLL | ALE Inactive Delay |  | 20 |  | 20 | ns |  |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low |  | 0 |  | 0 | ns | Equal Loading |
| TCHCTV | Control Active Delay 2 | 3 | 31 | 3 | 22 | ns |  |

## AC CHARACTERISTICS

## CLOCK TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL |  | 80C188XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C188XL CLKIN REQUIREMENTS(1) |  |  |  |  |  |  |  |
| TCKIN | CLKIN Period | 50 | $\infty$ | 40 | $\infty$ | ns |  |
| TCLCK | CLKIN Low Time | 20 | $\infty$ | 16 | $\infty$ | ns | 1.5 V (2) |
| T ${ }_{\text {CHCK }}$ | CLKIN High Time | 20 | $\infty$ | 16 | $\infty$ | ns | 1.5 V (2) |
| TCKHL | CLKIN Fall Time |  | 5 |  | 5 | ns | 3.5 to 1.0 V |
| TCKLH | CLKIN Rise Time |  | 5 |  | 5 | ns | 1.0 to 3.5 V |
| 80C188XL CLKOUT TIMING |  |  |  |  |  |  |  |
| T ${ }_{\text {IICO }}$ | CLKIN to CLKOUT Skew |  | 25 |  | 21 | ns |  |
| TCLCL | CLKOUT Period | 100 | $\infty$ | 80 | $\infty$ | ns |  |
| TCLCH | CLKOUT Low Time | 0.5 TCLCL - 6 |  | 0.5 TCLCL - 5 |  | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}(3)$ |
| TCHCL | CLKOUT High Time | 0.5 TCLCL - 6 |  | 0.5 TCLCL - 5 |  | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}(4)$ |
| $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLKOUT Rise Time |  | 10 |  | 10 | ns | 1.0 to 3.5 V |
| TCL2CL1 | CLKOUT Fall Time |  | 10 |  | 10 | ns | 3.5 to 1.0 V |

## NOTES:

1. External clock applied to X 1 and X 2 not connected.
2. $T_{\text {CLCK }}$ and $T_{C H C K}$ (CLKIN Low and High times) should not have a duration less than $40 \%$ of $T_{\text {CKIN }}$.
3. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$.
4. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$.

## AC CHARACTERISTICS

## CLOCK TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{I H}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL16 |  | 80C188XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C188XL CLKIN REQUIREMENTS(1) |  |  |  |  |  |  |  |
| TCKIN | CLKIN Period | 31.25 | $\infty$ | 25 | $\infty$ | ns |  |
| TCLCK | CLKIN Low Time | 13 | $\infty$ | 10 | $\infty$ | ns | 1.5 V (2) |
| TCHCK | CLKIN High Time | 13 | $\infty$ | 10 | $\infty$ | ns | 1.5 V (2) |
| TCKHL | CLKIN Fall Time |  | 5 |  | 5 | ns | 3.5 to 1.0 V |
| TCKLH | CLKIN Rise Time |  | 5 |  | 5 | ns | 1.0 to 3.5 V |
| 80C 188XL CLKOUT TIMING |  |  |  |  |  |  |  |
| TCICO | CLKIN to CLKOUT Skew |  | 17 |  | 17 | ns |  |
| TCLCL | CLKOUT Period | 62.5 |  | 50 |  | ns |  |
| TCLCH | CLKOUT Low Time | 0.5 TCLCL -5 |  | 0.5 T CLCL -5 |  | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}(3)$ |
| $\mathrm{T}_{\text {CHCL }}$ | CLKOUT High Time | 0.5 TCLCL - 5 |  | 0.5 TCLCL - 5 |  | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}(4)$ |
| $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLKOUT Rise Time |  | 10 |  | 8 | ns | 1.0 to 3.5 V |
| TCL2CL1 | CLKOUT Fall Time |  | 10 |  | 8 | ns | 3.5 to 1.0 V |

## NOTES:

1. External clock applied to $X 1$ and $X 2$ not connected.
2. TCLCK and $\mathrm{T}_{\text {CHCK }}$ (CLKIN Low and High times) should not have a duration less than $40 \%$ of $\mathrm{T}_{\text {CKIN }}$.
3. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$.
4. Tested under worst case conditions: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$.

## AC CHARACTERISTICS

READY, PERIPHERAL AND QUEUE STATUS TIMINGS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{I L}=0.45 \mathrm{~V}^{\prime}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{I H}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL |  | 80C188XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C188XL READY AND PERIPHERAL TIMING REQUIREMENTS


## NOTES:

1. To guarantee proper operation.
2. To guarantee recognition at clock edge.

## AC CHARACTERISTICS

READY, PERIPHERAL AND QUEUE STATUS TIMINGS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{I H}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{I H}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL16 |  | 80C188XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |

80C188XL READY AND PERIPHERAL TIMING REQUIREMENTS

| $T_{\text {SRYCL }}$ | Synchronous Ready (SRDY) <br> Transition Setup Time(1) | 15 |  | 10 |  | ns |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $T_{\text {CLSRY }}$ | SRDY Transition Hold Time(1) | 15 |  | 10 |  | ns |  |
| TARYCH | ARDY Resolution Transition <br> Setup Time(2) | 15 |  | 10 |  | ns |  |
| $T_{\text {CLARX }}$ | ARDY Active Hold Time(1) | 15 |  | 10 |  | ns |  |
| $\mathrm{~T}_{\text {ARYCHL }}$ | ARDY Inactive Holding Time | 15 |  | 10 |  | ns |  |
| $\mathrm{~T}_{\text {ARYLCL }}$ | Asynchronous Ready <br> (ARDY) Setup Time(1) | 25 |  | 15 |  | ns |  |
| $T_{\text {INVCH }}$ | INTx, NMI, TEST/BUSY, <br> TMR IN Setup Time(2) | 15 |  | 10 |  | ns |  |
| $T_{\text {INVCL }}$ | DRQ0, DRQ1 Setup Time(2) | 15 |  | 10 |  | ns |  |

80C188XL PERIPHERAL AND QUEUE STATUS TIMING RESPONSES

| $T_{\text {CLTMV }}$ | Timer Output Delay |  | 27 |  | 22 | ns |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathrm{~T}_{\text {CHQSV }}$ | Queue Status Delay |  | 30 |  | 27 | ns |  |

## NOTES:

1. To guarantee proper operation.
2. To guarantee recognition at clock edge.

## AC CHARACTERISTICS

## RESET AND HOLD/HLDA TIMINGS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL |  | 80C188XL12 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C188XL RESET AND HOLD/HLDA TIMING REQUIREMENTS |  |  |  |  |  |  |  |
| T RESIN | $\overline{\text { RES Setup }}$ | 15 |  | 15 |  | ns |  |
| THVCL | HOLD Setup ${ }^{(1)}$ | 15 |  | 15 |  | ns |  |
| 80C188XI GENERAI TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| TCLAZ | Address Float Delay | TCLAX | 30 | TCLAX | 25 | ns |  |
| Tclav | Address Valid Delay | 3 | 44 | 3 | 36 | ns |  |
| 80C188XL RESET AND HOLD/HLDA TIMING RESPONSES |  |  |  |  |  |  |  |
| TCLRO | Reset Delay |  | 40 |  | 33 | ns |  |
| TCLHAV | HLDA Valid Delay | 3 | 40 | 3 | 33 | ns |  |
| TCHCZ | Command Lines Float Delay |  | 40 |  | 33 | ns |  |
| TCHCV | Command Lines Valid Delay (after Float) |  | 44 |  | 36 | ns |  |

## NOTE:

1. To guarantee recognition at next clock.

## AC CHARACTERISTICS

## RESET AND HOLD/HLDA TIMINGS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
All timings are measured at 1.5 V and 100 pF loading on CLKOUT unless otherwise noted.
All output test conditions are with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.
For $A C$ tests, input $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ except at X 1 where $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$.

| Symbol | Parameter | Values |  |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 80C188XL16 |  | 80C188XL20 |  |  |  |
|  |  | Min | Max | Min | Max |  |  |
| 80C188XL RESET AND HOLD/HLDA TIMING REQUIREMENTS |  |  |  |  |  |  |  |
| Tresin | $\overline{\text { RES Setup }}$ | 15 |  | 15 |  | ns |  |
| THVCL | HOLD Setup(1) | 15 |  | 10 |  | ns |  |
| 80C188XL GENERAL TIMING RESPONSES (Listed More Than Once) |  |  |  |  |  |  |  |
| TCLAZ | Address Float Delay | TCLAX | 20 | TCLAX | 20 | ns |  |
| TCLAV | Address Valid Delay | 3 | 33 | 3 | 22 | ns |  |
| 80C188XL RESET AND HOLD/HLDA TIMING RESPONSES |  |  |  |  |  |  |  |
| TCLRO | Reset Delay |  | 27 |  | 22 | ns |  |
| TCLHAV | HLDA Valid Delay | 3 | 25 | 3 | 22 | ns |  |
| TCHCZ | Command Lines Float Delay |  | 28 |  | 25 | ns |  |
| TCHCV | Command Lines Valid Delay (after Float) |  | 32 |  | 26 | ns |  |

## NOTE:

1. To guarantee recognition at next clock.

## AC CHARACTERISTICS

READ CYCLE WAVEFORMS


## NOTES:

1. Status inactive in state preceding $\mathrm{T}_{4}$.
2. If latched $A_{1}$ and $A_{2}$ are selected instead of $\overline{P C S 5}$ and $\overline{P C S 6}$, only $T_{C L C S v}$ is applicable.
3. For write cycle followed by read cycle.
4. $T_{1}$ of next bus cycle.
5. Changes in T-state preceding next bus cycle if followed by write.

Figure 5

80C188XL

## AC CHARACTERISTICS

## WRITE CYCLE WAVEFORMS



Figure 6

## AC CHARACTERISTICS

## INTERRUPT ACKNOWLEDGE CYCLE WAVEFORMS



Figure 7

## AC CHARACTERISTICS

SOFTWARE HALT CYCLE WAVEFORMS


270975-46
NOTE:

1. For write cycle followed by halt cycle.

Figure 8

CLOCK WAVEFORMS


Figure 9

## AC CHARACTERSITICS

## RESET WAVEFORMS



Figure 10

## SYNCHRONOUS READY (SRDY) WAVEFORMS



Figure 11

## AC CHARACTERISTICS

## ASYNCHRONOUS READY (ARDY) WAVEFORMS



Figure 12

PERIPHERAL AND QUEUE STATUS WAVEFORMS


Figure 13

## AC CHARACTERISTICS

## HOLD/HLDA WAVEFORMS (Entering Hold)



Figure 14
HOLD/HLDA WAVEFORMS (Leaving Hold)


270975-40
Figure 15

## EXPLANATION OF THE AC SYMBOLS

Each timing symbol has from 5 to 7 characters. The first character is always a " T " (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.
A: Address
ARY: Asynchronous Ready Input
C: Clock Output
CK: Clock Input
CS: Chip Select
CT: Control (DT/信, $\overline{\mathrm{DEN}}, \ldots$. .)
D: Data Input
DE: DEN
H: Logic Level High
IN: Input (DRQ0, TIMO, . . .)
L: Logic Level Low or ALE
O: Output
QS: Queue Status (QS1, QS2)
R: $\overline{R D}$ Signal, RESET Signal
S : Status ( $\overline{\mathbf{S} 0}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 2}$ )
SRY: Synchronous Ready Input
V: Valid
W: WR Signal
X: No Longer a Valid Logic Level
Z: Float
Examples:
TCLAV- Time from Clock Low to Address Valid
$\mathrm{T}_{\mathrm{CH} L \mathrm{H}}$ - Time from Clock High to ALE High
TCLCSV- Time from Clock Low to Chip Select Valid

DERATING CURVES
Typical Output Delay Capacitive Derating


Figure 16. Capacitive Derating Curve

## Typical Rise and Fall Times for TTL Voltage Levels



270975-42
Figure 17. TTL Level Slew Rates for Output Buffers
Typical Rise and Fall Times for CMOS Voltage Levels


Figure 18. CMOS Level Slew Rates for Output Buffers

## 80C188XL EXPRESS

The Intel EXPRESS system offers enhancements to the operational specifications of the 80 C 188 XL microprocessor. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

The 80C188XL EXPRESS program includes an extended temperature range. With the commercial standard temperature range operational characteristics are guaranteed over the temperature range of $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$. With the extended temperature range option, operational characteristics are guaranteed over the range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

Package types and EXPRESS versions are identified by a one or two-letter prefix to the part number. The prefixes are listed in Table 2. All AC and DC specifications not mentioned in this section are the same for both commercial and EXPRESS parts.

Table 2. Prefix Identification

| Prefix | Package Type | Temperature Range |
| :---: | :---: | :---: |
| A | PGA | Commercial |
| N | PLCC | Commercial |
| R | LCC | Commercial |
| S | QFP | Commercial |
| TA | PGA | Extended |
| TN | PLCC | Extended |
| TR | LCC | Extended |
| TS | QFP | Extended |

## 80C188XL EXECUTION TIMINGS

A determination of 80C188XL program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

The 80C188XL 8-bit BIU is noticeably limited in its performance relative to the execution unit. A sufficient number of prefetched bytes may not reside in the prefetch queue much of the time. Therefore, actual program execution time will be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY


Shaded areas indicate instructions not available in 8086/8088 microsystems.

## *NOTE:

Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

80C188XL

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER (Continued) SEGMENT = Segment Override: |  |  |  |  |  |  |
| CS | 00101110 |  |  |  | 2 |  |
| SS | 00110110 |  |  |  | 2 |  |
| DS | 00111110 |  |  |  | 2 |  |
| ES | 00100110 |  |  |  | 2 |  |
| ARITHMETIC ADD = Add: |  |  |  |  |  |  |
| Reg/memory with register to either | 000000 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate to register/memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16* |  |
| Immediate to accumulator | 0000010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| ADC = Add with carry:Reg/memory with register to eitherReg |  |  |  |  |  |  |
|  |  |  |  |  | 3/10* |  |
| Immediate to register/memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16* |  |
| Immediate to accumulator | 0001010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| INC = Increment: |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 3/15* |  |
| Register | 01000 reg |  |  |  | 3 |  |
| SUB = Subtract: <br> Reg/memory and register to either $\quad 001010 \mathrm{dw}$ <br> $0 \mathrm{mod} \mathrm{reg} \mathrm{r/m}$ <br> 0 m |  |  |  |  |  |  |
|  |  |  |  |  | 3/10* |  |
| Immediate from register/memory | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s w}=01$ | 4/16* |  |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| SBB = Subtract with borrow:Reg/memory and register to either $\quad \begin{aligned} & \text { a }\end{aligned}$ |  |  |  |  |  |  |
|  |  |  |  |  | 3/10* |  |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16* |  |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| DEC = Decrement |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 3/15* |  |
| Register | 01001 reg |  |  |  | 3 |  |
| CMP = Compare: |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | mod reg r/m |  |  | 3/10* |  |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 3/10* |  |
| Immediate with register/memory | 100000 sw | $\bmod 111 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 3/10* |  |
| Immediate with accumulator | 0011110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NEG = Change sign register/memory | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | $3 / 10^{*}$ |  |
| AAA = ASCll adjust for add | 00110111 |  |  |  | 8 |  |
| DAA = Decimal adjust for add | 00100111 |  |  |  | 4 |  |
| AAS $=$ ASCII adjust for subtract | 00111111 |  |  |  | 7 |  |
| DAS $=$ Decimal adjust for subtract | 00101111 |  |  |  | 4 |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format | Clock |
| :--- | :---: | :---: | :---: |
| Cycles |  |  | Comments

Shaded areas indicate instructions not available in 8086/8088 microsystems.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if mod $=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
if mod $=00$ then DISP $=0^{*}$, disp-low and disphigh 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 $\mathrm{EA}=(\mathrm{BX})+(\mathrm{SI})+$ DISP
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)+(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=011$ then $\mathrm{EA}=(\mathrm{BP})+(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=100$ then EA $=(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then EA $=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+D^{2} S^{*}$
if $\mathrm{r} / \mathrm{m}=111$ then $E A=(B X)+$ DISP
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

## Segment Override Prefix

```
0
```

reg is assigned according to the following:

Segment Register ES CS SS DS

REG is assigned according to the following table:

| 16-Bit $(w=1)$ | $8-$ Bit $(w=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.

## REVISION HISTORY

The following changes were made between the -001 and -002 versions of the 80 C 188 XL data sheets. The -002 data sheet applies to any 80C188XL with a "B" alpha character after the FPO number. The FPO number location is shown in Figure 2.

1. Much of the information provided in the -001 version of the data sheet has been removed. Detail descriptions of part functionality may be found in the 80 C 188 XL . User's Manual.
2. All AC Timing waveforms were combined at the end of the AC Characteristics section.
3. ${ }^{\text {WHLLH }}$ for the 80 C 188 XL 12 was changed from $\mathrm{t}_{\mathrm{CLCH}}-10$ to $\mathrm{t}_{\mathrm{CLCH}}-14$ due to a previous typographical error.
4. tresin for the 80 C 188 XL 20 was changed from 10 ns to 15 ns .
5. Output test conditions were changed from $\mathrm{C}_{\mathrm{L}}=$ $50-200 \mathrm{pF}$ to $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ to reflect newer test equipment. Note: This has no effect on AC Timing specifications.

## ERRATA

An A or B step 80C188XL has the following errata. The $A$ or $B$ step 80 C 188 XL can be identified by the presence of an " A " or " B " alpha character, respectively, next to the FPO number. The FPO number location is shown in Figure 2.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistantly, it is dependent on interrupt timing.

## PRODUCT IDENTIFICATION

Intel 80C188XL devices are marked with a 9-character alphanumeric Intel FPO number underneath the product number. This data sheet (270975-002) is valid for 80C188XL devices with an " A " or " B " as the ninth character in the FPO number, as illustrated in Figure 2. 16-BIT HIGH INTEGRATION EMBEDDED PROCESSOR

■ 80C188 Upgrade for Power Critical Applications

- Full Static Operation
- True CMOS Inputs and Outputs
- Integrated Feature Set
- Static 186 CPU Core
- Power Save, Idle and Powerdown Modes
- Clock Generator
- 2 Independent DMA Channels
- 3 Programmable 16-Bit Timers
-Dynamic RAM Refresh Control Unit
- Programmable Memory and Peripheral Chip Select Logic
- Programmable Wait State Generator
- Local Bus Controller
-System-Level Testing Support (High Impedance Test Mode)
■ Speed Versions Available:
- 20 MHz (80C188EA20)
- 16 MHz (80C188EA16)
- 12.5 MHz (80C188EA12)
- Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Complete System Development Support
- All 8086/8088 and 80C186 Family Software Development Tools Can Be Used for 80C188EA System Development
- ASM86 Assembler, iC-86, Pascal-86, Fortran-86, PL/M-86, and System Utilities
- In-Circuit-Emulator (ICETM-186)
- Available in the Following Packages: -68-Pin Plastic Leaded Chip Carrier (PLCC)
- 80-Pin EIAJ Quad Flat Pack (QFP)

The 80C188EA is a CHMOS high integration embedded microprocessor. The 80C188EA includes all of the features of an "Enhanced Mode" 80C188 while adding the additional capabilities of Idle and Powerdown Modes.

80C188EA20, 16, 12
16-Bit High Integration Embedded Processor
CONTENTS PAGE
INTRODUCTION ......................... 24-600
OVERVIEW ..... 24-600
80C188EA CORE ARCHITECTURE ..... 24-600
Bus Interface Unit ..... 24-600
Clock Generator ..... 24-600
80C188EA PERIPHERAL ARCHITECTURE ..... 24-601
Interrupt Control Unit ..... 24-601
Timer/Counter Unit ..... 24-601
DMA Control Unit ..... 24-603
Chip-Select Unit ..... 24-603
Refresh Control Unit ..... 24-603
Power Management ..... 24-603
ONCETM Test Mode ..... 24-603
DIFFERENCES BETWEEN THE 80C188 AND THE 80C188EA ..... 24-603
Pinout Compatibility ..... 24-604
Operating Modes ..... 24-604
TTL vs CMOS Inputs ..... 24-604
Timing Specifications ..... 24-604
PACKAGE INFORMATION ..... 24-604
Pin Descriptions ..... 24-604
80C188EA Pinout ..... 24-609
PACKAGE THERMAL SPECIFICATIONS ..... 24-613


## INTRODUCTION

The 80C188EA is the second product in a new generation of low-power, high-integration microprocessors. it enhances the existing 80 Ci 88 by offering new features and new operating modes. The 80C188EA is object code compatible with the 80C186/80C188 embedded processor.

The feature set of the 80C188EA meets the needs of low-power, space-critical applications. Low-power applications benefit from the static design of the CPU core and the integrated peripherals. Minimum current consumption is achieved by providing a Powerdown Mode that halts operation of the device, and freezes the clock circuits. Peripheral design enhancements ensure that non-initialized peripherals consume little current.

Space-critical applications benefit from the integration of commonly used system peripherals. Two flexible DMA channels perform CPU-independent data transfers. A flexible chip select unit simplifies memory and peripheral interfacing. The interrupt unit provides sources for up to 128 external interrupts and will prioritize these interrupts with those generated from the on-chip peripherals. Three general purpose timer/counters round out the feature set of the 80C188EA.

## OVERVIEW

Figure 1 shows a block diagram of the 80C188EA. The Execution Unit (EU) is an enhanced 8086 CPU core that includes: dedicated hardware to speed up effective address calculations, enhance execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instructions, and static operation. The Bus Interface Unit (BIU) is the same as that found on the original 80 C 188 family products. An independent in-
ternal bus is used to allow communication between the BIU and internal peripherals.

## OOC189EA CORE ARCHITECTURE

## Bus Interface Unit

The 80C188EA core incorporates a bus controller that generates local bus control signals. In addition, it employs a HOLD/HLDA protocol to share the local bus with other bus masters.

The bus controller is responsible for generating 20 bits of address, read and write strobes, bus cycle status information and data (for write operations) information. It is also responsible for reading data off the local bus during a read operation. SRDY and ARDY input pins are provided to extend a bus cycle beyond the minimum four states (clocks).

The 80C188EA local bus controller also generates two control signals ( $\overline{\mathrm{DEN}}$ and $\mathrm{DT} / \overline{\mathrm{R}}$ ) when interfacing to external transceiver chips. This capability allows the addition of transceivers for simple buffering of the mulitplexed address/data bus.

## Clock Generator

The 80C188EA provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, and two low-power operating modes.

The oscillator circuit is designed to be used with either a parallel resonant fundamental or third-overtone mode crystal network. Alternatively, the oscillator circuit may be driven from an external clock source. Figure 2 shows the various operating modes of the 80C188EA oscillator circuit.


NOTE:

Figure 2. 80C188EA Clock Configurations

The crystal or clock frequency chosen must be twice the required processor operating frequency due to the internal divide-by-two counter. This counter is used to drive all internal phase clocks and the external CLKOUT signal. CLKOUT is a $50 \%$ duty cycle processor clock and can be used to drive other system components. All AC timings are referenced to CLKOUT.

The following parameters are recommended when choosing a crystal:

Temperature Range: Application Specific ESR (Equivalent Series Resistance): $\quad 60 \Omega$ max C0 (Shunt Capacitance of Crystal): $\quad 7.0 \mathrm{pF}$ max $\mathrm{C}_{\mathrm{L}}$ (Load Capacitance):
Drive Level:
$20 \mathrm{pF} \pm 5 \mathrm{pF}$ 2 mW max

## 80C188EA PERIPHERAL ARCHITECTURE

The 80C188EA has integrated several common system peripherals with a CPU core to create a compact, yet powerful system. The integrated peripherals are designed to be flexible and provide logical interconnections between supporting units (e.g., the interrupt control unit supports interrupt requests from the timer/counters or DMA channels).

The list of integrated peripherals include:

- 4-Input Interrupt Control Unit
- 3-Channel Timer/Counter Unit
- 2-Channel DMA Unit
- 13-Output Chip-Select Unit
- Refresh Control Unit
- Power Management logic

The registers associated with each integrated periheral are contained within a $128 \times 16$ register file
called the Peripheral Control Block (PCB). The PCB can be located in either memory or I/O space on any 256 byte address boundary.

Figure 3 provides a list of the registers associated with the PCB when the processor's Interrupt Control Unit is in Master Mode. In Slave Mode, the definitions of some registers change. Figure 4 provides register definitions specific to Slave Mode.

## Interrupt Control Unit

The 80C188EA can receive interrupts from a number of sources, both internal and external. The Interrupt Control Unit (ICU) serves to merge these requests on a priority basis, for individual service by the CPU. Each interrupt source can be independently masked by the Interrupt Control Unit or all interrupts can be globally masked by the CPU.

Internal interrupt sources include the Timers and DMA channels. External interrupt sources come from the four input pins INT3:0. The NMI interrupt pin is not controlled by the ICU and is passed directly to the CPU. Although the timers only have one request input to the ICU, separate vector types are generated to service individual interrupts within the Timer Unit.

## Timer/Counter Unit

The 80C188EA Timer/Counter Unit (TCU) provides three 16-bit programmable timers. Two of these are highly flexible and are connected to external pins for control or clocking. A third timer is not connected to any external pins and can only be clocked internally. However, it can be used to clock the other two timer channels. The TCU can be used to count external events, time external events, generate non-repetitive waveforms, generate timed interrupts, etc.

| $\left.\begin{gathered} \text { PCB } \\ \text { Offset } \end{gathered} \right\rvert\,$ | Function | PCB Offset | Function | $\begin{aligned} & \text { PCB } \\ & \text { Offset } \end{aligned}$ | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| OOH | Reserved | 40H | Reserved | 80 H | Reserved |
| 02H | Reserved | 42H | Reserved | 82 H | Reserved |
| 04H | Reserved | 44H | Reserved | 84H | Reserved |
| 06H | Reserved | 46H | Reserved | 86H | Reserved |
| 08H | Reserved | 48H | Reserved | 88 H | Reserved |
| OAH | Reserved | 4AH | Reserved | 8AH | Reserved |
| OCH | Reserved | 4 CH | Reserved | 8 CH | Reserved |
| OEH | Reserved | 4EH | Reserved | 8EH | Reserved |
| 10H | Reserved | 50 H | Timer 0 Count | 90 H | Reserved |
| 12 H | Reserved | 52H | Timer 0 Compare A | 92H | Reserved |
| 14H | Reserved | 54H | Timer 0 Compare B | 94H | Reserved |
| 16H | Reserved | 56H | Timer 0 Control | 96 H | Reserved |
| 18H | Reserved | 58 H | Timer 1 Count | 98H | Reserved |
| 1AH | Reserved | 5AH | Timer 1 Compare A | 9AH | Reserved |
| 1CH | Reserved | 5 CH | Timer 1 Compare B | 9 CH | Reserved |
| 1EH | Reserved | 5EH | Timer 1 Control | 9EH | Reserved |
| 20 H | Reserved | 60 H | Timer 2 Count | AOH | UMCS |
| 22 H | End of Interrupt | 62H | Timer 2 Compare | A2H | LMCS |
| 24H | Poll | 64H | Reserved | A4H | PACS |
| 26 H | Poll Status | 66H | Timer 2 Control | A6H | MMCS |
| 28 H | Interrupt Mask | 68H | Reserved | A8H | MPCS |
| 2AH | Priority Mask | 6AH | Reserved | AAH | Reserved |
| 2CH | In-Service | 6 CH | Reserved | ACH | Reserved |
| 2EH | Interrupt Request | 6EH | Reserved | AEH | Reserved |
| 30 H | Interrupt Status | 70 H | Reserved | BOH | Reserved |
| 32H | Timer Control | 72H | Reserved | B2H | Reserved |
| 34H | DMAO Int. Control | 74H | Reserved | B4H | Reserved |
| 36 H | DMA1 Int. Control | 76H | Reserved | B6H | Reserved |
| 38 H | INTO Control | 78H | Reserved | B8H | Reserved |
| 3AH | INT1 Control | 7AH | Reserved | BAH | Reserved |
| 3 CH | INT2 Control | 7 CH | Reserved | BCH | Reserved |
| 3EH | INT3 Control | 7EH | Reserved | BEH | Reserved |


| $\begin{aligned} & \text { PCB } \\ & \text { Offset } \end{aligned}$ | Function |
| :---: | :---: |
| COH | DMAO Src. Lo |
| C 2 H | DMAO Src. Hi |
| C4H | DMAO Dest. Lo |
| C6H | DMAO Dest. Hi |
| $\mathrm{C8H}$ | DMAO Count |
| CAH | DMAO Control |
| CCH | Reserved |
| CEH | Reserved |
| DOH | DMA1 Src. Lo |
| D2H | DMA1 Src. Hi |
| D4H | DMA1 Dest. Lo |
| D6H | DMA1 Dest. Hi |
| D8H | DMA1 Count |
| DAH | DMA1 Control |
| DCH | Reserved |
| DEH | Reserved |
| EOH | Refresh Base |
| E2H | Refresh Time |
| E4H | Refresh Control |
| E6H | Reserved |
| E8H | Reserved |
| EAH | Reserved |
| ECH | Reserved |
| EEH | Reserved |
| FOH | Power-Save |
| F 2 H | Power Control |
| F4H | Reserved |
| F6H | Step ID |
| F 8 H | Reserved |
| FAH | Reserved |
| FCH | Reserved |
| FEH | Relocation |

Figure 3. 80C188EA Peripheral Control Block Registers

| PCB <br> Offset | Function |
| :---: | :---: |
| 20 H | Interrupt Vector |
| 22 H | Specific EOI |
| 24 H | Reserved |
| 26 H | Reserved |
| 28 H | Interrupt Mask |
| 2 AH | Priority Mask |
| 2 C | In-Service |
| 2 E | Interrupt Request |
| 30 | Interrupt Status |
| 32 | TMR0 Interrupt Control |
| 34 | DMAO Interrupt Control |
| 36 | DMA1 Interrupt Control |
| 38 | TMR1 Interrupt Control |
| 3 A | TMR2 Interrupt Control |
| 3 C | Reserved |
| 3 E | Reserved |

Figure 4. 80C188EA Slave Mode Peripheral Control Block Registers

## DMA Control Unit

The 80C188EA DMA Contol Unit provides two independent high-speed DMA channels. Data transfers can occur between memory and I/O space in any combination: memory to memory, memory to $1 / O$, I/O to I/O or I/O to memory. Each data transfer consumes two bus cycles (a minimum of eight clocks), one cycle to fetch data and the other to store data. The chip-select/ready logic may be programmed to point to the memory or I/O space subject to DMA transfers in order to provide hardware chip-select lines. DMA cycles run at higher priority than general processor execution cycles.

## Chip-Select Unit

The 80C188EA Chip-Select Unit integrates logic which provides up to 13 programmable chip-selects to access both memories and peripherals. In addition, each chip-select can be programmed to automatically terminate a bus cycle independent of the condition of the SRDY and ARDY input pins. The chip-select lines are available for all memory and I/O bus cycles, whether they are generated by the CPU, the DMA unit, or the Refresh Control Unit.

## Refresh Control Unit

The Refresh Control Unit (RCU) automatically generates a periodic memory read bus cycle to keep dynamic or pseudo-static memory refreshed. A 9-bit counter controls the number of clocks between refresh requests.

A 9-bit address generator is maintained by the RCU with the address presented on the A9:1 address lines during the refresh bus cycle. Address bits A19:13 are programmable to allow the refresh address block to be located on any 8 Kbyte boundary.

## Power Management

The 80C188EA has three operational modes to control the power consumption of the device. They are Power Save Mode, Idle Mode, and Powerdown Mode.

Power Save Mode divides the processor clock by a programmable value to take advantage of the fact that current is linearly proportional to frequency. An unmasked interrupt, NMI, or reset will cause the 80C188EA to exit Power Save Mode.

Idle Mode freezes the clocks of the Execution Unit and the Bus Interface Unit at a logic zero state while all peripherals operate normally.

Powerdown Mode freezes all internal clocks at a logic zero level and disables the crystal oscillator. All internal registers hold their values provided $V_{C C}$ is maintained. Current consumption is reduced to transistor leakage only.

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80C188EA has a test mode available which forces all output and input/ output pins to be placed in the high-impedance state. ONCE stands for "ON Circuit Emulation". The ONCE mode is selected by forcing the UCS and $\overline{\mathrm{LCS}}$ pins LOW (0) during a processor reset (these pins are weakly held to a HIGH (1) level) while RESIN is active.

## DIFFERENCES BETWEEN THE 80C188 AND THE 80C188EA

The 80C188EA is intended as a direct functional upgrade for 80C188 designs. In many cases, it will be possible to replace an existing 80C188 with little or no hardware redesign. The following sections describe differences in pinout, operating modes, and AC and DC specifications to keep in mind.

## Pinout Compatibility

The 80C188EA requires a PDTMR pin to time the processor's exit from Powerdown Mode. The original pin arrangement for the 80C188 in the PLCC package did not have any spare leads to use for PDTMR, so the DT/ $\overline{\mathrm{R}}$ pin was sacrificed. The arrangement of all the other leads in the 68-lead PLCC is identical between the 80C188 and the 80C188EA. DT/ $\overline{\mathrm{R}}$ may be readily synthesized by latching the $\overline{\mathrm{S} 1}$ status output. Therefore, upgrading a PLCC 80C188 to PLCC 80C188EA is particularly straightforward. You must connect a capacitor to the 80C188EA PDTMR pin in order to use Powerdown Mode.

The 80-lead QFP (EIAJ) pinouts are distinctly different between the 80C188 and the 80C188EA. In addition to the PDTMR pin, the 80C188EA has more power and ground pins and the overall arrangement of pins was shifted. A new circuit board layout for the 80C188EA is required.

## Operating Modes

The 80C188 has two operating modes, Compatible and Enhanced. Compatible Mode is a pin-to-pin replacement for the NMOS 80188, except for numerics coprocessing. In Enhanced Mode, the processor has a Refresh Control Unit and the Power-Save feature. The 80C188EA does not have different operating modes. All 80C188EA features are present in regular operation.

## TTL vs CMOS Inputs

The inputs of the 80C188EA are rated for CMOS switching levels for improved noise immunity, but the 80C188 inputs are rated for TTL switching levels. In particular, the 80 C 188 EA requires a minimum $\mathrm{V}_{\mathrm{IH}}$ of 3.5 V to recognize a logic one while the 80 C 188 requires a minimum $\mathrm{V}_{\mathbb{H}}$ of only 1.9 V (assuming 5.0 V operation). The solution is to drive the 80C188EA with true CMOS devices, such as those from the HC and AC logic families, or to use pullup resistors where the added current draw is not a problem.

## Timing Specifications

80C188EA timing relationships are expressed in a simplified format over the 80 C 188 . The AC performance of an 80C188EA at a specified frequency will be very close to that of an 80 C 188 at the same frequency. Check the timings applicable to your design prior to replacing the 80 C 188 .

## PACKAGE INFORMATION

This section describes the pins, pinouts, and thermal characteristics for the 80C188EA in the Plastic Leaded Chip Carrier (PLCC) package and Quad Flat Pack (QFP) package. For complete package specifications and information, see the Intel Packaging Outlines and Dimensions Guide (Order Number: 231369).

## Pin Descriptions

Each pin or logical set of pins is described in Table 2. There are three columns for each entry in the Pin Description Table.

The Pin Name column contains a mnemonic that describes the pin function. Negation of the signal name (for example, $\overline{\text { RESIN }}$ ) denotes a signal that is active low.

The Pin Type column contains two kinds of information. The first symbol indicates whether a pin is power (P), ground (G), input only (1), output only ( O ) or input/output (I/O). Some pins have multiplexed functions (for example, A19/S6). Additional symbols indicate additional characteristics for each pin. Table 4 lists all the possible symbols for this column.

Input pins may be either synchronous or asynchronous. Asynchronous pins require that setup and hold times be met only in order to guarantee recognition at a particular clock edge. Synchronous pins require that setup and hold times be met to guarantee proper operation. For example, missing the setup or hold time for the SRDY pin (a synchronous input) will result in a system failure or lockup. Input pins may also be edge- or level-sensitive. The possible characteristics for input pins are $S(E), S(L), A(E)$ and $A(L)$.

Output states are dependent upon the current activity of the processor. There are four operational states that are different from regular operation: bus hold, reset, Idle Mode, and Powerdown Mode. Appropriate characteristics for these states are also indicated in this column, with the legend for all possible characteristics in Table 1.

Finally, the Pin Description column contains a text description of each pin.

As an example, consider AD7:0. I/O signifies the pins are bidirectional. $\mathrm{S}(\mathrm{L})$ signifies that the input function is synchronous and level-sensitive. $\mathrm{H}(\mathrm{Z})$ signifies that, as outputs, the pins are high-impedance upon acknowledgement of bus hold. $R(Z)$ signifies that the pins float during reset. $\mathrm{P}(\mathrm{X})$ signifies that the pins retain their states during Powerdown Mode.

Table 1. Pin Description Nomenclature

| Symbol | Description |
| :---: | :---: |
| $\begin{aligned} & \hline P \\ & G \\ & 1 \\ & O \\ & 1 / O \end{aligned}$ | Power Pin (Apply $+\mathrm{V}_{\mathrm{CC}}$ Voltage) <br> Ground (Connect to $\mathrm{V}_{\mathrm{SS}}$ ) <br> Input Only Pin <br> Output Only Pin <br> Input/Output Pin |
| $\begin{aligned} & \hline S(E) \\ & S(L) \\ & A(E) \\ & A(L) \\ & \hline \end{aligned}$ | Synchronous, Edge Sensitive Synchronous, Level Sensitive Asynchronous, Edge Sensitive Asynchronous, Level Sensitive |
| $\begin{aligned} & H(1) \\ & H(0) \\ & H(Z) \\ & H(Q) \\ & H(X) \end{aligned}$ | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Bus Hold <br> Output Driven to $\mathrm{V}_{\text {SS }}$ during Bus Hold <br> Output Floats during Bus Hold <br> Output Remains Active during Bus Hold <br> Output Retains Current State during Bus Hold |
| R(WH) <br> $R(1)$ <br> R(0) <br> R(Z) <br> R(Q) <br> R(X) | Output Weakly Held at $\mathrm{V}_{\mathrm{CC}}$ during Reset <br> Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Reset <br> Output Driven to $\mathrm{V}_{\text {SS }}$ during Reset <br> Output Floats during Reset <br> Output Remains Active during Reset <br> Output Retains Current State during Reset |
| I(1) <br> I(0) <br> I(Z) <br> I(Q) <br> I(X) | Output Driven to $V_{C C}$ during Idle Mode <br> Output Driven to $\mathrm{V}_{\mathrm{sS}}$ during Idle Mode <br> Output Floats during Idle Mode <br> Output Remains Active during Idle Mode <br> Output Retains Current State during Idle Mode |
| $P(1)$ <br> $P(0)$ <br> $P(Z)$ <br> $P(Q)$ <br> $P(X)$ | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Powerdown Mode <br> Output Driven to $\mathrm{V}_{\text {SS }}$ during Powerdown Mode <br> Output Floats during Powerdown Mode <br> Output Remains Active during Powerdown Mode <br> Output Retains Current State during Powerdown Mode |

Table 2. 80C188EA Pin Descriptions

| Name | Type | Description |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ |  | POWER connections consist of six pins which must be shorted externally to a $\mathrm{V}_{\mathrm{CC}}$ board plane. |
| $\mathrm{V}_{S S}$ |  | GROUND connections consist of five pins which must be shorted externally to a $\mathrm{V}_{\mathrm{SS}}$ board plane. |
| CLKIN | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | CLock INput is an input for an external clock. An external oscillator operating at two times the required 80C188EA operating frequency can be connected to CLKIN. For crystal operation, CLKIN (along with OSCOUT) are the crystal connections to an internal Pierce oscillator. |
| OSCOUT | 0 $H(Q)$ $\mathrm{R}(\mathrm{Q})$ $P(Q)$ | OSCillator OUTput is only used when using a crystal to generate the external clock. OSCOUT (along with CLKIN) are the crystal connections to an internal Pierce oscillator. This pin is not to be used as 2 X clock output for non-crystal applications (i.e., this pin is N.C. for non-crystal applications). OSCOUT does not float in ONCE mode. |
| CLKOUT | 0 <br> $H(Q)$ <br> R(Q) <br> $P(Q)$ | CLocK OUTput provides a timing reference for inputs and outputs of the processor, and is one-half the input clock (CLKIN) frequency. CLKOUT has a $50 \%$ duty cycle and transistions every falling edge of CLKIN. |
| $\overline{\text { RESIN }}$ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | RESet IN causes the 80C188EA to immediately terminate any bus cycle in progress and assume an initialized state. All pins will be driven to a known state, and RESOUT will also be driven active. The rising edge (low-to-high) transition synchronizes CLKOUT with CLKIN before the 80C188EA begins fetching opcodes at memory location OFFFFOH. |
| RESOUT | $\begin{gathered} 0 \\ \hline H(0) \\ R(1) \\ P(0) \\ \hline \end{gathered}$ | RESet OUTput that indicates the 80C188EA is currently in the reset state. RESOUT will remain active as long as $\overline{\text { RESIN }}$ remains active. When tied to the TEST/BUSY pin, RESOUT forces the 80C188EA into Numerics Mode. |
| PDTMR | I/O <br> A(L) H(WH) R(Z) $P(1)$ | Power-Down TiMeR pin (normally connected to an external capacitor) that determines the amount of time the 80C188EA waits after an exit from power down before resuming normal operation. The duration of time required will depend on the startup characteristics of the crystal oscillator. |
| NMI | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | Non-Maskable Interrupt input causes a Type 2 interrupt to be serviced by the CPU. NMI is latched internally. |
| TEST | $\begin{gathered} \hline 1 \\ A(E) \end{gathered}$ | TEST is used during the execution of the WAIT instruction to suspend CPU operation until the pin is sampled active (low). |
| AD7:0 | I/O <br> S(L) <br> H(Z) <br> R(Z) <br> $P(X)$ | These pins provide a multiplexed Address and Data bus. During the address phase of the bus cycle, address bits 0 through 15 are presented on the bus and can be latched using ALE. 8- or 16 -bit data information is transferred during the data phase of the bus cycle. |
| A15:8 | $\begin{aligned} & O \\ & \mathrm{H}(\mathrm{Z}) \\ & \mathrm{R}(\mathrm{Z}) \\ & \mathrm{P}(\mathrm{Z}) \end{aligned}$ | These pins provide Address information throughout the entire bus cycle. |
| $\begin{aligned} & \hline \text { A18:16 } \\ & \text { A19/S6 } \end{aligned}$ | $\begin{aligned} & \mathrm{H}(\mathrm{Z}) \\ & \mathrm{R}(\mathrm{Z}) \\ & \mathrm{P}(\mathrm{X}) \end{aligned}$ | These pins provide multiplexed Address during the address phase of the bus cycle. Address bits 16 through 19 are presented on these pins and can be latched using ALE. A18:16 are driven to a logic 0 during the data phase of the bus cycle. Also during the data phase, S6 is driven to a logic 0 to indicate a CPU-initiated bus cycle or logic 1 to indicate a DMA-initiated bus cycle or a refresh cycle. |

Table 2. 80C188EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| S2:0 | $\begin{gathered} \hline 0 \\ H(Z) \\ R(Z) \\ P(1) \end{gathered}$ | Bus cycle Status are encoded on these pins to provide bus transaction information. S2:0 are encoded as follows: |
| ALE/QSO | $\begin{gathered} \hline 0 \\ H(0) \\ R(0) \\ P(0) \\ \hline \end{gathered}$ | Address Latch Enable output is used to strobe address information into a transparent type latch during the address phase of the bus cycle. In Queue Status Mode, QS0 provides queue status information along with QS1. |
| $\overline{\mathrm{RFSH}}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | ReFreSH output signals that a refresh cycle is in progress. |
| $\overline{\text { RD/ }} \overline{\text { QSMD }}$ | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{P}(1) \end{gathered}$ | ReaD output signals that the accessed memory or I/O device must drive data information onto the data bus. Upon reset, this pin has an alternate function. As $\overline{\text { QSMD, it enables Queue Status Mode when grounded. In }}$ Queue Status Mode, the ALE/QS0 and WR/QS1 pins provide the following information about processor/instruction queue interaction: |
| $\overline{\text { WR/QS1 }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | WRite output signals that data available on the data bus are to be written into the accessed memory or I/O device. In Queue Status Mode, QS1 provides queue status information along with QSO. |
| ARDY | $\begin{gathered} 1 \\ A(L) \\ S(L) \end{gathered}$ | Asychronous ReaDY is an input to signal for the end of a bus cycle. ARDY is asynchronous on rising CLKOUT and synchronous on falling CLKOUT. ARDY or SRDY must be active to terminate any 80C188EA bus cycle, unless they are ignored due to correct programming of the Chip Select Unit. |
| SRDY | $\begin{gathered} 1 \\ S(L) \end{gathered}$ | Synchronous ReaDY is an input to signal for the end of a bus cycle. ARDY or SRDY must be active to terminate any 80C188EA bus cycle, unless they are ignored due to correct programming of the Chip Select Unit. |
| $\overline{\text { DEN }}$ | $\begin{gathered} O \\ H(Z) \\ R(Z) \\ P(1) \\ \hline \end{gathered}$ | Data ENable output to control the enable of bidirectional transceivers when buffering an 80C188EA system. DEN is active only when data is to be transferred on the bus. |

Table 2. 80C188EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| DT/ $\bar{R}$ | $\begin{gathered} O \\ H(Z) \\ R(Z) \\ P(X) \end{gathered}$ | Data Transmit/Receive output controls the direction of a bi-directional buffer when buffering an 80C188EA system. DT/ $\overline{\mathrm{R}}$ is only available for the QFP (EIAJ) package (S80C188EA). |
| LOCK | $\begin{gathered} 1 / O \\ H(Z) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | LOCK output indicates that the bus cycle in progress is not to be interrupted. The 80C188EA will not service other bus requests (such as HOLD) while $\overline{\text { LOCK }}$ is active. This pin is configured as a weakly held high input while RESIN is active and must not be driven low. |
| HOLD | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | HOLD request input to signal that an external bus master wishes to gain control of the local bus. The 80C188EA will relinquish control of the local bus between instruction boundaries not conditioned by a LOCK prefix. |
| HLDA | 0 <br> H(1) <br> R(0) <br> $P(0)$ | HoLD Acknowledge output to indicate that the 80C188EA has relinquish control of the local bus. When HLDA is asserted, the 80C188EA will (or has) floated its data bus and control signals allowing another bus master to drive the signals directly. |
| $\overline{U C S}$ | $\begin{gathered} O \\ H(1) \\ R(1) \\ P(1) \end{gathered}$ | Upper Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. After reset, $\overline{U C S}$ is configured to be active for memory accesses between OFFCOOH and OFFFFFH. During a processor reset, UCS and LCS are used to enable ONCE Mode. |
| $\overline{\text { LCS }}$ | 0 <br> $H(1)$ <br> $R(1)$ <br> $P(1)$ | Lower Chip Select will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. प्रS is inactive after a reset. During a processor reset, UCS and $\overline{\text { LCS }}$ are used to enable ONCE Mode. |
| $\overline{\text { MCS3:0 }}$ | $\begin{gathered} O \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \\ \mathrm{A}(\mathrm{~L}) \end{gathered}$ | If enabled, these pins comprise a block of Mid-Range Chip Select outputs which will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. |
| $\overline{\text { PCS4:0 }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Peripheral Chip Selects go active whenever the address of a memory or I/ $O$ bus cycle is within the address limitations programmed by the user. |
| $\begin{array}{\|l\|} \hline \overline{\mathrm{PCS5}} / \mathrm{A} 1 \\ \overline{\mathrm{PCS6} / \mathrm{A} 2} \end{array}$ | $\begin{gathered} 0 \\ H(1) / H(X) \\ R(1) \\ P(1) \\ \hline \end{gathered}$ | These pins provide a multiplexed function. As additional Peripheral Chip Selects, they go active whenever the address of a memory or I/O bus cycle is within the address limitations by the user. They may also be programmed to provide latched Address A2:1 signals. |
| $\begin{array}{\|l} \hline \text { TOOUT } \\ \text { T1OUT } \end{array}$ | 0 <br> $H(Q)$ <br> $R(1)$ <br> $P(Q)$ | Timer OUTput pins can be programmed to provide a single clock or continuous waveform generation, depending on the timer mode selected. |
| TOIN <br> T1IN | $\begin{gathered} 1 \\ A(L) \\ A(L) \end{gathered}$ | Timer INput is used either as clock or control signals, depending on the timer mode selected. |

Table 2. 80C188EA Pin Descriptions (Continued)

| Name | Type | Description |
| :--- | :---: | :--- |
| DRQ0 |  |  |
| DRQ1 |  |  |$\quad$| I |
| :---: |
| A(L) |$\quad$| DMA ReQuest is asserted by an external request when it is prepared for a |
| :--- |
| DMA transfer. |

## 80C188EA PINOUT

Tables 3 and 4 list the 80C188EA pin names with package location for the 68 -pin Plastic Leaded Chip Carrier (PLCC) component. Figure 5 depicts the complete 80C188EA pinout (PLCC package) as viewed from the top side of the component (i.e., contacts facing down).

Tables 5 and 6 list the 80C188EA pin names with package location for the 80 -pin Quad Flat Pack (EIAJ) component. Figure 6 depicts the complete 80C188EA (EIAJ QFP package) as viewed from the top side of the component (i.e., contacts facing down).

Table 3. PLCC Pin Names with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 17 |
| AD1 | 15 |
| AD2 | 13 |
| AD3 | 11 |
| AD4 | 8 |
| AD5 | 6 |
| AD6 | 4 |
| AD7 | 2 |
| A8 | 16 |
| A9 | 14 |
| A10 | 12 |
| A11 | 10 |
| A12 | 7 |
| A13 | 5 |
| A14 | 3 |
| A15 | 1 |
| A16 | 68 |
| A17 | 67 |
| A18 | 66 |
| A19/S6 | 65 |


| Bus Control |  |
| :--- | :---: |
| Name | Location |
| ALE/QSO | 61 |
| $\overline{\text { RFSH }}$ | 64 |
| $\overline{\text { S0 }}$ | 52 |
| $\overline{S 1}$ | 53 |
| $\overline{S 2}$ | 54 |
| $\overline{\operatorname{RD}} / \overline{\text { QSMD }}$ | 62 |
| $\overline{\text { WR/QS }} 1$ | 63 |
| ARDY | 55 |
| SRDY | 49 |
| $\overline{\text { DEN }}$ | 39 |
| $\overline{\text { LOCK }}$ | 48 |
| HOLD | 50 |
| HLDA | 51 |


| Processor Control |  |
| :--- | :---: |
| Name | Location |
| RESIN | 24 |
| RESOUT | 57 |
| CLKIN | 59 |
| OSCOUT | 58 |
| CLKOUT | 56 |
| TEST | 47 |
| PDTMR | 40 |
| NMI | 46 |
| INTO | 45 |
| INT1/SELECT | 44 |
| INT2//INTAO | 42 |
| INT3//INTA1/ | 41 |
| IRQ |  |


| 1/0 |  |
| :---: | :---: |
| Name | Location |
| UCS | 34 |
| LCS | 33 |
| MCSO | 38 |
| $\overline{\text { MCS1 }}$ | 37 |
| MCS2 | 36 |
| MCS3 | 35 |
| PCSO | 25 |
| PCS1 | 27 |
| PCS2 | 28 |
| $\overline{\text { PCS3 }}$ | 29 |
| $\overline{\text { PCS4 }}$ | 30 |
| $\overline{\text { PCS5/A1 }}$ | 31 |
| $\overline{\text { PCS6/A2 }}$ | 32 |
| TOOUT | 22 |
| TOIN | 20 |
| TIOUT | 23 |
| TIIN | 21 |
| DRQ0 | 18 |
| DRQ1 | 19 |

Table 4. PLCC Package Locations with Pin Name

| Location | Name |
| :---: | :--- |
| 1 | A15 |
| 2 | AD7 |
| 3 | A14 |
| 4 | AD6 |
| 5 | A13 |
| 6 | AD5 |
| 7 | A12 |
| 8 | AD4 |
| 9 | VCC |
| 10 | A11 |
| 11 | AD3 |
| 12 | A10 |
| 13 | AD2 |
| 14 | A9 |
| 15 | AD1 |
| 16 | A8 |
| 17 | AD0 |


| Location | Name |
| :---: | :--- |
| 18 | DRQ0 |
| 19 | DRQ1 |
| 20 | TOIN |
| 21 | T1IN |
| 22 | T0OUT |
| 23 | T1OUT |
| 24 | $\overline{\text { RESIN }}$ |
| 25 | $\overline{\text { PCS0 }}$ |
| 26 | $V_{S S}$ |
| 27 | $\overline{\text { PCS1 }}$ |
| 28 | $\overline{\text { PCS2 }}$ |
| 29 | $\overline{\text { PCS3 }}$ |
| 30 | $\overline{\text { PCS4 }}$ |
| 31 | $\overline{\text { PCS5 }} / \mathrm{A1}$ |
| 32 | $\overline{\text { PCS6 }} / \mathrm{A} 2$ |
| 33 | $\overline{\mathrm{LCS}}$ |
| 34 | $\overline{\mathrm{UCS}}$ |


| Location | Name |
| :---: | :--- |
| 35 | $\overline{\text { MCS3 }}$ |
| 36 | $\overline{\text { MCS2 }}$ |
| 37 | $\overline{\text { MCS1 }}$ |
| 38 | $\overline{\text { MCS0 }}$ |
| 39 | $\overline{\text { DEN }}$ |
| 40 | PDTMR |
| 41 | INT3/INTA1/ |
|  | IRQ |
| 42 | INT2/INTAO |
| 43 | VCC |
| 44 | INT1/SELECT |
| 45 | INTO |
| 46 | NMI |
| 47 | TEST |
| 48 | LOCK |
| 49 | SRDY |
| 50 | HOLD |
| 51 | HLDA |


| Location | Name |
| :---: | :--- |
| 52 | $\overline{\text { S0 }}$ |
| 53 | $\overline{S 1}$ |
| 54 | $\overline{\text { S2 }}$ |
| 55 | ARDY |
| 56 | CLKOUT |
| 57 | RESOUT |
| 58 | OSCOUT |
| 59 | CLKIN |
| 60 | VSS |
| 61 | ALE/QS0 |
| 62 | $\overline{\text { RD/ } \overline{Q S M D ~}}$ |
| 63 | $\overline{\text { WR/QS1 }}$ |
| 64 | $\overline{R F S H}$ |
| 65 | A19/S6 |
| 66 | A18 |
| 67 | A17 |
| 68 | A16 |



272020-6

## NOTE:

The nine-character alphanumeric code ( XXXXXXXXA$)$ underneath the product number is the Intel FPO number.
Figure 5. 68-Lead PLCC Pinout Diagram

Table 5. QFP (EIAJ) Pin Name with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 64 |
| AD1 | 66 |
| AD2 | 68 |
| AD3 | 70 |
| AD4 | 74 |
| AD5 | 76 |
| AD6 | 78 |
| AD7 | 80 |
| A8 | 65 |
| A9 | 67 |
| A10 | 69 |
| A11 | 71 |
| A12 | 75 |
| A13 | 77 |
| A14 | 79 |
| A15 | 1 |
| A16 | 3 |
| A17 | 4 |
| A18 | 5 |
| A19/S6 | 6 |


| Bus Control |  |
| :--- | :---: |
| Name | Location |
| ALE/QSO | 10 |
| $\overline{\text { RFSH }}$ | 7 |
| $\overline{\text { S0 }}$ | 23 |
| $\overline{S 1}$ | 22 |
| $\overline{\text { S2 }}$ | 21 |
| $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ | 9 |
| $\overline{\text { WR} / Q S 1 ~}$ | 8 |
| ARDY | 20 |
| SRDY | 27 |
| $\overline{D T / \bar{R}}$ | 37 |
| $\overline{\mathrm{DEN}}$ | 39 |
| $\overline{\text { LOCK }}$ | 28 |
| HOLD | 26 |
| HLDA | 25 |


| Processor Control |  |
| :--- | :---: |
| Name | Location |
| $\overline{\text { RESIN }}$ | 55 |
| RESOUT | 18 |
| CLKIN | 16 |
| OSCOUT | 17 |
| CLKOUT | 19 |
| TEST | 29 |
| PDTMR | 38 |
| NMI | 30 |
| INTO | 31 |
| INT1//SELECT | 32 |
| INT2/INTAO | 35 |
| INT3/INTA1/ | 36 |
| IRQ |  |
| N.C. | 11,14, |
|  | 15,63 |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{\mathrm{UCS}}$ | 45 |
| $\overline{\mathrm{LCS}}$ | 46 |
| $\overline{\mathrm{MCS0}}$ | 40 |
| $\overline{\mathrm{MCS}}$ | 41 |
| $\overline{\mathrm{MCS}}$ | 42 |
| $\overline{\mathrm{MCS3}}$ | 43 |
| $\overline{\text { PCS0 }}$ | 54 |
| $\overline{\text { PCS1 }}$ | 52 |
| $\overline{\text { PCS2 }}$ | 51 |
| $\overline{\text { PCS3 }}$ | 50 |
| $\overline{\text { PCS4 }}$ | 49 |
| $\overline{\text { PCS5 } / A 1}$ | 48 |
| $\overline{\text { PCS6/A2 }}$ | 47 |
| T0OUT | 57 |
| TOIN | 59 |
| T1OUT | 56 |
| T1IN | 58 |
| DRQ0 | 61 |
| DRQ1 | 60 |

Table 6. QFP (EIAJ) Package Location with Pin Names

| Location | Name |
| :---: | :--- |
| 1 | A 15 |
| 2 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 3 | A 16 |
| 4 | A 17 |
| 5 | A 18 |
| 6 | $\mathrm{~A} 19 / \mathrm{S} 6$ |
| 7 | $\overline{\text { RFSH }}$ |
| 8 | $\overline{\text { WR/QS1 }}$ |
| 9 | $\overline{\text { RD/ }} \overline{\mathrm{QSMD}}$ |
| 10 | ALE/QSO |
| 11 | N.C. |
| 12 | VSS |
| 13 | VSS |
| 14 | N.C. |
| 15 | N.C. |
| 16 | CLKIN |
| 17 | OSCOUT |
| 18 | RESOUT |
| 19 | CLKOUT |
| 20 | ARDY |


| Location | Name |
| :---: | :--- |
| 21 | $\overline{\text { S2 }}$ |
| 22 | $\overline{\mathrm{~S} 1}$ |
| 23 | $\overline{\mathrm{S0}}$ |
| 24 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 25 | HLDA |
| 26 | HOLD |
| 27 | SRDY |
| 28 | $\overline{\text { LOCK }}$ |
| 29 | $\overline{T E S T}$ |
| 30 | NMI |
| 31 | INTO |
| 32 | INT1/SELECT |
| 33 | VCC |
| 34 | VCC |
| 35 | INT2/INTAO |
| 36 | INT3/INTA1/ |
|  | IRQ |
| 37 | DT/ $\bar{R}$ |
| 38 | PDTMR |
| 39 | $\overline{\text { DEN }}$ |
| 40 | $\overline{\text { MCSO }}$ |


| Location | Name |
| :---: | :---: |
| 41 | $\overline{\mathrm{MCS}} 1$ |
| 42 | $\overline{\mathrm{MCS} 2}$ |
| 43 | $\overline{\mathrm{MCS3}}$ |
| 44 | $V_{C C}$ |
| 45 | UCS |
| 46 | LCS |
| 47 | PCS6/A2 |
| 48 | PCS5/A1 |
| 49 | $\overline{\text { PCS4 }}$ |
| 50 | $\overline{\text { PCS3 }}$ |
| 51 | $\overline{\text { PCS2 }}$ |
| 52 | $\overline{\text { PCS1 }}$ |
| 53 | $V_{S S}$ |
| 54 | $\overline{\text { PCSO }}$ |
| 55 | $\overline{\text { RESIN }}$ |
| 56 | T1OUT |
| 57 | TOOUT |
| 58 | T1IN |
| 59 | TOIN |
| 60 | DRQ1 |


| Location | Name |
| :---: | :--- |
| 61 | DRQ0 |
| 62 | VSS $^{2}$ |
| 63 | N.C. |
| 64 | AD0 |
| 65 | A8 |
| 66 | AD1 |
| 67 | A9 |
| 68 | AD2 |
| 69 | A10 |
| 70 | AD3 |
| 71 | A11 |
| 72 | V CC $^{73}$ |
| 73 | $V_{C C}$ |
| 74 | AD4 |
| 75 | A12 |
| 76 | AD5 |
| 77 | A13 |
| 78 | AD6 |
| 79 | A14 |
| 80 | AD7 |



272020-7
NOTE:
The nine-character alphanumeric code ( $X X X X X X X X A)$ underneath the product number is the Intel FPO number.
Figure 6. Quad Flat Pack (EIAJ) Pinout Diagram

## PACKAGE THERMAL <br> SPECIFICATIONS

The 80 C 188 EA is specified for operation when $T_{C}$ (the case temperature) is within the range of $0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ (PLCC package) or $0^{\circ} \mathrm{C}$ to $106^{\circ} \mathrm{C}$ (QFP-EIAJ) package. $T_{C}$ may be measured in any environment to determine whether the 80C188EA is within the specified operating range. The case temperature must be measured at the center of the top surface.
$T_{A}$ (the ambient temperature) can be calculated from $\theta_{\mathrm{CA}}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\text {CA }}$ at various airflows are given in Table 7 for the 68-pin Plastic Leaded Chip Carrier (PLCC) package.

Table 8 shows the maximum $T_{A}$ allowable (without exceeding $T_{C}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumption, specified in watts) is calculated by using the maximum ICC as tabulated in the DC specifications and $\mathrm{V}_{\mathrm{CC}}$ of 5.5 V .

$$
T_{A}=T_{C}-P \times \theta_{C A}
$$

Table 7. Thermal Resistance ( $\theta_{\mathrm{CA}}$ ) at Various Airflows (in ${ }^{\circ} \mathbf{C} /$ Watt)

|  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 <br> $(0)$ | 200 <br> $(1.01)$ | 400 <br> $(2.03)$ | 600 <br> $(3.04)$ | 800 <br> $(4.06)$ | 1000 <br> $(5.07)$ |
| $\theta_{\mathrm{CA}}$ (PLCC) | 29 | 25 | 21 | 19 | 17 | 16.5 |
| $\theta_{\mathrm{CA}}$ (QFP) | 66 | 63 | 60.5 | 59 | 58 | 57 |

Table 8. Maximum $\mathrm{T}_{\mathrm{A}}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TF | 0 | 200 | 400 | 600 | 800 | 1000 |
|  | (MHz) | (0) | (1.01) | (2.03) | (3.04) | (4.06) | (5.07) |
| $\mathrm{T}_{\mathrm{A}}$ (PLCC) | 25 | 78 | 80 | 81 | 82 | 82.5 | 83 |
|  | 32 | 74 | 76 | 78 | 79 | 79.5 | 80 |
|  | 40 | 70 | 72 | 74 | 75 | 76 | 76.5 |
| TA (QFP) | 25 | 84 | 85.5 | 86 | 87 | 87 | 87.5 |
|  | 32 | 77.5 | 79 | 80 | 80.5 | 81 | 81.5 |
|  | 40 | 70 | 71.5 | 73 | 74 | 74 | 75 |

## ELECTRICAL SPECIFICATIONS

## Ábsoiute Maximum Ratings*

Storage Temperature $\ldots . . . . . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Case Temperature under Bias $\ldots-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Supply Voltage with Respect
to $\mathrm{V}_{\mathrm{ss}} \ldots \ldots \ldots \ldots \ldots \ldots \ldots . .0 .5 \mathrm{~V}$ to +6.5 V
Voltage on Other Pins with Respect
to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots \ldots \ldots \ldots \ldots-0.5 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## Operating Conditions

| Symbol | Parameter | Min | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.5 | 5.5 | V |
| $\mathrm{~T}_{\mathrm{F}}$ | Input Clock Frequency |  |  |  |
|  | 80C188EA20 | 0 | 40 | MHz |
|  | 80C188EA16 | 0 | 32 | MHz |
|  | 80C188EA12 | 0 | 25 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature under Bias |  |  |  |
|  | N80C188EA (PLCC) | 0 | +100 | ${ }^{\circ} \mathrm{C}$ |
|  | S80C188EA (QFP) | 0 | +114 | ${ }^{\circ} \mathrm{C}$ |

## Recommended Connections

Power and ground connections must be made to multiple $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$ pins. Every 80C188EA based circuit board should contain separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $V_{S S}$ ) planes. All $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{S S}$ pins must be connected to the appropriate plane. Pins identified as "N.C." must not be connected in the system. Decoupling capacitors should be placed near the 80C188EA. The value and type of decoupling capac-
itors is application and board layout dependent. The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Always connect any unused input pins to an appropriate signal level. In particular, unused interrupt pins (NMI, INT3:0) should be connected to $\mathrm{V}_{\text {SS }}$ to avoid unwanted interrupts. Leave any unused output pin or any "N.C." pin unconnected.

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage for All Pins | -0.5 | $0.3 \mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage for All Pins | $0.7 \mathrm{~V}_{\text {CC }}$ | $V_{C C}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=3 \mathrm{~mA}(\mathrm{~min})$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $V_{C C}-0.5$ |  | V | $\mathrm{IOH}=-2 \mathrm{~mA}(\mathrm{~min})$ |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysterisis on RESIN | 0.30 |  | V |  |
| IL1 | Input Leakage Current (except $\overline{R D} / \overline{\text { QSMD }}, \overline{U C S}, \overline{L C S}$, and $\overline{\text { LOCK }})$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IIL2 | Input Leakage Current $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}, \mathrm{UCS}, \overline{L C S}, \text { and }} \overline{\mathrm{LOCK}})$ | -275 |  | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.7 \mathrm{~V}$ CC $($ Note 1) |
| ${ }^{\text {OLL}}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq V_{\text {OUT }} \leq V_{\text {CC }} \\ & \text { (Note 2) } \end{aligned}$ |
| $I_{\text {cc }}$ | ```Supply Current Cold (RESET) 80C188EA20 80C188EA16 80C188EA12``` |  | $\begin{gathered} 100 \\ 80 \\ 62.5 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 3) |
| ID | Supply Current In Idle Mode 80C188EA20 80C188EA16 80C188EA12 |  | $\begin{aligned} & 70 \\ & 56 \\ & 44 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| IPD | ```Supply Current In Powerdown Mode 80C188EA20 80C188EA16 80C188EA12``` |  | $\begin{aligned} & 100 \\ & 100 \\ & 100 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |  |
| Cout | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ (Note 4) |
| $\mathrm{C}_{\text {IN }}$ | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |

## NOTES:

1. $\overline{\operatorname{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}$ and $\overline{\mathrm{LOCK}}$, and have internal pullups that are only activated during RESET. Loading these pins above $\mathrm{IOL}_{\mathrm{OL}}=-275 \mu \mathrm{~A}$ will cause the 80C188EA to enter alternate modes of operation.
2. Output pins are floated using HOLD or ONCE Mode.
3. Measured at worst case temperature and $\mathrm{V}_{\mathrm{CC}}$ with all outputs loaded as specified in the AC Test Conditions, and with the device in RESET (RESIN held low). RESET is worst case for Icc.
4. Output capacitance is the capacitive load of a floating output pin.

## Icc VERSUS FREQUENCY AND VOLTAGE

The current (lcc) consumption of the 80C188EA is essentially composed of two components; lPD and lccs.

IPD is the quiescent current that represents internal device leakage, and is measured with all inputs or floating outputs at GND or $V_{C C}$ (no clock applied to the device). IPD is equal to the Powerdown current and is typically less than $50 \mu \mathrm{~A}$.

ICcs is the switching current used to charge and discharge parasitic device capacitance when changing logic levels. Since Iccs is typically much greater than IPD, IPD can often be ignored when calculating Icc.

Iccs is related to the voltage and frequency at which the device is operating. It is given by the formula:

$$
\begin{aligned}
& \text { Power }=\mathrm{V} \times \mathrm{I}=\mathrm{V} 2 \times \mathrm{C}_{\mathrm{DEV}} \times f \\
& \therefore \mathrm{I}=\mathrm{I}_{\mathrm{CC}}=\mathrm{I}_{\mathrm{CCS}}=\mathrm{V} \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f}
\end{aligned}
$$

Where: $\mathrm{V}=$ Device operating voltage $\left(\mathrm{V}_{\mathrm{CC}}\right)$
$C_{\text {DEV }}=$ Device capacitance
$\mathrm{f}=$ Device operating frequency
ICCS $=I_{\text {CC }}=$ Device current
Measuring CDEV on a device like the 80C188EA would be difficult. Instead, $\mathrm{C}_{\text {DEV }}$ is calculated using the above formula by measuring $\mathrm{I}_{\mathrm{CC}}$ at a known $\mathrm{V}_{\mathrm{CC}}$ and frequency (see Table 9). Using this CDEV value, ICC can be calculated at any voltage and frequency within the specified operating range.

EXAMPLE: Calculate the typical ICC when operating at $20 \mathrm{MHz}, 4.8 \mathrm{~V}$.

## PDTMR PIN DELAY CALCULATION

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown. A delay is required only when using the on-chip oscillator to allow the crystal or resonator circuit time to stabilize.

NOTE:
The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e., a device reset during Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized).

To calculate the value of capacitor required to provide a desired delay, use the equation:

$$
440 \times t=C_{P D} \quad\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where: $t=$ desired delay in seconds

$$
\mathrm{C}_{\mathrm{PD}}=\begin{aligned}
& \text { capacitive load on PDTMR in mi- } \\
& \text { crofarads }
\end{aligned}
$$

EXAMPLE: To get a delay of $300 \mu \mathrm{~s}$, a capacitor value of $\mathrm{C}_{\text {PD }}=440 \times\left(300 \times 10^{-6}\right)=0.132 \mu \mathrm{~F}$ is required. Round up to standard (available) capacitive values.

## NOTE:

The above equation applies to delay times greater than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ or $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $V_{C C}$ and/or lower temperature will decrease delay time, while lower $\mathrm{V}_{\mathrm{CC}}$ and/or higher temperature will increase delay time.

$$
I_{C C}=I_{C C S}=4.8 \times 0.515 \times 20 \approx 49 \mathrm{~mA}
$$

Table 9. CDEV Values

| Parameter | Typ | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{DEV}}$ (Device in Reset) | 0.515 | 0.905 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| $\mathrm{C}_{\mathrm{DEV}}$ (Device in Idle) | 0.391 | 0.635 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

1. Max $\mathrm{C}_{\text {DEV }}$ is calculated at $-40^{\circ} \mathrm{C}$, all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND, and all outputs loaded to 50 pF (including CLKOUT and OSCOUT).
2. Typical $\mathrm{C}_{\mathrm{DEV}}$ is calculated at $25^{\circ} \mathrm{C}$ with all outputs loaded to 50 pF except CLKOUT and OSCOUT, which are not loaded.

## AC SPECIFICATIONS

AC Characteristics-80C188EA20

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 40 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 25 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {CH }}$ | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1, 3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 17 | ns | 1, 4 |
| T | CLKOUT Period |  | ${ }^{*}{ }^{\text {T }}$ C | ns | 1 |
| $\mathrm{T}_{\mathrm{PH}}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{T}_{\text {PL }}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{B}} \mathrm{BE}$, LOCK, A19:16 | 3 | 22 | ns | 1,4,6, 7 |
| T ${ }_{\text {CHOV2 }}$ | $\overline{\text { MCS3:0, }} \overline{\text { LCS }}$, $\overline{U C S}, \overline{\text { PCS6:0 }}$, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 27 | ns | 1, 4, 6, 8 |
| TCLOV1 | $\overline{\mathrm{RFSH}}, \overline{\mathrm{DEN}}, \overline{\text { LOCK}}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 22 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS}}: \mathbf{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS6}} \mathbf{0}$, AD15:8, AD7:0, INTA1:0, $\overline{\text { S2:0 }}$ | 3 | 27 | ns | 1,4,6 |
| $\mathrm{T}_{\text {CHOF }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 25 | ns | 1 |
| TCLOF | DEN, A15:8, AD7:0 | 0 | 25 | ns | 1 |

SYNCHRONOUS INPUTS

| $T_{\text {CHIS }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:OIN, ARDY }}$ | 10 |  | ns | 1,9 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\text {CHIH }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:OIN, ARDY }}$ | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | A15:8, AD7:0, ARDY, SRDY, DRQ1:0 | 10 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIH }}$ | A15:8, AD7:0, ARDY, SRDY, DRQ1 | 3 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIS }}$ | HOLD | 10 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | HOLD | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | $\overline{\text { RESIN }}$ (to CLKIN) | 10 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | $\overline{\text { RESIN }}$ (from CLKIN) | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 16 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 17 for rise and fall times outside 50 pF .
6. See Figure 17 for rise and fall times.
7. TCHOV1 applies to $\overline{\mathrm{RFSH}}, \overline{\mathrm{LOCK}}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C188EA operation (SRDY, AD7:0).

AC SPECIFICATIONS (Continued)

## AC Characteristics-80C189EA16

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 32 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 31.25 | $\infty$ | ns | 1 |
| ${ }_{\text {TCH }}$ | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| ${ }_{\text {T }}^{\text {CR }}$ | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 20 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{2} \mathrm{~T}_{C}$ | ns | 1 |
| TPH | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| TPL | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |

OUTPUT DELAYS

| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{D E N}, ~ D T / \bar{R}, \overline{B H E}$, LOCK, A19:16 | 3 | 23 | ns | 1, 4, 6, 7 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCHOV2 | $\overline{\mathrm{MCS3}} \mathbf{0}$, LCS, $\overline{\mathrm{UCS}}, \overline{\mathrm{PCS}} \mathbf{0} \mathbf{0}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 28 | ns | 1, 4, 6, 8 |
| TCLOV1 | $\overline{R F S H}, \overline{D E N}, \overline{L O C K}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 23 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS}}: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\text { PCS6:0 }}$, A15:8, AD7:0, $\overline{\text { NTA1:0 }}, \mathbf{S 2 : 0}$ | 3 | 28 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 25 | ns | 1 |
| TCLOF | DEN, A15:8, AD7:0 | 0 | 25 | ns | 1 |

SYNCHRONOUS INPUTS

| $T_{\text {CHIS }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:0IN, ARDY }}$ | 10 |  | ns | 1,9 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\text {CHIH }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:0IN, ARDY }}$ | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | A15:8, AD7:0, ARDY, SRDY, DRQ1:0 | 10 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIH }}$ | A15:8, AD7:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIS }}$ | HOLD | 10 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | HOLD | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | $\overline{\text { RESIN }}$ (to CLKIN) | 10 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | $\overline{\text { RESIN }}$ (from CLKIN) | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 16 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 17 for rise and fall times outside 50 pF .
6. See Figure 17 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV} 1}$ applies to $\overline{\mathrm{RFSH}}, \overline{\mathrm{LOCK}}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C188EA operation (SRDY, AD7:0).

AC SPECIFICATIONS (Continued)
AC Characteristics-80C188EA12

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 25 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 40 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 12 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 12 | $\infty$ | ns | 1,2 |
| $\mathrm{T}_{\text {cR }}$ | CLKIN Rise Time | 1 | 8 | ns | 1, 3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 23 | ns | 1, 4 |
| T | CLKOUT Period |  | ${ }^{2} \mathrm{~T}_{\mathrm{C}}$ | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{T}_{\text {PL }}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BH}} \mathrm{E}$, LOCK, A19:16 | 3 | 25 | ns | 1, 4, 6, 7 |
| TCHOV2 | MCS3:0, $\overline{\text { LCS }}$, $\overline{U C S}, \overline{\text { PCS6:0 }}$, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 30 | ns | 1,4,6, 8 |
| TCLOV1 | $\overline{\mathrm{RFSH}}, \overline{\mathrm{DEN}}, \overline{\mathrm{LOCK}}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 25 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS}}: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS6}} \mathbf{0}$, A15:8, AD7:0, $\overline{\text { INTA1:0, }}$, $2: 0$ | 3 | 30 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:16 | 0 | 25 | ns | 1 |
| TCLOF | DEN, A15:8, AD7:0 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, INT3:0, T1:0IN, ARDY | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, INT3:0, T1:0IN, ARDY | 3 |  | ns | 1,9 |
| TCLIS | A15:8, AD7:0, ARDY, SRDY, DRQ1:0 | 10 |  | ns | 1,10 |
| TCLIH | A15:8, AD7:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 10 |  | ns | 1,9 |
| TCLIH | HOLD | 3 |  | ns | 1,9 |
| T ${ }_{\text {CLIS }}$ | $\overline{\text { RESIN }}$ (to CLKIN) | 10 |  | ns | 1,9 |
| TCLIH | $\overline{\text { RESIN }}$ (to CLKIN) | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 16 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 17 for rise and fall times outside 50 pF .
6. See Figure 17 for rise and fall times.
7. TCHOV1 applies to $\overline{\text { RFSH }}, \overline{\text { LOCK }}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C188EA operation (SRDY, AD7:0).

## AC SPECIFICATIONS (Continued)

Relative Timings (80C188EA20, 16, 12)

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Rising to ALE Falling | T-15 |  | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Falling | $1 / 2 \mathrm{~T}-10$ |  | ns |  |
| TPLLL | Chip Selects Valid to ALE Falling | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TLLAX | Address Hold from ALE Falling | $1 / 2 \mathrm{~T}-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{\mathrm{WR}}$ Falling | $1 / 2 \mathrm{~T}-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\mathrm{RD}}$ Falling | $1 / 2 \mathrm{~T}-15$ |  | ns | 1 |
| TRHLH | $\overline{\text { RD R }}$ ising to ALE Rising | $1 / 2 T-10$ |  | ns | 1 |
| TWHLH | $\overline{\text { WR Rising to ALE Rising }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| $\mathrm{T}_{\text {AFRL }}$ | Address Float to $\overline{\text { RD }}$ Falling | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Falling to $\overline{\mathrm{RD}}$ Rising | (2*T) - 5 |  | ns | 2 |
| TWLWH | $\overline{\text { WR Falling to } \overline{\text { WR }} \text { Rising }}$ | (2*T) - 5 |  | ns | 2 |
| TrHAV | $\overline{\mathrm{RD}}$ Rising to Address Active | T-15 |  | ns |  |
| TwHDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| TWHDEX | $\overline{\text { WR Rising to } \overline{\mathrm{DEN}} \text { Rising }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| T WHPH | $\overline{\text { WR Rising to Chip Select Rising }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1,4 |
| TRHPH | $\overline{\mathrm{RD}}$ Rising to Chip Select Rising | $1 / 2 \mathrm{~T}-10$ |  | ns | 1,4 |
| TPHPL | $\overline{\mathrm{CS}}$ Inactive to $\overline{\mathrm{CS}}$ Active | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TDXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/R Low | 0 |  | ns | 5 |
| TovRH | ONCE ( $\overline{\text { UCS, }}$ LCS) Active to $\overline{\text { RESIN }}$ Rising | T |  | ns | 3 |
| TRHOX | ONCE ( $\overline{U C S}, \overline{L C S}$ ) to $\overline{\text { RESIN }}$ Rising | T |  | ns | 3 |

## NOTES:

1. Assumes equal loading on both pins.
2. Can be extended using wait states.
3. Not tested.
4. Not applicable to latched A2:1. These signals change only on falling $T_{1}$.
5. For write cycle followed by read cycle.

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 7. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms, for AC specification definitions, test pins, and illustrations.


Figure 7. AC Test Load

## AC TIMING WAVEFORMS



Figure 8. Input and Output Clock Waveform


Figure 9. Output Delay and Float Waveform


272020-11
NOTE:
RESIN measured to CLKIN, not CLKOUT
Figure 10. Input Setup and Hold


Figure 11. Relative Signal Waveform

## DERATING CURVES



Figure 12. Typical Output Delay Variations Versus Load Capacitance

## RESET

The 80C188EA will perform a reset operation any time the RESIN pin is active. The RESIN pin is actually synchronized before it is presented internally, which means that the clock must be operating before a reset can take effect. From a power-on state, RESIN must be held active (low) in order to guarantee correct initialization of the 80C188EA. Failure to provide RESIN while the device is powering up will result in unspecified operation of the device.

Figure 14 shows the correct reset sequence when first applying power to the 80C188EA. An external clock connected to CLKIN must not exceed the VCC threshold being applied to the 80C188EA. This is normally not a problem if the clock driver is supplied with the same $V_{C C}$ that supplies the 80C188EA. When attaching a crystal to the device, $\overline{\text { RESIN }}$ must remain active until both $\mathrm{V}_{\mathrm{CC}}$ and CLKOUT are stable (the length of time is application specific and depends on the startup characteristics of the crystal


Figure 13. Typical Rise and Fall Variations Versus Load Capacitance
circuit). The $\overline{\text { RESIN }}$ pin is designed to operate correctly using an RC reset circuit, but the designer must ensure that the ramp time for $V_{C C}$ is not so long that RESIN is never really sampled at a logic low level when $V_{C C}$ reaches minimum operating conditions.

Figure 15 shows the timing sequence when RESIN is applied after $V_{C C}$ is stable and the device has been operating. Note that a reset will terminate all activity and return the 80C188EA to a known operating state. Any bus operation that is in progress at the time $\overline{\operatorname{RESIN}}$ is asserted will terminate immediately (note that most control signals will be driven to their inactive state first before floating).

While $\overline{R E S I N}$ is active, signals $\overline{R D} / \overline{Q S M D}$, UCS, LCS and LOCK, are configured as inputs and weakly held high by internal pullup transistors. Forcing UCS and LCS low selects ONCE Mode. Forcing QSMD low selects Queue Status Mode. Forcing LOCK low is prohibited and results in unspecified operation.


NOTE:
CLKOUT resynchronization occurs approximately $11 / 2$ CLKIN periods after $\overline{\text { RESIN }}$ is sampled low. If $\overline{\text { RESIN }}$ is sampled low while CLKOUT is transitioning high, then CLKOUT will remain high for two CLKIN periods. If RESIN is sampled low while CLKOUT is transitioning high, then CLKOUT will not be affected.

## BUS CYCLE WAVEFORMS

Figures 16 through 22 present the various bus cycles that are generated by the 80C188EA. What is shown in the figure is the relationship of the various bus signals to CLKOUT. These figures along with the information present in AC Specifications allow the user to determine all the critical timing analysis needed for a given application.


Figure 16. Read, Fetch and Refresh Cycle Waveform


Figure 17. Write Cycle Waveform


## NOTE:

The address driven is typically the location of the next instruction prefetch. The 80C188EA drives these pins to 0 during Idle and Powerdown Modes.

Figure 18. Halt Cycle Waveform


Figure 19. INTA Cycle Waveform


Figure 20. HOLD/HLDA Waveform


Figure 21. DRAM Refresh Cycle During Hold Acknowledge


## NOTES:

Figure 22. Ready Waveform

## REGISTER BIT SUMMARY

Figures 23 through 30 present the bit definition of each register that is active (not reserved) in the Pe ripheral Control Block (PCB). Each register can be thought to occupy one word (16-bits) of either memory or I/O space, although not all bits in the register necessarily have a function. A register bit is not
guaranteed to return a specific logic value if an " $X$ " appears for the bit definition (i.e., if a zero was written to the register bit it may not be returned as a zero when read). Furthermore, a 0 must be written to any bit that is indicated by an " $X$ " to ensure compatibility with future products or potential product changes.


Figure 23. Interrupt Control Unit Registers (Master Mode)




272020-26

Figure 24. Interrupt Control Unit Registers (Master Mode)


Figure 25. Interrupt Control Unit Registers (Slave Mode)


Figure 26. Timer Control Unit Registers


Figure 27. Chip-Select Unit Registers


| bit <br> 0 | TC0 |
| :--- | :---: |
| 1 | TC1 |
| 2 | TC2 |
| 3 | TC3 |
| 4 | TC4 |
| 5 | TC5 |
| 6 | TC6 |
| 7 | TC7 |
| 8 | TC8 |
| 9 | TC9 |
| 10 | TC10 |
| 11 | TC11 |
| 12 | TCMA |
| 13 | Counster |
| 14 | TC13 |
| 15 | TC14 |
|  | TC15 |


272020-32

Figure 28. DMA Unit Registers


Figure 29. Refresh Control Unit Registers


Figure 30. Power Management, Relocation and Stepping Registers

## 80C188EA EXPRESS

The Intel EXPRESS program offers an extended temperature range as an enhancement to the 80C188EA operational specifications. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

With the standard commercial temperature range, operational characteristics are guaranteed over a temperature range corresponding to $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ambient. With the extended temperature range option, operational characteristics are guaranteed over a temperature range corresponding to $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ambient.

Package types and EXPRESS versions are identified by a one- or two-letter prefix to the part number. The prefixes are listed in Table 9. All AC and DC specifications are the same for both commercial and EXPRESS parts.

Table 9. Prefix Identification

| Prefix | Package <br> Type | Temperature <br> Range |
| :---: | :--- | :--- |
| N | PLCC | Commercial |
| S | QFP (EIAJ) | Commercial |
| TN | PLCC | Extended |
| TS | QFP (EIAJ) | Extended |

## 80C188EA EXECUTION TIMINGS

A determination of 80C188EA program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

With an 8 -bit BIU, the 80 C 188 may not have sufficient bus performance to ensure that an adequate number of bytes will reside in the queue most of the time. Therefore, actual program execution time will be substantially greater than that derived from adding the instruction timings shown.

## INSTRUCTION SET SUMMARY

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER MOV = Move: |  |  |  |  |  |  |
| Register to Register/Memory | 1000100 w | mod reg r/m |  |  | 2/12* |  |
| Register/memory to register | 1000101 w | mod reg r/m |  |  | 2/9* |  |
| Immediate to register/memory | 1100011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 12/13 | 8/16-bit |
| Immediate to register | 1011 w reg | data | data if $w=1$ | . | 3/4 | 8/16-bit |
| Memory to accumulator | 1010000 w | addr-low | addr-high |  | 8* |  |
| Accumulator to memory | 1010001 w | addr-low | addr-high |  | 9* |  |
| Register/memory to segment register | 10001110 | mod 0 reg r/m |  |  | 2/13 |  |
| Segment register to register/memory | 10001100 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2/15 |  |
| PUSH = Push: |  |  |  |  |  |  |
| Memory | 11111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  | 20 |  |
| Register | 01010 reg |  |  | . | 14 |  |
| Segment register | 000 reg 110 |  |  |  | 13 |  |
| Immediate | 01101050 | data | data if $\mathrm{s}=0$ |  | 14 |  |
| Pusius = Push An | 01100000 |  | $\pi$ |  | 68 |  |
| POP = Pop: |  |  |  |  |  |  |
| Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 24 |  |
| Register | 01011 reg |  |  |  | 14 |  |
| Segment register | 000 reg 111 | $(\mathrm{reg}=01$ ) |  |  | 12 |  |
| POPA = Popall ............ | 01100001 | $\pi \sqrt{2} / \sqrt{2}$ |  |  | 83 |  |
| XCHG = Exchange: |  |  |  |  |  |  |
| Register/memory with register | 1000011 w | mod reg r/m |  |  | 4/17* |  |
| Register with accumulator | 10010 reg |  |  |  | 3 |  |
| $\boldsymbol{I N}=$ Input from: |  |  |  |  |  |  |
| Fixed port | 1110010 w | port |  |  | 10* |  |
| Variable port | 1110110 w |  |  |  | 8* |  |
| OUT = Output to: |  |  |  |  |  |  |
| Fixed port | 1110011 w | port |  |  | 9* |  |
| Variable port | 1110111 w |  |  |  | 7* |  |
| XLAT $=$ Translate byte to AL | 11010111 |  |  |  | 15 |  |
| LEA = Load EA to register | 10001101 | mod reg r/m |  |  | 6 |  |
| LDS = Load pointer to DS | 11000101 | mod reg r/m | $(\bmod \neq 11)$ |  | 26 |  |
| LES = Load pointer to ES | 11000100 | mod reg r/m | $(\bmod \neq 11)$ |  | 26 |  |
| LAHF = Load AH with flags | 10011111 |  |  |  | 2 |  |
| SAHF = Store AH into flags | 10011110 |  |  |  | 3 |  |
| PUSHF = Push flags | 10011100 |  |  |  | 13 |  |
| POPF $=$ Pop flags | 10011101 |  |  |  | 12 |  |

Shaded areas indicate instructions not available in 8086,8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER (Continued) SEGMENT = Segment Override: |  |  |  |  |  |  |
| CS | 00101110 |  |  |  | 2 |  |
| SS | 00110110 |  |  |  | 2 |  |
| DS | 00111110 |  |  |  | 2 |  |
| ES | 00100110 |  |  |  | 2 |  |
| ARITHMETIC ADD = Add: |  |  |  |  |  |  |
| Reg/memory with register to either | 000000 dw | mod reg r/m |  | , | 3/10* |  |
| Immediate to register/memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s} \mathbf{w}=01$ | 4/16* |  |
| Immediate to accumulator | 0000010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| ADC = Add with carry:Reg/memory with register to either $\quad 000100 \mathrm{dw}$ |  |  |  |  |  |  |
|  |  |  |  |  | 3/10* |  |
| Immediate to register/memory | 100000sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $s$ w $=01$ | 4/16* |  |
| Immediate to accumulator | 0001010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| INC = Increment: |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 3/15* |  |
| Register | 01000 reg |  |  |  | 3 |  |
| SUB = Subtract:Reg/memory and register to either $\quad 0.001010 \mathrm{dw}$ |  |  |  |  |  |  |
|  |  |  |  |  | 3/10* |  |
| Immediate from register/memory | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16* |  |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| SBB = Subtract with borrow: |  |  |  |  |  |  |
| Reg/memory and register to either | 000110 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16* |  |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| DEC = Decrement |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 3/15* |  |
| Register | 01001 reg |  |  |  | 3 |  |
| CMP = Compare: |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | mod reg r/m |  |  | 3/10* |  |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 3/10* |  |
| Immediate with register/memory | 100000 sw | $\bmod 111 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 3/10* |  |
| Immediate with accumulator | 0011110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NEG = Change sign register/memory | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | 3/10* |  |
| AAA $=$ ASCII adjust for add | 00110111 |  |  |  | 8 |  |
| DAA = Decimal adjust for add | 00100111 |  |  |  | 4 |  |
| AAS $=$ ASCII adjust for subtract | 00111111 |  |  |  | 7 |  |
| DAS $=$ Decimal adjust for subtract | 00101111 |  |  |  | 4 |  |

Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

## INSTRUCTION SET SUMMARY (Continued)



[^12]
## *NOTE:

Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 8088 microsystems.
*NOTE:
Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086,8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  | Clock <br> Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CONTROL TRANSFER (Continued) INT = Interrupt: |  |  |  | 4745$48 / 4$ | if INT. taken/ if INT. not taken |
| Type specified | 11001101 | type |  |  |  |
| Type 3 | 11001100 |  |  |  |  |
| INTO = interrupt on overflow | 11001110 |  |  |  |  |
| IRET = Interrupt return | 11001111 |  |  | 28 |  |
| Beund = Detect value out of range | $=001100010$ | modreg I/m |  | 33-35 |  |
| PROCESSOR CONTROL |  |  | - |  |  |
| CLC = Clear carry | 11111000 |  |  | 2 |  |
| CMC = Complement carry | 11110101 |  |  | 2 |  |
| STC = Set carry | 11111001 |  |  | 2 |  |
| CLD = Clear direction | 11111100 |  |  | 2 |  |
| STD $=$ Set direction | 11111101 |  |  | 2 |  |
| CLI = Clear interrupt | 11111010 |  |  | 2 | 1 |
| STI = Set interrupt | 11111011 |  |  | 2 | 1 |
| HLT $=$ Halt | 11110100 |  |  | 2 |  |
| WAIT = Wait | 10011011 |  |  | 6 | if $\overline{\text { TEST }}=0$ |
| LOCK = Bus lock prefix | 11110000 |  |  | 2 |  |
| NOP $=$ No Operation | 10010000 |  |  | 3 |  |

Shaded areas indicate instructions not available in 8086,8088 microsystems.

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if mod $=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field if mod $=00$ then DISP $=0^{*}$, disp-low and disphigh 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 EA $=(B X)+(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=001$ then $E A=(B X)+(D I)+$ DISP
if $\mathrm{r} / \mathrm{m}=010$ then EA $=(B P)+(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+D I S P$
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 $\mathrm{EA}=(\mathrm{BP})+\mathrm{DISP}^{*}$
if $\mathrm{r} / \mathrm{m}=111$ then EA $=(B X)+$ DISP

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

Segment Override Prefix

$$
\begin{array}{|lllllll|}
\hline 0 & 0 & 1 & \text { reg } & 1 & 1 & 0 \\
\hline
\end{array}
$$

reg is assigned according to the following:
Segment
reg Register
00 ES
01 CS
10 SS
11 DS

DISP follows $2 n d$ byte of instruction (before data if required)

[^13]REG is assigned according to the following table:

| $\mathbf{1 6 - B i t}(\mathbf{w}=\mathbf{1})$ | $\mathbf{8}$-Bit $(\mathbf{w}=\mathbf{0})$ |
| :---: | :---: |
| 000 AX | 000 AL |
| 001 CX | 001 CI |
| 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.


Figure 31. PLCC Principal Dimensions


NOTE:
Units are mm (inches) unless specified.
Figure 32. QFP (EIAJ) Principal Dimensions

## REVISION HISTORY

Intel 80C188EA devices are marked with a 9-character alphanumeric Inte! FPO number underneath the product number. This data sheet (272020-002) is valid for 80C188EA devices with an "A" or "B" as the ninth character in the FPO number, as illustrated in Figure 5 for the 68-lead PLCC package and Figure 6 for the 84-lead QFP (EIAJ) package. Such devices may also be identified by reading a value of 01 H or 02 H from the STEPID register.

The following changes were made between the -001 and -002 versions of the 80C188EA data sheets. The -002 data sheet applies to any 80C188EA with a "B" alpha character after the FPO number. The FPO number location is shown in Figures 5 and 6.

1. Much of the information provided in the - 001 version of the data sheet has been removed. Detail descriptions of part functionality may be found in the 80C188EA User's Manual.

## ERRATA

An 80C188EA with a STEPID value of 01 H or 02 H has the following known errata. A device with a STEPID of 01 H or 02 H can be visually identified by noting the presence of an "A" or "B" alpha character, respectively, next to the FPO number. The FPO number location is shown in Figures 5 and 6.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistently, it is dependent on interrupt timing.

# 80C188EB-20, -16, -13, -8 <br> 16-BIT HIGH-INTEGRATION EMBEDDED PROCESSOR 

\author{

- Full Static Operation <br> - True CMOS Inputs and Outputs <br> $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operating Temperature Range <br> - Low System Cost 8-Bit Interface
}

■ Integrated Feature Set

- Low-Power Static CPU Core
- Two Independent UARTs each with an Integral Baud Rate Generator
- Two 8-Bit Multiplexed I/O Ports
- Programmable Interrupt Controller
- Three Programmable 16-Bit Timer/Counters
- Clock Generator
- Ten Programmable Chip Selects with Integral Wait-State Generator
- Memory Refresh Control Unit
- System Level Testing Support (ONCETM Mode)
■ Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
■ Speed Versions Available:
-20 MHz (80C188EB-20)
- 16 MHz (80C188EB-16)
- 13 MHz (80C188EB-13)
- 8 MHz (80C188EB-8)
- Low-Power Operating Modes:
- Idle Mode Freezes CPU Clocks but keeps Peripherals Active
- Powerdown Mode Freezes All Internal Clocks
- Complete System Development Support
- ASM86 Assembler, PL/M 86, Pascal 86, Fortran 86, C-86, and System Utillities
- In-Circuit Emulator (ICETM-188EB)
- Available In:
- 80-Pin Quad Flat Pack (TS80C188EB)
-84-Pin Plastic Leaded Chip Carrier (TN80C188EB)

The 80 C 188 EB is a second generation CHMOS High-Integration microprocessor. It has features that are new to the 80C188 family and include a STATIC CPU core, an enhanced Chip Select decode unit, two independent Serial Channels, I/O ports, and the capability of Idle or Powerdown low power modes.



Figure 1. 80C188EB Block Diagram

## INTRODUCTION

The 80C188EB is the first product in a new generation of low-power, high-integration microprocessors. It enhances the existing 186 family by offering new features and new operating modes. The 80C188EB is object code compatible with the $80 \mathrm{C} 186 / 80 \mathrm{C} 188$ microprocessors. The 80C188EB has an 8-bit external data bus but still retains a 16-bit internal bus. An 8 -bit external bus reduces system cost by requiring that only single byte-wide memories be used.

The feature set of the 80 C 188 EB meets the needs of low power, space critical applications. Low-Power applications benefit from the static design of the CPU core and the integrated peripherals. Minimum current consumption is achieved by providing a Powerdown mode that halts operation of the device, and freezes the clock circuits. Peripheral design enhancements ensure that non-initialized peripherals consume little current.

Space critical applications benefit from the integration of commonly used system peripherals. Two serial channels are provided for services such as diagnostics, inter-processor communication, modem interface, terminal display interface, and many others. A flexible chip select unit simplifies memory and peripheral interfacing. The interrupt unit provides sources for up to 129 external interrupts and will prioritize these interrupts with those generated from the on-chip peripherals. Three general purpose timer/counters and sixteen multiplexed I/O port pins round out the feature set of the 80 C 188 EB .

## OVERVIEW

Figure 1 shows a block diagram of the 80C188EB. The Execution Unit (EU) is an enhanced 8088 CPU core that includes: dedicated hardware to speed up effective address calculations, enhance execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instruction, and full static operation. The Bus Interface Unit (BIU) is the same as that found on the original 188 family products, except the queuestatus mode has been deleted and buffer interface control has been changed to ease system design timings. An independent internal bus is used to allow communication between the BIU and internal peripherals.

## BUS INTERFACE UNIT

The 80C188EB core incorporates a bus controller that generates local bus control signals. In addition, it employs a HOLD/HLDA protocol to share the local bus with other bus masters.

The bus controller is responsible for generating 20 bits of address, read and write strobes, bus cycle status information, and data (for write operations) information. It is also responsible for reading data off the local bus during a read operation. A READY input pin is provided to extend a bus cycle beyond the minimum four states (clocks).

The 80 C 188 EB local bus controller also generates two control signals ( $\overline{\mathrm{DEN}}$ and $\mathrm{DT} / \overline{\mathrm{R}}$ ) when interfacing to external transceiver chips. (Both DEN and $D T / \bar{R}$ are available on the TN80C188EB device, only $\overline{\mathrm{DEN}}$ is available on the TS80C188EB device.) This capability allows the addition of transceivers for simple buffering of the mulitplexed address/data bus.

## CLOCK GENERATOR

The 80C188EB provides an on-chip clock generator for both internal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter, and two low-power operating modes.

The oscillator circuit is designed to be used with either a parallel resonant fundamental or third-overtone mode crystal network. Alternatively, the oscillator circuit may be driven from an external clock source. Figure 2 shows the various operating modes of the 80 C 188 EB oscillator circuit.

The crystal or clock frequency chosen must be twice the required processor operating frequency due to the internal divide-by-two counter. This counter is used to drive all internal phase clocks and the external CLKOUT signal. CLKOUT is a $50 \%$ duty cycle processor clock and can be used to drive other system components. All AC timings are referenced to CLKOUT.

The following parameters are recommended when choosing a crystal:

Temperature Range: Application Specific ESR (Equivalent Series Resistance): $\quad 40 \Omega$ max C0 (Shunt Capacitance of Crystal): $\quad 7.0 \mathrm{pF}$ max $\mathrm{C}_{\mathrm{L}}$ (Load Capacitance): $\quad 20 \mathrm{pF} \pm 2 \mathrm{pF}$ Drive Level:

1 mW max


270885-3
(A) Crystal Connection

NOTE:
The $L_{1} C_{1}$ network is only required when using a thirdovertone crystal.

(B) Clock Connection

Figure 2. 80C188EB Clock Configurations

## 80C188EB Peripheral Architecture

The 80C188EB has integrated several common system peripherals with a CPU core to create a compact, yet powerful system. The integrated peripherals are designed to be flexible and provide logical interconnections between supporting units (e.g., the interrupt control unit supports interrupt requests from the timer/counters or serial channels).

The list of integrated peripherals includes:

- 7-Input Interrupt Control Unit
- 3-Channel Timer/Counter Unit
- 2-Channel Serial Communications Unit
- 10-Output Chip-Select Unit
- I/O Port Unit
- Refresh Control Unit
- Power Management Unit

The registers associated with each integrated periheral are contained within a $128 \times 16$ register file called the Peripheral Control Block (PCB). The PCB can be located in either memory or I/O space on any 256 Byte address boundary.

The starting address of the PCB is controlled by a relocation register and can overlap any of the memory or I/O regions programmed into the Chip Select Unit. In this case, the overlapped chip select will not go active when the PCB is read or written.

Figure 3 provides a list of the registers associated with the PCB. The Register Bit Summary at the end of this specification individually lists all of the registers and identifies each of their programming attributes.

## INTERRUPT CONTROL UNIT

The 80C188EB can receive interrupts from a number of sources, both internal and external. The interrupt control unit serves to merge these requests, on a priority basis, for individual service by the CPU. Each interrupt source can be independently masked by the Interrupt Control Unit (ICU) or all interrupts can be globally masked by the CPU.

Internal interrupt sources include the Timers and Serial channel 0 . External interrupt sources come from the five input pins INT4:0. The NMI interrupt pin is not controlled by the ICU and is passed directly to the CPU. Although the Timer and Serial channel each have only one request input to the ICU, separate vector types are generated to service individual interrupts within the Timer and Serial channel units.

## TIMER/COUNTER UNIT

The 80C188EB Timer/Counter Unit (TCU) provides three 16 -bit programmable timers. Two of these are highly flexible and are connected to external pins for control or clocking. A third timer is not connected to any external pins and can only be clocked internally. However, it can be used to clock the other two timer channels. The TCU can be used to count external events, time external events, generate non-repetitive waveforms, generate timed interrupts. etc.

| PCB <br> Offset | Function | $\begin{gathered} \text { PCB } \\ \text { Offset } \end{gathered}$ | Function | $\begin{gathered} \text { PCB } \\ \text { Offset } \end{gathered}$ | Function | $\begin{aligned} & \text { PCB } \\ & \text { Offset } \end{aligned}$ | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00H | Reserved | 40H | Timer2 Count | 80 H | GCSO Start | COH | Reserved |
| 02H | End Of Interrupt | 42 H | Timer2 Compare | 82H | GCSO Stop | C 2 H | Reserved |
| 04H | Poll | 44H | Reserved | 84H | GCS1 Start | C4H | Reserved |
| 06H | Poll Status | 46 H | Timer2 Control | 86H | GCS1 Stop | C 6 H | Reserved |
| 08H | Interrupt Mask | 48 H | Reserved | 88 H | GCS2 Start | C8H | Reserved |
| OAH | Priority Mask | 4AH | Reserved | 8AH | GCS2 Stop | CAH | Reserved |
| OCH | In-Service | 4 CH | Reserved | 8CH | GCS3 Start | CCH | Reserved |
| OEH | Interrupt Request | 4EH | Reserved | 8EH | GCS3 Stop | CEH | Reserved |
| 10 H | Interrupt Status | 50 H | Reserved | 90 H | GCS4 Start | DOH | Reserved |
| 12 H | Timer Control | 52H | Porto Pin | 92H | GCS4 Stop | D2H | Reserved |
| 14H | Serial Control | 54H | Porto Control | 94H | GCS5 Start | D4H | Reserved |
| 16H | INT4 | 56 H | Port0 Latch | 96 H | GCS5 Stop | D6H | Reserved |
| 18H | INTO Control | 58 H | Port1 Direction | 98H | GCS6 Start | D8H | Reserved |
| 1AH | INT1 Control | 5AH | Port1 Pin | 9AH | GCS6 Stop | DAH | Reserved |
| 1 CH | INT2 Control | 5 CH | Port1 Control | 9CH | GCS7 Start | DCH | Reserved |
| 1EH | INT3 Control | 5EH | Port1 Latch | 9EH | GCS7 Stop | DEH | Reserved |
| 20 H | Reserved | 60 H | Serial0 Baud | AOH | LCS Start | EOH | Reserved |
| 22 H | Reserved | 62H | Serial0 Count | A2H | LCS Stop | E2H | Reserved |
| 24H | Reserved | 64H | Serial0 Control | A4H | UCS Start | E4H | Reserved |
| 26H | Reserved | 66H | Serial0 Status | A6H | UCS Stop | E6H | Reserved |
| 28 H | Reserved | 68H | Serial0 RBUF | A8H | Relocation | E8H | Reserved |
| 2AH | Reserved | 6AH | Serial0 TBUF | AAH | Reserved | EAH | Reserved |
| 2 CH | Reserved | 6CH | Reserved | ACH | Reserved | ECH | Reserved |
| 2EH | Reserved | 6EH | Reserved | AEH | Reserved | EEH | Reserved |
| 30 H | Timer0 Count | 70 H | Serial1 Baud | BOH | Refresh Base | FOH | Reserved |
| 32H | Timer0 Compare A | 72H | Serial1 Count | B2H | Refresh Time | F2H | Reserved |
| 34H | Timer0 Compare B | 74H | Serial1 Control | B4H | Refresh Control | F4H | Reserved |
| 36 H | Timer0 Control | 76H | Serial1 Status | B6H | Refresh Address | F6H | Reserved |
| 38 H | Timer1 Count | 78H | Serial1 RBUF | B8H | Power Control | F8H | Reserved |
| 3AH | Timer1 Compare A | 7AH | Serial1 TBUF | BAH | Reserved | FAH | Reserved |
| 3 CH | Timer1 Compare B | 7 CH | Reserved | BCH | Step ID | FCH | Reserved |
| 3EH | Timer1 Control | 7EH | Reserved | BEH | Reserved | FEH | Reserved |

Figure 3. 80C188EB Peripheral Control Block Registers

## SERIAL COMMUNICATIONS UNIT

The Serial Control Unit (SCU) of the 80C188EB contains two independent channels. Each channel is identical in operation except that only channel 0 is supported by the integrated interrupt controller (channel 1 has an external interrupt pin). Each channel has its own baud rate generator that is independent of the Timer/Counter Unit, and can be internally or externally clocked up at one half the 80C188EB operating frequency.

Independent baud rate generators are provided for each of the serial channels. For the asynchronous modes, the generator supplies an $8 x$ baud clock to both the receive and transmit register logic. A 1x baud clock is provided in the synchronous mode.

## CHIP-SELECT UNIT

The 80C188EB Chip-Select Unit (CSU) integrates logic which provides up to ten programmable chipselects to access both memories and peripherals. In addition, each chip-select can be programmed to automatically insert additional clocks (wait-states) into the current bus cycle and automatically terminate a bus cycle independent of the condition of the READY input pin.

## I/O PORT UNIT

The I/O Port Unit (IPU) on the 80C188EB supports two 8 -bit channels of input, output, or input/output operation. Port 1 is multiplexed with the chip select pins and is output only. Most of Port 2 is multiplexed with the serial channel pins. Port 2 pins are limited to either an output or input function depending on the operation of the serial pin it is multiplexed with.

## REFRESH CONTROL UNIT

The Refresh Control Unit (RCU) automatically generates a periodic memory read bus cycle to keep dynamic or pseudo-static memory refreshed. A 9-bit counter controls the number of clocks between refresh requests.

A 12-bit address generator is maintained by the RCU and is presented on the A12:1 address lines during the refresh bus cycle. Address bits A19:13 are programmable to allow the refresh address block to be located on any 8 Kbyte boundary.

## POWER MANAGEMENT UNIT

The 80C188EB Power Management Unit (PMU) is provided to control the power consumption of the device. The PMU provides three power modes: Active, Idle, and Powerdown.

Active Mode indicates that all units on the 80C188EB are functional and the device consumes maximum power (depending on the level of peripheral operation). Idle Mode freezes the clocks of the Execution and Bus units at a logic zero state (all peripherals continue to operate normally).

The Powerdown mode freezes all internal clocks at a logic zero level and disables the crystal oscillator. All internal registers hold their values provided $V_{\mathrm{CC}}$ is maintained. Current consumption is reduced to just transistor junction leakage.

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80C188EB has a test mode available which forces all output and input/ output pins to be placed in the high-impedance state. ONCE stands for "ON Circuit Emulation". The ONCE mode is selected by forcing the A19/ONCE pin LOW ( 0 ) during a processor reset (this pin is weakly held to a HIGH (1) level while RESIN is active).

## PACKAGE INFORMATION

This section describes the pins, pinouts, and thermal characteristics for the 80 C 188 EB in the Plastic Leaded Chip Carrier (PLCC) package and Quad Flat Pack (QFP) package. For complete package specifications and information, see the Intel Packaging Outlines and Dimensions Guide (Order Number: 231369).

## Pin Descriptions

The 80C188EB pins are described in this section. Table 1 presents the legend for interpreting the pin descriptions in Table 2. Figure 4 provides an example pin description entry. The "I/O" signifies that the pins are bidirectional (i.e., have both an input and output function). The " S " indicates that, as an input, the signal is synchronized to CLKOUT for proper operation. The " $\mathrm{H}(\mathrm{Z})$ " indicates that these pins will float while the processor is in the Hold Acknowledge state. $\mathbf{R}(Z)$ indicates that these pins will float while RESIN is low. $P(X)$ Indicates that these pins will retain their current value when Idle or Powerdown Modes are entered.

All pins float while the processor is in the ONCETM Mode, except OSCOUT (OSCOUT is required for crystal operation).

| Name | Type | Description |
| :---: | :---: | :--- |
| AD7:0 | I/O | These pins provide a multiplexed |
|  | S(L) | ADDRESS and DATA bus. During |
|  | H(Z) | the address phase of the bus |
|  | R(Z) | cycle, address bits 0 through 15 |
|  | P(X) | are presented on the bus and can |
|  |  | be latched using ALE. 8-bit data |
|  |  | information are transerred during |
|  |  | the data phase of the bus cycle. |

Figure 4. Example Pin Description Entry

Table 1. Pin Description Nomenclature

| Symbol | Description |
| :---: | :---: |
| 1 | Input Only Pin |
| 0 | Output Only Pin |
| I/O | Pin can be either input or output |
| - | Pin "must be" connected as described |
| S(..) | Synchronous. Input must meet setup and hold times for proper operation of the processor. The pin is: <br> $\mathrm{S}(\mathrm{E})$ edge sensitive <br> $S(L)$ level sensitive |
| A(..) | Asynchronous. Input must meet setup and hold only to guarantee recognition. The pin is: <br> $A(E)$ edge sensitive <br> $A(L)$ level sensitive |
| H(..) | While the processor's bus is in the Hold Acknowiedge state, the pin: <br> $H(1)$ is driven to $V_{C C}$ <br> $H(0)$ is driven to $V_{S S}$ <br> $H(Z)$ floats <br> $H(Q)$ remains active <br> $H(X)$ retains current state |
| R(..) | While the processor's $\overline{\text { RES }}$ line is low, the pin: <br> $R(1)$ is driven to $V_{C C}$ <br> $R(0)$ is driven to $V_{S S}$ <br> $R(Z)$ fioats <br> R(WH) weak pullup <br> R(WL) weak pulldown |
| P(..) | While Idle or Powerdown modes are active, the pin: <br> $P(1)$ is driven to $V_{C C}$ <br> $P(0)$ is driven to $V_{S S}$ <br> $P(Z)$ floats <br> $P(Q)$ remains active ${ }^{(1)}$ <br> $P(X)$ retains current state |

## NOTE:

1. Any pin that specifies $P(Q)$ are valid for Idle Mode. All pins are $P(X)$ for Powerdown Mode.

Table 2. 80C188EB Pin Descriptions

| Name | Type | Description |
| :---: | :---: | :---: |
| ${ }^{\mathrm{V}} \mathrm{Cc}$ |  | POWER connections consisi oí íour pins which musi be shorted externally to a $\mathrm{V}_{\mathrm{CC}}$ board plane. |
| $\mathrm{V}_{\text {SS }}$ |  | GROUND connections consist of six pins which must be shorted externally to a $\mathrm{V}_{\text {SS }}$ board plane. |
| CLKIN | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | CLock INput is an input for an external clock. An external oscillator operating at two times the required 80C188EB operating frequency can be connected to CLKIN. For crystal operation, CLKIN (along with OSCOUT) are the crystal connections to an internal Pierce oscillator. |
| OSCOUT | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(\mathrm{Q}) \\ \mathrm{P}(\mathrm{Q}) \end{gathered}$ | OSCillator OUTput is only used when using a crystal to generate the external clock. OSCOUT (along with CLKIN) are the crystal connections to an internal Pierce oscillator. This pin is not to be used as 2 X clock output for non-crystal applications (i.e., this pin is N.C. for non-crystal applications). OSCOUT does not float in ONCE mode. |
| CLKOUT | 0 <br> $H(Q)$ <br> R(Q) <br> $P(Q)$ | CLock OUTput provides a timing reference for inputs and outputs of the processor, and is one-half the input clock (CLKIN) frequency. CLKOUT has a 50\% duty cycle and transistions every falling edge of CLKIN. |
| $\overline{\text { RESIN }}$ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | RESet IN causes the 80C188EB to immediately terminate any bus cycle in progress and assume an initialized state. All pins will be driven to a known state, and RESOUT will also be driven active. The rising edge (low-to-high) transition synchronizes CLKOUT with CLKIN before the 80C188EB begins fetching opcodes at memory location OFFFFOH. |
| RESOUT | $\begin{gathered} 0 \\ H(0) \\ R(1) \\ P(0) \\ \hline \end{gathered}$ | RESet OUTput that indicates the 80 C 188 EB is currently in the reset state. RESOUT will remain active as long as $\overline{\operatorname{RESIN}}$ remains active. |
| PDTMR | $\begin{gathered} I / O \\ A(L) \\ H(W H) \\ R(Z) \\ P(1) \end{gathered}$ | Power-Down TiMeR pin (normally connected to an external capacitor) that determines the amount of time the 80C188EB waits after an exit from power down before resuming normal operation. The duration of time required will depend on the startup characteristics of the crystal oscillator. |
| NMI | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | Non-Maskable Interrupt input causes a TYPE-2 interrupt to be serviced by the CPU. NMI is latched internally. |
| TEST | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | TEST is used during the execution of the WAIT instruction to suspend CPU operation until the pin is sampled active (LOW). |
| AD7:0 | I/O <br> S(L) <br> H(Z) <br> R(Z) <br> $P(X)$ | These pins provide a multiplexed Address and Data bus. During the address phase of the bus cycle, address bits 0 through 7 are presented on the bus and can be latched using ALE. 8 -bit data information is transferred during the data phase of the bus cycle. |
| A15:8 | $\begin{gathered} O \\ H(Z) \\ R(Z) \\ P(X) \end{gathered}$ | These pins provide Address information throughout the entire bus cycle. |

Table 2. 80C188EB Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| A18:16 <br> A19/ONCE | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{~W} 1) \\ \mathrm{P}(\mathrm{X}) \end{gathered}$ | These pins provide multiplexed ADDRESS during the address phase of the bus cycle. Address bits 16 through 19 are presented on these pins and can be latched using ALE. These pins are driven to a logic 0 during the data phase of the bus cycle. During a processor reset (RESIN active), A19/ ONCE is used to enable ONCE mode. A18:16 must not be driven low during reset or improper 80 C 188 EB operation may result. |
| S2:0 | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \end{gathered}$ | Bus cycle Status are encoded on these pins to provide bus transaction information. $\overline{\text { S2:0 }} 0$ are encoded as follows: |
| ALE | $\begin{gathered} \hline \mathrm{O} \\ \mathrm{H}(0) \\ \mathrm{R}(0) \\ \mathrm{P}(0) \end{gathered}$ | Address Latch Enable output is used to strobe address information into a transparent type latch during the address phase of the bus cycle. |
| $\overline{\text { RFSH }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | ReFreSH output signals that a refresh bus cycle is in progress. |
| $\overline{\mathrm{RD}}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | ReaD output signals that the accessed memory or I/O device must drive data information onto the data bus. |
| $\overline{W R}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \end{gathered}$ | WRite output signals that data available on the data bus are to be written into the accessed memory or I/O device. |
| READY | $\begin{gathered} 1 \\ A(L) \\ G(1) \end{gathered}$ | READY input to signal the completion of a bus cycle. READY must be active to terminate any 80C188EB bus cycle, unless it is ignored by correctly programming the Chip-Select Unit. |
| $\overline{\text { DEN }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Data ENable output to control the enable of bi-directional transceivers when buffering a 80C188EB system. DEN is active only when data is to be transferred on the bus. |

Table 2. 80C188EB Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
|  | 0 <br> H(Z) <br> R(Z) <br> $P(X)$ | Data Transmit/Receive output controis the direction of a bi-directionai buffer when buffering an 80C188EB system. DT/ $\overline{\mathrm{R}}$ is only available for the PLCC package (TN80C188EB). |
| LOCK | $\begin{gathered} 1 / O \\ H(Z) \\ R(W 1) \\ P(1) \\ \hline \end{gathered}$ | LOCK output indicates that the bus cycle in progress is not to be interrupted. The 80C188EB will not service other bus requests (such as HOLD) while $\overline{\text { LOCK }}$ is active. This pin is configured as a weakly held high input while RESIN is active and must not be driven low. |
| HOLD | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | HOLD request input to signal that an external bus master wishes to gain control of the local bus. The 80C188EB will relinquish control of the local bus between instruction boundaries not conditioned by a LOCK prefix. |
| HLDA | 0 <br> $H(1)$ <br> R(0) <br> $P(0)$ | HoLD Acknowledge output to indicate that the 80C188EB has relinquish control of the local bus. When HLDA is asserted, the 80C188EB will (or has) floated its data bus and control signals allowing another bus master to drive the signals directly. |
| $\overline{U C S}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Upper Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. After reset, $\overline{U C S}$ is configured to be active for memory accesses between OFFCOOH and OFFFFFH. |
| $\overline{\text { LCS }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Lower Chip Select will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. $\overline{\mathrm{LCS}}$ is inactive after a reset. |
| P1.0/GCS0 P1.1/GCS1 P1.2/GCS2 P1.3/GCS3 P1.4/GCS4 P1.5/GCS5 P1.6/GCS6 P1.7/GCS7 | $\begin{gathered} O \\ H(X) / H(1) \\ R(1) \\ P(X) / P(1) \end{gathered}$ | These pins provide a multiplexed function. If enabled, each pin can provide a Generic Chip Select output which will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. When not programmed as a Chip-Select, each pin may be used as a general purpose output Port. As an output port pin, the value of the pin can be read internally. |
| TOOUT T10UT | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(1) \\ \mathrm{P}(\mathrm{Q}) \\ \hline \end{gathered}$ | Timer OUTput pins can be programmed to provide a single clock or continuous waveform generation, depending on the timer mode selected. |
| $\begin{aligned} & \text { TOIN } \\ & \text { T1IN } \end{aligned}$ | $\begin{gathered} \hline 1 \\ A(L) \\ A(E) \end{gathered}$ | Timer INput is used either as clock or control signals, depending on the timer mode selected. |

Table 2. 80C188EB Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| INTO INT1 INT4 | $\stackrel{1}{A(E, L)}$ | Maskable INTerrupt input will cause a vector to a specific Type interrupt routine. To allow interrupt expansion, INT0 and/or INT1 can be used with $\overline{\mathrm{INTAO}}$ and $\overline{\text { INTA1 }}$ to interface with an external slave controller. |
| INT2/INTAO INT3//\NTA1 | I/O A(E,L) /H(1) $\mathrm{R}(\mathrm{Z})$ /P(1) | These pins provide a multiplexed function. As inputs, they provide a maskable INTerrupt that will cause the CPU to vector to a specific Type interrupt routine. As outputs, each is programmatically controlled to provide an INTERRUPT ACKNOWLEDGE handshake signal to allow interrupt expansion. |
| $\begin{array}{\|l\|} \hline \text { P2.7 } \\ \text { P2.6 } \end{array}$ | $\begin{aligned} & I / O \\ & A(L) \\ & H(X) \\ & R(Z) \\ & P(X) \end{aligned}$ | BI-DIRECTIONAL, open-drain Port pins. |
| $\begin{array}{\|l\|} \hline \overline{\text { CTSO }} \\ \text { P2.4/CTS1 } \end{array}$ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | Clear-To-Send input is used to prevent the transmission of serial data on their respective TXD signal pin. CTS1 is multiplexed with an input only port function. |
| $\begin{array}{\|l\|} \hline \text { TXD0 } \\ \text { P2.1/TXD1 } \end{array}$ | $\begin{gathered} O \\ H(X) / H(Q) \\ R(1) \\ P(X) / P(Q) \end{gathered}$ | Transmit Data output provides serial data information. TXD1 is multiplexed with an output only Port function. During synchronous serial communications, TXD will function as a clock output. |
| $\begin{array}{\|l\|} \text { RXDO } \\ \text { P2.0/RXD1 } \end{array}$ | I/O <br> A(L) <br> $R(Z)$ <br> $H(Q)$ <br> $P(X)$ | Receive Data input accepts serial data information. RXD1 is multiplexed with an input only Port function. During synchronous serial communications, RXD is bi-directional and will become an output for transmission or data (TXD becomes the clock). |
| $\begin{array}{\|l\|} \hline \text { P2.5/BCLK0 } \\ \text { P2.2/BCLK1 } \end{array}$ | $\begin{gathered} 1 \\ A(L) / A(E) \end{gathered}$ | Baud CLocK input can be used as an alternate clock source for each of the integrated serial channels. BCLKx is multiplexed with an input only Port function, and cannot exceed a clock rate greater than one-half the operating frequency of the 80 C 188 EB . |
| P2.3/SINT1 | $\begin{gathered} O \\ H(X) / H(Q) \\ R(O) \\ P(X) / P(Q) \end{gathered}$ | Serial INTerrupt output will go active to indicate serial channel 1 requires service. SINT1 is multiplexed with an output only Port function. |

## 80C188EB PINOUT

Tables 3 and 4 list the 80C188EB pin names with package location for the 84 -pin Plastic Leaded Chip Carrier (PLCC) component. Figure 5 depicts the complete 80C188EB pinout (PLCC package) as viewed from the top side of the component (i.e., contacts facing down).

Tables 5 and 6 list the 80C188EB pin names with package location for the 80 -pin Quad Flat Pack (QFP) component. Figure 6 depicts the complete socteocd (QFP package) as viewed from the top side of the component (i.e., contacts facing down).

Table 3. PLCC Pin Names with Package Location

| Address/Data Bus |  | Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Name | Location | Name | Location | Name | Location |
| ADO | 61 | ALE | 6 | $\overline{\text { RESIN }}$ | 37 |
| AD1 | 66 | $\overline{\text { RFSH }}$ | 7 | RESOUT | 38 |
| AD2 | 68 | SO | 10 | CLKIN | 41 |
| AD3 | 70 | S1 | 9 | OSCOUT | 40 |
| AD4 | 72 | S2 | 8 | CLKOUT | 44 |
| AD5 | 74 | $\overline{\mathrm{RD}}$ | 4 | TEST | 14 |
| AD6 | 76 | $\overline{\mathrm{WR}}$ | 5 | NC | 60 |
| AD7 | 78 | READY | 18 | NC | 39 |
| A8 | 62 |  |  |  |  |
| A9 | 67 | $\overline{\mathrm{DEN}}$ | 11 | NC | 3 |
| A10 | 69 | DT/ $\overline{\text { A }}$ | 16 | PDTMR | 36 |
| A11 | 71 | LOCK | 15 | NMI | 17 |
| A12 | 73 | HOLD | 13 | INTO | 31 |
| A13 | 75 | HLDA | 12 | INT1 | 32 |
| A14 | 77 |  |  | INT2/İNTAO | 33 |
| A15 | 79 |  |  | INT3/\/NTA1 | 34 |
| A16 | 80 | Name | Location | INT4 | 35 |
| A17 | 81 |  |  |  |  |
| A18 | 82 | $\mathrm{V}_{\text {ss }}$ | 2, 22, 43, |  |  |
| A19/ONCE | 83 |  | 63, 65, 84 |  |  |
|  |  | $\mathrm{V}_{\mathrm{cc}}$ | $\begin{aligned} & 1,23, \\ & 42,64 \end{aligned}$ |  |  |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{U C S}$ | 30 |
| $\overline{\text { LCS }}$ | 29 |
| P1.0/GCS0 | 28 |
| P1.1/GCS1 | 27 |
| P1.2/GCS2 | 26 |
| P1.3/GCS3 | 25 |
| P1.4/GCS4 | 24 |
| P1.5/द्GCS5 | 21 |
| P1.6/GCS6 | 20 |
| P1.7/GCS7 | 19 |
| T00UT | 45 |
| T0IN | 46 |
| T1OUT | 47 |
| T1IN | 48 |
| RXD0 | 53 |
| TXD0 | 52 |
| P2.5/BCLK0 | 54 |
| CTS0 | 51 |
| P2.0/RXD1 | 57 |
| P2.1/TXD1 | 58 |
| P2.2/BCLK1 | 59 |
| P2.3/SINT1 | 55 |
| P2.4/प्CTS1 | 56 |
| P2.6 | 50 |
| P2.7 | 49 |

Table 4. PLCC Package Locations with Pin Name

| Location | Name |
| :---: | :--- |
| 1 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 2 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 3 | NC |
| 4 | $\overline{\mathrm{RD}}$ |
| 5 | $\overline{\mathrm{WR}}$ |
| 6 | ALE |
| 7 | $\overline{\mathrm{RFSH}}$ |
| 8 | $\overline{\mathrm{~S} 2}$ |
| 9 | $\overline{\mathrm{~S} 1}$ |
| 10 | $\overline{\mathrm{S0}}$ |
| 11 | $\overline{\mathrm{DEN}}$ |
| 12 | HLDA |
| 13 | HOLD |
| 14 | $\overline{\mathrm{TEST}}$ |
| 15 | $\overline{\mathrm{LOCK}}$ |
| 16 | $\mathrm{DT} / \bar{R}$ |
| 17 | NMI |
| 18 | READY |
| 19 | $\mathrm{P} 1.7 / \overline{\mathrm{GCS7}}$ |
| 20 | $\mathrm{P} 1.6 / \overline{\mathrm{GCS}}$ |
| 21 | $\mathrm{P} 1.5 / \overline{\mathrm{GCS5}}$ |


| Location | Name |
| :---: | :--- |
| 22 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 23 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 24 | $\mathrm{P} 1.4 / \overline{\mathrm{GCS}}$ |
| 25 | $\mathrm{P} 1.3 / \overline{\mathrm{GCS3}}$ |
| 26 | $\mathrm{P} 1.2 / \overline{\mathrm{GCS2}}$ |
| 27 | $\mathrm{P} 1.1 / \overline{\mathrm{GCS1}}$ |
| 28 | $\mathrm{P} 1.0 / \overline{\mathrm{GCS0}}$ |
| 29 | $\overline{\mathrm{LCS}}$ |
| 30 | $\overline{\mathrm{UCS}}$ |
| 31 | INTO |
| 32 | INT1 |
| 33 | INT2/INTA0 |
| 34 | INT3/INTA1 |
| 35 | INT4 |
| 36 | PDTMR |
| 37 | $\overline{R E S I N}$ |
| 38 | RESOUT |
| 39 | NC |
| 40 | OSCOUT |
| 41 | CLKIN |
| 42 | VCC |


| Location | Name |
| :---: | :--- |
| 43 | $\mathrm{~V}_{\text {SS }}$ |
| 44 | CLKOUT |
| 45 | TOOUT |
| 46 | TOIN |
| 47 | T1OUT |
| 48 | T1IN |
| 49 | P2.7 |
| 50 | P2.6 |
| 51 | CTS0 |
| 52 | TXD0 |
| 53 | RXD0 |
| 54 | P2.5/BCLK0 |
| 55 | P2.3/SINT1 |
| 56 | P2.4/CTS1 |
| 57 | P2.0/RXD1 |
| 58 | P2.1/TXD1 |
| 59 | P2.2/BCLK1 |
| 60 | NC |
| 61 | AD0 |
| 62 | A8 |
| 63 | $V_{\text {SS }}$ |


| Location | Name |
| :---: | :---: |
| 64 | $\mathrm{V}_{\mathrm{Cc}}$ |
| 65 | $\mathrm{V}_{\text {SS }}$ |
| 66 | AD1 |
| 67 | A9 |
| 68 | AD2 |
| 69 | A10 |
| 70 | AD3 |
| 71 | A11 |
| 72 | AD4 |
| 73 | A12 |
| 74 | AD5 |
| 75 | A13 |
| 76 | AD6 |
| 77 | A14 |
| 78 | AD7 |
| 79 | A15 |
| 80 | A16 |
| 81 | A17 |
| 82 | A18 |
| 83 | A19/ONCE |
| 84 | $V_{\text {SS }}$ |



Figure 5. 84-Pin Plastic Leaded Chip Carrier Pinout Diagram

Table 5. QFP Pin Name with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 10 |
| AD1 | 15 |
| AD2 | 17 |
| AD3 | 19 |
| AD4 | 21 |
| AD5 | 23 |
| AD6 | 25 |
| AD7 | 27 |
| A8 | 11 |
| A9 | 16 |
| A10 | 18 |
| A11 | 20 |
| A12 | 22 |
| A13 | 24 |
| A14 | 26 |
| A15 | 28 |
| A16 | 29 |
| A17 | 30 |
| A18 | 31 |
| A19/ONCE | 32 |


| Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: |
| Name | Location | Name | Location |
| ALE | 38 | $\overline{\text { RESIN }}$ | 68 |
| $\overline{\text { RFSH }}$ | 39 | RESOUT | 69 |
| So | 42 | CLKIN | 71 |
| S1 | 41 | OSCOUT | 70 |
| S2 | 40 | CLKOUT | 74 |
| $\overline{\mathrm{RD}}$ | 36 | TEST | 46 |
| $\overline{\mathrm{WR}}$ | 37 | PDTMR | 67 |
| READY | 49 | NMI | 48 |
| $\overline{\text { DEN }}$ | 43 | INTO | 62 |
|  | 47 | INT1 | 63 |
| LOCK | 47 | INT2/INTAO | 64 |
| HOLD | 45 | INT3/\/NTA1 | 65 |
| HLDA | 44 | INT4 | 66 |
|  |  | Pow | wer |
|  |  | Name | Location |
|  |  | $\mathrm{V}_{\mathrm{SS}}$ | $\begin{aligned} & 12,14,33, \\ & 35,53,73 \end{aligned}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & 13,34, \\ & 54,72 \end{aligned}$ |


| I/O |  |
| :--- | :---: |
| Name | Location |
| $\overline{\text { UCS }}$ | 61 |
| LCS | 60 |
| P1.0/GCS0 | 59 |
| P1.1/द्GC1 | 58 |
| P1.2/GCS2 | 57 |
| P1.3/GCS3 | 56 |
| P1.4/GCS4 | 55 |
| P1.5/द्GCS5 | 52 |
| P1.6/GCS6 | 51 |
| P1.7/GCS7 | 50 |
| T0OUT | 75 |
| T0IN | 76 |
| T1OUT | 77 |
| T1IN | 78 |
| RXD0 | 3 |
| TXD0 | 2 |
| P2.5/BCLK0 | 4 |
| CTS0 | 1 |
| P2.0/RXD1 | 7 |
| P2.1/TXD1 | 8 |
| P2.2/BCLK1 | 9 |
| P2.3/SINT1 | 5 |
| P2.4/CTS1 | 6 |
| P2.6 | 80 |
| P2.7 | 79 |

Table 6. QFP Package Location with Pin Names

| Location | Name |
| :---: | :---: |
| 1 | CTSO |
| 2 | TXD0 |
| 3 | RXD0 |
| 4 | P2.5/BCLK0 |
| 5 | P2.3/SINT1 |
| 6 | P2.4/CTS 1 |
| 7 | P2.0/RXD1 |
| 8 | P2.1/TXD1 |
| 9 | P2.2/BCLK1 |
| 10 | ADO |
| 11 | A8 |
| 12 | $V_{\text {SS }}$ |
| 13 | $\mathrm{V}_{\mathrm{CC}}$ |
| 14 | $V_{\text {SS }}$ |
| 15 | AD1 |
| 16 | A9 |
| 17 | AD2 |
| 18 | A10 |
| 19 | AD3 |
| 20 | A11 |


| Location | Name |
| :---: | :--- |
| 21 | ADA |
| 22 | A12 |
| 23 | AD5 |
| 24 | A 13 |
| 25 | $\mathrm{AD6}$ |
| 26 | A 14 |
| 27 | $\mathrm{AD7}$ |
| 28 | A 15 |
| 29 | A 16 |
| 30 | A 17 |
| 31 | A 18 |
| 32 | $\mathrm{~A} 19 / \overline{\mathrm{ONCE}}$ |
| 33 | VSS |
| 34 | V CC |
| 35 | VSS |
| 36 | $\overline{\mathrm{RD}}$ |
| 37 | $\overline{\text { WR }}$ |
| 38 | ALE |
| 39 | $\overline{\mathrm{RFSH}}$ |
| 40 | $\overline{\text { S2 }}$ |


| Location | Name |
| :---: | :---: |
| 41 | ST |
| 42 | So |
| 43 | DEN |
| 44 | HLDA |
| 45 | HOLD |
| 46 | TEST |
| 47 | LOCK |
| 48 | NMI |
| 49 | READY |
| 50 | P1.7/GCS7 |
| 51 | P1.6/GCS6 |
| 52 | P1.5/GCS5 |
| 53 | $\mathrm{V}_{\text {SS }}$ |
| 54 | $V_{C C}$ |
| 55 | P1.4/GCS4 |
| 56 | P1.3/GCS3 |
| 57 | P1.2/GCS2 |
| 58 | P1.1/GCS1 |
| 59 | P1.0/GCS0 |
| 60 | LCS |


| Location | Name |
| :---: | :--- |
| 61 | UCS |
| 62 | INTO |
| 63 | INT1 |
| 64 | INT2/INTAO |
| 65 | INT3/INTA1 |
| 66 | INT4 |
| 67 | PDTMR |
| 68 | $\overline{\text { RESIN }}$ |
| 69 | RESOUT |
| 70 | OSCOUT |
| 71 | CLKIN |
| 72 | VCC |
| 73 | VSS |
| 74 | CLKOUT |
| 75 | TOOUT |
| 76 | TOIN |
| 77 | T1OUT |
| 78 | T1IN |
| 79 | P2.7 |
| 80 | P2.6 |



NOTE:
This is the FPO number location (indicated by the X 's).
Figure 6. Quad Flat Pack Pinout Diagram

## PACKAGE THERMAL SPECIFICATIONS

The 80C18858 is spocified for operation when TC (the case temperature) is within the range of $-40^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (PLCC package) or $-40^{\circ} \mathrm{C}$ to $+114^{\circ} \mathrm{C}$ (QFP package). $T_{C}$ may be measured in any environment to determine whether the 80C188EB is within the specified operating range. The case temperature must be measured at the center of the top surface.
$T_{A}$ (the ambient temperature) can be calculated from $\theta_{C A}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\mathrm{CA}}$ at various airflows are given in Table 7 for the 84-pin Plastic Leaded Chip Carrier (PLCC) package.

Table 8 shows the maximum $\mathrm{T}_{\mathrm{A}}$ allowable (without exceeding $T_{C}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumption, specified in watts) is calculated by using the maximum ICC as tabulated in the DC specifications and $\mathrm{V}_{\mathrm{CC}}$ of 5.5 V .
$T_{A}=T_{C}-P^{*} \theta_{C A}$
Table 7. Thermal Resistance ( $\boldsymbol{\theta}_{\mathbf{C A}}$ ) at Various Airflows (in ${ }^{\circ} \mathbf{C} /$ Watt)

|  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 200 |  |  |  |  |
| $(0)$ | $\mathbf{1 . 0 1 )}$ | $\mathbf{4 0 0}$ |  |  |  |  |
| $\mathbf{( 2 . 0 3 )}$ | $\mathbf{6 0 0}$ <br> $(3.04)$ | 800 <br> $(4.06)$ | 1000 <br> $(5.07)$ |  |  |  |
| $\theta_{\mathrm{CA}}$ (PLCC) | 30 | 24 | 21 | 19 | 17 | 16.5 |
| $\theta_{\mathrm{CA}}$ (QFP) | 58 | 47 | 43 | 40 | 38 | 36 |

Table 8. Maximum $\mathrm{T}_{\mathrm{A}}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow Linear ft/min (m/sec) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{T}_{\mathbf{F}}$ | (0) | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{gathered} 400 \\ (2.03) \end{gathered}$ | $\begin{gathered} 600 \\ (3.04) \end{gathered}$ | $\begin{gathered} 800 \\ (4.06) \end{gathered}$ | $\begin{gathered} 1000 \\ (5.07) \end{gathered}$ |
|  | (MHz) |  |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{A}}$ (PLCC) | 16 | 91.5 | 93.5 | 94 | 94.5 | 95.5 | 95.5 |
|  | 26 | 88.5 | 91 | 92 | 92.5 | 93.5 | 93.5 |
|  | 32 | 85 | 87.5 | 89.5 | 90.5 | 91.5 | 92 |
| TA (QFP) | 16 | 98 | 101 | 102 | 103 | 103.5 | 104 |
|  | 26 | 92 | 96 | 97.5 | 99 | 99.5 | 100 |
|  | 32 | 85 | 90.5 | 92.5 | 94 | 95 | 96 |

## ELECTRICAL SPECIFICATIONS

## Absolute Maximum Ratings

Parameter Maximum Rating
Storage Temperature $\ldots \ldots \ldots-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Case Temp Under Bias $\ldots \ldots \ldots-65^{\circ} \mathrm{C}$ to $+120^{\circ} \mathrm{C}$

| Supply Voltage |
| :--- |
| with respect to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots \ldots \ldots-0.5 \mathrm{~V}$ to +6.5 V |
| Voltage on other Pins |
| with respect to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots . .-0.5 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |

> NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

OPERATING CONDITIONS

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.5 | 5.5 | V |
| $\mathrm{T}_{\mathrm{F}}$ | Input Clock Frequency 80C188EB-20 <br> 80C188EB-16 <br> 80C188EB-13 <br> 80C188EB | 0 | 40 | MHz |
|  |  | 0 | 32 | MHz |
|  |  | 0 | 26.08 | MHz |
|  |  | 0 | 16 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature Under Bias TN80C188EB-XX (PLCC) TS80C188EB-XX (QFP) | -40 | +100 | ${ }^{\circ} \mathrm{C}$ |
|  |  | -40 | +114 | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED CONNECTIONS

Power and ground connections must be made to multiple $V_{C C}$ and $V_{S S}$ pins. Every 80 C 188 EB -based circuit board should include separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $\mathrm{V}_{S S}$ ) planes. Every $\mathrm{V}_{\mathrm{CC}}$ pin must be connected to the power plane, and every $\mathrm{V}_{\text {SS }}$ pin must be connected to the ground plane. Pins identified as "NC" must not be connected in the system. Liberal decoupling capacitance should be placed near the 80 C 188 EB . The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance is reduced by placing the decoupling capacitors as close as possible to the $80 \mathrm{C} 188 \mathrm{~EB} \mathrm{~V}_{\mathrm{CC}}$ and $V_{S S}$ package pins.

Always connect any unused input to an appropriate signal level. In particular, unused interrupt inputs (iNTO:4) should be connected to $\mathrm{V}_{\mathrm{Cc}}$ through a pull-up resistor (in the range of $50 \mathrm{~K} \Omega$ ). Leave any unused output pin or any NC pin unconnected.

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | $0.3 * V_{C C}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 0.7* $\mathrm{V}_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=3 \mathrm{~mA}(\mathrm{Min})$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}(\mathrm{Min})$ |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysterisis on RESIN | 0.50 |  | V |  |
| LLIt | Input Leakage Current for pins: AD7:0, READY, HOLD, RESIN, CLKIN, TEST, NMI, INT4:0, TOIN, TIIN, RXDO, $\overline{\text { BCLKO }}, \overline{\mathrm{CTSO}}$, RXD1, $\overline{\mathrm{BCLK1}}, \overline{\mathrm{CTS}} 1$, P2.6, P2. 7 |  | $\pm 15$ | $\mu \mathrm{A}$ | $\mathrm{O} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| LL12 | Input Leakage Current for pins: A19/ONCE, A18:16, $\overline{\text { LOCK }}$ | -0.275 | -5.0 | mA | $\mathrm{V}_{\mathrm{IN}}=0.7 \mathrm{~V}_{\text {CC }}$ (Note 1) |
| Lo | Output Leakage Current |  | $\pm 15$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}} \\ & \text { (Note 2) } \end{aligned}$ |
| ICC | Supply Current Cold (RESET)$80 \mathrm{C} 188 \mathrm{~EB}-20$$80 \mathrm{C} 188 \mathrm{~EB}-16$$80 \mathrm{C} 188 \mathrm{~EB}-13$$80 \mathrm{C} 188 \mathrm{~EB}-8$ |  | 108 | mA | (Note 3) |
|  |  |  | 90 | mA | (Note 3) |
|  |  |  | 73 | mA | (Note 3) |
|  |  |  | 45 | mA | (Note 3) |
| 1 I | Supply Current Idle$80 \mathrm{C} 188 \mathrm{~EB}-20$$80 \mathrm{C} 188 \mathrm{~EB}-16$$80 \mathrm{C} 188 \mathrm{~EB}-13$$80 \mathrm{C} 188 \mathrm{~EB}-8$ |  | 76 | mA | (Note 4) |
|  |  |  | 63 | mA | (Note 4) |
|  |  |  | 48 | mA | (Note 4) |
|  |  |  | 31 | mA | (Note 4) |
| IPD | Supply Current Powerdown$80 \mathrm{C} 188 \mathrm{~EB}-20$$80 \mathrm{C} 188 \mathrm{~EB}-16$$80 \mathrm{C} 188 \mathrm{~EB}-13$$80 \mathrm{C} 188 \mathrm{~EB}-8$ | " | 100 | $\mu \mathrm{A}$ | (Note 5) |
|  |  |  | 100 | $\mu \mathrm{A}$ | (Note 5) |
|  |  |  | 100 | $\mu \mathrm{A}$ | (Note 5) |
|  |  |  | 100 | $\mu \mathrm{A}$ | (Note 5) |
| CIN | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |
| COUT | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ ( Note 6) |

## NOTES:

1. These pins have an internal pull-up device that is active while $\overline{R E S I N}$ is low and ONCE Mode is not active. Sourcing more current than specified (on any of these pins) may invoke a factory test mode.
2. Tested by outputs being floated by invoking ONCE Mode or by asserting HOLD.
3. Measured with the device in RESET and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{SS}}$.
4. Measured with the device in HALT (IDLE Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\text {SS }}$.
5. Measured with the device in HALT (Powerdown Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with

ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $V_{C C}$ or $V_{S S}$.
6. Output Capacitance is the capacitive load of a floating output pin.

## Icc VERSUS FREQUENCY AND VOLTAGE

The current (IcC) consumption of the 80 C 188 EB is essentially composed of two components; I IPD and Iccs.

IPD is the quiescent current that represents internal device leakage, and is measured with all inputs or floating outputs at GND or $V_{C C}$ (no clock applied to the device). IpD is equal to the Powerdown current and is typically less than $50 \mu \mathrm{~A}$.

Iccs is the switching current used to charge and discharge parasitic device capacitance when changing logic levels. Since Iccs is typically much greater than $I_{P D}, I_{P D}$ can often be ignored when calculating Icc.

ICCS is related to the voltage and frequency at which the device is operating. It is given by the formula:

$$
\begin{aligned}
& \text { Power }=\mathrm{V} \times \mathrm{I}=\mathrm{V} 2 \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f} \\
& \therefore \mathrm{I}=\mathrm{I} \mathrm{CC}=\mathrm{I}_{\mathrm{CCS}}=\mathrm{V} \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f}
\end{aligned}
$$

Where: $\mathrm{V}=$ Device operating voltage $\left(\mathrm{V}_{\mathrm{CC}}\right)$
$\mathrm{C}_{\text {DEV }}=$ Device capacitance
$\mathrm{f}=$ Device operating frequency
Iccs $=I_{\text {ICC }}=$ Device current
Measuring $C_{\text {DEV }}$ on a device like the 80C188EB would be difficult. Instead, $\mathrm{C}_{\mathrm{DEV}}$ is calculated using the above formula by measuring $\mathrm{I}_{\mathrm{CC}}$ at a known $\mathrm{V}_{\mathrm{CC}}$ and frequency (see Table 9). Using this $\mathrm{C}_{\text {DEV }}$ value, Icc can be calculated at any voltage and frequency within the specified operating range.

EXAMPLE: Calculate the typical ICC when operating at $10 \mathrm{MHz}, 4.8 \mathrm{~V}$.

## PDTMR PIN DELAY CALCULATION

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown. A delay is required only when using the on-chip oscillator to allow the crystal or resonator circuit time to stabilize.

NOTE:
The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e., a device reset during Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized).

To calculate the value of capacitor required to provide a desired delay, use the equation:

$$
440 \times t=C_{P D} \quad\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where: $t=$ desired delay in seconds
$\mathrm{C}_{\mathrm{PD}}=$ capacitive load on PDTMR in microfarads

EXAMPLE: To get a delay of $300 \mu \mathrm{~s}$, a capacitor value of $\mathrm{C}_{P D}=440 \times\left(300 \times 10^{-6}\right)=0.132 \mu \mathrm{~F}$ is required. Round up to standard (available) capacitive values.

## NOTE:

The above equation applies to delay times greater than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ or $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $\mathrm{V}_{\mathrm{CC}}$ and/or lower temperature will decrease delay time, while lower $V_{C C}$ and/or higher temperature will increase delay time.

$$
I_{\mathrm{CC}}=I_{\mathrm{CCS}}=4.8 \times 0.583 \times 10 \approx 28 \mathrm{~mA}
$$

Table 9. Device Capacitance ( $C_{\text {DEv }}$ ) Values

| Parameter | Typ | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {DEV }}$ (Device in Reset) | 0.583 | 1.02 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| $\mathrm{C}_{\text {DEV }}$ (Device in Idle) | 0.408 | 0.682 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

1. Max $C_{D E V}$ is calculated at $-40^{\circ} \mathrm{C}$, all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND, and all outputs loaded to 50 pF (including CLKOUT and OSCOUT).
2. Typical $\mathrm{C}_{\mathrm{DEV}}$ is calculated at $25^{\circ} \mathrm{C}$ with all outputs loaded to 50 pF except CLKOUT and OSCOUT, which are not loaded.

AC SPECIFICATIONS
AC Characteristics-80C188EB-20

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 40 | MHz | 1 |
| TC | CLKIN Period | 25 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {ch }}$ | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| TCD | CLKIN to CLKOUT Delay | 0 | 17 | ns | 1,4 |
| T | CLKOUT Period |  | $2^{*} \mathrm{~T}$ c | ns | 1 |
| TPH | CLKOUT High Time | (T/2)-5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPL | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PR}}$ | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2: }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{RFSH}}$, LOCK, A19:16 | 3 | 20 | ns | 1,4,6, 7 |
| TCHOV2 | GCS0:7, $\overline{\text { LCS }}$, UCS, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 25 | ns | 1,4,6, 8 |
| TClov1 | RFSH, DEN, LOCK, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 20 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}}: \mathbf{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD7:0, NCS, INTA1:0, $\overline{\text { S2:0 }}, \mathbf{A 1 5 : 8}$ | 3 | 25 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:8 | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD7:0, A15:8 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0, P2.6, P2.7 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, INT4:0, BCLK1:0, T1:0IN, READY, CTS1:0 | 3 |  | ns | 1,9 |
| TCLIS | AD7:0, READY | 10 |  | ns | 1,10 |
| TCLIH | READY, AD7:0 | 3 |  | ns | 1, 10 |
| TCLIS | HOLD | 10 |  | ns | 1,9 |
| TCLIH | HOLD | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$ -
4. Specified for a 50 pF load, see Figure 13 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 14 for rise and fall times outside 50 pF .
6. See Figure 14 for rise and fall times.
7. TCHOV1 applies to RFSH, $\overline{\text { LOCK }}$ and A19:8 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80 C 188 EB operation.

AC SPECIFICATIONS (Continued)

## AC Characteristics-80C188EB-16

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 32 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 31.25 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| $\mathrm{T}_{\mathrm{CL}}$ | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| $\mathrm{T}_{\text {CR }}$ | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| TCD | CLKIN to CLKOUT Delay | 0 | 20 | ns |  |
| T | CLKOUT Period |  | 2*TC | ns | 1 |
| TPH | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{T}_{\mathrm{PL}}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |

## OUTPUT DELAYS

| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{RFSH}}$, LOCK, A19:16 | 3 | 22 | ns | 1,4, 6, 7 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCHOV2 | GCS0:7, $\overline{\text { LCS }}$, $\overline{U C S}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 27 | ns | 1, 4, 6, 8 |
| TCLOV1 | RFSH, $\overline{D E N}, \overline{L O C K}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 22 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}}: \mathbf{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD7:0, $\overline{\text { NCS }}, \overline{\text { INTA1:0 }}, \overline{\text { S2:0 }}, \mathrm{A} 15: 8$ | 3 | 27 | ns | 1, 4, 6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:8 | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD7:0, A15:8 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0, P2.6, P2.7 | 10 |  | ns | 1, 9 |
| $\mathrm{T}_{\mathrm{CHIH}}$ | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0 | 3 |  | ns | 1, 9 |
| TCLIS | AD7:0, READY | 10 |  | ns | 1,10 |
| TCLIH | READY, AD7:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CLIH }}$ | HOLD | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 13 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 14 for rise and fall times outside 50 pF .
6. See Figure 14 for rise and fall times.
7. TCHOV1 applies to RFSH, LOCK and A19:8 only after a HOLD release.
8. $\mathrm{T}_{\mathrm{CHOV} 2}$ applies to $\overline{\mathrm{RD}}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C188EB operation.

AC SPECIFICATIONS (Continued)

## AC Characteristics-80C188EB-13

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{F}$ | CLKIN Frequency | 0 | 26.08 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 38.34 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 12 | $\infty$ | ns | 1, 2 |
| $\mathrm{T}_{\mathrm{CL}}$ | CLKIN Low Time | 12 | $\infty$ | ns | 1, 2 |
| $\mathrm{T}_{\text {CR }}$ | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{CD}}$ | CLKIN to CLKOUT Delay | 0 | 23 | ns | 1,4 |
| T | CLKOUT Period |  | $2^{*} \mathrm{~T}_{\mathrm{C}}$ | ns | 1 |
| TPH | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPL | CLKOUT Low Time | (T/2)-5 | $(T / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{RFSH}}$, LOCK, A19:16 | 3 | 25 | ns | 1, 4, 6, 7 |
| TCHOV2 | GCS0:7, $\overline{\text { LCS }}$, UCS, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 30 | ns | 1, 4, 6, 8 |
| TCLOV1 | $\overline{\text { RFSH, }} \overline{\mathrm{DEN}}, \overline{\text { LOCK, RESOUT, HLDA, }}$ TOOUT, T1OUT, A19:16 | 3 | 25 | ns | 1, 4, 6 |
| TClOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}} 7: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD7:0, $\overline{\text { NCS }}, \overline{\text { INTA1:0 }}, \overline{\text { S2:0 }}, \mathrm{A} 15: 8$ | 3 | 30 | ns | 1, 4, 6 |
| T CHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:16 | 0 | 25 | ns | 1 |
| TCLOF | DEN, AD7:0, A15:8 | 0 | 25 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0, P2.6, P2.7 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\mathrm{CHIH}}$ | TEST, NMI, INT4:0, BCLK1:0, T1:OIN, READY, CTS1:0 | 3 |  | ns | 1,9 |
| TCLIS | AD7:0, READY | 10 |  | ns | 1,10 |
| $\mathrm{T}_{\text {CLIH }}$ | READY, AD7:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 10 |  | ns | 1,9 |
| TCLIH | HOLD | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 13 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 14 for rise and fall times outside 50 pF .
6. See Figure 14 for rise and fall times.
7. TCHOV 1 applies to $\overline{\text { RFSH}}, \overline{\text { LOCK }}$ and A8:0 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C188EB operation.

80C188EB

AC SPECIFICATIONS (Continued)
AC Characteristics-80C188EB-8

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 16 | MHz | 1 |
| Tc | CLKIN Period | 62.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 15 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 15 | $\infty$ | ns | 1,2 |
| $\mathrm{T}_{\text {ch }}$ | CLKIN Rise Time | 1 | 8 | ns | 1, 3 |
| $\mathrm{T}_{\text {CF }}$ | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 27 | ns | 1, 4 |
| T | CLKOUT Period |  | ${ }^{2}{ }^{\text {T }}$ C | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PL}}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PR}}$ | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| $\mathrm{T}_{\text {PF }}$ | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{RFSH}}$, LOCK, A19:16 | 3 | 30 | ns | 1,4,6,7 |
| TCHOV2 | GCS0:7, $\overline{\text { LCS }}$, $\overline{\text { UCS }}, \overline{\text { RD }}, \overline{\text { WR }}$ | 3 | 35 | ns | 1, 4, 6, 8 |
| TCLOV1 | RFSH, $\overline{\mathrm{DEN}}, \overline{\mathrm{LOCK}}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 30 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}}: \mathbf{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD7:0, $\overline{\text { NCS }}, \overline{\text { INTA1:0 }}, \overline{\text { S2:0 }}, \mathrm{A} 15: 8$ | 3 | 35 | ns | 1,4,6 |
| TCHOF | $\overline{\text { RD, }} \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:16 | 0 | 30 | ns | 1 |
| TCLOF | DEN, AD7:0, A15:8 | 0 | 35 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| TCHIS | TEST, NMI, INT4:0, BCLK1:0 T1:OIN, READY, CTS1:0, P2.6, P2.7 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, INT4:0, BCLK1:0 <br> T1:0IN, READY, CTS1:0 | 3 |  | ns | 1,9 |
| TCLIS | AD7:0, READY | 10 |  | ns | 1,10 |
| TCLIH | READY, AD7:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 10 |  | ns | 1,9 |
| TCLIH | HOLD | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 13 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 14 for rise and fall times outside 50 pF .
6. See Figure 14 for rise and fall times.
7. TCHOV1 applies to RFSH, $\overline{\text { LOCK }}$ and A19:8 only after a HOLD release.
8. TCHOV2 applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C188EB operation.

AC SPECIFICATIONS (Continued)
Relative Timings (80C188EB-20, $-16,-13,-8$ )

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Rising to ALE Falling | T-15 |  | ns |  |
| TAVLL | Address Valid to ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TPLLL | Chip Selects Valid to ALE Falling | $1 / 2 T-10$ |  | ns | 1 |
| TLLAX | Address Hold from ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{\text { WR }}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\mathrm{RD}}$ Falling | $1 / 2 \mathrm{~T}-15$ |  | ns | 1 |
| TWHLH | $\overline{\text { WR Rising to ALE Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| TAFRL | Address Float to $\overline{\mathrm{RD}}$ Falling | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Falling to $\overline{\mathrm{RD}}$ Rising | (2*T) - 5 |  | ns | 2 |
| T WLWH | $\overline{\text { WR }}$ Falling to $\overline{\text { WR }}$ Rising | (2*T) - 5 |  | ns | 2 |
| TRHAV | $\overline{\mathrm{RD}}$ Rising to Address Active | T-15 |  | ns |  |
| T WHDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| TWHPH | $\overline{\text { WR Rising to Chip Select Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| $\mathrm{T}_{\text {RHPH }}$ | $\overline{\mathrm{RD}}$ Rising to Chip Select Rising | $1 / 2 T-10$ |  | ns | 1 |
| TPHPL | $\overline{\text { CS }}$ Inactive to $\overline{C S}$ Active | $1 / 2 T-10$ |  | ns | 1 |
| TovRH | ONCE Active to $\overline{\text { RESIN }}$ Rising | T |  | ns | 3 |
| TRHOX | ONCE Hold from RESIN Rising | T |  | ns | 3 |

## NOTES:

1. Assumes equal loading on both pins.
2. Can be extended using wait states.
3. Not tested.

AC SPECIFICATIONS (Continued)

Serial Port Mode 0 Timings (80C188EB-20, 16, -13, -8)

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TXLXL | TXD Clock Period | $T(n+1)$ |  | ns | 1, 2 |
| TXLXH | TXD Clock Low to Clock High ( $n>1$ ) | 2T-35 | $2 T+35$ | ns | 1 |
| TXLXH | TXD Clock Low to Clock High ( $\mathrm{n}=1$ ) | T-35 | $T+35$ | ns | 1 |
| TXHXL | TXD Clock High to Clock Low ( $n>1$ ) | $(\mathrm{n}-1) \mathrm{T}-35$ | $(\mathrm{n}-1) \mathrm{T}+35$ | ns | 1, 2 |
| TXHXL | TXD Clock High to Clock Low ( $\mathrm{n}=1$ ) | T-35 | T+35 | ns | 1 |
| T QVXH | RXD Output Data Setup to TXD Clock High ( $\mathrm{n}>1$ ) | $(\mathrm{n}-1) \mathrm{T}-35$ |  | ns | 1, 2 |
| TQVXH | RXD Output Data Setup to TXD Clock High ( $n=1$ ) | T-35 |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $n>1$ ) | 2T-35 |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High $(n=1)$ | T-35 |  | ns | 1 |
| TXHQZ | RXD Output Data Float after Last TXD Clock High |  | $T+20$ | ns | 1 |
| TDVXH | RXD Input Data Setup to TXD Clock High | $T+20$ |  | ns | 1 |
| TXHDX | RXD Input Data Hold after TXD Clock High | 0 |  | ns | 1 |

## NOTES:

1. See Figure 12 for waveforms.
2. $n$ is the value of the BxCMP register ignoring the iCLK bit (i.e., ICLK $=0$ ).

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 7. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms, for AC specification definitions, test pins, and illustrations.


Figure 7. AC Test Load

## AC TIMING WAVEFORMS



Figure 8. Input and Output Clock Waveform


Figure 9. Output Delay and Float Waveform


Figure 10. Input Setup and Hold


Figure 11. Relative Signal Waveform


Figure 12. Serial Port Mode 0 Waveform

## DERATING CURVES

TYPICAL OUTPUT DELAY VARIATIONS VERSUS LOAD CAPACITANCE


Figure 13
TYPICAL RISE AND FALL VARIATIONS VERSUS LOAD CAPACITANCE


Figure 14

## RESET

The 80C188EB will perform a reset operation any time the $\overline{R E S I N}$ pin active. The $\overline{\text { RESIN }}$ pin is actually synchronized before it is presented internally, which means that the clock must be operating before a reset can take effect. From a power-on state, RESIN must be held active (low) in order to guarantee correct initialization of the 80C188EB. Failure to provide RESIN while the device is powering up will result in unspecified operation of the device.

Figure 15 shows the correct reset sequence when first applying power to the 80C188EB. An external clock connected to CLKIN must not exceed the $V_{C C}$ threshold being applied to the 80 C 188 EB . This is normally not a problem if the clock driver is supplied with the same $V_{C C}$ that supplies the 80C188EB. When attaching a crystal to the device, $\overline{\text { RESIN }}$ must remain active until both $\mathrm{V}_{\mathrm{CC}}$ and CLKOUT are stable (the length of time is application specific and depends on the startup characteristics of the crystal circuit). The RESIN pin is designed to operate correctly using an RC reset circuit, but the designer
must ensure that the ramp time for $V_{C C}$ is not so long that RESIN is never really sampled at a logic low level when $V_{C C}$ reaches minimum operating conditions.

Figure 16 shows the timing sequence when RESIN is applied after $\mathrm{V}_{\mathrm{CC}}$ is stable and the device has been operating. Note that a reset will terminate all activity and return the 80C188EB to a known operating state. Any bus operation that is in progress at the time RESIN is asserted will terminate immediately (note that most control signals will be driven to their inactive state first before floating).

While $\overline{\text { RESIN }}$ is active, bus signals $\overline{\text { LOCK, A19/ }}$ $\overline{O N C E}$, and A18:16 are configured as inputs and weakly held high by internal pullup transistors. Only 19/ONCE can be overdriven to a low and is used to enable ONCE Mode. Forcing LOCK or A18:16 low at any time while $\overline{\operatorname{RESIN}}$ is low is prohibited and will cause unspecified device operation.



## BUS CYCLE WAVEFORMS

Figures 17 through 23 present the various bus cycles that are generated by the 80C188EB. What is shown in the figure is the relationship of the various bus signals to CLKOUT. These figures along with
the information present in AC Specifications allow the user to determine all the critical timing analysis needed for a given application.

MEMORY READ, I/O READ, INSTRUCTION FETCH, AND REFRESH WAVEFORM


Figure 17

MEMORY WRITE AND I/O WRITE CYCLE WAVEFORM


Figure 18

HALT CYCLE WAVEFORM


Figure 19

CASCADE MODE INTERRUPT ACKNOWLEDGE CYCLE WAVEFORM


Figure 20

HOLD/HLDA CYCLE WAVEFORMS


Figure 21

REFRESH DURING HLDA CYCLE WAVEFORM


Figure 22

READY CYCLE WAVEFORM


## NOTES:

Figure 23

## REGISTER BIT SUMMARY

Figures 24 through 31 present the bit definition of each register that is active (not reserved) in the Peripheral Control Block (PCB). Each register can be thought to occupy one word (16-bits) of either memory or I/O space, although not all bits in the register necessarily have a function. A register bit is not
guaranteed to return a specific logic value if an " $X$ " appears for the bit definition (i.e., if a zero was written to the register bit it may not be returned as a zero when read) Furthermore, a 0 must be written to any bit that is indicated by an " $X$ " to ensure compatibility with future products or potential product changes.


Figure 24. Interrupt Control Unit Registers



270885-28

Figure 25. Interrupt Control Unit Registers




270885-29

Figure 26. Timer Control Unit Registers


Figure 27. I/O Port Unit Registers


Figure 28. Serial Communications Unit Registers


Figure 29. Chip-Select Unit Registers


| 0 | RCO | Current Refresh <br> - Clock Count <br> (Read Only) |
| :---: | :---: | :---: |
| 1 | RC1 |  |
| 2 | RC2 |  |
| 3 | RC3 |  |
| 4 | RC4 |  |
| 5 | RC5 |  |
| 6 | RC6 |  |
| 7 | RC7 |  |
| 8 | RC8 |  |
| 9 | X |  |
| 10 | X |  |
| 11 | $X$ |  |
| 12 | X |  |
| 13 | X |  |
| 14 | X |  |
| 15 | REN | 1 = Enable Refresh |
|  | $\begin{aligned} & \text { CON (B4 } \\ & \text { ESET }= \end{aligned}$ |  |



Figure 30. Refresh Control Unit Registers


Figure 31. Power Management Unit Registers

## 80C188EB EXECUTION TIMINGS

A determination of 80 C 188 EB program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

The 80 C 188 EB 8 -bit BIU is noticeably limited in its performance relative to the execution unit. A sufficient number of prefetched bytes may not reside in the prefetch queue much of the time. Therefore, actual program execution time will be substantially greater than that derived from adding the instruction timings shown.

INSTRUCTION SET SUMMARY


Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER (Continued) |  |  |  |  |  |  |
| cs | 00101110 |  |  |  | 2 |  |
| SS | 00110110 |  |  |  | 2 |  |
| DS | 00111110 |  |  |  | 2 |  |
| ES | 00100110 |  |  |  | 2 |  |
| ARITHMETIC ADD = Add: |  |  |  |  |  |  |
| Reg/memory with register to either | 000000 dw | mod reg r/m |  |  | 3/10 |  |
| Immediate to register/memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} \mathbf{w}=01$ | 4/16 |  |
| Immediate to accumulator | 0000010 w | data | data if $\mathbf{w}=1$ |  | 3/4 | 8/16-bit |
| L.DC = Add with carry:Reg/memory with register to either $\quad 000100 \mathrm{dw}$ w mod reg |  |  |  |  |  |  |
|  |  |  |  |  | 3/10 |  |
| Immediate to register/memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if s w $=01$ | 4/16 |  |
| Immediate to accumulator | 0001010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| INC = Increment: |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 3/15 |  |
| Register | 01000 reg |  |  |  | 3 |  |
| SUB = Subtract:Reg/memory and register to either $\quad$ <br> R |  |  |  |  |  |  |
|  |  |  |  |  | 3/10 |  |
| Immediate from register/memory | 100000sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if sw=01 | 4/16 |  |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| SBB = Subtract with borrow:Reg/memory and register to either |  |  |  |  |  |  |
|  |  |  |  |  | 3/10 |  |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s} \mathbf{w}=01$ | 4/16 |  |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| DEC = Decrement |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ | . |  | 3/15 |  |
| Register | 01001 reg |  |  |  | 3 |  |
| CMP = Compare: |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | modreg r/m |  |  | 3/10 |  |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 3/10 |  |
| Immediate with register/memory | 100000 sw | mod $111 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s w}=01$ | 3/10 |  |
| Immediate with accumulator | 0011110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NEG = Change sign register/memory | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | 3/10 |  |
| AAA $=$ ASCII adjust for add | 00110111 |  |  |  | 8 |  |
| DAA = Decimal adjust for add | 00100111 |  |  |  | 4 |  |
| AAS $=$ ASCII adjust for subtract | 00111111 |  |  |  | 7 |  |
| DAS $=$ Decimal adjust for subtract | 00101111 |  |  |  | 4 |  |
| MUL = Multiply (unsigned): | 1111011 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Register-Byte |  |  |  |  | 26-28 |  |
| Register-Word |  |  |  |  | 35-37 |  |
| Memory-Byte |  |  |  |  | 32-34 |  |
| Memory-Word |  |  |  |  | 41-43 |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


[^14]INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

80C188EB

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if mod $=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
if mod $=00$ then DISP $=0^{*}$, disp-low and disphigh 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)+D I S P$
if $\mathrm{r} / \mathrm{m}=001$ then $\mathrm{EA}=(\mathrm{BX})+(\mathrm{DI})+\mathrm{DISP}$
if $\mathrm{r} / \mathrm{m}=010$ then $\mathrm{EA}=(\mathrm{BP})+(\mathrm{SI})+\mathrm{DISP}$
if $\mathrm{r} / \mathrm{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 $\mathrm{r} / \mathrm{m}=101$ then $E A=(\mathrm{DI})+\mathrm{DISP}$
if $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=(\mathrm{BP})+\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 $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then EA $=$ disp-high: disp-low.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

Segment Override Prefix

$$
\begin{array}{|lllllll|}
\hline 0 & 0 & 1 & \text { reg } & 1 & 1 & 0 \\
\hline
\end{array}
$$

reg is assigned according to the following:

> Segment
reg Register
00 ES
01 CS
10 SS
11 DS
REG is assigned according to the following table:

| $\mathbf{1 6 - B i t}(\mathbf{w}=\mathbf{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.


Figure 32. PLCC Principal Dimensions


## NOTE:

Units are mm (inches) unless specified.
Figure 33. QFP Principal Dimensions

## ERRATA

An 80C188EB with a STEPID value of 0001H has the following known errata. A device with a STEPID of 0001 H can be visually identified by noting the absence of an alpha character next to the FPO number or by the presence of an "A" alpha character next to the FPO number. The FPO number location is shown in Figures 5 and 6.

1. A19/ONCE is not latched by the rising edge of $\overline{\text { RESIN. A19/ONCE must remain active (LOW) at }}$ all times to remain in the ONCETM Mode. Removing A19/ONCE after $\overline{\text { RESIN }}$ is high will return all output pins to a driving state, however, the 80C188EB will remain in a reset state.
2. During interrupt acknowledge (INTA) bus cycles, the bus controller will ignore the state of the READY pin if the previous bus cycle ignored the state of the READY pin. This errata can only occur if the Chip-Select Unit is being used. All active chip-selects must be programmed to use READY (RDY bit must be programmed to a 1) if waitstates are required for INTA bus cycles.
3. CLKOUT will transition off the rising edge of CLKIN rather than the falling edge of CLKIN. This does not affect any bus timings other than $\mathrm{T}_{\mathrm{CICO}}$.
4. $\overline{R E S I N}$ has a hysterisis of only 130 mV . It is recommended that RESIN be driven with a Schmitt triggered device to avoid processor lockup during reset when using an RC circuit.
5. SINT1 will only go active for one clock period when a receive or transmit interrupt is pending (i.e., it does not remain active until the S1STS register is read). If SINT1 is to be connected to any of the 80C188EB interrupt lines (INT0-INT4), then it must be latched by user logic.

An 80C188EB with a STEPID value of 0001 H or 0002 H has the following known errata. Otherwise, an 80C188EB with a STEPID value of 0002 H has no known errata (as of this publication). A device with a STEPID of 0002H can be visually identified by noting the presence of a " $B$ " or " $C$ " alpha character next to the FPO number. The FPO number location is shown in Figures 5 and 6.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistantly, it is dependent on interrupt timing.

## REVISION HISTORY

The following changes have been made between the -001 version and this -002 version of the 80C188EB data sheet. This -002 data sheet applies to any 80C188EB with a " $B$ " alpha character after the FPO number. The FPO number location is shown in Figures 5 and 6.

1. The data sheet was changed from a Product Preview version to an Advanced Information version.
2. Figures $1,5,6,8,12,17,19,20,21,22,23,29$, and 31 and Table 1 were updated to correct for errors.
3. The DC specifications table has changed. Also, notes 3, 4 and 5 have been changed/added.
4. Graphs for ICC versus Frequency have been changed to equations with supporting text.
5. Graphs for PDTMR pin capacitance have been changed to equations with supporting text.
6. AC Hold timings have been changed from 0 ns to 3 ns .
7. READY input setup time has been changed from 13 ns to 10 ns .
8. Serial port MODE 0 timings have been changed.
9. Various typing errors have been corrected throughout the document.

The following changes were made between the -002 and -003 versions of the 80C188EB data sheets. The -003 data sheet applies to any 80C188EB with a "B" alpha character after the FPO number. The FPO number location is shown in Figures 5 and 6.

1. 20 MHz Electrical, DC and AC Specifications were added to the appropriate sections.
2. The following 80C186EB Core Architecture sections were deleted:
Register Set
Instruction Set
Memory Organization
Addressing Modes
Data Types
Interrupts
3. Most of the 80C188EB Peripheral Architecture sections were condensed along with the Register Bit Summary section.
4. Most of the Tables and Figures have been renumbered due to edits.

# 80C188EC-16, -13 16-BIT HIGH-INTEGRATION EMBEDDED PROCESSOR 

\author{

- Full Static Operation <br> - True CMOS Inputs and Outputs <br> $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operating Temperature Range
}

Integrated Feature Set:

- Low-Power, Static, Enhanced 8088 CPU Core
- Two Independent DMA Supported UARTs, each with an Integral Baud Rate Generator
- Four Independent DMA Channels
- 24 Multiplexed I/O Port Pins
- Two 8259A Compatible Programmable Interrupt Controllers
- Three Programmable 16-Bit Timer/ Counters
- 32-Bit Watchdog Timer
- Ten Programmable Chip Selects with Integral Wait-State Generator
- Memory Refresh Control Unit
- Power Management Unit
-On-Chip Oscillator
- System Level Testing Support (ONCETM Mode)
- Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Low-Power Operating Modes:
- Idle Mode Freezes CPU Clocks but Keeps Peripherals Active
- Powerdown Mode Freezes All Internal Clocks
- Powersave Mode Divides All Clocks by Programmable Prescalar
- Complete System Development Support
- ASM86 Assembler, PL/M 86, Pascal86, Fortran 86, iC-86 and System Utilities
- In-Circult Emulator (ICETM-186EC)

Package Types:

- 100-Pin EIAJ Quad Flat Pack (QFP) (S80C188EC)
- 100-Pin Plastic Quad Flat Pack (PQFP) (KU80C188EC)
Speed Versions Available:
-16 MHz (80C188EC-16)
-13 MHz (80C188EC-13)

The 80 C 188 EC is a member of the 186 Integrated Processor Family. The 186 Integrated Processor Family incorporates several different VLSI devices all of which share a common CPU architecture: the 8086/8088. The 80C188EC uses the latest high density CHMOS technology to integrate several of the most common system peripherals with an enhanced 8088 CPU core to create a powerful system on a single monolithic silicon die.
80C188EC-16, -1316-Bit High Integration Embedded Processor
CONTENTS PAGE CONTENTS PAGE
INTRODUCTION ..... 24-707 ..... 24-726
ELECTRICAL SPECIFICATIONS
OVERVIEW ..... 24-707
80C188EC CORE ARCHITECTURE ..... 24-707
Bus Interface Unit ..... 24-707
Clock Generator ..... 24-708
80C188EC Peripheral Architecture ..... 24-708
Programmable Interrupt Controllers ..... 24-709
Timer/Counter Unit ..... 24-709
Serial Communications Unit ..... 24-709
DMA Unit ..... 24-711
Chip-Select Unit ..... 24-711
I/O Port Unit ..... 24-711
Refresh Control Unit ..... 24-711
Watchdog Timer Unit ..... 24-711
Power Management Unit ..... 24-711
ONCETM Test Mode ..... 24-711
PACKAGE INFORMATION ..... 24-712
Pin Descriptions ..... 24-712
80C188EC Pinout ..... 24-719
PACKAGE THERMAL SPECIFICATIONS ..... 24-725
24-726
Absolute Maximum Ratings
Operating Conditions ..... 24-726
Recommended Connections ..... 24-726
DC SPECIFICATIONS ..... 24-727
Icc versus Frequency and Voltage ..... 24-728
PDTMR Pin Delay Calculation ..... 24-728
AC SPECIFICATIONS ..... 24-729
AC Characteristics-80C188EC-16 ..... 24-729
AC Characteristics-80C188EC-13 ..... 24-730
Relative Timings-80C188EC-16, 13 ..... 24-731
Serial Port Mode 0 Timings- 80C188EC-16, 13 ..... 24-732
AC TEST CONDITIONS ..... 24-733
AC TIMING WAVEFORMS ..... 24-733
DERATING CURVES ..... 24-736
RESET ..... 24-737
BUS CYCLE WAVEFORMS ..... 24-740
REGISTER BIT SUMMARY ..... 24-747
80C188EC EXECUTION TIMINGS ..... 24-754
INSTRUCTION SET SUMMARY ..... 24-755


272076-1
Figure 1. 80C188EC Block Diagram

## INTRODUCTION

The 186 Integrated Processor Family incorporates a wide range of VLSI devices tailored to suit the needs of embedded system designers. All 186 Family devices share a common CPU architecture: the industry standard 8086/8088. Code developed on other "X86" platforms can be ported with little or no modification to any of the 186 Integrated Processor Family devices.

Each of the 186 Integrated Processor Family devices adds a full complement of peripherals to the 8086/8088 CPU core. The type of peripherals and level of integration vary between family members. A complete 186 Family system can often be designed with just the addition of RAM, ROM and simple glue logic. The space savings afforded by high-integration are critical as designers continue to strive for smaller size and portability.

The 80C188EC is one of the highest integration members of the 186 Integrated Processor Family. Two serial ports are provided for services such as interprocessor communication, diagnostics and modem interfacing. Four DMA channels allow for high speed data movement as well as support of the onboard serial ports. A flexible chip select unit simplifies memory and peripheral interfacing. The three general purpose timer/counters can be used for a variety of time measurement and waveform generation tasks. A watchdog timer is provided to insure system integrity even in the most hostile of environments. Two 8259A compatible interrupt controllers handle internal interrupts, and, up to 57 external interrupt requests. A DRAM refresh unit and 24 multiplexed I/O ports round out the feature set of the 80C188EC.

## OVERVIEW

Figure 1 shows a block diagram of the 80 C 188 EC . The execution unit (EU) is an enhanced 8086 CPU core that includes: dedicated hardware to speed up effective address calculations, enhanced execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instructions and full static operation. The bus interface unit (BIU) is the same as that found on the original 186 family products, except the queuestatus mode has been deleted and buffer interface control has been changed to ease system design timings. An independent internal bus is used for communication between the BIU and on-chip peripherals.

## 80C188EC CORE ARCHITECTURE

## Bus Interface Unit

The 80C188EC core incorporates a bus controller that generates local bus control signals. In addition, it employs a HOLD/HLDA protocol to share the local bus with other bus masters.

The bus controller is responsible for generating 20 bits of address, read and write strobes, bus cycle status information and data (for write operations) information. It is also responsible for reading data from the local bus during a read operation. A ready input pin is provided to extend a bus cycle beyond the minimum four states (clocks).

The 80C188EC bus controller also generates two control signals ( $\overline{\mathrm{DEN}}$ ) and DT/ $\overline{\text { R }}$ ) when interfacing to external transceiver chips. This capability allows the addition of transceivers for simple buffering of the multiplexed address/data bus.

## Clock Generator

The 80C188EC provides an on-chip clock generator for both interinal and external clock generation. The clock generator features a crystal oscillator, a divide-by-two counter and three low-power operating modes.

The oscillator circuit is designed to be used with either a parallel resonant fundamental or third-overtone mode crystal network. Alternatively, the oscillator circuit may be driven from an external clock source. Figure 2 shows the various operating modes of the 80 C 188 EC oscillator circuit.

The crystal or clock frequency chosen must be twice the required processor operating frequency due to the internal divide-by-two counter. This counter is used to drive all internal phase clocks and the external CLKOUT signal. CLKOUT is a $50 \%$ duty cycle processor clock and can be used to drive other system components. All AC timings are referenced to CLKOUT.

The following parameters are recommended when choosing a crystal:

| Temperature Range: | Application Specific |
| :--- | ---: |
| ESR (Equivalent Series Res.): | $40 \Omega$ max |
| CO (Shunt Capacitance of Crystal): | 7.0 pF max |
| CL (Load Capacitance): | $20 \mathrm{pF} \pm 2 \mathrm{pF}$ |
| Drive Level: | 1 mW (max) |

## 80C188EC Peripheral Architecture

The 80C188EC integrates several common system poriphorals with a CPU core to create a compact, yet powerful system. The integrated peripherals are designed to be flexbile and provide logical interconnections between supporting units (e.g., the DMA unit can accept requests from the Serial Communications Unit).

The list of integrated peripherals includes:

- Two cascaded, 8259A compatible, Programmable Interrupt Controllers
- 3-Channel Timer/Counter Unit
- 2-Channel Serial Communications Unit
- 4-Channel DMA Unit
- 10-Output Chip-Select Unit
- 32-bit Watchdog Timer Unit
- I/O Port Unit
- Refresh Control Unit
- Power Management Unit

The registers associated with each integrated peripheral are contained within a $128 \times 16$-bit register file called the Peripheral Control Block (PCB). The base address of the PCB is programmable and can be located on any 256 byte address boundary in either memory or I/O space.

(A) CRYSTAL CONNECTION

(B) CLOCK CONNECTION

NOTE:

1. The LC network is only required when using a third overtone crystal.

Figure 2. 80C188EC Clock Connections

Figure 3 provides a list of the registers associated with the PCB. The Register Bit Summary individually lists all of the registers and identifies each of their programming attributes.

## Programmable Interrupt Controllers

The 80C188EC utilizes two 8259A compatible Programmable Interrupt Controllers (PIC) to manage both internal and external interrupts. The 8259A modules are configured in a master/slave arrangement.

Seven of the external interrupt pins, INTO through INT6, are connected to the master 8259A module. The eighth external interrupt pin, INT7, is connected to the slave 8259A module.

There are a total of 11 internal interrupt sources from the integrated peripherals: 4 Serial, 4 DMA, and 3 Timer/Counter.

## Timer/Counter Unit

The 80C188EC Timer/Counter Unit (TCU) provides three 16-bit programmable timers. Two of these are highly flexible and are connected to external pins for external control or clocking. The third timer is not
connected to any external pins and can only be clocked internally. However, it can be used to clock the other two timer channels. The TCU can be used to count external events, time external events, generate non-repetitive waveforms or generate timed interrupts.

## Serial Communications Unit

The Serial Communications Unit (SCU) of the 80C188EC contains two independent channels. Each channel is identical in operation except that only channel 0 is directly supported by the integrated interrupt controller (the channel 1 interrupts are routed to external interrupt pins). Each channel has its own baud rate generator and can be internally or externally clocked up to one half the 80 C 188 EC operating frequency. Both serial channels can request service from the DMA unit thus providing block reception and transmission without CPU intervention.

Independent baud rate generators are provided for each of the serial channels. For the asynchronous modes, the generator supplies an $8 x$ baud clock to both the receive and transmit shifting register logic. A 1x baud clock is provided in the synchronous mode.

| PCB <br> Offset | Function | PCB Offset | Function | $\begin{array}{\|c\|} \text { PCB } \\ \text { Offset } \end{array}$ | Function | PCB <br> Offset | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OOH | Master PiC Port Ó | 40゙̈i | T2 Count | 80 | GCSO Siari | Cuti | Sivía ô Souluice Lơw |
| 02H | Master PIC Port 1 | 42H | T2 Compare | 82H | GCSO Stop | C2H | DMA 0 Source High |
| 04H | Slave PIC Port 0 | 44H | Reserved | 84H | GCS1 Start | C4H | DMA 0 Dest. Low |
| 06H | Slave PIC Port 1 | 46H | T2 Control | 86H | GCS1 Stop | C6H | DMA 0 Dest. High |
| 08H | Reserved | 48 H | Port 3 Direction | 88 H | GCS2 Start | $\mathrm{C8H}$ | DMA 0 Count |
| OAH | SCU Int. Req. Ltch. | 4AH | Port 3 Pin State | 8AH | GCS2 Stop | CAH | DMA 0 Control |
| OCH | DMA Int. Req. Ltch. | 4 CH | Port 3 Mux Control | 8 CH | GCS3 Start | CCH | DMA Module Pri. |
| OEH | TCU int. Req. Ltch. | 4EH | Port 3 Data Latch | 8EH | GCS3 Stop | CEH | DMA Halt |
| 10H | Reserved | 50 H | Port 1 Direction | 90H | GCS4 Start | DOH | DMA 1 Source Low |
| 12 H | Reserved | 52H | Port 1 Pin State | 92H | GCS4 Stop | D2H | DMA 1 Source High |
| 14H | Reserved | 54H | Port 1 Mux Control | 94H | GCS5 Start | D4H | DMA 1 Dest. Low |
| 16H | Reserved | 56H | Port 1 Data Latch | 96H | GCS5 Stop | D6H | DMA 1 Dest. High |
| 18H | Reserved | 58 H | Port 2 Direction | 98H | GCS6 Start | D8H | DMA 1 Count |
| 1AH | Reserved | 5AH | Port 2 Pin State | 9AH | GCS6 Stop | DAH | DMA 1 Control |
| 1 CH | Reserved | 5 CH | Port 2 Mux Control | 9 CH | GCS7 Start | DCH | Reserved |
| 1EH | Reserved | 5EH | Port 2 Data Latch | 9EH | GCS7 Stop | DEH | Reserved |
| 20 H | WDT Reload High | 60H | SCU 0 Baud | AOH | LCS Start | EOH | DMA 2 Source Low |
| 22 H | WDT Reload Low | 62H | SCU 0 Count | A2H | LCS Stop | E2H | DMA 2 Source High |
| 24H | WDT Count High | 64H | SCU 0 Control | A4H | UCS Start | E4H | DMA 2 Dest. Low |
| 26H | WDT Count Low | 66H | SCU 0 Status | A6H | UCS Stop | E6H | DMA 2 Dest. High |
| 28 H | WDT Clear | 68H | SCU ORBUF | A8H | Relocation Register | E8H | DMA 2 Count |
| 2AH | WDT Disable | 6AH | SCU OTBUF | AAH | Reserved | EAH | DMA 2 Control |
| 2 CH | Reserved | 6CH | Reserved | ACH | Reserved | ECH | Reserved |
| 2EH | Reserved | 6EH | Reserved | AEH | Reserved | EEH | Reserved |
| 30 H | TO Count | 70 H | SCU 1 Baud | BOH | Refresh Base Addr. | FOH | DMA 3 Source Low |
| 32H | TO Compare A | 72H | SCU 1 Count | B2H | Refresh Time | F2H | DMA 3 Source High |
| 34H | T0 Compare B | 74H | SCU 1 Control | B4H | Refresh Control | F4H | DMA 3 Dest. Low |
| 46H | TO Control | 76H | SCU 1 Status | B6H | Refresh Address | F6H | DMA 3 Dest. High |
| 38H | T1 Count | 78H | SCU 1 RBUF | $\mathrm{B8H}$ | Power Control | F 8 H | DMA 3 Count |
| 3AH | T1 Compare A | 7AH | SCU 1 TBUF | BAH | Reserved | FAH | DMA 3 Control |
| 3 CH | T1 Compare B | 7 CH | Reserved | BCH | Step ID | FCH | Reserved |
| 3EH | T1 Control | 7EH | Reserved | BEH | Powersave | FEH | Reserved |

Figure 3. 80C188EC Peripheral Control Block Registers

## DMA Unit

The four channel Direct Memory Access (DMA) Unit is comprised of two modules with two channels each. All four channels are identical in operation. DMA transfers can take place from memory to memory, I/O to memory, memory to I/O or I/O to I/O. DMA requests can be external (on the DRQ pins), internal (from Timer 2 or a serial channel) or software initiated.

The DMA unit transfers data as bytes only. Each data transfer requires two bus cycles, one to fetch data and one to deposit. The minimum clock count for each transfer is 8 , but this will vary depending on synchronization and wait states.

## Chip-Select Unit

The 80C188EC Chip-Select Unit (CSU) integrates logic which provides up to ten programmable chipselects to access both memories and peripherals. In addition, each chip-select can be programmed to automatically insert additional clocks (wait states) into the current bus cycle, and/or automatically terminate a bus cycle independent of the condition of the READY input pin.

## I/O Port Unit

The I/O Port Unit on the 80C188EC supports two 8bit channels and one 6-bit channel of input, output or input/output operation. Port 1 is multiplexed with the chip select pins and is output only. Port 2 is multiplexed with the pins for serial channels 1 and 2. All Port 2 pins are input/output. Port 3 has a total of 6 pins: four that are multiplexed with DMA and serial port interrupts and two that are non-multiplexed, open drain I/O.

## Refresh Control Unit

The Refresh Control Unit (RCU) automatically generates a periodic memory read bus cycle to keep dynamic or pseudo-static memory refreshed. A 9-bit counter controls the number of clocks between refresh requests. A 12 -bit address generator is maintained by the RCU and is presented on the A12:1 address lines during the refresh bus cycle. Address bits A19:13 are programmable to allow the refresh address block to be located on any 8 Kbyte boundary.

## Watchdog Timer Unit

The Watchdog Timer Unit (WDT) allows for graceful recovery from unexpected hardware and software upsets. The WDT consists of a 32 -bit counter that decrements every clock cycle. If the counter reaches zero before being reset, the WDTOUT pin is pulled low for four clock cycles. Logically ANDing the WDTOUT pin with the power-on reset signal allows the WDT to reset the device in the event of a WDT timeout. If a less drastic method of recovery is desired, WDTOUT can be connected directly to NMI or one of the INT input pins. The WDT may also be used as a general purpose timer.

## Power Management Unit

The 80C188EC Power Management Unit (PMU) is provided to control the power consumption of the device. The PMU provides four power management modes: Active, Powersave, Idle and Powerdown.

Active Mode indicates that all units on the 80 C 188 EC are operating at $1 / 2$ the CLKIN frequency.

Idle Mode freezes the clocks of the Execution and Bus units at a logic zero state (all peripherals continue to operate normally).

The Powerdown Mode freezes all internal clocks at a logic zero level and disables the crystal oscillator.

In Powersave Mode, all internal clock signals are divided by a programmable prescalar (up to $1 / 64$ the normal frequency). Powersave Mode can be used with Idle Mode as well as during normal (Active Mode) operation.

## ONCETM Test Mode

To facilitate testing and inspection of devices when fixed into a target system, the 80C188EC has a test mode available which forces all output and input/ output pins to be placed in the high-impedance state. ONCE stands for "ON Circuit Emulation". The ONCE mode is selected by forcing the A19/S6/ONCE pin low during a processor reset (this pin is weakly held high during reset to prevent inadvertant entrance into ONCE Mode).

## PACKAGE INFORMATION

This section describes the pin functions, pinout and thermal characteristics for the 80C188EC in both the Plastic Quad Flat Pack (JEDEC PQFP) and the EIAJ Quad Flat Pack (QFP). For complete package specifications and information, see the Intel Packaging Outlines and Dimensions Guide (Order Number: 231369).

## Pin Descriptions

Each pin or logical set of pins is described in Table 2. There are four columns for each entry in the Pin Description Table. The following sections describe each column.

## Column 1: Pin Name

In this column is a mnemonic that describes the pin function. Negation of the signal name (i.e. RESIN) implies that the signal is active low.

## Column 2: Pin Type

A pin may be either power ( P ), ground (G), input only (I), output only (O) or input/output (I/O). Please note that some pins have more than 1 function. A19/S6/ONCE, for example, is normally an output but functions as an input during reset. For this reason A19/S6/ONCE is classified as an input/ output pin.
Column 3: Input Type (for I and I/O types only)
There are two different types of input pins on the 80 C 188 EC : asynchronous and synchronous. Asynchronous pins require that setup and hold times be met only to guarantee recognition. Synchronous input pins require that the setup and hold times be met to guarantee proper operation. Stated simply, missing a setup or hold on an asynchronous pin will result in something minor (i.e. a timer count will be missed) whereas missing a setup or hold on a synchronous pin will result in system failure (the system will "lock up").
An input pin may also be edge or level sensitive.

## Column 4: Output States (for $O$ and I/O types only)

The state of an output or I/O pin is dependent on the operating mode of the device. There are four modes of operation that are different from normal active mode: Bus Hold, Reset, Idle Mode, Powerdown Mode. This column describes the output pin state in each of these modes.

The legend for interpreting the information in the Pin Descriptions is shown in Table 1.

As an example, please refer to the table entry for AD12:0. The "I/O" signifies that the pins are bidirectional (i.e. have both an input and output function). The " S " indicates that, as an input the signal must be synchronized to CLKOUT for proper operation. The " $H(Z)$ " indicates that these pins will float while the processor is in the Hold Acknowledge state. $R(Z)$ indicates that these pins will float while RESIN is low. $P(0)$ and $I(0)$ indicate that these pins will drive 0 when the device is in either Powerdown or Idle Mode.

Some pins, the I/O Ports for example, can be programmed to perform more than one function. Multifunction pins have a " $/$ " in their signal name between the different functions (i.e. P3.0/RX11). If the input pin type or output pin state differ between functions, then that will be indicated by separating the state (or type) with a " $/$ " (i.e: $\mathrm{H}(\mathrm{X}) / \mathrm{H}(\mathrm{Q})$ ). In this example when the pin is configured as P3.0 then its hold output state is $\mathrm{H}(\mathrm{X})$; when configured as RXI1 its output state is $H(Q)$.

All pins float while the processor is in the ONCE Mode (with the exception of OSCOUT).

Table 1. Pin Description Nomenclature

| Symbol | Description |
| :---: | :---: |
| P | Power Pin (apply $+\mathrm{V}_{\text {CC }}$ voltage) |
| G | Ground (connect to $\mathrm{V}_{\mathrm{SS}}$ ) |
| 1 | Input only pin |
| 0 | Output only pin |
| 1/0 | Input/Output pin |
| S(E) | Synchronous, edge sensitive |
| S(L) | Synchronous, level sensitive |
| A(E) | Asynchronous, edge sensitive |
| A(L) | Asynchronous, level sensitive |
| H(1) | Output driven to $\mathrm{V}_{\mathrm{CC}}$ during bus hold |
| H(0) | Output driven to $\mathrm{V}_{\text {SS }}$ during bus hold |
| H(Z) | Output floats during bus hold |
| H(Q) | Output remains active during bus hold |
| H(X) | Output retains current state during bus hold |
| R(WH) | Output weakly held at $\mathrm{V}_{\mathrm{CC}}$ during reset |
| R (1) | Output driven to $\mathrm{V}_{\text {CC }}$ during reset |
| R(0) | Output driven to $\mathrm{V}_{\text {SS }}$ during reset |
| $\mathrm{R}(\mathrm{Z})$ | Output floats during reset |
| $\mathrm{R}(\mathrm{Q})$ | Output remains active during reset |
| $\mathrm{R}(\mathrm{X})$ | Output retains current state during reset |
| I(1) | Output driven to $\mathrm{V}_{\mathrm{CC}}$ during Idle Mode |
| $1(0)$ | Output driven to $\mathrm{V}_{\text {SS }}$ during Idle Mode |
| I(Z) | Output floats during Idle Mode |
| I(Q) | Output remains active during Idle Mode |
| $1(\mathrm{X})$ | Output retains current state during Idle Mode |
| $\mathrm{P}(1)$ | Output driven to $\mathrm{V}_{\text {CC }}$ during Powerdown Mode |
| $\mathrm{P}(0)$ | Output driven to $\mathrm{V}_{\text {ss }}$ during Powerdown Mode |
| $\mathrm{P}(\mathrm{Z})$ | Output floats during Powerdown Mode |
| $\mathrm{P}(\mathrm{Q})$ | Output remains active during Powerdown Mode |
| $\mathrm{P}(\mathrm{X})$ | Output retains current state during Powerdown Mode |

Table 2. 80C188EC Pin Descriptions

| Pin Name | Pin Type | Input Type | Output States | Pin Description |
| :---: | :---: | :---: | :---: | :---: |
| $V_{C C}$ | P | - | - | POWER +5 V 土10\% power supply connection |
| $\mathrm{V}_{\text {SS }}$ | G | - | - | GROUND |
| CLKIN | 1 | A(E) | - | CLocK INput is the external clock input. An external oscillator operating at two times the required 80C188EC operating frequency can be connected to CLKIN. For crystal operation, CLKIN (along with OSCOUT) are the crystal connections to an internal Pierce oscillator. |
| OSCOUT | 0 | - | H(Q) <br> R(Q) <br> I(Q) <br> $P(X)$ | OSCillator OUTput is only used when using a crystal to generate the internal clock. OSCOUT (along with CLKIN) are the crystal connections to an internal Pierce oscillator. This pin can not be used as 2 X clock output for noncrytsal applications (i.e. this pin is not connected for noncrystal applications). |
| CLKOUT | 0 | - | H(Q) <br> R(Q) <br> I(Q) <br> $P(X)$ | CLocK OUTput provides a timing reference for inputs and outputs of the processor, and is one-half the input clock (CLKIN) frequency. CLKOUT has a $50 \%$ duty cycle and transitions every falling edge of CLKIN. |
| $\overline{\text { RESIN }}$ | 1 | A(L) | - | RESet IN causes the 80C188EC to immediately terminate any bus cycle in progress and assume an initialized state. All pins will be driven to a known state, and RESOUT will also be driven active. The rising edge (low-to-high) transition synchronizes CLKOUT with CLKIN before the 80C188EC begins fetching opcodes at memory location OFFFFOH. |
| RESOUT | 0 | - | $\begin{gathered} H(0) \\ R(1) \\ I(0) \\ P(0) \\ \hline \end{gathered}$ | RESet OUTput that indicates the 80C188EC is currently in the reset state. RESOUT will remain active as long as $\overline{\text { RESIN }}$ remains active. |
| PDTMR | 1/0 | A(L) | $\begin{aligned} & \mathrm{H}(\mathrm{WH}) \\ & \mathrm{R}(\mathrm{Z}) \\ & \mathrm{P}(\mathrm{WH}) \\ & \mathrm{I}(\mathrm{WH}) \end{aligned}$ | Power-Down TiMeR pin (normally connected to an external capacitor) that determines the amount of time the 80C188EC waits after an exit from Powerdown before resuming normal operation. The duration of time required will depend on the startup characteristics of the crystal oscillator. |
| NMI | 1 | A(E) | - | Non-Maskable Interrupt input causes a TYPE-2 interrupt to be serviced by the CPU. NMI is latched internally. |
| TEST | 1 | A(E) | - | TEST is used during the execution of the WAIT instruction to suspend CPU operation until the pin is sampled active (LOW). |
| A19/S6/ONCE | 1/O | A(L) | $\begin{gathered} \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{I}(0) \\ \mathrm{P}(0) \end{gathered}$ | This pin drives address bit 19 during the address phase of the bus cycle. During T2 and T3 this pin functions as status bit 6 . S6 is low to indicate CPU bus cycles and high to indicate DMA or refresh bus cycles. During a processor reset ( $\overline{R E S I N}$ active) this pin becomes the ONCE input pin. Holding this pin low during reset will force the part into ONCE Mode. |

Table 2. 80C188EC Pin Descriptions (Continued)

| Pin Name | $\begin{aligned} & \text { Pin } \\ & \text { Type } \end{aligned}$ | Input Type | Output States | Pin Description |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { A18/S5 } \\ & \text { A17/S4 } \\ & \text { A16/S3 } \end{aligned}$ | 1/O | A(L) | $\begin{gathered} H(Z) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{I}(0) \\ \mathrm{P}(0) \end{gathered}$ | These pins drive address information during the address phase of the bus cycle. During T2 and T3 these pins drive status information (which is always 0 on the 80C188EC). These pins are used as inputs during factory test; driving these pins low during reset will cause unspecified operation. |
| A15/CAS2 <br> A14/CAS1 <br> A13/CAS0 <br> A12:8 | 1/O | S(L) | H(Z) <br> R(Z) <br> I(0) <br> $P(0)$ | These pins are part of the ADDRESS bus. During the address phase of the bus cycle, address bits 15 through 8 are presented on these pins and can be latched using ALE. Pins AD15:13/CAS2:0 drive the 82C59 slave address information during interrupt acknowledge cycles. |
| AD7:0 | 1/0 | S(L) | H(Z) <br> R(Z) <br> 1(0) <br> $P(0)$ | These pins provide a multiplexed ADDRESS and DATA bus. During the address phase of the bus cycle, address bits 0 through 7 are presented on the bus and can be latched using ALE. 8-bit data information is transferred during the data phase of the bus cycle. |
| S2:0 | 0 | - | $H(Z)$ <br> R(1) <br> I(1) <br> $P(1)$ | Bus cycle Status are encoded on these pins to provide bus transaction information. $\overline{\mathbf{S 2}: 0}$ are encoded as follows: |
| ALE | 0 | - | H(0) <br> R(0) <br> I(0) <br> $P(0)$ | Address Latch Enable output is used to strobe address information into a transparent type latch during the address phase of the bus cycle. |
| $\overline{\mathrm{RFSH}}$ | 0 | - | $\begin{gathered} H(Z) \\ R(Z) \\ I(1) \\ P(1) \\ \hline \end{gathered}$ | ReFreSH output signals that a refresh bus cycle is in progress. |
| $\overline{\mathrm{RD}}$ | 0 | - | $\begin{aligned} & H(Z) \\ & R(Z) \\ & I(1) \\ & P(1) \\ & \hline \end{aligned}$ | ReaD output signals that the accessed memory or I/O device should drive data information onto the data bus. |

Table 2. 80C188EC Pin Descriptions (Continued)

| Pin Name | Pin <br> Type | Input <br> Type | Output <br> States | Pin Description |
| :--- | :---: | :---: | :---: | :--- |$|$| WR |
| :--- |
| WR |
| READY |

Table 2. 80C188EC Pin Descriptions (Continued)

| Pin Name | Pin Type | Input Type | Output States | Pin Description |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { LCS }}$ | 0 | - | $\begin{aligned} & H(1) \\ & R(1) \\ & I(1) \\ & P(1) \\ & \hline \end{aligned}$ | Lower Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address range programmed by the user. LCS is inactive after a reset. |
| $\begin{aligned} & \mathrm{P} 1.0 / \overline{\mathrm{GCS0}} \\ & \mathrm{P} 1.1 / \overline{\mathrm{GCS} 1} \\ & \mathrm{P} 1.2 / \overline{\mathrm{GCS}} \\ & \mathrm{P} 1.3 / \overline{\mathrm{GCS} 3} \\ & \mathrm{P} 1.4 / \overline{\mathrm{GCS}} \\ & \mathrm{P} 1.5 / \overline{\mathrm{GCS5}} \\ & \mathrm{P} 1.6 / \overline{\mathrm{GCS}} \\ & \mathrm{P} 1.7 / \overline{\mathrm{GCS}} \end{aligned}$ | 0 | - | $\begin{gathered} H(X) / H(1) \\ R(1) \\ I(X) / I(1) \\ P(X) / P(1) \end{gathered}$ | These pins provide a multiplexed function. If enabled, each pin can provide a General purpose Chip Select output which will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. When not programmed as a Chip-Select, each pin may be used as a general purpose output port. |
| TOOUT T1OUT | 0 | - | $\begin{aligned} & \mathrm{H}(\mathrm{Q}) \\ & \mathrm{R}(1) \\ & \mathrm{I}(\mathrm{Q}) \\ & \mathrm{P}(\mathrm{X}) \end{aligned}$ | Timer OUTput pins can be programmed to provide single clock or continuous waveform generation, depending on the timer mode selected. |
| $\begin{aligned} & \text { TOIN } \\ & \text { T1IN } \end{aligned}$ | 1 | $\begin{aligned} & A(L) \\ & A(E) \end{aligned}$ | - | Timer INput is used either as clock or control signals, depending on the timer mode selected. This pin may be either level or edge sensitive depending on the programming mode. |
| INT7:0 | 1 | $\begin{aligned} & A(L) \\ & A(E) \end{aligned}$ | - | Maskable INTerrupt input will cause a vector to a specific Type interrupt routine. The INT6:0 pins can be used as cascade inputs from slave 8259A devices. The INT pins can be configured as level or edge sensitive. |
| $\overline{\text { INTA }}$ | 0 | - | $\begin{aligned} & H(1) \\ & R(1) \\ & I(1) \\ & P(1) \\ & \hline \end{aligned}$ | INTerrupt Acknowledge output is a handshaking signal used by external 82C59A-2 Programmable Interrupt Controllers. |
| $\begin{aligned} & \text { P3.5 } \\ & \text { P3. } \end{aligned}$ | 1/0 | A(L) | $\begin{aligned} & H(X) \\ & R(Z) \\ & I(X) \\ & H(X) \\ & \hline \end{aligned}$ | Bidirectional, open-drain port pins. |
| $\begin{aligned} & \text { P3.3/DMAI1 } \\ & \text { P3.2/DMAIO } \end{aligned}$ | 0 | - | $H(X)$ <br> R(0) <br> I(Q) <br> $P(X)$ | DMA Interrupt output goes active to indicate that the channel has completed a transfer. DMAI1 and DMAIO are multiplexed with output only port functions. |
| P3.1/TX11 | 0 | - | $\begin{gathered} H(X) / H(Q) \\ R(0) \\ I(Q) \\ P(X) \\ \hline \end{gathered}$ | Transmit Interrupt output goes active to indicate that serial channel 1 has completed a transfer. TXI1 is multiplexed with an output only Port function. |

Table 2. 80C188EC Pin Descriptions (Continued)

| Pin Name | $\begin{aligned} & \text { Pin } \\ & \text { Type } \end{aligned}$ | Input Type | Output States | Pin Description |
| :---: | :---: | :---: | :---: | :---: |
| P3.0/RXI1 | 0 | - | $\begin{gathered} H(X) / H(Q) \\ R(0) \\ I(Q) \\ P(X) \\ \hline \end{gathered}$ | Receive Interrupt output goes active to indicate that serial channel 1 has completed a reception. RXI1 is multiplexed with an output only port function. |
| WDTOUT | 0 | - | $\begin{aligned} & \hline H(Q) \\ & R(1) \\ & I(Q) \\ & P(X) \end{aligned}$ | WatchDog Timer OUTput is driven low for four clock cycles when the watchdog timer reaches zero. WDTOUT may be ANDed with the power-on reset signal to reset the 80C188EC when the watchdog timer is not properly reset. |
| $\begin{aligned} & \hline \text { P2.7/ } \overline{\text { CTS } 1} \\ & \text { P2.3/ } \overline{\text { CTS0 }} \end{aligned}$ | 1/0 | A(L) | $\begin{aligned} & H(X) \\ & R(Z) \\ & I(X) \\ & P(X) \end{aligned}$ | Clear-To-Send input is used to prevent the transmission of serial data on the TXD signal pin. CTS1 and CTS0 are multiplexed with an I/O Port function. |
| $\begin{aligned} & \text { P2.6/BCLK1 } \\ & \text { P2.2/BCLKO } \end{aligned}$ | 1/0 | $\begin{gathered} \hline A(L) / \\ A(E) \end{gathered}$ | $\begin{aligned} & H(X) \\ & R(Z) \\ & I(X) \\ & P(X) \end{aligned}$ | Baud CLocK input can be used as an alternate clock source for each of the integrated serial channels. The BCLK inputs are multiplexed with I/O Port functions. The BCLK input frequency cannot exceed $1 / 2$ the operating frequency of the 80C188EC. |
| $\begin{aligned} & \text { P2.5/TXD1 } \\ & \text { P2.1/TXD0 } \end{aligned}$ | 1/0 | A(L) | $\begin{gathered} H(Q) \\ R(Z) \\ I(X) / I(Q) \\ P(X) \end{gathered}$ | Transmit Data output provides serial data information. The TXD outputs are multiplexed with I/O Port functions. During synchronous serial communications, TXD will function as a clock output. |
| $\begin{aligned} & \hline \text { P2.4/RXD1 } \\ & \text { P2.0/RXDO } \end{aligned}$ | 1/0 | A(L) | $\begin{gathered} H(X) / H(Q) \\ R(Z) \\ I(X) / I(Q) \\ P(X) \end{gathered}$ | Receive Data input accepts serial data information. The RXD pins are multiplexed with I/O Port functions. During synchronous serial communications, RXD is bi-directional and will become an output for transmission of data (TXD becomes the clock). |
| DRQ3:0 | 1 | A(L) | - | DMA ReQuest input pins are used to request a DMA transfer. The timing of the request is dependent on the programmed synchronization mode. |

## NOTE:

1. READY is $A(E)$ for the rising edge of CLKOUT, $S(E)$ for the falling edge of CLKOUT.

## 80C188EC Pinout

Tables 3 and 4 list the 80C188EC pin names with package location for the 100 -pin Plastic Quad Flat Pack (PQFP) component. Figure 4 depicts the complete 80C188EC pinout (PQFP) package as viewed from the top side of the component (i.e. contacts facing down).

Tables 5 and 6 list the 80C188EC pin names with package location for the 100 -pin EIAJ Quad Flat Pack (QFP) component. Figure 5 depicts the complete 80C188EC (QFP package) as viewed from the top side of the component (i.e. contacts facing down).

Table 3. 80C 188EC PQFP Pin Functions with Location

| AD Bus |  |
| :--- | :--- |
| Name | Pin |
| AD0 | 73 |
| AD1 | 72 |
| AD2 | 71 |
| AD3 | 70 |
| AD4 | 66 |
| AD5 | 65 |
| AD6 | 64 |
| AD7 | 63 |
| A8 | 60 |
| A9 | 59 |
| A10 | 58 |
| A11 | 57 |
| A12 | 56 |
| A13/CAS0 | 55 |
| A14/CAS1 | 54 |
| A15/CAS2 | 53 |
| A16/S3 | 77 |
| A17/S4 | 76 |
| A18/S5 | 75 |
| A19/S6/ONCE | 74 |
|  |  |


| Bus Control |  |
| :---: | :---: |
| Name | Pin |
| ALE | 52 |
| $\overline{\text { RFSH }}$ | 51 |
| $\overline{\text { So }}$ | 78 |
| S1 | 79 |
| S2 | 80 |
| $\overline{\mathrm{RD}}$ | 50 |
| $\overline{\mathrm{WR}}$ | 49 |
| READY | 85 |
| $\overline{\text { DEN }}$ | 47 |
| DT/ $\bar{R}$ | 46 |
| LOCK | 48 |
| HOLD | 44 |
| HLDA | 45 |
| INTA | 34 |


| Power and Ground |  |
| :---: | :---: |
| Name | Pin |


| 1/0 |  |
| :---: | :---: |
| Name | Pin |
| UCS | 88 |
| LCS | 89 |
| P1.7/GCS7 | 90 |
| P1.6/GCS6 | 91 |
| P1.5/GCS5 | 92 |
| P1.4/GCS4 | 93 |
| P1.3/GCS3 | 94 |
| P1.2/GCS2 | 95 |
| P1.1/GCS1 | 96 |
| P1.0/GCS0 | 97 |
| P2.7/CTS | 23 |
| P2.6/BCLK1 | 22 |
| P2.5/TXD1 | 21 |
| P2.4/RXD1 | 20 |
| P2.3/CTS0 | 19 |
| P2.2/BCLK0 | 18 |
| P2.1/TXD0 | 17 |
| P2.0/RXD0 | 16 |
| P3. 5 | 29 |
| P3.4 | 28 |
| P3.3/DMA11 | 27 |
| P3.2/DMAIO | 26 |
| P3.1/TXI1 | 25 |
| P3.0/RXI1 | 24 |
| TOIN | 3 |
| TOOUT | 2 |
| T1IN | 5 |
| T10UT | 4 |
| DRQ0 | 98 |
| DRQ1 | 99 |
| DRQ2 | 100 |
| DRQ3 | 1 |
| WDTOUT | 36 |

Table 4. PQFP Pin Locations with Pin Name

| Pin | Name |
| :---: | :---: |
| 1 | DRQ3 |
| 2 | ToOUT |
| 3 | ToIN |
| 4 | T1OUT |
| 5 | T1IN |
| 6 | CLKOUT |
| 7 | RESOUT |
| 8 | RESIN |
| 9 | PDTMR |
| 10 | CLKIN |
| 11 | OSCOUT |
| 12 | VSS |
| 13 | VCC |
| 14 | VCC |
| 15 | VSS |
| 16 | P2.0/RXDO |
| 17 | P2.1/TXDO |
| 18 | P2.2/BCLK0 |
| 19 | P2.3/CTS0 |
| 20 | P2.4/RXD1 |
| 21 | P2.5/TXD1 |
| 22 | P2.6/BCLK1 |
| 23 | P2.7/CTS1 |
| 24 | P3.0/RXI1 |
| 25 | P3.1/TXI1 |


| Pin | Name |
| :---: | :---: |
| 26 | DMAAio/P3.2 |
| 27 | DMAI1/P3.3 |
| 28 | P3.4 |
| 29 | P3.5 |
| 30 | INTO |
| 31 | INT1 |
| 32 | INT2 |
| 33 | INT3 |
| 34 | INTA |
| 35 | N.C. |
| 36 | $\overline{\text { WDTOUT }}$ |
| 37 | VSS |
| 38 | VCC |
| 39 | VSS |
| 40 | INT4 |
| 41 | INT5 |
| 42 | INT6 |
| 43 | INT7 |
| 44 | HOLD |
| 45 | HLDA |
| 46 | DT/R |
| 47 | $\overline{D E N}$ |
| 48 | LOCK |
| 49 | $\overline{\text { WR }}$ |
| 50 | RD |


| Pin | Name |
| :---: | :---: |
| 51 | $\overline{\text { FFSFi }}$ |
| 52 | ALE |
| 53 | A15 |
| 54 | A14 |
| 55 | A13 |
| 56 | A12 |
| 57 | A11 |
| 58 | A10 |
| 59 | A9 |
| 60 | A8 |
| 61 | VSS |
| 62 | VCC |
| 63 | AD7 |
| 64 | AD6 |
| 65 | AD5 |
| 66 | AD4 |
| 67 | VCC |
| 68 | VSS |
| 69 | VCC |
| 70 | AD3 |
| 71 | AD2 |
| 72 | AD1 |
| 73 | AD0 |
| 74 | A19/S6/ONCE |
| 75 | A18/S5 |


| Pin | Name |
| :---: | :---: |
| 76 | Aitisis |
| 77 | A16/S3 |
| 78 | So |
| 79 | S1 |
| 80 | S2 |
| 81 | $\mathrm{V}_{S S}$ |
| 82 | NMI |
| 83 | TEST |
| 84 | $V_{C C}$ |
| 85 | READY |
| 86 | $\mathrm{V}_{\mathrm{CC}}$ |
| 87 | $V_{\text {SS }}$ |
| 88 | UCS |
| 89 | LCS |
| 90 | P1.7/GCS7 |
| 91 | P1.6/GCS6 |
| 92 | P1.5/GCS5 |
| 93 | P1.4/GCS4 |
| 94 | P1.3/GCS3 |
| 95 | P1.2/GCS2 |
| 96 | P1.1/GCS1 |
| 97 | P1.0/GCS0 |
| 98 | DRQ0 |
| 99 | DRQ1 |
| 100 | DRQ2 |



272076-4
Figure 4. 100-Pin Plastic Quad Flat Pack Package (PQFP)

Table 5. QFP Pin Names with Package Location

| AD Bus |  |
| :--- | :---: |
| Name | Pin |
| AD0 | 76 |
| AD1 | 75 |
| AD2 | 74 |
| AD3 | 73 |
| AD4 | 69 |
| AD5 | 68 |
| AD6 | 67 |
| AD7 | 66 |
| A8 | 63 |
| A9 | 62 |
| A10 | 61 |
| A11 | 60 |
| A12 | 59 |
| A13/CAS0 | 58 |
| A14/CAS1 | 57 |
| A15/CAS2 | 56 |
| A16/S3 | 80 |
| A17/S4 | 79 |
| A18/S5 | 78 |
| A19/S6/ONCE | 77 |


| Bus Control |  |
| :--- | :---: |
| Name | Pin |
| ALE | 55 |
| $\overline{R F S H}$ | 54 |
| $\overline{S 0}$ | 81 |
| $\overline{S 1}$ | 82 |
| $\overline{S 2}$ | 83 |
| $\overline{\operatorname{RD}}$ | 53 |
| $\overline{\text { WR }}$ | 52 |
| READY | 88 |
| $\overline{D E N}$ | 50 |
| DT/ $\bar{R}$ | 49 |
| LOCK | 51 |
| HOLD | 47 |
| HLDA | 48 |
| INTA | 37 |


| Processor <br> Control |  |
| :--- | ---: |
| Name | Pin |
| RESIN | 11 |
| RESOUT | 10 |
| CLKIN | 13 |
| OSCOUT | 14 |
| CLKOUT | 9 |
| TEST | 86 |
| PDTMR | 12 |
| NMI | 85 |
| INTO | 33 |
| INT1 | 34 |
| INT2 | 35 |
| INT3 | 36 |
| INT4 | 43 |
| INT5 | 44 |
| INT6 | 45 |
| INT7 | 46 |


| I/O |  |
| :--- | ---: |
| Name | Pin |
| UCS | 91 |
| LCS | 92 |
|  |  |
| P1.7/GCS7 | 93 |
| P1.6/GCS6 | 94 |
| P1.5/GCS5 | 95 |
| P1.4/GCS4 | 96 |
| P1.3/GCS3 | 97 |
| P1.2/GCS2 | 98 |
| P1.1/GCS1 | 99 |
| P1.0/GCS0 | 100 |
|  |  |
| P2.7/CTS1 | 26 |
| P2.6/BCLK1 | 25 |
| P2.5/TXD1 | 24 |
| P2.4/RXD1 | 23 |
| P2.3/CTS0 | 22 |
| P2.2/BCLK0 | 21 |
| P2.1/TXD0 | 20 |
| P2.0/RXD0 | 19 |
| P3.5 | 32 |
| P3.4 | 31 |
| P3.3/DMAI1 | 30 |
| P3.2/DMAIO | 29 |
| P3.1/TXI1 | 28 |
| P3.0/RXI1 | 27 |
|  |  |
| TOIN | 6 |
| TOOUT | 5 |
| T1IN | 8 |
| T10UT | 7 |
|  |  |
| DRQ0 | 1 |
| DRQ1 | 2 |
| DRQ2 | 3 |
| DRQ3 | 4 |
| WDTOUT | 39 |
|  |  |

Table 6. QFP Package Location with Pin Names

| Pin | Name |
| :---: | :---: |
| 1 | DRQ0 |
| 2 | DRQ1 |
| 3 | DRQ2 |
| 4 | DRQ3 |
| 5 | TOOUT |
| 6 | TOIN |
| 7 | T1OUT |
| 8 | T1IN |
| 9 | CLKOUT |
| 10 | RESOUT |
| 11 | RESIN |
| 12 | PDTMR |
| 13 | CLKIN |
| 14 | OSCOUT |
| 15 | VSS |
| 16 | VCC |
| 17 | VCC |
| 18 | VSS |
| 19 | P2.0/RXD0 |
| 20 | P2.1/TXDO |
| 21 | P2.2/BCLK0 |
| 22 | P2.3/CTS0 |
| 23 | P2.4/RXD1 |
| 24 | P2.5/TXD1 |
| 25 | P2.6/BCLK1 |


| Pin | Name |
| :---: | :---: |
| 26 | P2.7/̄TST1 |
| 27 | P3.0/RXI1 |
| 28 | P3.1/TXI1 |
| 29 | DMAIO/P3.2 |
| 30 | DMA11/P3.3 |
| 31 | P3.4 |
| 32 | P3.5 |
| 33 | INTO |
| 34 | INT1 |
| 35 | INT2 |
| 36 | INT3 |
| 37 | INTA |
| 38 | N.C. |
| 39 | WDTOUT |
| 40 | VSS |
| 41 | VCC |
| 42 | VSS |
| 43 | INT4 |
| 44 | INT5 |
| 45 | INT6 |
| 46 | INT7 |
| 47 | HOLD |
| 48 | HLDA |
| 49 | DT/R |
| 50 | DEN |


| Pin | Name |
| :---: | :---: |
| 51 | LOCK |
| 52 | $\overline{W R}$ |
| 53 | $\overline{\mathrm{RD}}$ |
| 54 | $\overline{\text { RFSH }}$ |
| 55 | ALE |
| 56 | A15 |
| 57 | A14 |
| 58 | A13 |
| 59 | A12 |
| 60 | A11 |
| 61 | A10 |
| 62 | A9 |
| 63 | A8 |
| 64 | $V_{\text {SS }}$ |
| 65 | $V_{\text {cc }}$ |
| 66 | AD7 |
| 67 | AD6 |
| 68 | AD5 |
| 69 | AD4 |
| 70 | $V_{\text {cc }}$ |
| 71 | $V_{\text {ss }}$ |
| 72 | $V_{\text {cc }}$ |
| 73 | AD3 |
| 74 | AD2 |
| 75 | AD1 |


| Pin | Name |
| :---: | :---: |
| 76 | ADO |
| 77 | A19/S6/ONCE |
| 78 | A18/S5 |
| 79 | A17/S4 |
| 80 | A16/S3 |
| 81 | So |
| 82 | $\overline{51}$ |
| 83 | S2 |
| 84 | Vss |
| 85 | NMI |
| 86 | TEST |
| 87 | $V_{C C}$ |
| 88 | READY |
| 89 | $V_{\text {cc }}$ |
| 90 | $V_{\text {SS }}$ |
| 91 | UCS |
| 92 | LCS |
| 93 | P1.7/GCS7 |
| 94 | P1.6/GCS6 |
| 95 | P1.5/GCS5 |
| 96 | P1.4/GCS4 |
| 97 | P1.3/GCS3 |
| 98 | P1.2/GCS2 |
| 99 | P1.1/GCS1 |
| 100 | P1.0/GCS0 |

24


## PACKAGE THERMAL SPECIFICATIONS

The 80 C 188 EC is specified for operation when $\mathrm{T}_{\mathrm{C}}$ (the case temperature) is within the range of $-40^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$. $\mathrm{T}_{\mathrm{C}}$ may be measured in any environment to determine whether the 80C188EC is within the specified operating range. The case temperature must be measured at the center of the top surface.
$T_{A}$ (the ambient temperature) can be calculated from $\theta_{\mathrm{CA}}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\mathrm{CA}}$ at various airflows are given in Table 7 for the 100-pin Quad Flat Pack (QFP) package.

Table 8 shows the maximum $\mathrm{T}_{\mathrm{A}}$ allowable (without exceeding $T_{C}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumptionspecified in Watts) is calculated by using the maximum $\mathrm{I}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{CC}}$ of 5.5 V .

$$
T_{A}=T_{C}-P^{*} \theta_{C A}
$$

Table 7. Thermal Resistance ( $\theta_{\mathrm{CA}}$ ) at Various Airflows (in ${ }^{\circ} \mathrm{C} / \mathrm{Watt}$ )

|  | Airflow in $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec}$ ) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} 0 \\ (0) \end{gathered}$ | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{gathered} 400 \\ (2.03) \end{gathered}$ | $\begin{gathered} 600 \\ (3.04) \end{gathered}$ | $\begin{gathered} 800 \\ (4.06) \end{gathered}$ | $\begin{gathered} 1000 \\ (5.07) \end{gathered}$ |
| $\theta_{\text {CA }}$ (PQFP) | 27.0 | 22.0 | 18.0 | 15.0 | 14.0 | 13.5 |
| $\theta_{\mathrm{CA}}(\mathrm{QFP})$ | 64.5 | 55.5 | 51.0 | TBD | TBD | TBD |

Table 8. Maximum $\mathrm{T}_{\mathrm{A}}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow in $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec})$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \mathbf{T}_{\mathbf{F}} \\ (\mathbf{M H z}) \end{gathered}$ | 0 <br> (0) | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{gathered} 400 \\ (2.03) \end{gathered}$ | $\begin{gathered} 600 \\ (3.04) \end{gathered}$ | $\begin{gathered} 800 \\ (4.06) \end{gathered}$ | $\begin{gathered} 1000 \\ \mathbf{( 5 . 0 7 )} \end{gathered}$ |
| $\theta_{\text {CA }}$ (PQFP) | TBD | TBD | TBD | TBD | TBD | TBD | TBD |
| $\theta_{\text {CA }}(\mathrm{QFP})$ | TBD | TBD | TBD | TBD | TBD | TBD | TBD |

## ELECTRICAL SPECIFICATIONS

```
Absolute Maximum Ratings
Storage Temperature.........\(-65^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}\)
Case Temperature Under Bias . . . \(-65^{\circ} \mathrm{C}\) to \(+100^{\circ} \mathrm{C}\)
Supply Voltage
    with Respect to \(\mathrm{V}_{\mathrm{SS}} \ldots \ldots . . .-0.5 \mathrm{~V}\) to +6.5 V
Voltage on Other Pins
    with Respect to \(\mathrm{V}_{\mathrm{SS}} \ldots \ldots-0.5 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}\)
```

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with youir local intel Sales office that you have the latest data sheet before finalizing a design.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## Operating Conditions

| Symbol | Parameter | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.5 | 5.5 | V |
| $\mathrm{~T}_{\mathrm{F}}$ | Input Clock Frequency |  |  |  |
|  | $80 \mathrm{C} 188 \mathrm{EC}-16$ | 0 | 32 | MHz |
|  | $80 \mathrm{C} 188 \mathrm{EC}-13$ | 0 | 26.08 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature Under Bias |  |  |  |
|  | KU80C188EC-XX (PQFP) | $-40^{\circ} \mathrm{C}$ | +100 | ${ }^{\circ} \mathrm{C}$ |
|  | S80C188EC-XX (QFP) | $-40^{\circ} \mathrm{C}$ | +100 | ${ }^{\circ} \mathrm{C}$ |

## Recommended Connections

Power and ground connections must be made to multiple $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\text {SS }}$ pins. Every 80C188EC-based circuit board should include separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $\mathrm{V}_{\mathrm{SS}}$ ) planes. Every $\mathrm{V}_{\mathrm{CC}}$ pin must be connected to the power plane, and every $\mathrm{V}_{\text {ss }}$ pin must be connected to the ground plane. Liberal decoupling capacitance should be placed near the 80 C 188 EC . The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance is reduced by placing the decoupling capacitors as close as possible to the 80C188EC $V_{C C}$ and $V_{S S}$ package pins.

Always connect any unused input to an appropriate signal level. In particular, unused interrupt inputs (NMI, INT0:7) should be connected to $\mathrm{V}_{\text {SS }}$ through a pull-down resistor. Leave any unused output pin unconnected.

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | $0.3 * V_{\text {CC }}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | $0.7 *{ }^{\text {V }}$ CC | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=3 \mathrm{~mA}(\mathrm{Min})$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}(\mathrm{Min})$ |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysteresis on RESIN | 0.5 |  | V |  |
| $\mathrm{I}_{\text {LI }}$ | Input Leakage Current for Pins: AD15:0, READY, HOLD, RESIN, CLKIN, TEST, NMI, INT7:0, TOIN, T1IN, P2.7-P2.0, P3.5-P3.0, DRQ3:0 |  | $\pm 15$ | $\mu \mathrm{A}$ | $0 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ILIU | Input Leakage for Pins with Pullups Active During Reset: <br> A19:16, LOCK | -0.2 | -5 | mA | $\begin{aligned} & \mathrm{V}_{\text {IN }}=0.7 \mathrm{~V}_{\mathrm{CC}} \\ & \text { (Note 1) } \end{aligned}$ |
| Lo | Output Leakage for Floated Output Pins |  | $\pm 15$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}} \\ & \text { (Note 2) } \end{aligned}$ |
| ICC | Supply Current Cold (in RESET) 80C188EC-16 80C188EC-13 |  | $\begin{aligned} & 85 \\ & 70 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 3) |
| ID | Supply Current in Idle Mode 80C188EC-16 80C188EC-13 |  | $\begin{array}{r} 60 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 4) |
| IPD | Supply Current in Powerdown Mode 80C188EC-16 80C188EC-13 |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ | (Note 5) |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |
| Cout | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ (Note 6) |

## NOTES:

1. These pins have an internal pull-up device that is active while $\overline{\text { RESIN }}$ is low and ONCE Mode is not active. Sourcing more current than specified (on any of these pins) may invoke a factory test mode.
2. Tested by outputs being floated by invoking ONCE Mode or by asserting HOLD.
3. Measured with the device in RESET and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $V_{C C}$ or GND.
4. Measured with the device in HALT (IDLE Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND.
5. Measured with the device in HALT (Powerdown Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with

ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $V_{C C}$ or GND.
6. Output Capacitance is the capacitive load of a floating output pin.

## Icc versus Frequency and Voltage

The Icc consumed by the 80C188EC is composed of two components:

1. IPD-The quiescent current that represents internal device leakage. Measured with all inputs at either $\mathrm{V}_{\mathrm{CC}}$ or ground and no clock applied.
2. IcCS-The switching current used to charge and discharge internal parasitic capacitance when changing logic levels. Iccs is related to both the frequency of operation and the device supply voltage ( $\mathrm{V}_{\mathrm{CC}}$ ). ICCS is given by the formula:

$$
\begin{gathered}
\text { Power }=\mathrm{V} * \mathrm{I}=\mathrm{V} 2 * \mathrm{C}_{\mathrm{DEV}}^{*} \mathrm{f} \\
\therefore \mathrm{ICCS}=\mathrm{v} * \mathrm{C}_{\mathrm{DEV}}^{*} \mathrm{f}
\end{gathered}
$$

Where:
$V=$ Supply Voltage $\left(V_{C C}\right)$
$C_{D E V}=$ Device Capacitance
$f=$ Operating Frequency

Measuring $\mathrm{C}_{\text {PD }}$ on a device like the 80C188EC would be difficult. Instead, $\mathrm{C}_{P D}$ is calculated using the above formula with ICC values measured at known $\mathrm{V}_{\mathrm{CC}}$ and frequency. Using the $\mathrm{C}_{P D}$ value, the user can calculate ICC at any voltage and frequency within the specified operating range.

Example. Calculate typical ICC at $14 \mathrm{MHz}, 5.2 \mathrm{~V}$ VCC .

$$
\begin{aligned}
I_{C C} & =I_{\text {PD }}+I_{\text {CCS }} \\
& =0.1 \mathrm{~mA}+5.2 \mathrm{~V} * 0.77 * 14 \mathrm{MHz} \\
& =56.2 \mathrm{~mA}
\end{aligned}
$$

## PDTMR Pin Delay Calculation

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown Mode. A delay is required only when using the on chip oscillator to allow the crystal or resonator circuit to stabilize.

## NOTE:

The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e. a device reset while in Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized.

To calculate the value of capacitor to use to provide a desired delay, use the equation:

$$
440 \times t=C_{P D}\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where:
$\mathrm{t}=$ desired delay in seconds
$\mathrm{C}_{\mathrm{PD}}=$ capacitive load on PDTMR in microfarads
Example. For a delay of $300 \mu \mathrm{~s}$, a capacitor value of $\mathrm{C}_{P D}=440 \times\left(300 \times 10^{-6}=0.132 \mu \mathrm{~F}\right.$ is required. Round up to a standard (available) capacitor value.

## NOTE:

The above equation applies to delay time longer than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ to $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $\mathrm{V}_{\mathrm{CC}}$ and/or lower temperatures will decrease delay time, while lower $V_{C C}$ and/or higher temperature will increase delay time.

| Parameter | Target Typical | Target Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| CPD | 0.77 | 1.37 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| CPD (Idle Mode) | 0.55 | 0.96 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

## NOTES:

1. Maximum $C_{P D}$ is measured at $-40^{\circ} \mathrm{C}$ with all outputs loaded as specified in the $A C$ test conditions and the device in reset (or Idle Mode). Due to tester limitations, CLKOUT and OSCOUT also have 50 pF loads that increase ICc by $\mathrm{V}^{*} \mathrm{C}^{*} \mathrm{~F}$. 2. Typical CPD is calculated at $25^{\circ} \mathrm{C}$ assuming no loads on CLKOUT or OSCOUT and the device in reset (or Idle Mode).

## AC SPECIFICATIONS

AC Characteristics-80C188EC-16

| Symbol | Parameter | TARGET Min | TARGET Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 32 | MHz | 1 |
| TC | CLKIN Period | 31.25 | $\infty$ | ns | 1 |
| TCH | CLKIN High Time | 10 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 10 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 10 | ns | 1, 3 |
| TCF | CLKIN Fall Time | 1 | 10 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{CD}}$ | CLKIN to CLKOUT Delay | 0 | 20 | ns | 1, 4 |
| T | CLKOUT Period |  | 2*TC | ns | 1. |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\text {PL }}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}$, RFSH, LOCK, A19:16 | 3 | 22 | ns | 1,4,6,7 |
| TCHOV2 | $\begin{aligned} & \hline \overline{\mathrm{GCS}}: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \\ & \mathrm{RD}, \overline{\mathrm{WR}}, \mathrm{NCS}, \mathrm{WDTOUT} \end{aligned}$ | 3 | 27 | ns | 1,4,6, 8 |
| TCLOV1 | $\overline{\text { RFSH, }} \overline{\text { ENN }}, \overline{\text { LOCK, RESOUT, }}$ HLDA, TOOUT, T1OUT, A19:16 | 3 | 22 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GSC7}}: \overline{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \mathrm{~A} 15: 8,$ $\text { AD7:0, } \overline{\text { NTA }}, \bar{S} 2: 0$ | 3 | 27 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{LOCK}}$, S2:0, A19:16 | 0 | 25 | ns | 1 |
| TCLOF | DEN, A15:8, AD7:0 | 0 | 25 | ns | 1 |


| T $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, T1IN, TOIN, READY, <br> CTS1:0, BCLK1:0, P3.4, P3.5 | 10 |  | ns | 1,9 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{~T}_{\text {CHIH }}$ | TEST, NMI, T1IN, TOIN, READY, | 3 |  | ns | 1,9 |
| CTS1:0, DRQ1:0, BCLK1:0, P3.4, P3.5 |  |  |  |  |  |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 16 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 17 for rise and fall times outside 50 pF .
6. See Figure 17 for rise and fall times.
7. TCHOV1 applies to RFSH, $\overline{\text { LOCK }}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C188EC operation.

AC Characteristics-80C188EC-13

| Symbol | Parameter | TARGET Min | TARGET Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 26.08 | MHz | 1 |
| TC | CLKIN Period | 38.34 | $\infty$ | ns | 1 |
| TCH | CLKIN High Time | 12 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 12 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 10 | ns | 1, 3 |
| TCF | CLKIN Fall Time | 1 | 10 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{C D}$ | CLKIN to CLKOUT Delay | 0 | 23 | ns | 1,4 |
| T | CLKOUT Period |  | 2*TC | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{T}_{\mathrm{PL}}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| $\mathrm{T}_{\mathrm{PR}}$ | CLKOUT Rise Time | 1 | 6 | ns | 1,5 |
| $\mathrm{T}_{\text {PF }}$ | CLKOUT Fall Time | 1 | 6 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:O }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{RFSH}}, \overline{\mathrm{LOCK}}$, A19:16 | 3 | 25 | ns | 1, 4, 6, 7 |
| TCHOV2 | $\overline{\text { GCS7: }}, \overline{\text { LCS }}, \overline{U C S}, \overline{R D}, \overline{\mathrm{WR}}$, WDTOUT | 3 | 30 | ns | 1, 4, 6, 8 |
| TCLOV1 | $\overline{\mathrm{RFSH}}, \overline{\mathrm{DEN}}, \overline{\text { LOCK}}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 25 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}}: \overline{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{NCS}}$, INTA, S2:0, A15:8, AD7:0 | 3 | 30 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{FFSH}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{LOCK}}$, S2:0, A19:16 | 0 | 30 | ns | 1 |
| TCLOF | $\overline{\text { DEN, }}$ A15:8, AD7:0 | 0 | 30 | ns | 1 |
| INPUT REQUIREMENTS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, T1IN, TOIN, READY, CTS1:0, BCLK1:0, P3.4, P3.5 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, T1IN, TOIN, READY, CTS1:0, DRQ3:0, BCLK1:0, P3.4, P3. 5 | 3 |  | ns | 1,9 |
| TCLIS | AD7:0, READY | 10 |  | ns | 1,10 |
| $\mathrm{T}_{\text {CLIH }}$ | AD7:0, READY | 3 |  | ns | 1,10 |
| TCLIS | HOLD, DRQ3:0 | 10 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CLIH }}$ | HOLD, DRQ3:0 | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 16 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 17 for rise and fall times outside 50 pF .
6. See Figure 17 for rise and fall times.
7. TCHOV1 applies to $\overline{\text { RFSH}}, \overline{\text { LOCK }}$ and A19:16 only after a HOLD release.
8. TCHOV2 applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80C188EC operation.

Relative Timings-80C188EC-16, 13

| Symbol | Parameter | TARGET Min | TARGET Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Active Pulse Width | T-15 |  | ns |  |
| TAVLL | AD Valid Setup before ALE Falls | $1 / 2 \mathrm{~T}-10$ |  | ns |  |
| TPLLL | Chip Select Valid before ALE Falls | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TLLAX | AD Hold after ALE Falls | $1 / 2 \mathrm{~T}-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{\text { WR }}$ Falling | $1 / 2 \mathrm{~T}-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\text { RD }}$ Falling | $1 / 2 \mathrm{~T}-15$ |  | ns | 1 |
| T WHLH | $\overline{\text { WR }}$ Rising to Next ALE Rising | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TAFRL | AD Float to $\overline{\mathrm{RD}}$ Falling | 0 |  | ns |  |
| T ${ }_{\text {RLRH }}$ | $\overline{R D}$ Active Pulse Width | 2T-5 |  | ns | 2 |
| T WLWH | $\overline{\text { WR Active Pulse Width }}$ | 2T-5 |  | ns | 2 |
| T RHAX | $\overline{\mathrm{RD}}$ Rising to Next Address Active | T-15 |  | ns |  |
| TwHDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| TWHPH | $\overline{\text { WR Rise to Chip Select Rise }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TRHPH | $\overline{\mathrm{RD}}$ Rise to Chip Select Rise | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| TPHPL | Chip Select Inactive to Next Chip Select Active | $1 / 2 \mathrm{~T}-10$ |  | ns | 1 |
| ToVRH | ONCE Active Setup to RESIN Rising | T |  | ns |  |
| TrHOX | ONCE Hold after RESIN Rise | T |  | ns |  |
| TIHIL | $\overline{\text { INTA }}$ High to Next INTA Low during INTA Cycle | 4T-5 |  | ns | 4 |
| TILIH | INTA Active Pulse Width | 2T-5 |  | ns | 2, 4 |
| TCVIL | CAS2:0 Setup before 2nd INTA Pulse Low | 8T |  | ns | 2, 4 |
| TILCX | CAS2:0 Hold after 2nd INTA Pulse Low | 4 T |  | ns | 2, 4 |
| TIRES | Interrupt Resolution Time |  | 150 | ns | 3 |
| $\mathrm{T}_{\text {IRLH }}$ | IR Low Time to Reset Edge Detector | 50 |  | ns |  |
| TIRHIF | IR Hold Time after 1st INTA Falling | 25 |  | ns | 4,5 |

## NOTES:

1. Assumes equal loading on both pins.
2. Can be extended using wait states.
3. Interrupt resolution time is the delay between an unmasked interrupt request going active and the interrupt output of the 82C59A module going active. This is not directly measureable by the user. For interrupt pin INT7 the delay from an active signal to an active input to the CPU would actually be twice the TIRES value since the signal must pass through two 82C59A modules.
4. See INTA Cycle Waveforms for definition.
5. To guarantee interrupt is not spurious.

Serial Port Mode 0 Timings-80C188EC-16, 13

| Symbol | Parameter | TARGET Min | TARGET Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TXLXL | TXD Clock Period | $T(n+1)$ |  | ns | 1, 2 |
| $T_{\text {XLXH }}$ | TXD Clock Low to Clock High ( $\mathrm{N}>1$ ) | 2T-35 | $2 T+35$ | ns | 1 |
| TXLXH | TXD Clock Low to Clock High ( $\mathrm{N}=1$ ) | T-35 | T+35 | ns | 1 |
| $\mathrm{T}_{\text {XHXL }}$ | TXD Clock High to Clock Low ( $\mathrm{N}>1$ ) | $(\mathrm{n}-1) \mathrm{T}-35$ | ( $\mathrm{n}-1$ ) T+35 | ns | 1,2 |
| $T_{\text {XHXL }}$ | TXD Clock High to Clock Low ( $\mathrm{N}=1$ ) | T-35 | T+35 | ns | 1 |
| T ${ }_{\text {QVXH }}$ | RXD Output Data Setup to TXD <br> Clock High ( $\mathrm{N}>1$ ) | $(n-1) T-35$ |  | ns | 1,2 |
| TQVXH | RXD Output Data Setup to TXD Clock High ( $\mathrm{N}=1$ ) | T-35 |  | ns | 1 |
| $\mathrm{T}_{\text {XHQX }}$ | RXD Output Data Hold after TXD Clock High ( $\mathrm{N}>1$ ) | $2 \mathrm{~T}-35$ |  | ns | 1 |
| $\mathrm{T}_{\text {XHQX }}$ | RXD Output Data Hold after TXD Clock High ( $\mathrm{N}=1$ ) | T-35 |  | ns | 1 |
| TXHQZ | RXD Output Data Float after Last TXD Clock High |  | T+20 | ns | 1 |
| TDVXH | RXD Input Data Setup to TXD Clock High | T + 20 | . | ns | 1 |
| TXHDX | RXD Input Data Setup after TXD Clock High | 0 |  | ns | 1 |

## NOTES:

1. See Figure 15 for Waveforms.
2. $n$ is the value in the BxCMP register ignoring the ICLK bit.

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 9. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms for AC specification definitions, test pins and illustrations.


Figure 6. AC Test Load

## AC TIMING WAVEFORMS



Figure 7. Input and Output Clock Waveforms


Figure 8. Output Delay and Float Waveforms


272076-9
Figure 9. Input Setup and Hold


Figure 10. Relative Interrupt Signal Timings


Figure 11. Relative Signal Waveform


Figure 12. Serial Port Mode 0 Waveform

## DERATING CURVES



Figure 13. Typical Output Delay Variations vs Load Capacitance


Figure 14. Typical Rise and Fall Variations vs Load Capacitance

## RESET

The 80C188EC will perform a reset operation any time the RESIN pin is active. The RESIN pin is synchronized before it is presented internally, which means that the clock must be operating before a reset can take effect. From a power-on state, $\overline{\text { RESIN }}$ must be held active (low) in order to guarantee correct initialization of the 80C188EC. Failure to provide RESIN while the device is powering up will result in unspecified operation of the device.

Figure 15 shows the correct reset sequence when first applying power to the 80C188EC. An external clock connected to CLKIN must not exceed the $\mathrm{V}_{\mathrm{CC}}$ threshold being applied to the 80C188EC. This is normally not a problem if the clock driver is supplied with the same $\mathrm{V}_{\mathrm{CC}}$ that supplies the 80 C 188 EC . When attaching a crystal to the device, RESIN must remain active until both $\mathrm{V}_{\mathrm{CC}}$ and CLKOUT are stable (the length of time is application specific and depends on the startup characteristics of the crystal circuit). The RESIN pin is designed to operate cor-
rectly using a RC reset circuit, but the designer must ensure that the ramp time for $\mathrm{V}_{\mathrm{CC}}$ is not so long that $\overline{\text { RESIN }}$ is never sampled at a logic low level when $\mathrm{V}_{\mathrm{CC}}$ reaches minimum operating conditions.

Figure 16 shows the timing sequence when $\overline{\text { RESIN }}$ is applied after $\mathrm{V}_{\mathrm{CC}}$ is stable and the device has been operating. Note that a reset will terminate all activity and return the 80C188EC to a known operating state. Any bus operation that is in progress at the time $\overline{\text { RESIN }}$ is asserted will terminate immediately (note that most control signals will be driven to their inactive state first before floating).

While $\overline{\text { RESIN }}$ is active, bus signals LOCK, A19/S16/ONCE and A18:16 are configured as inputs and weakly held high by internal pullup transistors. Only A19/ONCE can be overdriven to a low and is used to enable the ONCETM Mode. Forcing LOCK or A18:16 low at any time while RESIN is low is prohibited and will cause unspecified device operation.

NOTE:
CLKOUT synchronization occurs on the rising edge of $\overline{\text { RESIN. If }} \overline{\text { RESIN }}$ is sampled high while CLKOUT is high (solid line), then CLKOUT will remain low for two CLKIN periods. If RESIN is sampled high while CLKOUT is low (dashed line), then CLKOUT will not be affected.

80C188EC-16,-13 ADVANCE UNFORNATION

## BUS CYCLE WAVEFORMS

Figures 17 through 29 present the various bus cycles that are generated by the 80C180EC. Whinat is shown in the figure is the relationship of the various
bus signals to CLKOUT. These figures along with the information present in Section 4.5, AC Specifications, allow the user to determine all the critical timing analysis neeuded for a given application.


Figure 17. Memory Read, I/O Read, Instruction Fetch and Refresh Waveform


Figure 18. Memory Write and I/O Write Cycle Waveform


Figure 19. Halt Cycle Waveform


Figure 20. Interrupt Acknowledge Cycle Waveform


Figure 21. HOLD/HLDA Cycle Waveforms


Figure 22. Refresh during HLDA Waveforms


Figure 23. Ready Cycle Waveforms

## REGISTER BIT SUMMARY

Figures 24 through 37 present the bit definition of each register that is active (not reserved) in the Pe ripheral Control Block (PCB). Each register can be thought to occupy one word (16-bits) of either memory or I/O space, although not all bits in the register necessarily have a function. A register bit is not guaranteed to return a specific logic value if an " $X$ "
appears for the bit definition (i.e., if a zero was written to the register bit it may not be returned as a zero when read). Furthermore, a 0 must be written to any bit that is indicated by an " $X$ " to ensure compatibility with future products or potential product changes. Any register bit that has a specific value in it (a " 0 " or a " 1 "), must be written to that value in order to guarantee proper operation of the 80C188EC.


272076-25
Figure 24. 8259A Module Initialization Command Words (ICWs)

Bit



Figure 25. 8259A Module Initialization Command Words (ICWs) (Continued)

| 0 | MO | $\begin{aligned} 0 & =\text { INPUT IS NOT MASKED } \\ 1 & =\text { INPUT IS MASKED }\end{aligned}$ |
| :---: | :---: | :---: |
| 1 | M1 |  |
| 2 | M2 |  |
| 3 | M3 |  |
| 4 | M4 |  |
| 5 | M5 |  |
| 6 | M6 |  |
| 7 | M7 |  |
| 8 | X |  |
| 9 | X |  |
| 0 | X |  |
| 1 | X |  |
| 2 | X |  |
| 3 | X |  |
| 14 | $X$ |  |
| 5 | X |  |
|  | $\begin{gathered} \mathrm{CO2H}, \\ \mathrm{~T}=\mathrm{XX} \end{gathered}$ |  |


| - | LO | - IR IEVEI To ACT ON <br> $001=$ NON SPECIFIC EOI $011=$ SPECIFIC EOI $101=$ ROTATE ON NS EOI $100=$ SET ROTATE $\operatorname{IN}$ AEOI $000=$ CLEAR ROTATE IN AEOI $111=$ ROTATE ON SPEC EOI $110=$ SET PRIORITY COMMAND $010=$ NO OPERATION |
| :---: | :---: | :---: |
| 1 | 1! |  |
| 2 | L2 |  |
| 3 | 0 |  |
| 4 | 0 |  |
| 5 | EOI |  |
| 6 | SL |  |
| 7 | R |  |
| 8 | $X$ |  |
| 9 | X |  |
| 10 | X |  |
| 11 | X |  |
| 12 | $X$ |  |
| 13 | $X$ |  |
| 14 | X |  |
| 15 | X |  |
|  | $\begin{aligned} & \mathrm{OOOH}, \\ & \mathrm{~T}=\mathrm{XX} \end{aligned}$ |  |



Figure 26. 8259A Module Operation Command Words




Figure 27. Interrupt Request Latch Registers

| BIt |  |  | Bit |  |  | Bit |  | Bit |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | WRO |  | 0 | WR 16 |  | 0 | WCO | 0 | WC16 |  |  |
| 1 | WR1 |  | 1 | WR17 |  | 1 | WC1 | 1 | WC17 |  |  |
| 2 | WR2 |  | 2 | WR18 |  | 2 | WC2 | 2 | WC18 |  |  |
| 3 | WR3 |  | 3 | WR19 |  | 3 | WC3 | 3 | WC19 |  |  |
| 4 | WR4 |  | 4 | WR20 |  | 4 | WC4 | 4 | WC20 |  |  |
| 5 | WR5 |  | 5 | WR21 |  | 5 | WC5 | 5 | WC21 |  |  |
| 6 | WR6 |  | 6 | WR22 |  | 6 | WC6 | 6 | WC22 |  |  |
| 7 | WR7 |  | 7 | WR23 |  | 7 | WC7 | 7 | WC23 |  |  |
| 8 | WR8 | RELOAD | 8 | WR24 | RELOAD | 8 | WC8 | (LOW) | WC24 | (HIGH) |  |
| 9 | WR9 | (LOW) | 9 | WR25 | (HIGH) | 9 | WC9 | 9 | WC25 |  |  |
| 10 | WR10 |  | 10 | WR26 |  | 10 | WC10 | 10 | WC26 |  |  |
| 11 | WR11 |  | 11 | WR27 |  | 11 | WC11 | 11 | WC27 |  |  |
| 12 | WR12 |  | 12 | WR28 |  | 12 | WC12 | 12 | WC28 |  |  |
| 13 | WR13 |  | 13 | WR29 |  | 13 | WC13 | 13 | WC29 |  |  |
| 14 | WR14 |  | 14 | WR30 |  | 14 | WC14 | 14 | WC30 |  |  |
| 15 | WR15 ] |  | 15 | WR31 |  | 15 | WC15 | 15 | WC3 1 |  |  |
|  | $\text { DTRLDL }(22 \mathrm{H})$ $\mathrm{ESET}=\mathrm{FFFFH}$ |  |  | $\begin{aligned} & \text { WDTRLDH (2OH) } \\ & \text { RESET }=0000 \mathrm{H} \end{aligned}$ |  |  | WDTCNTL (26H) <br> RESET $=$ FFFFH |  | WDTCNTH (24H) <br> RESET $=0000 \mathrm{H}$ |  | 272076-29 |

Figure 28. Watchdog Timer Registers


Figure 29. Timer Control Unit Registers


Figure 30. I/O Port Unit Registers


Figure 31. Serial Communications Unit Registers


Figure 32. Chip-Select Unit Registers


Figure 33. Refresh Control Unit Registers


272076-35
Figure 34. Power Management Unit Registers


Figure 35. DMA Unit Registers


Figure 36. DMA Unit Registers (Continued)


Figure 37. Relocation and Stepping Identifier Registers

## 80C188EC EXECUTION TIMINGS

A determination of 80 C 188 EC program execution timing must consider the bus cycles necessary to prefetch instructions as well as the number of execution unit cycles necessary to execute instructions. The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

- The opcode, along with any data or displacement required for execution of a particular instruction, has been prefetched and resides in the queue at the time it is needed.
- No wait states or bus HOLDs occur.
- All word-data is located on even-address boundaries.

All jumps and calls include the time required to fetch the opcode of the next instruction at the destination address.

All instructions which involve memory accesses can require one or two additional clocks above the minimum timings shown due to the asynchronous handshake between the bus interface unit (BIU) and execution unit.

INSTRUCTION SET SUMMARY


Shaded areas indicate instructions not available in 8086/8088 microsystems.

## NOTE:

*Clock cycles shown for byte transfers. For word transfers add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA TRANSFER (Continued) SEGMENT = Segment Override: |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
| CS | 00101110 |  |  |  | 2 |  |
| SS | 00110110 |  |  |  | 2 |  |
| DS | 00111110 |  |  |  | 2 |  |
| ES | 00100110 |  |  |  | 2 |  |
| $\begin{aligned} & \text { ARITHMETIC } \\ & \text { ADD = Add: } \end{aligned}$ |  |  |  |  |  |  |
| Reg/memory with register to either | 000000 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate to register/memory | 100000sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16* |  |
| Immediate to accumulator | 0000010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| ADC = Add with carry: |  |  |  |  |  |  |
| Reg/memory with register to either | 000100 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate to register/memory | 100000sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16* |  |
| Immediate to accumulator | 0001010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| INC = Increment: |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 3/15* |  |
| Register | 01000 reg |  |  |  | 3 |  |
| SUB = Subtract: |  |  |  |  |  |  |
| Reg/memory and register to either | 001010 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate from register/memory | 100000sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathbf{s} \mathbf{w}=01$ | 4/16* |  |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| SBB = Subtract with borrow: |  |  |  |  |  |  |
| Reg/memory and register to either | 000110 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate from register/memory | 100000sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 4/16* |  |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| DEC = Decrement |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 3/15* |  |
| Register | 01001 reg |  |  |  | 3 |  |
| CMP = Compare: |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | mod reg r/m |  |  | 3/10* |  |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 3/10* |  |
| Immediate with register/memory | 100000 sw | $\bmod 111 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 3/10* |  |
| Immediate with accumulator | 0011110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NEG = Change sign register/memory | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | 3/10* |  |
| AAA $=$ ASCll adjust for add | 00110111 |  |  |  | 8 |  |
| DAA = Decimal adjust for add | 00100111 |  |  |  | 4 |  |
| AAS $=$ ASCII adjust for subtract | 00111111 |  |  |  | 7 |  |
| DAS = Decimal adjust for subtract | 00101111 |  |  |  | 4 |  |
| MUL = Multiply (unsigned): | 1111011 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Register-Byte |  |  |  |  | 26-28 |  |
| Register-Word |  |  |  |  | 35-37 |  |
| Memory-Byte |  |  |  |  | 32-34 |  |
| Memory-Word |  |  | , |  | 41-43* |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

## NOTE:

*Clock cycles shown for byte transfers. For word transfers add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.
NOTE:
*Clock cycles shown for byte transfers. For word transfers add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)

| Function | Format |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LOGIC (Continued) XOR = Exclusive or: |  |  |  |  |  |  |
| Reg/memory and register to either | 001100 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate to register/memory | 1000000 w | $\bmod 110 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ | 4/16* |  |
| Immediate to accumulator | 0011010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NOT = Invert register/memory | 1111011 w | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  | 3/10* |  |
| STRING MANIPULATION |  |  |  |  |  |  |
| MOVS $=$ Move byte/word | 1010010 w |  |  |  | 14* |  |
| CMPS = Compare byte/word | 1010011 w |  |  |  | 22* |  |
| SCAS = Scan byte/word | 1010111 w |  |  |  | 15* |  |
| LODS = Load byte/wd to AL/AX | 1010110 w |  |  |  | 12* |  |
| STOS $=$ Store byte/wd from AL/AX | 1010101 w |  |  |  | 10* |  |
| Mis = Input byte/wd from DX port outs = Cutput byte/ wd to Dx port | $\frac{0110110 \mathrm{w}}{0110111 \mathrm{w}}$ |  |  |  | $\begin{aligned} & 14 \\ & 14 \end{aligned}$ |  |
| Repeated by count in CX (REP/REPE/REPZ/REPNE/REPNZ) |  |  |  |  |  |  |
| MOVS = Move string | 11110010 | 1010010 w |  |  | $8+8{ }^{*}$ |  |
| CMPS = Compare string | 11110012 | 1010011 w |  |  | $5+22 n^{*}$ |  |
| SCAS $=$ Scan string | 1111001 z | 1010111 w |  |  | $5+15{ }^{*}$ |  |
| LODS = Load string | 11110010 | 1010110 w |  |  | $6+11{ }^{*}$ |  |
| STOS $=$ Store string | 11110010 | 1010101 w |  |  | $6+9{ }^{*}$ |  |
| HS $=$ Input string <br> ours = Dutput string | $\frac{11110010}{11110010}$ | $\frac{0110110 \mathrm{w}}{0110111 \mathrm{w}}$ |  |  | $\begin{aligned} & 8+8 n^{*} \\ & 8+8 n^{*} \end{aligned}$ |  |
| CONTROL TRANSFER |  | CALL = Call: |  |  |  |  |
| Direct within segment | 11101000 | disp-low | disp-high |  | 19 | ' |
| Register/memory indirect within segment | 11111111 | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  | 17/27 |  |
| Direct intersegment | 10011010 | segme | ffset |  | 31 |  |
|  |  | segmen | lector |  |  |  |
| Indirect intersegment | 11111111 | $\bmod 011 \mathrm{r} / \mathrm{m}$ | $(\bmod \neq 11)$ |  | 54 |  |
| JMP = Unconditional jump: |  |  |  |  |  |  |
| Short/long | 11101011 | disp-low |  |  | 14 |  |
| Direct within segment | 11101001 | disp-low | disp-high |  | 14 |  |
| Register/memory indirect within segment | 11111111 | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  | 11/21 |  |
| Direct intersegment | 11101010 | segment offset |  |  | 14 |  |
|  |  | segment selector |  |  |  |  |
| Indirect intersegment | 11111111 | $\bmod 101 \mathrm{r} / \mathrm{m}$ | $(\bmod \neq 11)$ |  | 34 |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

## NOTE:

*Clock cycles shown for byte transfers. For word transfers add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086/8088 microsystems.

## NOTE:

*Clock cycles shown for byte transfers. For word transfers add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)

| Function |  | Format | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PROCESSON CONTİOL |  |  |  |  |
| $C L C=$ Clear carry | 11111000 |  | 2 |  |
| CMC = Complement carry | 11110101 |  | 2 |  |
| STC = Set carry | 11111001 |  | 2 |  |
| CLD = Clear direction | 11111100 |  | 2 |  |
| STD $=$ Set direction | 11111101 |  | 2 |  |
| CLI = Clear interrupt | 11111010 |  | 2 |  |
| STI $=$ Set interrupt | 11111011 |  | 2 |  |
| HLT $=$ Halt | 11110100 |  | 2 |  |
| WAIT $=$ Wait | 10011011 |  | 6 | if $\overline{\text { TEST }}=0$ |
| LOCK = Bus lock prefix | 11110000 |  | 2 |  |
| NOP $=$ No Operation | 10010000 |  | 3 |  |
| (TTT LLL are opcode to processor extension) |  |  |  |  |

Shaded areas indicate instructions not available in 8086/8088 microsystems.

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if $\mathrm{mod}=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
if mod $=00$ then DISP $=0^{*}$, disp-low and disphigh 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 $\mathrm{EA}=(\mathrm{BX})+(\mathrm{SI})+\mathrm{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)+D I S P$
if $\mathrm{r} / \mathrm{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 $\mathrm{r} / \mathrm{m}=101$ then $E A=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $\mathrm{EA}=(\mathrm{BP})+$ DISP* $^{*}$
if $\mathrm{r} / \mathrm{m}=111$ then $\mathrm{EA}=(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.

EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

## Segment Override Prefix

| 0 | 0 | 1 | reg | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

reg is assigned according to the following:

| reg | Segment <br> Register |
| :---: | :---: |
| 00 | ES |
| 01 | CS |
| 10 | SS |
| 11 | DS |

REG is assigned according to the following table:

| $\mathbf{1 6 - B i t}(\mathbf{w}=\mathbf{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.

■ 3V Operation, $\mathrm{V}_{\mathrm{Cc}}=2.7 \mathrm{~V}-5.5 \mathrm{~V}$

- Full Static Operation
- True CMOS Inputs and Outputs
- Integrated Feature Set
- Static 186 CPU Core
- Power Save, Idle and Powerdown Modes
- Clock Generator
- 2 Independent DMA Channels
- 3 Programmable 16-Bit Timers
- Dynamic RAM Refresh Control Unit
- Programmable Memory and Peripheral Chip Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- System-Level Testing Support (High Impedance Test Mode)
■ Speed Versions Available:
- 13 MHz (80L188EA13)
- 8 MHz (80L188EA8)
- Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Complete System Development Support
- All 8086/8088 and 80C188 Family Software Development Tools Can Be Used for 80L188EA System Development
- ASM86 Assembler, iC-86, Pascal-86, FORTRAN-86, PL/M-86, and System Utilities - In-Circuit-Emulator (ICETM-186)
- Available in the Following Packages: -68-Pin Plastic Leaded Chip Carrier (PLCC)
- 80-Pin EIAJ Quad Flat Pack (QFP)
- Available in EXPRESS Extended Temperature Range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

The 80L188EA is the $3 V$ version of the 80C188EA Embedded Processor. By reducing $V_{C C}$, further power savings can be realized over the standard 80C188EA, making the 80L188EA ideal for portable, battery-powered applications.


## INTRODUCTION

The 80L188EA is the second member of the 186 Integrated Processor Family to go to 3 V operation, following the 80L188EB. The 80L188EA is the 3 V version of the 80C188EA. The 80L188EA is functionally compatible with the industry standard 80C188 embedded processor. Current 80C188 users can easily upgrade their designs to use the 80L188EA and benefit from the reduced power consumption of 3 V operation.

The feature set of the 80L188EA meets the needs of battery-powered applications. Battery-powered applications benefit from the static CPU core and peripherals. Minimum current consumption is achieved by combining low voltage operation along with the features of the Power Management Unit, thus maximizing battery life. Peripheral design enhancements ensure that non-initialized peripherals consume little current.

Space-critical applications benefit from the integration of commonly used system peripherals. Two flexible DMA channels perform CPU-independent data transfers. A flexible chip select unit simplifies memory and peripheral interfacing. The interrupt unit provides sources for up to 128 external interrupts and will prioritize these interrupts with those generated from the on-chip peripherals. Three general purpose timer/counters round out the feature set of the 80L188EA.

## OVERVIEW

Figure 1 shows a block diagram of the 80 L 188 EA . The Execution Unit (EU) is an enhanced 8086 CPU core that includes: dedicated hardware to speed up effective address calculations, enhance execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instructions, and static operation. The Bus Interface Unit (BIU) is the same as that found on the original 80 C 188 family products. An independent internal bus is used to allow communication between the BIU and internal peripherals.

## Pinout Compatibility

The 80L188EA requires a PDTMR pin to time the processor's exit from Powerdown Mode. The original pin arrangement for the 80C188 in the PLCC package did not have any spare leads to use for PDTMR, so the $D T / \bar{R}$ pin was sacrificed. The arrangement of all the other leads in the 68-lead PLCC is identical between the 80C188 and the 80L188EA. DT/雷 may be readily synthesized by latching the $\overline{\mathrm{S} 1}$ status output. Therefore, upgrading a PLCC 80C188 to PLCC

80L188EA is particularly straightforward. You must connect a capacitor to the 80L188EA PDTMR pin in order to use Powerdown Mode.

The 80-lead QFP (EIAJ) pinouts are distinctly different between the 80C188 and the 80L188EA. In addition to the PDTMR pin, the 80L188EA has more power and ground pins and the overall arrangement of pins was shifted. A new circuit board layout for the 80L188EA is required.

## Operating Modes

The 80C188 has two operating modes, Compatible and Enhanced. Compatible Mode is a pin-to-pin replacement for the NMOS 80188, except for numerics coprocessing. In Enhanced Mode, the processor has a Refresh Control Unit and the Power-Save feature. The 80L188EA does not have different operating modes. All 80L188EA features are present in regular operation.

## PACKAGE INFORMATION

This section describes the pins, pinouts, and thermal characteristics for the 80L188EA in the Plastic Leaded Chip Carrier (PLCC) package and Quad Flat Pack (QFP) package. For complete package specifications and information, see the Intel Packaging Outlines and Dimensions Guide (Order Number: 231369).

## Pin Descriptions

Each pin or logical set of pins is described in Table 2. There are three columns for each entry in the Pin

The Pin Name column contains a mnemonic that describes the pin function. Negation of the signal name (for example, RESIN) denotes a signal that is active low.

The Pin Type column contains two kinds of information. The first symbol indicates whether a pin is power (P), ground (G), input only (I), output only ( O ) or input/output (I/O). Some pins have multiplexed functions (for example, A19/S6). Additional symbols indicate additional characteristics for each pin. Table 4 lists all the possible symbols for this column.

Input pins may be either synchronous or asynchronous. Asynchronous pins require that setup and hold times be met only in order to guarantee recognition at a particular clock edge. Synchronous pins require that setup and hold times be met to guarantee proper operation. For example, missing the setup or hold time for the SRDY pin (a synchronous input) will re-
sult in a system failure or lockup. Input pins may also be edge- or level-sensitive. The possible characteristics for input pins are $S(E), S(L), A(E)$ and $A(L)$.

Output states are dependent upon the current activity of the processor. There are four operational states that are different from regular operation: bus hold, reset, Idle Mode, and Powerdown Mode. Appropriate characteristics for these states are also indicated in this column, with the legend for all possible characteristics in Table 1.

Finally, the Pin Description column contains a text description of each pin.

As an example, consider AD7:0. I/O signifies the pins are bidirectional. $\mathrm{S}(\mathrm{L})$ signifies that the input function is synchronous and level-sensitive. $H(Z)$ signifies that, as outputs, the pins are high-impedance upon acknowledgement of bus hold. $\mathrm{R}(\mathrm{Z})$ signifies that the pins float during reset. $P(X)$ signifies that the pins retain their states during Powerdown Mode.

Table 1. Pin Description Nomenclature

| Symbol | Description |
| :---: | :---: |
| $\begin{aligned} & P \\ & G \\ & \mathrm{I} \\ & \mathrm{O} \\ & \mathrm{I} / \mathrm{O} \end{aligned}$ | Power Pin (Apply $+\mathrm{V}_{\mathrm{CC}}$ Voltage) <br> Ground (Connect to $\mathrm{V}_{\mathrm{SS}}$ ) <br> Input Only Pin <br> Output Only Pin <br> Input/Output Pin |
| $\begin{aligned} & \mathrm{S}(\mathrm{E}) \\ & \mathrm{S}(\mathrm{~L}) \\ & \mathrm{A}(\mathrm{E}) \\ & \mathrm{A}(\mathrm{~L}) \\ & \hline \end{aligned}$ | Synchronous, Edge Sensitive Synchronous, Level Sensitive Asynchronous, Edge Sensitive Asynchronous, Level Sensitive |
| $\begin{aligned} & H(1) \\ & H(0) \\ & H(Z) \\ & H(Q) \\ & H(X) \\ & \hline \end{aligned}$ | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Bus Hold <br> Output Driven to VSs during Bus Hold <br> Output Floats during Bus Hold <br> Output Remains Active during Bus Hold <br> Output Retains Current State during Bus Hold |
| $\begin{aligned} & \mathrm{R}(\mathrm{WH}) \\ & \mathrm{R}(1) \\ & \mathrm{R}(0) \\ & \mathrm{R}(\mathrm{Z}) \\ & \mathrm{R}(\mathrm{Q}) \\ & \mathrm{R}(\mathrm{X}) \\ & \hline \end{aligned}$ | Output Weakly Held at $\mathrm{V}_{\mathrm{CC}}$ during Reset <br> Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Reset <br> Output Driven to $\mathrm{V}_{\mathrm{SS}}$ during Reset <br> Output Floats during Reset <br> Output Remains Active during Reset <br> Output Retains Current State during Reset |
| I(1) <br> I(0) <br> I(Z) <br> I(Q) <br> I(X) | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Idle Mode <br> Output Driven to $\mathrm{V}_{\text {SS }}$ during Idle Mode <br> Output Floats during Idle Mode <br> Output Remains Active during Idle Mode <br> Output Retains Current State during Idie Mode |
| $P(1)$ <br> $P(0)$ <br> $P(Z)$ <br> $P(Q)$ <br> $P(X)$ | Output Driven to $\mathrm{V}_{\mathrm{CC}}$ during Powerdown Mode <br> Output Driven to $\mathrm{V}_{\text {SS }}$ during Powerdown Mode <br> Output Floats during Powerdown Mode <br> Output Remains Active during Powerdown Mode <br> Output Retains Current State during Powerdown Mode |

Table 2. 80L188EA Pin Descriptions

| Name | Type | Description |
| :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ |  | POWER connections consist of six pins which must be shorted externally to a $\mathrm{V}_{\mathrm{CC}}$ board plane. |
| $\mathrm{V}_{\mathrm{SS}}$ |  | GROUND connections consist of five pins which must be shorted externally to a $V_{\text {SS }}$ board plane. |
| CLKIN | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | CLocK INput is an input for an external clock. An external oscillator operating at two times the required 80L188EA operating frequency can be connected to CLKIN. For crystal operation, CLKIN (along with OSCOUT) are the crystal connections to an internal Pierce oscillator. |
| OSCOUT | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(\mathrm{Q}) \\ \mathrm{P}(\mathrm{Q}) \end{gathered}$ | OSCillator OUTput is only used when using a crystal to generate the external clock. OSCOUT (along with CLKIN) are the crystal connections to an internal Pierce oscillator. This pin is not to be used as 2 X clock output for non-crystal applications (i.e., this pin is N.C. for non-crystal applications). OSCOUT does not float in ONCE mode. |
| CLKOUT | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(\mathrm{Q}) \\ \mathrm{P}(\mathrm{Q}) \\ \hline \end{gathered}$ | CLocK OUTput provides a timing reference for inputs and outputs of the processor, and is one-half the input clock (CLKIN) frequency. CLKOUT has a $50 \%$ duty cycle and transistions every falling edge of CLKIN. |
| $\overline{\text { RESIN }}$ | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | RESet IN causes the 80L188EA to immediately terminate any bus cycle in progress and assume an initialized state. All pins will be driven to a known state, and RESOUT will also be driven active. The rising edge (low-to-high) transition synchronizes CLKOUT with CLKIN before the 80L188EA begins fetching opcodes at memory location OFFFFOH. |
| RESOUT | $\begin{gathered} O \\ H(0) \\ R(1) \\ P(0) \\ \hline \end{gathered}$ | RESet OUTput that indicates the 80L188EA is currently in the reset state. RESOUT will remain active as long as $\overline{\text { RESIN }}$ remains active. |
| PDTMR | 1/O <br> A(L) <br> H(WH) <br> $R(Z)$ <br> $P(1)$ | Power-Down TiMeR pin (normally connected to an external capacitor) that determines the amount of time the 80L188EA waits after an exit from power down before resuming normal operation. The duration of time required will depend on the startup characteristics of the crystal oscillator. |
| NMI | $\begin{gathered} 1 \\ A(E) \end{gathered}$ | Non-Maskable Interrupt input causes a Type 2 interrupt to be serviced by the CPU. NMI is latched internally. |
| $\overline{\text { TEST }}$ | $\begin{gathered} 1 \\ A(E) \\ \hline \end{gathered}$ | TEST is used during the execution of the WAIT instruction to suspend CPU operation until the pin is sampled active (low). |
| AD7:0 | I/O <br> S(L) <br> H(Z) <br> R(Z) <br> $P(X)$ | These pins provide a multiplexed Address and Data bus. During the address phase of the bus cycle, address bits 0 through 15 are presented on the bus and can be latched using ALE. 8 - or 16 -bit data information is transferred during the data phase of the bus cycle. |
| A15:8 | 0 <br> H(Z) <br> R(Z) <br> $P(Z)$ | These pins provide Address information throughout the entire bus cycle. |
| $\begin{aligned} & \text { A18:16 } \\ & \text { A19/S6 } \end{aligned}$ | $\begin{aligned} & H(Z) \\ & R(Z) \\ & P(X) \end{aligned}$ | These pins provide multiplexed Address during the address phase of the bus cycle. Address bits 16 through 19 are presented on these pins and can be latched using ALE. A18:16 are driven to a logic 0 during the data phase of the bus cycle. Also during the data phase, S 6 is driven to a logic 0 to indicate a CPU-initiated bus cycle or logic 1 to indicate a DMA-initiated bus cycle or a refresh cycle. |

80L188EA-13, - 8

Table 2. 80L188EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| 32:0 | 0 <br> H(Z) <br> R(Z) <br> $P(1)$ | Bus cycie Status are encouded onit these pinis to provide bus trañaction information. S2:0 are encoded as follows: |
| ALE/QSO | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(0) \\ \mathrm{R}(0) \\ \mathrm{P}(0) \\ \hline \end{gathered}$ | Address Latch Enable output is used to strobe address information into a transparent type latch during the address phase of the bus cycle. In Queue Status Mode, QS0 provides queue status information along with QS1. |
| $\overline{\mathrm{RFSH}}$ | $\begin{gathered} O \\ H(Z) \\ R(Z) \\ P(1) \end{gathered}$ | ReFreSH output signals that a refresh cycle is in progress. |
| $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{P}(1) \end{gathered}$ | ReaD output signals that the accessed memory or I/O device must drive data information onto the data bus. Upon reset, this pin has an alternate function. As QSMD, it enables Queue Status Mode when grounded. In Queue Status Mode, the ALE/QS0 and WR/QS1 pins provide the following information about processor/instruction queue interaction: |
| WR/QS1 | $\begin{gathered} 0 \\ H(Z) \\ R(Z) \\ P(1) \\ \hline \end{gathered}$ | WRite output signals that data available on the data bus are to be written into the accessed memory or I/O device. In Queue Status Mode, QS1 provides queue status information along with QSO. |
| ARDY | $\begin{aligned} & 1 \\ & A(L) \\ & S(L) \end{aligned}$ | Asychronous ReaDY is an input to signal for the end of a bus cycle. ARDY is asynchronous on rising CLKOUT and synchronous on falling CLKOUT. ARDY or SRDY must be active to terminate any 80L188EA bus cycle, unless they are ignored due to correct programming of the Chip Select Unit. |
| SRDY | $\begin{gathered} 1 \\ S(L) \end{gathered}$ | Synchronous ReaDY is an input to signal for the end of a bus cycle. ARDY or SRDY must be active to terminate any 80L188EA bus cycle, unless they are ignored due to correct programming of the Chip Select Unit. |
| $\overline{\text { DEN }}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{Z}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | Data ENable output to control the enable of bidirectional transceivers when buffering an 80L188EA system. DEN is active only when data is to be transferred on the bus. |

Table 2. 80L188EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| DT/ $\overline{\mathrm{R}}$ | 0 <br> $H(Z)$ <br> R(Z) <br> $P(X)$ | Data Transmit/Receive output controls the direction of a bi-directional buffer when buffering an 80L188EA system. DT/ $\overline{\mathrm{R}}$ is only available for the QFP (EIAJ) package (S80L188EA). |
| LOCK | $\begin{gathered} \mathrm{I} O \\ \mathrm{H}(\mathrm{Z}) \\ \mathrm{R}(\mathrm{WH}) \\ \mathrm{P}(1) \\ \hline \end{gathered}$ | LOCK output indicates that the bus cycle in progress is not to be interrupted. The 80L188EA will not service other bus requests (such as HOLD) while LOCK is active. This pin is configured as a weakly held high input while RESIN is active and must not be driven low. |
| HOLD | $\begin{gathered} 1 \\ A(L) \end{gathered}$ | HOLD request input to signal that an external bus master wishes to gain control of the local bus. The 80L188EA will relinquish control of the local bus between instruction boundảries not conditioned by a LOCK prefix. |
| HLDA | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(0) \\ \mathrm{P}(0) \\ \hline \end{gathered}$ | HoLD Acknowledge output to indicate that the 80L188EA has relinquish control of the local bus. When HLDA is asserted, the 80L188EA will (or has) floated its data bus and control signals allowing another bus master to drive the signals directly. |
| $\overline{U C S}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(1) \\ \mathrm{R}(1) \\ \mathrm{P}(1) \end{gathered}$ | Upper Chip Select will go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. After reset, UCS is configured to be active for memory accesses between OFFCOOH and OFFFFFH. During a processor reset, $\overline{U C S}$ and $\overline{\mathrm{LCS}}$ are used to enable ONCE Mode. |
| $\overline{\text { LCS }}$ | $\begin{gathered} O \\ H(1) \\ R(1) \\ P(1) \end{gathered}$ | Lower Chip Select will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. $\overline{\mathrm{LCS}}$ is inactive after a reset. During a processor reset, $\overline{U C S}$ and $\overline{\mathrm{LCS}}$ are used to enable ONCE Mode. |
| $\overline{\text { MCS3:0 }}$ | $\begin{gathered} O \\ H(1) \\ R(1) \\ P(1) \\ A(L) \end{gathered}$ | If enabled, these pins comprise a block of Mid-Range Chip Select outputs which will go active whenever the address of a memory bus cycle is within the address limitations programmed by the user. |
| $\overline{\text { PCS4:0 }}$ | $\begin{gathered} O \\ H(1) \\ R(1) \\ P(1) \end{gathered}$ | Peripheral Chip Selects go active whenever the address of a memory or I/O bus cycle is within the address limitations programmed by the user. |
| $\begin{aligned} & \overline{\overline{\mathrm{PCS5}} / \mathrm{A} 1} \\ & \overline{\mathrm{PCS}} / \mathrm{A} 2 \end{aligned}$ | $\begin{gathered} \hline 0 \\ H(1) / H(X) \\ R(1) \\ P(1) \end{gathered}$ | These pins provide a multiplexed function. As additional Peripheral Chip Selects, they go active whenever the address of a memory or I/O bus cycle is within the address limitations by the user. They may also be programmed to provide latched Address A2:1 signals. |
| $\begin{aligned} & \text { TOOUT } \\ & \text { T10UT } \end{aligned}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{H}(\mathrm{Q}) \\ \mathrm{R}(1) \\ \mathrm{P}(\mathrm{Q}) \end{gathered}$ | Timer OUTput pins can be programmed to provide a single clock or continuous waveform generation, depending on the timer mode selected. |
| TOIN <br> TIIN | $\begin{gathered} \hline 1 \\ \text { A(L) } \\ \text { A(E) } \end{gathered}$ | Timer INput is used either as clock or control signals, depending on the timer mode selected. |

Table 2. 80L188EA Pin Descriptions (Continued)

| Name | Type | Description |
| :---: | :---: | :---: |
| $\begin{aligned} & \text { DRQO } \\ & \text { DRQ1 } \end{aligned}$ | $\begin{gathered} \vdots \\ A(L) \end{gathered}$ | DIMA ReQuest is asserted by an external request when it is propared for a DMA transfer. |
| INTO <br> INT1/SELECT | $\stackrel{I}{A(E, L)}$ | Maskable INTerrupt input will cause a vector to a specific Type interrupt routine. To allow interrupt expansion, INT0 and/or INT1 can be used with $\overline{\mathbb{1 N T A O}}$ and $\overline{\mathrm{NT} T A 1}$ to interface with an external slave controller. INT1 becomes SELECT when the ICU is configured for Slave Mode. |
| INT2//्NTAO <br> INT3//NTA1/IRQ | $\begin{gathered} \hline I / O \\ A(E, L) \\ / H(1) \\ R(Z) \\ / P(1) \\ \hline \end{gathered}$ | These pins provide multiplexed functions. As inputs, they provide a maskable INTerrupt that will cause the CPU to vector to a specific Type interrupt routine. As outputs, each is programmatically controlled to provide an INTerrupt Acknowledge handshake signal to allow interrupt expansion. INT3//्NTA1 becomes IRQ when the ICU is configured for Slave Mode. |
| N.C. | - | No Connect. For compatibility with future products, do not connect to these pins. |

## 80L188EA PINOUT

Tables 3 and 4 list the 80L188EA pin names with package location for the 68 -pin Plastic Leaded Chip Carrier (PLCC) component. Figure 2 depicts the complete 80L188EA pinout (PLCC package) as viewed from the top side of the component (i.e., contacts facing down).

Tables 5 and 6 list the 80L188EA pin names with package location for the 80 -pin Quad Flat Pack (EIAJ) component. Figure 3 depicts the complete 80L188EA (EIAJ QFP package) as viewed from the top side of the component (i.e., contacts facing down).

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 17 |
| AD1 | 15 |
| AD2 | 13 |
| AD3 | 11 |
| AD4 | 8 |
| AD5 | 6 |
| AD6 | 4 |
| AD7 | 2 |
| A8 | 16 |
| A9 | 14 |
| A10 | 12 |
| A11 | 10 |
| A12 | 7 |
| A13 | 5 |
| A14 | 3 |
| A15 | 1 |
| A16 | 68 |
| A17 | 67 |
| A18 | 66 |
| A19/S6 | 65 |

Table 3. PLCC Pin Names with Package Location

| Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: |
| Name | Location | Name | Location |
| ALE/QSO | 61 | $\overline{\text { RESIN }}$ | 24 |
| $\overline{\text { RFSH }}$ | 64 | RESOUT | 57 |
| $\overline{\text { So }}$ | 52 | CLKIN | 59 |
| $\overline{\text { S1 }}$ | 53 | OSCOUT | 58 |
| S2 | 54 | CLKOUT | 56 |
| $\overline{\mathrm{RD}} / \overline{\text { QSMD }}$ | 62 | TEST | 47 |
| WR/QS1 | 63 | PDTMR | 40 |
| ARDY | 55 | NMI | 46 |
| SRDY | 49 | INTO | 45 |
| $\overline{\mathrm{DEN}}$ | 39 | INT1/SELECT | 44 |
| LOCK | 48 | INT2/INTAO | 42 |
| HOLD | 50 | INT3/INTA1/ | 41 |
| HLDA | 51 | IRQ |  |


| 1/0 |  |
| :---: | :---: |
| Name | Location |
| $\overline{\text { UCS }}$ | 34 |
| LCS | 33 |
| $\overline{\text { MCSO }}$ | 38 |
| MCS1 | 37 |
| $\overline{\mathrm{MCS}} 2$ | 36 |
| $\overline{\text { MCS3 }}$ | 35 |
| PCSO | 25 |
| PCS1 | 27 |
| PCS2 | 28 |
| $\overline{\text { PCS3 }}$ | 29 |
| PCS4 | 30 |
| PCS5/A1 | 31 |
| $\overline{\text { PCS6/A2 }}$ | 32 |
| TOOUT | 22 |
| TOIN | 20 |
| T10UT | 23 |
| T1IN | 21 |
| DRQ0 | 18 |
| DRQ1 | 19 |

Table 4. PLCC Package Locations with Pin Name

| Location | Name |
| :---: | :--- |
| 1 | A15 |
| 2 | AD7 |
| 3 | A14 |
| 4 | AD6 |
| 5 | A13 |
| 6 | AD5 |
| 7 | A12 |
| 8 | AD4 |
| 9 | VCC |
| 10 | A11 |
| 11 | AD3 |
| 12 | A10 |
| 13 | AD2 |
| 14 | A9 |
| 15 | AD1 |
| 16 | A8 |
| 17 | ADO |


| Location | Name |
| :---: | :--- |
| 18 | DRQ0 |
| 19 | DRQ1 |
| 20 | TOIN |
| 21 | T1IN |
| 22 | TOOUT |
| 23 | T1OUT |
| 24 | $\overline{\text { RESIN }}$ |
| 25 | $\overline{\text { PCS0 }}$ |
| 26 | V SS |
| 27 | $\overline{\text { PCS1 }}$ |
| 28 | $\overline{\text { PCS2 }}$ |
| 29 | $\overline{\text { PCS3 }}$ |
| 30 | $\overline{\text { PCS4 }}$ |
| 31 | $\overline{\text { PCS5/A1 }}$ |
| 32 | $\overline{\text { PCS6/A2 }}$ |
| 33 | $\overline{\text { LCS }}$ |
| 34 | $\overline{U C S}$ |


| Location | Name |
| :---: | :--- |
| 35 | $\overline{\text { MCS3 }}$ |
| 36 | $\overline{\text { MCS2 }}$ |
| 37 | $\overline{M C S 1}$ |
| 38 | $\overline{M C S 0}$ |
| 39 | $\overline{\mathrm{DEN}}$ |
| 40 | PDTMR |
| 41 | INT3/INTA1/ |
|  | IRQ |
| 42 | INT2/INTAO |
| 43 | VCC |
| 44 | INT1/SELECT |
| 45 | INTO |
| 46 | NMI |
| 47 | $\overline{\text { TEST }}$ |
| 48 | LOCK |
| 49 | SRDY |
| 50 | HOLD |
| 51 | HLDA |


| Location | Name |
| :---: | :--- |
| 52 | $\overline{S 0}$ |
| 53 | $\overline{\mathrm{~S} 1}$ |
| 54 | $\overline{\mathrm{~S} 2}$ |
| 55 | ARDY |
| 56 | CLKOUT |
| 57 | RESOUT |
| 58 | OSCOUT |
| 59 | CLKIN |
| 60 | $\overline{\mathrm{SS}}$ |
| 61 | ALE/QSO |
| 62 | $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ |
| 63 | $\overline{\mathrm{WR}} / \mathrm{QS} 1$ |
| 64 | $\overline{\mathrm{RFSH}}$ |
| 65 | A19/S6 |
| 66 | A18 |
| 67 | A17 |
| 68 | A16 |



NOTE:
The nine-character alphanumeric code (XXXXXXXXA) underneath the product number is the intel FPO number.
Figure 2. 68-Lead PLCC Pinout Diagram

Table 5. QFP (EIAJ) Pin Name with Package Location

| Address/Data Bus |  | Bus Control |  | Processor Control |  | 1/0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Ṅame | Location | Niame | Location | Name | Location | Niame | Location |
| ADO | 64 | ALE/QSO | 10 | $\overline{\text { RESIN }}$ | 55 | UCS | 45 |
| AD1 | 66 | $\overline{\text { RFSH }}$ | 7 | RESOUT | 18 | LCS | 46 |
| AD2 | 68 | $\overline{\text { S0 }}$ | 23 | CLKIN | 16 | $\overline{\mathrm{MCSO}}$ | 40 |
| AD3 | 70 | S1 | 22 | OSCOUT | 17 | $\overline{\text { MCS1 }}$ | 41 |
| AD4 | 74 | S2 | 21 | CLKOUT | 19 | $\overline{\text { MCS2 }}$ | 42 |
| AD5 | 76 | RD/QSMD | 9 | TEST | 29 | $\overline{\mathrm{MCS3}}$ | 43 |
| AD6 | 78 | WR/QS1 | 8 | PDTMR | 38 | $\overline{\text { PCSO }}$ | 54 |
| AD7 | 80 | ARDY | 20 | NMI | 30 | $\overline{\text { PCS1 }}$ | 52 |
| A8 | 65 | SRDY | 27 | INTO | 31 | $\overline{\text { PCS2 }}$ | 51 |
| A9 | 67 | DT/ $\overline{\mathrm{R}}$ | 37 | INT1/SELECT | 32 | $\overline{\mathrm{PCS3}}$ | 50 |
| A10 | 69 | $\overline{\text { DEN }}$ | 39 | INT2/INTAO | 35 | $\overline{\text { PCS4 }}$ | 49 |
| A11 | 71 | $\overline{\text { DEN }}$ | 28 | INT3/\/NTA1/ | 36 | PCS5/A1 | 48 |
| A12 | 75 | LOCK | 28 | IRQ |  | PCS6/A2 | 47 |
| A13 | 77 | HOLD | 26 | N.C. | 11, 14, | TOOUT | 57 |
| A14 | 79 | HLDA | 25 |  | 15,63 | TOIN | 59 |
| A15 | 1 |  |  |  |  | T1OUT | 56 |
| A16 | 3 | Power |  |  |  | TIIN | 58 |
| A17 | 4 | Name | Location |  |  | DRQ0 | 61 |
| A18 <br> A19/S6 | 5 | $\mathrm{V}_{\mathrm{SS}}$ | $\text { 12. 13. } 24 .$ |  |  | DRQ1 | 60 |
| A19/S6 | 6 |  | $\begin{gathered} 12,13,24 \\ 53,62 \\ 2,33,34 \\ 44,72,73 \end{gathered}$ |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}$ |  |  |  |  |  |
|  |  |  |  |  |  |  |  |

Table 6. QFP (EIAJ) Package Location with Pin Names

| Location | Name |
| :---: | :--- |
| 1 | A 15 |
| 2 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 3 | A 16 |
| 4 | A 17 |
| 5 | A 18 |
| 6 | $\mathrm{~A} 19 / \mathrm{S} 6$ |
| 7 | $\overline{\mathrm{RFSH}}$ |
| 8 | $\overline{\mathrm{WR} / Q S 1}$ |
| 9 | $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ |
| 10 | $\mathrm{ALE} / \mathrm{QSO}$ |
| 11 | $\mathrm{~N} . \mathrm{C}$. |
| 12 | VSS |
| 13 | VSS |
| 14 | N.C. |
| 15 | N.C. |
| 16 | CLKIN |
| 17 | OSCOUT |
| 18 | RESOUT |
| 19 | CLKOUT |
| 20 | ARDY |


| Location | Name | Location | Name |
| :---: | :---: | :---: | :---: |
| 21 | S2 | 41 | $\overline{\mathrm{MCS}} 1$ |
| 22 | S1 | 42 | $\overline{\text { MCS2 }}$ |
| 23 | $\overline{\text { So }}$ | 43 | $\overline{\mathrm{MCS3}}$ |
| 24 | $V_{\text {SS }}$ | 44 | $V_{\text {CC }}$ |
| 25 | HLDA | 45 | UCS |
| 26 | HOLD | 46 | LCS |
| 27 | SRDY | 47 | PCS6/A2 |
| 28 | LOCK | 48 | PCS5/A1 |
| 29 | TEST | 49 | $\overline{\text { PCS4 }}$ |
| 30 | NMI | 50 | $\overline{\text { PCS3 }}$ |
| 31 | INTO | 51 | $\overline{\text { PCS2 }}$ |
| 32 | INT1/SELECT | 52 | $\overline{\text { PCS1 }}$ |
| 33 | $V_{\text {CC }}$ | 53 | $\mathrm{V}_{\text {SS }}$ |
| 34 | $V_{\text {CC }}$ | 54 | $\overline{\text { PCSO }}$ |
| 35 | INT2/INTAO | 55 | RESIN |
| 36 | INT3/[/TTA1/ | 56 | T10UT |
|  | IRQ | 57 | T00UT |
| 37 | DT/ $\overline{\mathrm{R}}$ | 58 | T1IN |
| 38 | PDTMR | 59 | TOIN |
| 39 | DEN | 60 | DRQ1 |


| Location | Name |
| :---: | :---: |
| 61 | DRQ0 |
| 62 | $\mathrm{V}_{\text {SS }}$ |
| 63 | N.C. |
| 64 | ADO |
| 65 | A8 |
| 66 | AD1 |
| 67 | A9 |
| 68 | AD2 |
| 69 | A10 |
| 70 | AD3 |
| 71 | A11 |
| 72 | $\mathrm{V}_{\mathrm{CC}}$ |
| 73 | $V_{C C}$ |
| 74 | AD4 |
| 75 | A12 |
| 76 | AD5 |
| 77 | A13 |
| 78 | AD6 |
| 79 | A14 |
| 80 | AD7 |



272022-4
NOTE:
The nine-character alphanumeric code (XXXXXXXXA) underneath the product number is the Intel FPO number.
Figure 3. Quad Flat Pack (EIAJ) Pinout Diagram

## PACKAGE THERMAL SPECIFICATIONS

The 80L188EA is specified for operation when $T_{C}$ (the case temperature) is within the range of $0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ (PLCC package) or $0^{\circ} \mathrm{C}$ to $106^{\circ} \mathrm{C}$ (QFP-EIAJ) package. $\mathrm{T}_{\mathrm{C}}$ may be measured in any environment to determine whether the 80L188EA is within the specified operating range. The case temperature must be measured at the center of the top surface.
$\mathrm{T}_{\mathrm{A}}$ (the ambient temperature) can be calculated from $\theta_{C A}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{C A}$ at various airflows are given in Table 7 for the 68 -pin Plastic Leaded Chip Carrier (PLCC) package.

Table 8 shows the maximum $\mathrm{T}_{\mathrm{A}}$ allowable (without exceeding $T_{C}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumption, specified in watts) is calculated by using the maximum ICC as tabulated in the DC specifications and $\mathrm{V}_{\mathrm{CC}}$ of 5 V .

$$
T_{A}=T_{C} \cdot P \times \theta_{C A}
$$

Table 7. Thermal Resistance ( $\theta_{\mathrm{CA}}$ ) at Various Airflows (in ${ }^{\circ} \mathrm{C} / \mathrm{Watt}$ )

|  | Airflow Linear $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec})$ |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{0}$ <br> $\mathbf{( 0 )}$ | $\mathbf{2 0 0}$ <br> $\mathbf{1 . 0 1 )}$ | $\mathbf{4 0 0}$ <br> $\mathbf{1 2 . 0 3 )}$ | $\mathbf{6 0 0}$ <br> $\mathbf{1 3 . 0 4 )}$ | $\mathbf{8 0 0}$ <br> $\mathbf{( 4 . 0 6 )}$ | $\mathbf{1 0 0 0}$ <br> $\mathbf{( 5 . 0 7 )}$ |
| $\theta_{\mathrm{CA}}$ (PLCC) | 29 | 25 | 21 | 19 | 17 | 16.5 |
| $\theta_{\mathrm{CA}}$ (QFP) | 66 | 63 | 60.5 | 59 | 58 | 57 |

Table 8. Maximum $\mathrm{T}_{\mathrm{A}}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow Linear $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec})$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TF | 0 | 200 | 400 | 600 | 800 | 1000 |
|  | (MHz) | (0) | (1.01) | (2.03) | (3.04) | (4.06) | (5.07) |
| TA (PLCC) | 25 | 78 | 80 | 81 | 82 | 82.5 | 83 |
|  | 32 | 74 | 76 | 78 | 79 | 79.5 | 80 |
|  | 40 | 70 | 72 | 74 | 75 | 76 | 76.5 |
| $\mathrm{T}_{\mathrm{A}}$ (QFP) | 25 | 84 | 85.5 | 86 | 87 | 87 | 87.5 |
|  | 32 | 77.5 | 79 | 80 | 80.5 | 81 | 81.5 |
|  | 40 | 70 | 71.5 | 73 | 74 | 74 | 75 |

## ELECTRICAL SPECIFICATIONS

## ABSOLUTE MAXIMUM RATINGS*

Storage Temperature $\ldots . . . . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Case Temperature under Bias ... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Supply Voltage with Respect
to $\mathrm{V}_{\mathrm{ss}} \ldots \ldots \ldots \ldots \ldots \ldots \ldots . \mathrm{F}^{2.5 \mathrm{~V}}$ to +6.5 V
Voltage on Other Pins with Respect
to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots \ldots \ldots \ldots \ldots-0.5 \mathrm{~F}$ to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

OPERATING CONDITIONS

| Symbol | Parameter | Min | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 2.7 | 5.5 | V |
| $\mathrm{~T}_{\mathrm{F}}$ | Input Clock Frequency <br> 80L188EA13 | 0 | 26 | MHz |
|  | 80L188EA8 | 0 | 16 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ |  | Case Temperature under Bias |  |  |
|  | N80L188EA (PLCC) |  |  |  |
|  | S80L188EA (QFP) | 0 | +100 | ${ }^{\circ} \mathrm{C}$ |
|  |  | 0 | +114 | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED CONNECTIONS

Power and ground connections must be made to multiple $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$ pins. Every 80L188EA based circuit board should contain separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $\mathrm{V}_{\mathrm{SS}}$ ) planes. All $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$ pins must be connected to the appropriate plane. Pins identified as "N.C." must not be connected in the system. Decoupling capacitors should be placed near the 80L188EA. The value and type of decoupling capac-
itors is application and board layout dependent. The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Always connect any unused input pins to an appropriate signal level. In particular, unused interrupt pins (NMI, INT3:0) should be connected to $\mathrm{V}_{\text {SS }}$ to avoid unwanted interrupts. Leave any unused output pin or any "N.C." pin unconnected.

80L188EA-13, -8
ADVANCE ONFORMATRON

DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voitage for All Pins | -0.5 | $0.3 \mathrm{~V}_{C C}$ | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage for All Pins | 0.7 V CC | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}(\mathrm{~min})$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\mathrm{IOH}=-1 \mathrm{~mA}(\mathrm{~min})$ |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysterisis on RESIN | 0.30 |  | V |  |
| ILL1 | Input Leakage Current (except $\overline{\text { RD/ }} \overline{\text { QSMD }}, \overline{U C S}, \overline{L C S}, \overline{M C S O}$, $\overline{M C S 1, ~ L O C K, ~ a n d ~ T E S T) ~}$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ILL2 | Input Leakage Current ( $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}, \overline{\mathrm{UCS}}, \overline{\mathrm{LCS}}, \overline{\mathrm{MCSO}}$, $\overline{\text { MCS1, }}$, LOCK, and TEST) | -275 |  | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0.7 \mathrm{~V}_{\text {CC }}$ (Note 1) |
| loL | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}} \\ & (\text { Note 2) } \end{aligned}$ |
| ${ }^{\text {cC5 }}$ | $\begin{aligned} & \text { Supply Current (RESET, 5.5V) } \\ & \text { 80L188EA-13 } \\ & \text { 80L188EA-8 } \end{aligned}$ |  | 40 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 3) <br> (Note 3) |
| ${ }^{\text {ICC3 }}$ | Supply Current (RESET, 2.7V) 80L188EA-13 80L188EA-8 |  | 20 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ | (Note 3) (Note 3) |
| IID5 | $\begin{aligned} & \text { Supply Current Idle (5.5V) } \\ & \text { 80L188EA-13 } \\ & \text { 80L188EA-8 } \end{aligned}$ |  | 28 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| IID3 | Supply Current Idle (2.7V) 80L188EA-13 80L188EA-8 |  | 14 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| IPD5 | $\begin{aligned} & \text { Supply Current Powerdown (5.5V) } \\ & \text { 80L188EA-13 } \\ & \text { 80L188EA-8 } \end{aligned}$ |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ |  |
| $\mathrm{IPD3}$ | Supply Current Powerdown (2.7V) <br> 80L188EA-13 <br> 80L188EA-8 |  | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |  |
| Cout | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ ( Note 4) |

## NOTES:

1. $\overline{R D} / \overline{Q S M D}, \overline{U C S}, \overline{L C S}, \overline{M C S 0}, \overline{M C S 1}, \overline{T E S T}$ and $\overline{\text { LOCK }}$, and have internal pullups that are only activated during RESET.

Loading these pins above $\mathrm{I}_{\mathrm{LL}}=-275 \mu \mathrm{~A}$ will cause the 80L188EA to enter alternate modes of operation.
2. Output pins are floated using HOLD or ONCE Mode.
3. Measured at worst case temperature and $\mathrm{V}_{C C}$ with all outputs loaded as specified in the AC Test Conditions, and with the device in RESET (RESIN held low).
4. Output capacitance is the capacitive load of a floating output pin.

## Icc VERSUS FREQUENCY AND VOLTAGE

The current (IcC) consumption of the 80L188EA is essentially composed of two components; IPD and Iccs.

IPD is the quiescent current that represents internal device leakage, and is measured with all inputs or floating outputs at GND or $V_{C C}$ (no clock applied to the device). IPD is equal to the Powerdown current and is typically less than $50 \mu \mathrm{~A}$.

ICCS is the switching current used to charge and discharge parasitic device capacitance when changing logic levels. Since Iccs is typically much greater than IPD, IPD can often be ignored when calculating Icc.

Iccs is related to the voltage and frequency at which the device is operating. It is given by the formula:

$$
\begin{aligned}
& \text { Power }=\mathrm{V} \times \mathrm{I}=\mathrm{V} 2 \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f} \\
& \therefore \mathrm{I}=\mathrm{I}_{\mathrm{CC}}=\mathrm{I}_{\mathrm{CCS}}=\mathrm{V} \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f}
\end{aligned}
$$

Where: $\mathrm{V}=$ Device operating voltage $\left(\mathrm{V}_{\mathrm{CC}}\right)$
$C_{\text {DEV }}=$ Device capacitance
$f=$ Device operating frequency
Iccs = Icc = Device current
Measuring $C_{\text {DEV }}$ on a device like the 80L188EA would be difficult. Instead, $\mathrm{C}_{\text {DEV }}$ is calculated using the above formula by measuring $\mathrm{I}_{\mathrm{CC}}$ at a known $\mathrm{V}_{\mathrm{CC}}$ and frequency (see Table 9). Using this CDEV value, ICC can be calculated at any voltage and frequency within the specified operating range.

EXAMPLE: Calculate the typical ICc when operating at $20 \mathrm{MHz}, 4.8 \mathrm{~V}$.

## PDTMR PIN DELAY CALCULATION

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown. A delay is required only when using the on-chip oscillator to allow the crystal or resonator circuit time to stabilize.

## NOTE:

The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e., a device reset during Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized).

To calculate the value of capacitor required to provide a desired delay, use the equation:

$$
440 \times t=C_{P D} \quad\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where: $\mathbf{t}=$ desired delay in seconds

$$
\mathrm{C}_{\mathrm{PD}}=\begin{aligned}
& \text { capacitive load on PDTMR in mi- } \\
& \text { crofarads }
\end{aligned}
$$

EXAMPLE: To get a delay of $300 \mu \mathrm{~s}$, a capacitor value of $\mathrm{C}_{\mathrm{PD}}=440 \times\left(300 \times 10^{-6}\right)=0.132 \mu \mathrm{~F}$ is required. Round up to standard (available) capacitive values.

## NOTE:

The above equation applies to delay times greater than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ or $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $\mathrm{V}_{\mathrm{CC}}$ and/or lower temperature will decrease delay time, while lower $V_{C C}$ and/or higher temperature will increase delay time.

$$
I_{\mathrm{cC}}=\mathrm{I}_{\mathrm{CCS}}=4.8 \times 0.515 \times 20 \approx 49 \mathrm{~mA}
$$

Table 9. CDEV Values

| Parameter | Typ | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {DEV }}$ (Device in Reset) | 0.515 | 0.905 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| $\mathrm{C}_{\mathrm{DEV}}$ (Device in Idle) | 0.391 | 0.635 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

1. Max $C_{D E V}$ is calculated at $-40^{\circ} \mathrm{C}$, all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND, and all outputs loaded to 50 pF (including CLKOUT and OSCOUT).
2. Typical $\mathrm{C}_{\text {DEV }}$ is calculated at $25^{\circ} \mathrm{C}$ with all outputs loaded to 50 pF except CLKOUT and OSCOUT, which are not loaded.

## AC SPECIFICATIONS

AC Characteristics-801 188 EA 13

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 26 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 38.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {CH }}$ | CLKIN High Time | 12 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 12 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 45 | ns | 1, 4 |
| T | CLKOUT Period |  | ${ }^{*}{ }^{\text {T }}$ C | ns | 1 |
| $\mathrm{T}_{\text {PH }}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| TPL | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 15 | ns | 1,5 |
| $\mathrm{T}_{\text {PF }}$ | CLKOUT Fall Time | 1 | 15 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, LOCK | 3 | 27 | ns | 1,4,6,7 |
| TCHOV2 | $\overline{\mathrm{MCS3}} \mathbf{0}, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \overline{\mathrm{PCS6}} \mathbf{0}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 32 | ns | 1, 4, 6, 8 |
| TCHOV3 | S $\overline{\text { S2:0 }}$, $\overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{BHE}}, \mathrm{A19:16}$ | 3 | 30 | ns | 1, 4, 6, 11 |
| TCLOV1 | LOCK, RESOUT, HLDA, TOOUT, T1OUT | 3 | 27 | ns | 1,4,6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS} 3: 0}, \overline{\overline{C S S},} \overline{\mathrm{UCS},} \overline{\mathrm{PCS}}: 0$, INTA1:0 | 3 | 32 | ns | 1, 4, 6 |
| TCLOV3 | BHE, DEN, A19:16 | 3 | 30 | ns | 1, 4, 6 |
| TCLOV4 | A15:8, AD7:0 | 3 | 34 | ns | 1,4,6 |
| TCLOV5 | S2:0 | 3 | 38 | ns | 1, 4, 6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 30 | ns | 1 |
| TCLOF | DEN, AD15:0 | 0 | 35 | ns | 1 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\text {IH }}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 9 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 10 for rise and fall times outside 50 pF .
6. See Figure 10 for rise and fall times.
7. TCHOV1 applies to LOCK only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L186EA operation (SRDY, AD15:0).
11. $\mathrm{T}_{\mathrm{CHO}} 3$ applies to $\overline{\mathrm{RFSH}}$ and A19:16 only after a HOLD release.

## AC SPECIFICATIONS

AC Characteristics-80L188EA13 (Continued)

| Symbol | Parameter | Min | Max | Units | Notes |
| :--- | :--- | :---: | :---: | :---: | :---: |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| $T_{\text {CHIS }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:OIN, ARDY }}$ | 25 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CHIH }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:OIN, ARDY }}$ | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | AD15:0, ARDY, SRDY, DRQ1:0 | 25 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIH }}$ | AD15:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIS }}$ | HOLD | 25 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | HOLD | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | $\overline{\text { RESIN }}$ (to CLKIN) | 25 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | $\overline{\text { RESIN }}$ (from CLKIN) | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $I_{C C}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 9 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 10 for rise and fall times outside 50 pF .
6. See Figure 10 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV}}^{1}$ applies to $\overline{\mathrm{LOCK}}$ after a HOLD release.
8. TCHOV2 applies to RD and WR only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L186EA operation (SRDY, AD15:0).
11. $\mathrm{T}_{\text {CHOV3 }}$ applies to $\overline{\mathrm{RFSH}}$ and $\mathrm{A} 19: 16$ only after a HOLD release.

AC SPECIFICATIONS

## AC Characteristics-s0L1885 As

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 16 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 62.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\text {ch }}$ | CLKIN High Time | 12 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 12 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 50 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{*} \mathrm{~T}_{C}$ | ns | 1 |
| TPH | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPL | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 15 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 15 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { LOCK }}$ | 3 | 30 | ns | 1,4,6,7 |
| TCHOV2 | MCS3:0, $\overline{\text { LCS }}$, UCS, $\overline{\text { PCS6:0 }}$, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 35 | ns | 1, 4, 6, 8 |
| TCHOV3 |  | 3 | 30 | ns | 1, 4, 6, 11 |
| TCLOV1 | $\overline{\text { RFSH, }} \overline{\mathrm{DEN}}, \overline{\text { LOCK, }}$, RESOUT, HLDA, TOOUT, T1OUT, A19:16 | 3 | 30 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{MCS}}: \mathbf{0}, \overline{\mathrm{LCS}}$, $\overline{U C S}, \overline{P C S 6: 0}, \overline{\text { INTA1:0 }}$ | 3 | 35 | ns | 1, 4, 6 |
| TCLOV3 | / $\mathrm{RFSH}, \overline{\mathrm{DEN}}, \mathrm{A} 19: 16$ | 3 | 30 | ns | 1,4,6 |
| TCLOV4 | A15:8, AD7:0 | 3 | 35 | ns | 1,4,6 |
| TCLOV5 | S2:0 | 3 | 40 | ns | 1, 4, 6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, S2:0, A19:16 | 0 | 30 | ns | 1 |
| TCLOF | $\overline{\text { DEN, }}$ A15:8, AD7:0 | 0 | 35 | ns | 1 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 9 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 10 for rise and fall times outside 50 pF .
6. See Figure 10 for rise and fall times.
7. TCHOV1 applies to LOCK and only after a HOLD release.
8. TCHOV2 applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L188EA operation (SRDY, AD7:0).
11. $\mathrm{T}_{\mathrm{CHOV}}$ applies to $\overline{\mathrm{RFSH}}$ and A19:16 only after a HOLD release.

## AC SPECIFICATIONS

AC Characteristics-80L188EA8 (Continued)

| Symbol | Parameter | Min | Max | Units | Notes |
| :--- | :--- | :---: | :---: | :---: | :---: |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| $T_{\text {CHIS }}$ | $\overline{T E S T}$, NMI, INT3:0, T1:0IN, ARDY | 25 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CHIH }}$ | $\overline{\text { TEST, NMI, INT3:0, T1:0IN, ARDY }}$ | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | A15:8, AD7:0, ARDY, SRDY, DRQ1:0 | 25 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIH }}$ | A15:8, AD7:0, ARDY, SRDY, DRQ1:0 | 3 |  | ns | 1,10 |
| $\mathrm{~T}_{\text {CLIS }}$ | HOLD | 25 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | HOLD | 3 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIS }}$ | $\overline{\text { RESIN }}$ (to CLKIN) | 25 |  | ns | 1,9 |
| $\mathrm{~T}_{\text {CLIH }}$ | $\overline{\text { RESIN }}$ (to CLKIN) | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measured at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 9 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 10 for rise and fall times outside 50 pF .
6. See Figure 10 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV} 1}$ applies to $\overline{\text { LOCK }}$ and only after a HOLD release.
8. TCHOV2 applies to RD and WR only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L188EA operation (SRDY, AD7:0).
11. $\mathrm{T}_{\mathrm{CHOV} 3}$ applies to $\overline{\mathrm{RFSH}}$ and $\mathrm{A} 19: 16$ only after a HOLD release.

## AC SPECIFICATIONS

Relative Timings-80L-188EA-13, -8

| Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| TLHLL | ALE Rising to ALE Falling | T-15 |  | ns |  |
| TAVLL | Address Valid to ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TPLLL | Chip Selects Valid to ALE Falling | $1 / 2 T-10$ |  | ns | 1 |
| TLLAX | Address Hold from ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{\text { WR }}$ Falling | $1 / 2 \mathrm{~T}-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\mathrm{RD}}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| $\mathrm{T}_{\text {RHLH }}$ | $\overline{\mathrm{RD}}$ Rising to ALE Rising | $1 / 2 T-10$ |  | ns | 1 |
| TWHLH | $\overline{\text { WR Rising to ALE Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| T AFRL | Address Float to $\overline{\text { RD }}$ Falling | 0 |  | ns |  |
| T ${ }_{\text {RLRH }}$ | $\overline{\mathrm{RD}}$ Falling to $\overline{\mathrm{RD}}$ Rising | (2*T) - 5 |  | ns | 2 |
| TWLWH | $\overline{\text { WR }}$ Falling to $\overline{\text { WR }}$ Rising | (2*) -5 |  | ns | 2 |
| TRHAV | $\overline{\mathrm{RD}}$ Rising to Address Active | T-15 |  | ns |  |
| Twhdx | Output Data Hold after WR Rising | T-15 |  | ns |  |
| Twhdex | $\overline{\text { WR Rising to } \overline{\mathrm{DEN}} \text { Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| TWHPH | $\overline{\text { WR Rising to Chip Select Rising }}$ | $1 / 2 \mathrm{~T}-10$ |  | ns | 1,4 |
| TRHPH | $\overline{\mathrm{RD}}$ Rising to Chip Select Rising | $1 / 2 T-10$ |  | ns | 1,4 |
| TPHPL | $\overline{\text { CS }}$ Inactive to $\overline{C S}$ Active | $1 / 2 T-10$ |  | ns | 1 |
| T DXDL | $\overline{\mathrm{DEN}}$ Inactive to DT/ $\overline{\mathrm{R}}$ Low | 0 |  | ns | 5 |
| ToVRH | ONCE ( $\overline{U C S}$, LCSS) Active to $\overline{\text { RESIN }}$ Rising | T |  | ns | 3 |
| TRHOX | ONCE (UCS, $\overline{L C S}$ ) to $\overline{\text { RESIN }}$ Rising | T |  | ns | 3 |

## NOTES:

1. Assumes equal loading on both pins.
2. Can be extended using wait states.
3. Not tested.
4. Not applicable to latched A2:1. These signals change only on falling $\mathrm{T}_{1}$.
5. For write cycle followed by read cycle.

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 4. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms, for AC specification definitions, test pins, and illustrations.


Figure 4. AC Test Load

## AC TIMING WAVEFORMS



Figure 5. Input and Output Clock Waveform


NOTE:
$20 \% V_{C C}<$ Float $<80 \% V_{C C}$
Figure 6. Output Delay and Float Waveform


272022-8

## NOTE:

RESIN measured to CLKIN, not CLKOUT
Figure 7. Input Setup and Hold


Figure 8. Relative Signal Waveform

## DERATING CURVES



Figure 9. Typical Output Delay Variations Versus Load Capacitance


Figure 10. Typical Rise and Fall Variations Versus Load Capacitance

## 80L188EA EXPRESS

The Intel EXPRESS program offers an extended temperature range as an enhancement to the 80L188EA operational specifications. EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

With the standard commercial temperature range, operational characteristics are guaranteed over a temperature range corresponding to $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ambient. With the extended temperature range option, operational characteristics are guaranteed over a temperature range corresponding to $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ambient.

Package types and EXPRESS versions are identified by a one- or two-letter prefix to the part number. The prefixes are listed in Table 10. All AC and DC specifications are the same for both commercial and EXPRESS parts.

Table 10. Prefix Identification

| Prefix | Package <br> Type | Temperature <br> Range |
| :---: | :--- | :--- |
| N | PLCC | Commercial |
| S | QFP (EIAJ) | Commercial |
| TN | PLCC | Extended |
| TS | QFP (EIAJ) | Extended |




NOTE:
Units are mm/(inches).
Figure 11. PLCC Principal Dimensions


Figure 12. QFP (EIAJ) Principal Dimensions

## REVISION HISTORY

Intel 80L188EA devices are marked with a 9-character alphanumeric Intel FPO number underneath the product number. This data sheet (272022-001) is valid for 80L188EA devices with an " $A$ " as the ninth character in the FPO number, as illustrated in Figure 2 for the 68-lead PLCC package and Figure 3 for the 80-lead QFP (EIAJ) package. Such devices may also be identified by reading a value of 01 H from the STEPID register.

The following changes were made from revision -001 to -002 of this datasheet.

1. AC and DC specifications for 13 MHz parts were added.

An 80L188EA with a STEPID value of 01 H or 02 H has the following known errata. A device with a STEPID of 01 H or 02 H can be visually identified by noting the presence of a " $A$ " or " $B$ " alpha character, respectively, next to the FPO number. The FPO number location is shown in Figures 2 and 3.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistantly, it is dependent on interrupt timing.

# 80L188EB-13, 8 <br> 16-BIT HIGH-INTEGRATION EMBEDDED PROCESSOR 

\author{

- 3V Operation, VCC $=2.7 \mathrm{~V}-5.5 \mathrm{~V}$ <br> - Full Static Operation <br> - True CMOS Inputs and Outputs <br> $\bullet-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operating Temperature Range <br> - Low System Cost 8-Bit Interface
}
- Integrated Feature Set
- Low-Power Static CPU Core
- Two Independent UARTs each with an Integral Baud Rate Generator
—Two 8-Bit Multiplexed I/O Ports
- Programmable Interrupt Controller
- Three Programmable 16-Bit Timer/Counters
- Clock Generator
- Ten Programmable Chip Selects with Integral Wait-State Generator
- Memory Refresh Control Unit
- System Level Testing Support (ONCETM Mode)
Direct Addressing Capability to 1 Mbyte Memory and 64 Kbyte I/O
- Speed Version Available:
-13 MHz (80L188EB-13)
-8 MHz (80L188EB-8)
- Low-Power Operating Modes:
- Idle Mode Freezes CPU Clocks but keeps Peripherals Active
- Powerdown Mode Freezes All Internal Clocks
- Complete System Development Support
- ASM86 Assembler, PL/M 86, Pascal 86, Fortran 86, C-86, and System Utilities
- In-Circuit Emulator (ICETM-188EB)
- Available In:
- 80-Pin Quad Flat Pack (TS80L188EB)
- 84-Pin Plastic Leaded Chip Carrier (TN80L188EB)

The 80L188EB is the $3 V$ version of the 80 C 188 EB embedded processor. By reducing $\mathrm{V}_{\mathrm{CC}}$, further power savings can be realized over the standard 80C188EB making the 80L188EB ideal for battery-powered portable applications.



Figure 1. 80L188EB Block Diagram

## INTRODUCTION

The 80L188EB is the first product in a new generation of low-power, hight-integration micioprocessors. It enhances the existing 186 family by offering new features and new operating modes. The 80L188EB is object code compatible with the 80C186/80C188 microprocessors. The 80L188EB has an 8-bit external data bus but still retains a 16 -bit internal bus. An 8 -bit external bus reduces system cost by requiring that only single byte-wide memories be used.

The feature set of the 80L188EB meets the needs of battery-powered applications. Battery-powered applications benefit from the static CPU core and peripherals. Minimum current consumption is achieved by combining low voltage operation along with the features of the power management unit, thus maximizing battery life. Peripheral design enhancements ensure that non-initialized peripherals consume little current.

Space critical applications benefit from the integration of commonly used system peripherals. Two serial channels are provided for services such as diagnostics, inter-processor communication, modem interface, terminal display interface and many others. A flexible chip select unit simplifies memory and peripheral interfacing. The interrupt unit provides sources for up to 129 external interrupts and will prioritize these interrupts with those generated from the on-chip peripherals. Three general purpose timer/counters and sixteen multiplexed I/O port pins round out the feature set of the 80L188EB.

## OVERVIEW

Figure 1 shows a block diagram of the 80L188EB. The Execution Unit (EU) is an enhanced 8088 CPU core that includes: dedicated hardware to speed up effective address calculations, enhance execution speed for multiple-bit shift and rotate instructions and for multiply and divide instructions, string move instructions that operate at full bus bandwidth, ten new instructions and full static operation. The Bus Interface Unit (BIU) is the same as that found on the original 188 family products, except the queuestatus mode has been deleted and buffer interface control has been changed to ease system design timings. An independent internal bus is used to allow communication between the BIU and internal peripherals.

## PACKAGE INFORMATION

This section describes the pins, pinouts, and thermal characteristics for the 80L188EB in the Plastic Leaded Chip Carrier (PLCC) package and Quad Flat Pack (QFP) package. For complete package specifications and information, see the Intel Packaging handbook (Order Number: 240800).

## 80L188EB PINOUT

Tables 1 and 2 list the 80L188EB pin names with package location for the 84-pin Plastic Leaded Chip Carrier (PLCC) component. Figure 2 depicts the complete 80L188EB pinout (PLCC package) as viewed from the top side of the component (i.e., contacts facing down).

Tables 3 and 4 list the 80L188EB pin names with package location for the 80 -pin Quad Flat Pack (QFP) component. Figure 3 depicts the complete 80L188EB (QFP package) as viewed from the top side of the component (i.e., contacts facing down).

Table 1. PLCC Pin Names with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Location |
| AD0 | 61 |
| AD1 | 66 |
| AD2 | 68 |
| AD3 | 70 |
| AD4 | 72 |
| AD5 | 74 |
| AD6 | 76 |
| AD7 | 78 |
| A8 | 62 |
| A9 | 67 |
| A10 | 69 |
| A11 | 71 |
| A12 | 73 |
| A13 | 75 |
| A14 | 77 |
| A15 | 79 |
| A16 | 80 |
| A17 | 81 |
| A18 | 82 |
| A19/ONCE | 83 |


| Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: |
| Name | Location | Name | Location |
| ALE | 6 | RESIN | 37 |
| $\overline{\text { RFSH }}$ | 7 | RESOUT | 38 |
| S0 | 10 | CLKIN | 41 |
| S1 | 9 | OSCOUT | 40 |
| S2 | 8 | CLKOUT | 44 |
| $\overline{\mathrm{RD}}$ | 4 | TEST | 14 |
| $\overline{W R}$ | 5 | NC | 60 |
| READY | 18 | NC | 39 |
| $\overline{\mathrm{DEN}}$ | 11 | NC | 3 |
| DT/ $\bar{R}$ | 16 | PDTMR | 36 |
| LOCK | 15 | NMI | 17 |
| HOLD | 13 | INTO | 31 |
| HLDA | 12 | INT1 | 32 |
|  |  | INT2/INTAO | 33 |
| Power |  | INT3/INTA1 | 34 |
|  |  | INT4 | 35 |


| I/O |  |
| :--- | :---: |
| Name | Location |
| UCS | 30 |
| LCS | 29 |
| P1.0/GCS0 | 28 |
| P1.1/GCS1 | 27 |
| P1.2/GCS2 | 26 |
| P1.3/GCS3 | 25 |
| P1.4/GCS4 | 24 |
| P1.5/GCS5 | 21 |
| P1.6/GCS6 | 20 |
| P1.7/GCS7 | 19 |
| TOOUT | 45 |
| TOIN | 46 |
| T1OUT | 47 |
| T1IN | 48 |
| RXDO | 53 |
| TXD0 | 52 |
| P2.5/BCLK0 | 54 |
| CTS0 | 51 |
| P2.0/RXD1 | 57 |
| P2.1/TXD1 | 58 |
| P2.2/BCLK1 | 59 |
| P2.3/SINT1 | 55 |
| P2.4/CTS1 | 56 |
| P2.6 | 50 |
| P2.7 | 49 |

Table 2. PLCC Package Locations with Pin Name

| Location | Name |
| :---: | :--- |
| $\mathbf{i}$ | $V_{\mathrm{CC}}$ |
| 2 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 3 | NC |
| 4 | $\overline{\mathrm{RD}}$ |
| 5 | $\overline{\mathrm{WR}}$ |
| 6 | ALE |
| 7 | $\overline{\mathrm{RFSH}}$ |
| 8 | $\overline{\mathrm{~S} 2}$ |
| 9 | $\overline{\mathrm{~S} 1}$ |
| 10 | $\overline{\mathrm{SO}}$ |
| 11 | $\overline{\mathrm{DEN}}$ |
| 12 | HLDA |
| 13 | HOLD |
| 14 | $\overline{\mathrm{TEST}}$ |
| 15 | $\overline{\mathrm{LOCK}}$ |
| 16 | $\mathrm{DT} / \overline{\mathrm{R}}$ |
| 17 | NMI |
| 18 | READY |
| 19 | $\mathrm{P} 1.7 / \overline{\mathrm{GCS7}}$ |
| 20 | $\mathrm{P} 1.6 / \overline{\mathrm{GCS6}}$ |
| 21 | $\mathrm{P} 1.5 / \overline{\mathrm{GCS5}}$ |


| Location | Name |
| :---: | :---: |
| 22 | $\mathrm{v}_{\text {ss }}$ |
| 23 | V cc |
| 24 | P1.4/亩CS4 |
| 25 | P1.3/GCS3 |
| 26 | P1.2/GCS2 |
| 27 | P1.1/GCS1 |
| 28 | P1.0/GCS0 |
| 29 | $\overline{\text { LCS }}$ |
| 30 | UCS |
| 31 | INTO |
| 32 | INT1 |
| 33 | INT2/INTAO |
| 34 | INT3/INTA1 |
| 35 | INT4 |
| 36 | PDTMR |
| 37 | $\overline{\text { RESIN }}$ |
| 38 | RESOUT |
| 39 | NC |
| 40 | oscout |
| 41 | CLKIN |
| 42 | $\mathrm{V}_{\text {CC }}$ |


| Location | Name |
| :---: | :--- |
| 43 | Vss |
| 44 | CLKOUT |
| 45 | TOOUT |
| 46 | TOIN |
| 47 | T1OUT |
| 48 | T1IN |
| 49 | P2.7 |
| 50 | P2.6 |
| 51 | CTS0 |
| 52 | TXDO |
| 53 | RXDO |
| 54 | PP.5/BCLKO |
| 55 | P2.3/SINT1 |
| 56 | P2.4/CTS1 |
| 57 | P2.0/RXD1 |
| 58 | P2.1/TXD1 |
| 59 | P2.2/BCLK1 |
| 60 | NC |
| 61 | ADO |
| 62 | A8 |
| 63 | $V_{S S}$ |


| Location | Name |
| :---: | :--- |
| 64 | $V_{C C}$ |
| 65 | $V_{\text {SS }}$ |
| 66 | AD1 |
| 67 | A9 |
| 68 | AD2 |
| 69 | A10 |
| 70 | AD3 |
| 71 | A11 |
| 72 | AD4 |
| 73 | A12 |
| 74 | AD5 |
| 75 | A13 |
| 76 | AD6 |
| 77 | A14 |
| 78 | AD7 |
| 79 | A15 |
| 80 | A16 |
| 81 | A17 |
| 82 | A18 |
| 83 | A19/ONCE |
| 84 | $V_{\text {SS }}$ |



270920-3
NOTE:
This is the FPO number location (indicated by the X's).
Figure 2. 84-Pin Plastic Leaded Chip Carrier Pinout Diagram

Table 3. QFP Pin Name with Package Location

| Address/Data Bus |  |
| :--- | :---: |
| Name | Locaition |
| AD0 | 10 |
| AD1 | 15 |
| AD2 | 17 |
| AD3 | 19 |
| AD4 | 21 |
| AD5 | 23 |
| AD6 | 25 |
| AD7 | 27 |
| A8 | 11 |
| A9 | 16 |
| A10 | 18 |
| A11 | 20 |
| A12 | 22 |
| A13 | 24 |
| A14 | 26 |
| A15 | 28 |
| A16 | 29 |
| A17 | 30 |
| A18 | 31 |
| A19/ONCE | 32 |


| Bus Control |  | Processor Control |  |
| :---: | :---: | :---: | :---: |
| Ṅame | Location | Name | Location |
| ALE | 38 | RESIN | 68 |
| $\overline{\text { RFSH }}$ | 39 | RESOUT | 69 |
| $\overline{\text { S0 }}$ | 42 | CLKIN | 71 |
| $\overline{\text { S1 }}$ | 41 | OSCOUT | 70 |
| $\overline{\mathrm{S} 2}$ | 40 | CLKOUT | 74 |
| $\overline{\mathrm{RD}}$ | 36 | TEST | 46 |
| $\overline{\text { WR }}$ | 37 | PDTMR | 67 |
| READY | 49 | NMI | 48 |
| DEN | 43 | INTO | 62 |
| DEN | 43 | INT1 | 63 |
| $\overline{\text { LOCK }}$ | 47 | INT2/İNTAO | 64 |
| HOLD | 45 | INT3/\/INTA1 | 65 |
| HLDA | 44 | INT4 | 66 |
|  |  | Pow | ver |
|  | , | Name | Location |
|  |  | $V_{C C}$ | $13,34,$ |
| , |  | $\mathrm{V}_{\text {SS }}$ | 12, 14, 33, |
|  |  |  | 35,53,73 |


| I/O |  |
| :--- | :---: |
| Namé | Lóacatiōn |
| $\overline{\text { UCS }}$ | 61 |
| LCS | 60 |
| P1.0/GCS0 | 59 |
| P1.1/GCS1 | 58 |
| P1.2/GCS2 | 57 |
| P1.3/GCS3 | 56 |
| P1.4/GCS4 | 55 |
| P1.5/GCS5 | 52 |
| P1.6/GCS6 | 51 |
| P1.7/GCS7 | 50 |
| T00UT | 75 |
| TOIN | 76 |
| T1OUT | 77 |
| T1IN | 78 |
| RXD0 | 3 |
| TXD0 | 2 |
| P2.5/BCLK0 | 4 |
| CTS0 | 1 |
| P2.0/RXD1 | 7 |
| P2.1/TXD1 | 8 |
| P2.2/BCLK1 | 9 |
| P2.3/SINT1 | 5 |
| P2.4/CTS1 | 6 |
| P2.6 | 80 |
| P2.7 | 79 |

Table 4. QFP Package Location with Pin Names

| Location | Name |
| :---: | :--- |
| 1 | CTS0 |
| 2 | TXD0 |
| 3 | RXD0 |
| 4 | P2.5/BCLK0 |
| 5 | P2.3/SINT1 |
| 6 | P2.4/CTS1 |
| 7 | P2.0/RXD1 |
| 8 | P2.1/TXD1 |
| 9 | P2.2/BCLK1 |
| 10 | AD0 |
| 11 | A8 |
| 12 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 13 | V CC |
| 14 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 15 | AD1 |
| 16 | A9 |
| 17 | AD2 |
| 18 | A10 |
| 19 | AD3 |
| 20 | A11 |


| Location | Name |
| :---: | :--- |
| 21 | AD4 |
| 22 | A12 |
| 23 | AD5 |
| 24 | A 13 |
| 25 | $\mathrm{AD6}$ |
| 26 | A 14 |
| 27 | $\mathrm{AD7}$ |
| 28 | A 15 |
| 29 | A 16 |
| 30 | A 17 |
| 31 | A 18 |
| 32 | $\mathrm{~A} 19 / \overline{\mathrm{ONCE}}$ |
| 33 | $\mathrm{~V} S \mathrm{~S}$ |
| 34 | $\mathrm{~V} C \mathrm{C}$ |
| 35 | V SS |
| 36 | RD |
| 37 | $\overline{\mathrm{WR}}$ |
| 38 | ALE |
| 39 | $\overline{\mathrm{RFSH}}$ |
| 40 | $\overline{\mathrm{~S} 2}$ |


| Location | Name |
| :---: | :--- |
| 41 | $\overline{\mathrm{~S} 1}$ |
| 42 | $\overline{\mathrm{SO}}$ |
| 43 | $\overline{\mathrm{DEN}}$ |
| 44 | HLDA |
| 45 | HOLD |
| 46 | $\overline{\mathrm{TEST}}$ |
| 47 | $\overline{\mathrm{LOCK}}$ |
| 48 | NMI |
| 49 | READY |
| 50 | $\mathrm{P} 1.7 / \overline{\mathrm{GCS}}$ |
| 51 | $\mathrm{P} 1.6 / \overline{\mathrm{GCS}}$ |
| 52 | $\mathrm{P} 1.5 / \overline{\mathrm{GCS}}$ |
| 53 | V |
| 54 | V |
| 54 |  |
| 55 | $\mathrm{P} 1.4 / \overline{\mathrm{GCS}}$ |
| 56 | $\mathrm{P} 1.3 / \overline{\mathrm{GCS3}}$ |
| 57 | $\mathrm{P} 1.2 / \overline{\mathrm{GCS}}$ |
| 58 | $\mathrm{P} 1.1 / \overline{\mathrm{GCS}}$ |
| 59 | $\mathrm{P} 1.0 / \overline{\mathrm{GCS}}$ |
| 60 | $\overline{\mathrm{LCS}}$ |


| Location | Name |
| :---: | :--- |
| 61 | $\overline{\text { UCS }}$ |
| 62 | INT0 |
| 63 | INT1 |
| 64 | INT2/IINTAO |
| 65 | INT3/INTA1 |
| 66 | INT4 |
| 67 | PDTMR |
| 68 | $\overline{\text { RESIN }}$ |
| 69 | RESOUT |
| 70 | OSCOUT |
| 71 | CLKIN |
| 72 | VCC |
| 73 | VSS |
| 74 | CLKOUT |
| 75 | TOOUT |
| 76 | TOIN |
| 77 | T1OUT |
| 78 | T1IN |
| 79 | P2.7 |
| 80 | P2.6 |



Figure 3. Quad Flat Pack Pinout Diagram

## PACKAGE THERMAL SPECIFICATIONS

The 80L188EB is specified for operation when $T_{C}$ (the case temperature) is within the range of $-40^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ (PLCC package) or $-40^{\circ} \mathrm{C}$ to $+114^{\circ} \mathrm{C}$ (QFP package). $T_{C}$ may be measured in any environment to determine whether the 80L188EB is within the specified operating range. The case temperature must be measured at the center of the top surface.
$\mathrm{T}_{\mathrm{A}}$ (the ambient temperature) can be calculated from $\theta_{C A}$ (thermal resistance from the case to ambient) with the following equation:

Typical values for $\theta_{\mathrm{CA}}$ at various airflows are given in Table 5 for the 84-pin Plastic Leaded Chip Carrier (PLCC) package.

Table 6 shows the maximum $T_{A}$ allowable (without exceeding $T_{C}$ ) at various airflows and operating frequencies. $P$ (the maximum power consumption, specified in watts) is calculated by using the maximum ICC as tabulated in the DC specifications and $\mathrm{V}_{\mathrm{CC}}$ of 5 V .

$$
T_{A}=T_{C}-P^{*} \theta_{C A}
$$

Table 5. Thermal Resistance ( $\theta_{\mathrm{CA}}$ ) at Various Airflows (in ${ }^{\circ} \mathrm{C} /$ Watt)

|  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Airflow Linear $\mathbf{f t} / \mathrm{min}(\mathbf{m} / \mathbf{s e c})$ |  |  |  |  |  |
|  | $\mathbf{0}$ <br> $\mathbf{( 0 )}$ | $\mathbf{2 0 0}$ <br> $\mathbf{( 1 . 0 1 )}$ | $\mathbf{4 0 0}$ <br> $\mathbf{( 2 . 0 3 )}$ | $\mathbf{6 0 0}$ <br> $\mathbf{( 3 . 0 4 )}$ | $\mathbf{8 0 0}$ <br> $\mathbf{( 4 . 0 6 )}$ | $\mathbf{1 0 0 0}$ <br> $\mathbf{( 5 . 0 7 )}$ |
| $\theta_{\text {CA }}$ (PLCC) | 30 | 24 | 21 | 19 | 17 | 16.5 |
| $\theta_{\text {CA }}$ (QFP) | 58 | 47 | 43 | 40 | 38 | 36 |

Table 6. Maximum $T_{A}$ at Various Airflows (in ${ }^{\circ} \mathrm{C}$ )

|  |  | Airflow Linear $\mathrm{ft} / \mathrm{min}(\mathrm{m} / \mathrm{sec}$ ) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{T}_{\mathrm{F}}$ | $\begin{gathered} 0 \\ (0) \end{gathered}$ | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{aligned} & 400 \\ & (2.03) \end{aligned}$ | $\begin{gathered} 600 \\ (3.04) \end{gathered}$ | $\begin{gathered} 800 \\ (4.06) \end{gathered}$ | $\begin{gathered} 1000 \\ (5.07) \end{gathered}$ |
|  | (MHz) |  |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{A}}$ (PLCC) | 16 | 91.5 | 93.5 | 94 | 94.5 | 95.5 | 95.5 |
| $\mathrm{T}_{\mathrm{A}}$ (QFP) | 16 | 98 | 101 | 102 | 103 | 103.5 | 104 |

## ELECTRICAL SPECIFICATIONS

Absolute Maximum Ratings<br>Parameter<br>Maximum Rating<br>Storage Temperature.........$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$<br>Case Temp Under Bias . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+120^{\circ} \mathrm{C}$<br>Supply Voltage wrt $V_{\text {SS }} \ldots \ldots . . .-0.5 \mathrm{~V}$ to +6.5 V<br>Voltage on other Pins<br>with respect to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots . .-0.5 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## OPERATING CONDITIONS

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 2.7 | 5.5 | V |
| $\mathrm{T}_{\mathrm{F}}$ | Input Clock Frequency 80L188EB-13 80L188EB-8 | 0 | 26 | MHz |
|  |  | 0 | 16 | MHz |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature Under Bias N80L188EB-X (PLCC) S80L188EB-X (QFP) | -40 | +100 | ${ }^{\circ} \mathrm{C}$ |
|  |  | -40 | +114 | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED CONNECTIONS

Power and ground connections must be made to multiple $V_{C C}$ and $V_{S S}$ pins. Every 80L188EB-based circuit board should include separate power ( $\mathrm{V}_{\mathrm{CC}}$ ) and ground ( $\mathrm{V}_{\mathrm{SS}}$ ) planes. Every $\mathrm{V}_{\mathrm{CC}}$ pin must be connected to the power plane, and every $\mathrm{V}_{\text {SS }}$ pin must be connected to the ground plane. Pins identified as "NC" must not be connected in the system. Liberal decoupling capacitance should be placed near the 80L188EB. The processor can cause transient power surges when its output buffers transition, particularly when connected to large capacitive loads.

Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance is reduced by placing the decoupling capacitors as close as possible to the $80 \mathrm{~L} 188 \mathrm{~EB} \mathrm{~V}_{\mathrm{CC}}$ and $V_{S S}$ package pins.

Always connect any unused input to an appropriate signal level. In particular, unused interrupt inputs (INT0:4) should be connected to $\mathrm{V}_{\mathrm{CC}}$ through a pull-up resistor (in the range of $50 \mathrm{~K} \Omega$ ). Leave any unused output pin or any NC pin unconnected.

80L188EB

## DC SPECIFICATIONS

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | $0.3 * V_{\text {CC }}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | $0.7 *{ }^{\text {V }}$ CC | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \text { (Min) } \\ & \text { (Note 1) } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \text { (Min) } \\ & \text { (Note 1) } \end{aligned}$ |
| $\mathrm{V}_{\text {HYR }}$ | Input Hysterisis on RESIN | 0.50 |  | V |  |
| $\mathrm{l}_{\text {LI1 }}$ | Input Leakage Current for pins: <br> AD15:0, READY, HOLD, RESIN, CLKIN, TEST, NMI, INT4:0, TOIN, T1IN, RXDO, $\overline{\text { BCLKO }}, \overline{\mathrm{CTSO}}, \mathrm{RXD1}, \overline{\mathrm{BCLK}}, \overline{\mathrm{CTS}}$, Sint1, P2.6, P2. 7 |  | $\pm 15$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{l}_{\text {L12 }}$ | Input Leakage Current for pins: A19/ONCE, A18:16, $\overline{\text { LOCK }}$ | -0.275 | -0.5 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathbb{N}}=0.7 \mathrm{~V}_{\mathrm{CC}} \\ & \text { (Note 2) } \end{aligned}$ |
| Lo | Output Leakage Current |  | $\pm 15$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \leq \mathrm{V}_{\mathrm{OUT}} \leq \mathrm{V}_{\mathrm{CC}} \\ & \text { (Note 3) } \end{aligned}$ |
| ICC5 | Supply Current (RESET, 5.5V) <br> 80L188EB-13 <br> 80L188EB-8 |  | $\begin{aligned} & 70 \\ & 45 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 4) <br> (Note 4) |
| ICC3 | Supply Current (RESET, 2.7V) <br> 80L188EB-13 <br> 80L188EB-8 |  | $\begin{aligned} & 36 \\ & 22 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 4) <br> (Note 4) |
| IID5 | Supply Current Idle (5.5V) 80L188EB-13 <br> 80L188EB-8 |  | $\begin{aligned} & 48 \\ & 31 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 5) <br> (Note 5) |
| IID3 | Supply Current Idle (2.7V) 80L188EB-13 <br> 80L188EB-8 |  | $\begin{aligned} & 24 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | (Note 5) <br> (Note 5) |
| IPD5 | Supply Current Powerdown (5.5V) <br> 80L188EB-13 <br> 80L188EB-8 |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | (Note 6) (Note 6) |
| IpD3 | Supply Current Powerdown (2.7V) <br> 80L188EB-13 <br> 80L188EB-8 |  | $\begin{aligned} & 30 \\ & 30 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | (Note 6) <br> (Note 6) |
| $\mathrm{Cin}^{\text {I }}$ | Input Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ |
| Cout | Output Pin Capacitance | 0 | 15 | pF | $\mathrm{T}_{\mathrm{F}}=1 \mathrm{MHz}$ (Note 7) |

## NOTES:

1. $\mathrm{I}_{\mathrm{OL}}$ and $\mathrm{I}_{\mathrm{OH}}$ measured at $\mathrm{V}_{\mathrm{CC}}=2.7 \mathrm{~V}$.
2. These pins have an internal pull-up device that is active while $\overline{\text { RESIN }}$ is low and ONCE Mode is not active. Sourcing more current than specified (on any of these pins) may invoke a factory test mode.
3. Tested by outputs being floated by invoking ONCE Mode or by asserting HOLD.
4. Measured with the device in RESET and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{SS}}$.
5. Measured with the device in HALT (IDLE Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{SS}}$.
6. Measured with the device in HALT (Powerdown Mode active) and at worst case frequency, $\mathrm{V}_{\mathrm{CC}}$, and temperature with

ALL outputs loaded as specified in AC Test Conditions, and all floating outputs driven to $V_{C C}$ or $V_{S S}$.
7. Output Capacitance is the capacitive load of a floating output pin.

## Icc Versus frequency and voltage

The current (lcc) consumption of the 80L188EB is essentially composed of two components; lop and Iccs.
$I_{P D}$ is the quiescent current that represents internal device leakage, and is measured with all inputs or floating outputs at GND or V $_{\mathrm{CC}}$ (no clock applied to the device). IPD is equal to the Powerdown current and is typically less than $50 \mu \mathrm{~A}$.

Iccs is the switching current used to charge and discharge parasitic device capacitance when changing logic levels. Since ICCS is typically much greater than IPD, IPD can often be ignored when calculating Icc.

ICCS is related to the voltage and frequency at which the device is operating. It is given by the formula:

$$
\begin{aligned}
& \text { Power }=\mathrm{V} \times \mathrm{I}=\mathrm{V} 2 \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f} \\
& \therefore \mathrm{I}=\mathrm{I}_{\mathrm{CC}}=\mathrm{I}_{\mathrm{CCS}}=\mathrm{V} \times \mathrm{C}_{\mathrm{DEV}} \times \mathrm{f}
\end{aligned}
$$

Where: $\mathrm{V}=$ Device operating voltage $\left(\mathrm{V}_{\mathrm{CC}}\right)$
$C_{D E V}=$ Device capacitance
$f=$ Device operating frequency
$I_{C C S}=I_{C C}=$ Device current

Measuring CDEV on a device like the 80C188EB would be difficult. Instead, $\mathrm{C}_{\text {DEV }}$ is calculated using the above formula by measuring I ICC at a known $\mathrm{V}_{\mathrm{CC}}$ and frequency (see Table 7). Using this $\mathrm{C}_{\text {DEV }}$ value, Icc can be calculated at any voltage and frequency within the specified operating range.

EXAMPLE: Calculate the typical ICC when operating at $8 \mathrm{MHz}, 3 \mathrm{~V}$.

## PDTMR PIN DELAY CALCULATION

The PDTMR pin provides a delay between the assertion of NMI and the enabling of the internal clocks when exiting Powerdown. A delay is required only when using the on-chip oscillator to allow the crystal or resonator circuit time to stabilize.

## NOTE:

The PDTMR pin function does not apply when $\overline{\text { RESIN }}$ is asserted (i.e., a device reset during Powerdown is similar to a cold reset and RESIN must remain active until after the oscillator has stabilized).

To calculate the value of capacitor required to provide a desired delay, use the equation:

$$
440 \times t=C_{P D} \quad\left(5 \mathrm{~V}, 25^{\circ} \mathrm{C}\right)
$$

Where: $t=$ desired delay in seconds
$\mathrm{C}_{\mathrm{PD}}=$ capacitive load on PDTMR in microfarads

EXAMPLE: To get a delay of $300 \mu \mathrm{~s}$, a capacitor value of $\mathrm{C}_{P D}=440 \times\left(300 \times 10^{-6}\right)=0.132 \mu \mathrm{~F}$ is required. Round up to standard (available) capacitive values.

## NOTE:

The above equation applies to delay times greater than $10 \mu \mathrm{~s}$ and will compute the TYPICAL capacitance needed to achieve the desired delay. A delay variance of $+50 \%$ or $-25 \%$ can occur due to temperature, voltage, and device process extremes. In general, higher $\mathrm{V}_{\mathrm{CC}}$ and/or lower temperature will decrease delay time, while lower $V_{C C}$ and/or higher temperature will increase delay time.

$$
\mathrm{I}_{\mathrm{cc}}=\mathrm{I}_{\mathrm{Ccs}}=3 \times 0.583 \times 8 \approx 14 \mathrm{~mA}
$$

Table 7. Device Capacitance ( $C_{\text {DEV }}$ ) Values

| Parameter | Typ | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {DEV }}$ (Device in Reset) | 0.583 | 1.02 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |
| $\mathrm{C}_{\text {DEV }}$ (Device in Idle) | 0.408 | 0.682 | $\mathrm{~mA} / \mathrm{V}^{*} \mathrm{MHz}$ | 1,2 |

1. Max $\mathrm{C}_{\text {DEV }}$ is calculated at $-40^{\circ} \mathrm{C}$, all floating outputs driven to $\mathrm{V}_{\mathrm{CC}}$ or GND, and all outputs loaded to 50 pF (including CLKOUT and OSCOUT).
2. Typical $\mathrm{C}_{\text {DEV }}$ is calculated at $25^{\circ} \mathrm{C}$ with all outputs loaded to 50 pF except CLKOUT and OSCOUT, which are not loaded.

## AC SPECIFICATIONS

AC Characteristics-(80L188EB-8)

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| TF | CLKIN Frequency | 0 | 16 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 62.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 15 | $\infty$ | ns | 1,2 |
| TCL | CLKIN Low Time | 15 | $\infty$ | ns | 1,2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1, 3 |
| TCF | CLKIN Fall Time | 1 | 8 | ns | 1,3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{CD}}$ | CLKIN to CLKOUT Delay | 0 | 50 | ns | 1,4 |
| T | CLKOUT Period |  | ${ }^{2 *} \mathrm{~T}_{C}$ | ns | 1 |
| $\mathrm{TPH}^{\text {P }}$ | CLKOUT High Time | (T/2) - 5 | (T/2) +5 | ns | 1 |
| $\mathrm{TPL}^{\text {P }}$ | CLKOUT Low Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | , | 15 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 15 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{RFSH}}$, LOCK, A19:16 | 3 | 30 | ns | 1,4,6, 7 |
| $\mathrm{T}_{\mathrm{CHOV} 2}$ | GCS0:7, LCS, $\overline{\text { UCS, }} \overline{\text { RD }}, \overline{\mathrm{WR}}$ | 3 | 35 | ns | 1,4,6,8 |
| T ${ }_{\text {clov1 }}$ | $\overline{\text { RFSH, }} \overline{\mathrm{DEN}}, \overline{\text { LOCK, RESOUT, HLDA, }}$ TOOUT, T1OUT, A19:16 | 3 | 30 | ns | 1,4,6 |
| T ${ }_{\text {clov2 }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}}: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}$, AD7:0, NCS, INTA1:0, $\overline{\text { S2:0 }}, \mathrm{A} 15: 8$ | 3 | 35 | ns | 1,4,6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, LOCK, $\overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 30 | ns | 1 |
| TCLOF | DEN, AD7:0, A15:8 | 0 | 35 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, INT4:0, T1:OIN, P2.6, P2.7 READY, CTS1:0, BCLK1:0 | 25 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CHIH }}$ | TEST, NMI, INT4:0, T1:OIN, BCLK1:0 READY, CTS1:0 | 3 |  | ns | 1,9 |
| TCLIS | AD7:0, READY | 25 |  | ns | 1,10 |
| TCLIH | READY, AD7:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 25 |  | ns | 1,9 |
| TCLIH | HOLD | 3 |  | ns | 1,9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $V_{I H}$ for high time, $V_{I L}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $T_{C}, T_{C H}$ and $T_{C L}$.
4. Specified for a 50 pF load, see Figure 10 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 11 for rise and fall times outside 50 pF .
6. See Figure 11 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV}}^{1}$ applies to $\overline{\mathrm{RFSH}}, \overline{\mathrm{LOCK}}$ and A19:8 only after a HOLD release.
8. TCHOV2 applies to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L188EB operation.

## AC SPECIFICATIONS

## AC Characteristics-(80L188EB-13)

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{F}}$ | CLKIN Frequency | 0 | 26 | MHz | 1 |
| $\mathrm{T}_{\mathrm{C}}$ | CLKIN Period | 38.5 | $\infty$ | ns | 1 |
| $\mathrm{T}_{\mathrm{CH}}$ | CLKIN High Time | 15 | $\infty$ | ns | 1,2 |
| $\mathrm{T}_{\mathrm{CL}}$ | CLKIN Low Time | 15 | $\infty$ | ns | 1, 2 |
| TCR | CLKIN Rise Time | 1 | 8 | ns | 1,3 |
| $\mathrm{T}_{\text {CF }}$ | CLKIN Fall Time | 1 | 8 | ns | 1, 3 |
| OUTPUT CLOCK |  |  |  |  |  |
| $\mathrm{T}_{\text {CD }}$ | CLKIN to CLKOUT Delay | 0 | 40 | ns | 1, 4 |
| T | CLKOUT Period |  | 2*TC | ns | 1 |
| $\mathrm{T}_{\mathrm{PH}}$ | CLKOUT High Time | (T/2) - 5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPL | CLKOUT Low Time | (T/2)-5 | $(\mathrm{T} / 2)+5$ | ns | 1 |
| TPR | CLKOUT Rise Time | 1 | 10 | ns | 1,5 |
| TPF | CLKOUT Fall Time | 1 | 10 | ns | 1,5 |
| OUTPUT DELAYS |  |  |  |  |  |
| TCHOV1 | ALE, $\overline{\text { S2:0 }}, \overline{\mathrm{DEN}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{RFSH}}$, LOCK, A19:16 | 3 | 25 | ns | 1, 4, 6, 7 |
| TCHOV2 | GCS0:7, $\overline{\text { LCS }}$, $\overline{U C S}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 3 | 30 | ns | 1, 4, 6, 8 |
| TCLOV1 | RFSH, $\overline{\mathrm{DEN}}, \overline{L O C K}$, RESOUT, HLDA, T0OUT, T1OUT, A19:16 | 3 | 25 | ns | 1, 4, 6 |
| TCLOV2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{GCS}} 7: 0, \overline{\mathrm{LCS}}, \overline{\mathrm{UCS}}, \mathrm{A} 15: 8$, AD7:0, $\bar{N} C \bar{S}, ~ \overline{N T A 1: 0}$ | 3 | 30 | ns | 1, 4, 6 |
| TCLOV3 | $\overline{\mathrm{S} 2: 0}$ | 3 | 35 | ns | 1, 4, 6 |
| TCHOF | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{RFSH}}, \mathrm{DT} / \overline{\mathrm{R}}$, $\overline{\text { LOCK, }} \overline{\text { S2:0 }}, \mathrm{A} 19: 16$ | 0 | 30 | ns | 1 |
| TCLOF | DEN, AD7:0, A15:8 | 0 | 35 | ns | 1 |
| SYNCHRONOUS INPUTS |  |  |  |  |  |
| $\mathrm{T}_{\text {CHIS }}$ | TEST, NMI, INT4:0, T1:OIN, P2.6, P2.7 READY, CTS1:0, BCLK1:0 | 20 |  | ns | 1, 9 |
| $\mathrm{T}_{\mathrm{CHIH}}$ | TEST, NMI, INT4:0, T1:OIN, BCLK1:0 READY, CTS1:0 | 3 |  | ns | 1, 9 |
| TCLIS | AD7:0, READY | 20 |  | ns | 1,10 |
| TCLIH | READY, AD7:0 | 3 |  | ns | 1,10 |
| TCLIS | HOLD | 20 |  | ns | 1,9 |
| $\mathrm{T}_{\text {CLIH }}$ | HOLD | 3 |  | ns | 1, 9 |

## NOTES:

1. See AC Timing Waveforms, for waveforms and definition.
2. Measure at $\mathrm{V}_{\mathrm{IH}}$ for high time, $\mathrm{V}_{\mathrm{IL}}$ for low time.
3. Only required to guarantee $\mathrm{I}_{\mathrm{CC}}$. Maximum limits are bounded by $\mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{CH}}$ and $\mathrm{T}_{\mathrm{CL}}$.
4. Specified for a 50 pF load, see Figure 10 for capacitive derating information.
5. Specified for a 50 pF load, see Figure 11 for rise and fall times outside 50 pF .
6. See Figure 11 for rise and fall times.
7. $\mathrm{T}_{\mathrm{CHOV} 1}$ applies to $\overline{\mathrm{RFSH}}, \overline{\mathrm{LOCK}}$ and A19:8 only after a HOLD release.
8. TCHOV2 applies to $\overline{R D}$ and $\overline{W R}$ only after a HOLD release.
9. Setup and Hold are required to guarantee recognition.
10. Setup and Hold are required for proper 80L188EB operation.

AC SPECIFICATIONS (Continued)
Relative Timings (80L188EB-13, -8)

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE TIMINGS |  |  |  |  |  |
| THLL | ALE Rising to ALE Falling | T-15 |  | ns |  |
| TAVLL | Address Valid to ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TPLLL | Chip Selects Valid to ALE Falling | $1 / 2 T-10$ |  | ns | 1 |
| TLLAX | Address Hold from ALE Falling | $1 / 2 T-10$ |  | ns |  |
| TLLWL | ALE Falling to $\overline{W R}$ Falling | $1 / 2 T-15$ |  | ns | 1 |
| TLLRL | ALE Falling to $\overline{\mathrm{RD}}$ Falling | 1/2T-15 |  | ns | 1 |
| TWHLH | $\overline{\text { WR Rising to ALE Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| TAFRL | Address Float to $\overline{\mathrm{RD}}$ Falling | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Falling to $\overline{\mathrm{RD}}$ Rising | (2*T) - 5 |  | ns | 2 |
| TWLWH |  | (2*T) -5 |  | ns | 2 |
| T ${ }_{\text {RHAX }}$ | $\overline{\mathrm{RD}}$ Rising to Address Active | $T-15$ |  | ns |  |
| TWHDX | Output Data Hold after WR Rising | T-15 |  | ns |  |
| TWHPH | $\overline{\text { WR Rising to Chip Select Rising }}$ | $1 / 2 T-10$ |  | ns | 1 |
| TRHPH | $\overline{\mathrm{RD}}$ Rising to Chip Select Rising | $1 / 2 T-10$ |  | ns | 1 |
| TPHPL | $\overline{\mathrm{CS}}$ Active to $\overline{\mathrm{CS}}$ Inactive | $1 / 2 T-10$ |  | ns | 1 |
| TovRH | ONCE Active to $\overline{\text { RESIN Rising }}$ | 1 T |  | ns |  |
| TRHOX | $\overline{\text { ONCE }}$ Hold from $\overline{\text { RESIN }}$ Rising | 1 T |  | ns |  |

## NOTES:

1. Assumes equal loading on both pins.

AC SPECIFICATIONS (Continued)
Serial Port Mode 0 Timings ( $80 \mathrm{~L} 189 \mathrm{CD}=13,-8$ )

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TXLXL | TXD Clock Period | $T(N+1)$ |  | ns | 1,2 |
| TXLXH | TXD Clock Low to Clock High ( $\mathrm{N}>1$ ) | 2T-35 | $2 T+35$ | ns | 1,2 |
| TXLXH | TXD Clock Low to Clock High ( $\mathrm{N}=1$ ) | T-35 | T+35 | ns | 1,2 |
| TXHXL | TXD Clock High to Clock Low ( $\mathrm{N}>1$ ) | $T(N-1)-35$ | $T(N-1)+35$ | ns | 2 |
| TXHXL | TXD Clock High to Clock Low ( $\mathrm{N}=1$ ) | T-35 | $T+35$ | ns | 2 |
| T QVXH | RXD Output Data Setup to TXD Clock High ( $n>1$ ) | $T(N-1)-35$ |  | ns | 1, 2 |
| T QVXH | RXD Output Data Setup to TXD Clock High ( $n=1$ ) | T-35 |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $n>1$ ) | $2 \mathrm{~T}-35$ |  | ns | 1 |
| TXHQX | RXD Output Data Hold after TXD Clock High ( $n=1$ ) | T-35 |  | ns | 1 |
| TXHQZ | RXD Output Data Float after Last TXD Clock High |  | $T+20$ | ns | 1 |
| TDVXH | RXD Input Data Setup to TXD Clock High | T+20 |  | ns | 1 |
| TXHDX | RXD Input Data Hold after TXD Clock High | 0 |  | ns | 1 |

## NOTES:

1. See Figure 9 for waveforms.
2. $n$ is the value of the BxCMP register ignoring the iCLK bit (i.e., ICLK $=0$ ).

## AC TEST CONDITIONS

The AC specifications are tested with the 50 pF load shown in Figure 4. See the Derating Curves section to see how timings vary with load capacitance.

Specifications are measured at the $\mathrm{V}_{\mathrm{CC}} / 2$ crossing point, unless otherwise specified. See AC Timing Waveforms, for AC specification definitions, test


Figure 4. AC Test Load pins, and illustrations.

## AC TIMING WAVEFORMS



Figure 5. Input and Output Clock Waveform


270920-8
NOTE:
$20 \% V_{C C}<$ Float $<80 \% V_{C C}$
Figure 6. Output Delay and Float Waveform


270920-9
Figure 7. Input Setup and Hold



Figure 8. Relative Signal Waveform


270920-11
Figure 9. Serial Port Mode 0 Waveform

## DERATING CURVES



Figure 10. Typical Output Delay Variations vs Load Capacitance


Figure 11. Typical Rise and Fall Variations vs Load Capacitance


Figure 12. PLCC Principal Dimensions


NOTE:
Units are mm (inches) unless specified.
Figure 13. QFP Principal Dimensions

## ERRATA

An 80L188EB with a STEPID value of 0001 H has the following known errata. A device with a STEPID of 0001 H can be visually identified by noting the absence of an alpha character next to the FPO number or by the presence of an "A" alpha character next to the FPO number. The FPO number location is shown in Figures 2 and 3.

1. A19/ $\overline{O N C E}$ is not latched by the rising edge of $\overline{R E S I N}$. A19/ONCE must remain active (LOW) at all times to remain in the ONCETM Mode. Removing A19/ONCE after RESIN is high will return all output pins to a driving state, however, the 80L188EB will remain in a reset state.
2. During interrupt acknowledge (INTA) bus cycles, the bus controller will ignore the state of the READY pin if the previous bus cycle ignored the state of the READY pin. This errata can only occur if the Chip-Select Unit is being used. All active chip-selects must be programmed to use READY (RDY bit must be programmed to a 1) if waitstates are required for INTA bus cycles.
3. CLKOUT will transition off the rising edge of CLKIN rather than the falling edge of CLKIN. This does not affect any bus timings other than $\mathrm{T}_{\mathrm{CICO}}$
4. $\overline{\text { RESIN }}$ has a hysterisis of only 130 mV . It is recommended that RESIN be driven with a Schmitt triggered device to avoid processor lockup during reset when using an RC circuit.
5. SINT1 will only go active for one clock period when a receive or transmit interrupt is pending (i.e., it does not remain active until the S1STS register is read). If SINT1 is to be connected to any of the 80L188EB interrupt lines (INT0-INT4), then it must be latched by user logic.

An 80L186EB with a STEPID value of 0001H or 0002 H has the following known errata. Otherwise, an 80L186EB with a STEPID value of 0002 H has no known errata (as of this publication). A device with a STEPID of 0002 H can be visually identified by noting the presence of a " $B$ " or " $C$ " alpha character next to the FPO number. The FPO number location is shown in Figures 2 and 3.

1. An internal condition with the interrupt controller can cause no acknowledge cycle on the INTA1 line in response to INT1. This errata only occurs when Interrupt 1 is configured in cascade mode and a higher priority interrupt exists. This errata will not occur consistantly, it is dependent on interrupt timing.

## REVISION HISTORY

The following changes have been made between the -001 version and this (-002) version of the 80L188EB data sheet. This -002 data sheet applies to any 80L188EB with a "B" alpha character after the FPO number. The FPO number location is shown in Figures 2 and 3.

1. The data sheet was changed from a Product Preview version to an Advanced Information version.
2. The DC specifications table has changed. Also notes have been changed/added.
3. Graphs for ICC versus Frequency have been changed to equations with supporting text.
4. Graphs for PDTMR pin capacitance have been changed to equations with supporting text.
5. Serial port MODE 0 timings have been changed.
6. Various typing errors have been corrected throughout the document.

The following changes were made between the -002 and -003 versions of the 80L186EB data sheets. The -003 data sheet applies to any 80L186EB with a " $B$ " alpha character after the FPO number. The FPO number location is shown in Figures 2 and 3.

1. 13 MHz Electrical, DC and AC Specifications were added to the appropriate sections.
2. The timing TClov3 was added to the AC Specifications for $\overline{\mathrm{S} 2: 0}$.
3. An errata appearing on both $A$ and $B$ steppings (INTA1) was added.

## 82188 <br> INTEGRATED BUS CONTROLLER FOR 8086, 8088, 80186, 80188 PROCESSORS

Provides Flexibility in System Configurations
-Supports 8087 Math Coprocessor in 8 MHz 80186 and 80188 Systems

- Provides a Low-cost Interface for 8086, 8088 Systems to an 82586 LAN Coprocessor or 82730 Text Coprocessor
Facilitates Interface to one or more Multimaster Busses
- Supports Multiprocessor, Local Bus Systems
- Allows use of 80186/80188 HighIntegration Features
- 3-State, Command Output Drivers
- Available in EXPRESS
- Standard Temperature Range - Extended Temperature Range

Available in Plastic DIP or Cerdip Package
(See Packaging Outlines and Dimensions, Order \# 231369)

The 82188 Integrated Bus Controller (IBC) is a 28 -pin HMOS III component for use with $80186,80188,8086$ and 8088 systems. The IBC provides command and control timing signals plus a configurable $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} \longleftrightarrow$ HOLD-HLDA converter. The device may be used to interface an 8087 Math Coprocessor with an 80186 or 80188 Processor. Also, an 82586 Local Area Network (LAN) Coprocessor or 82730 Text Coprocessor may be interfaced to an 8086 or 8088 with the IBC.


Figure 1. 82188 Pin Configuration


231051-2

Figure 2.
82188 Block Diagram

## PIN DESCRIPTIONS

| Symbol | Pin No. | Type | Name and Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \frac{\overline{\mathrm{S} 0}}{\frac{\mathrm{~S} 1}{\mathrm{~S} 2}} \end{aligned}$ | $\begin{aligned} & 27 \\ & 26 \\ & 25 \end{aligned}$ | 1 | Status Input Pins <br> $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ correspond to the status pins of the CPU. <br> The 82188 uses the status lines to detect and identify the processor bus cycles. The 82188 decodes $\overline{\mathrm{S} 0}-\overline{\mathrm{S} 2}$ to generate the command and control signals. $\overline{\mathbf{0} 0}-\overline{\mathrm{S} 2}$ are also used to insert 3 wait states into the SRO line during the first 25680186 bus cycles after RESET. A HIGH input on all three lines indicates that no bus activity is taking place. The status input lines contain weak internal pull-up devices. |  |  |  |
|  |  |  | $\overline{\text { S2 }}$ | $\overline{\mathbf{S 1}}$ | $\overline{\mathbf{s} 0}$ | Bus Cycle Initiated |
|  |  |  | 0 0 0 0 1 1 1 1 | 0 0 1 1 0 0 1 1 | 0 1 0 1 0 1 0 1 | interrupt acknowledge read I/O <br> write I/O <br> halt <br> instruction fetch read data from memory write data to memory passive (no bus cycle) |
| CLK | 15 | 1 | CLOCK <br> CLK is the clock signal generated by the CPU or clock generator device. CLK edges establish when signals are sampled and generated. |  |  |  |
| RESET | 5 | 1 | RESET <br> RESET is a level triggered signal that corresponds to the system reset signal. The signal initializes an internal bus cycle counter, thus enabling the 82188 to insert internally generated wait states into the SRO signal during system initialization. The 82188 mode is also determined during RESET. $\overline{R D}, \overline{W R}$, and $\overline{\mathrm{DEN}}$ are driven HIGH during RESET regardless of $\overline{\text { AEN. RESET is active HIGH. }}$ |  |  |  |
| $\overline{\text { AEN }}$ | 19 | 1 | Address Enable <br> This signal enables the system command lines when active. If $\overline{\operatorname{AEN}}$ is inactive (HIGH), $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{DEN}}$ will be tri-stated and ALE will be driven LOW (DT/ $\bar{R}$ will not be effected). $\overline{A E N}$ is an asynchronous signal and is active LOW. |  |  |  |
| ALE | 24 | 0 | Address Latch Enable <br> This signal is used to strobe an address into address latches. ALE is active HIGH and latch should occur on the HIGH to LOW transition. ALE is intended for use with transparent D-type latches. |  |  |  |
| $\overline{\text { DEN }}$ | 21 | 0 | Data Enable <br> This signal is used to enable data transceivers located on either the local or system data bus. The signal is active LOW. DEN is tri-stated when $\overline{\text { EN }}$ is inactive. |  |  |  |
| DT/ $\overline{\mathrm{R}}$ | 20 | 0 | Data TRANSMIT/RECEIVE <br> This signal establishes the direction of data flow through the data transceivers. A HIGH on this line indicates TRANSMIT (write to I/O or memory) and a LOW indicates RECEIVE (Read from I/O or memory). |  |  |  |

PIN DESCRIPTIONS (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{\text { BD }}$ | 23 | $\bigcirc$ | READ <br> This signal instructs an I/O or memory device to drive its data onto the data bus. The $\overline{\mathrm{RD}}$ signal is similiar to the $\overline{R D}$ signal of the 80186(80188) in Non-Queue-Status Mode. $\overline{\mathrm{RD}}$ is active LOW and is tri-stated when $\overline{\mathrm{AEN}}$ is inactive. |
| $\overline{W R}$ | 22 | 0 | WRITE <br> This signal instructs an I/O or memory device to record the data presented on the data bus. The WR signal is similiar to the WR signal of the 80186(80188) in Non-Queue-Status Mode. WR is active LOW and is tri-stated when $\overline{A E N}$ is inactive. |
| HOLD | 7 | 0 | HOLD <br> The HOLD signal is used to request bus control from the 80186 or 80188 . The request can come from either the 8087 ( $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ ) or from the third processor (SYSHOLD). The signal is active HIGH. |
| HLDA | 6 | 1 | HOLD Acknowledge <br> 80186 MODE-This line serves to translate the HLDA output of the $80186(80188)$ to the appropriate signal of the device requesting the bus. HLDA going active (HIGH) indicates that the 80186 has relinquished the bus. If the requesting device is the 8087, HLDA will be translated into the grant pulse of the $\overline{R Q} / \overline{G T O}$ line. If the requesting device is the optional third processor, HLDA will be routed into the SYSHLDA line. <br> This pin also determines the mode in which the 82188 will operate. If this line is HIGH during the falling edge of RESET, the 82188 will enter the 8086 mode. If LOW, the 82188 will enter the 80186 mode. For 8086 mode, this pin should be strapped to $\mathrm{V}_{\mathrm{CC}}$. |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ | 8 | 1/0 | Request/Grant 0 <br> $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ is connected to $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ of the 8087 Numeric Coprocessor. When initiated by the $8087, \overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ will be translated to HOLD-HLDA to acquire the bus from the $80186(80188)$. This line is bidirectional, and is active LOW. RQ/GTO has a weak internal pull-up device to prevent erroneous request/grant signals. |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ | 11 | 1/0 | Request/Grant 1 <br> 80186 Mode-In 80186 Mode, $\overline{R Q} / \overline{\mathrm{GT}} 1$ allows a third processor to take control of the local bus when the 8087 has bus control. For a HOLD-HLDA type third processor, the 82188 's $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 11$ line should be connected to the $\overline{\mathrm{RQ}} / \overline{\mathrm{G}} 11$ line of the 8087. <br> 8086 MODE- $\ln 8086$ Mode, $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ is connected to either $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ or $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ of the $8086 . \overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ will start its request/grant sequence when the SYSHOLD line goes active. In 8086 Mode, $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ is used to gain bus control from the 8086 or 8088 . <br> $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ is a bidirectional line and is active LOW. This line has a weak internal pull-up device to prevent erroneous request/grant signals. |

PIN DESCRIPTIONS (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| SYSHOLD | 9 | 1 | System Hold <br> 80186 MODE-SYSHOLD serves as a hold input for an optional third processor in an 80186(80188)-8087 system. If the $80186(80188)$ has bus control, SYSHOLD will be routed to HOLD to gain control of the bus. If the 8087 has bus control, SYSHOLD will be translated to $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ to gain control of the bus. <br> 8086 MODE-SYSHOLD serves as a hold input for a coprocessor in an 8086 or 8088 system. SYSHOLD is translated to $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ of the 82188 to allow the coprocessor to take control of the bus. <br> SYSHOLD may be an asynchronous signal. |
| SYSHLDA | 10 | 0 | System Hold Acknowledge <br> SYSHLDA serves as a hold acknowledge line to the processor or coprocessor connected to it. The device connected to the SYSHOLD-SYSHLDA lines is allowed the bus when SYSHLDA goes active (HIGH). |
| SRDY | 17 | 1 | Synchronous Ready <br> The SRDY input serves the same function as SRDY of the 80186(80188). The 82188 combines SRDY with ARDY to form a synchronized ready output signal (SRO). SRDY must be synchronized external to the 82188 and is active HIGH. If tied to $\mathrm{V}_{\mathrm{CC}}$, SRO will remain active (HIGH) after the first 25680186 cycles following RESET. If only ARDY is to be used, SRDY should be tied LOW. |
| ARDY | 18 | 1 | Asynchronous Ready <br> The ARDY input serves the same function as ARDY of the 80186(80188). ARDY may be an asynchronous input, and is active HIGH. Only the rising edge of ARDY is synchronized by the 82188. The falling edge must be synchronized external to the 82188. If connected to $\mathrm{V}_{\mathrm{CC}}$, SRO will remain active (HIGH) after the first 25680186 bus cycles following RESET. If only SRDY is to be used, ARDY should be connected LOW. |
| SRO | 16 | 0 | Synchronous READY Output <br> SRO provides a synchronized READY signal which may be interfaced directly with the SRDY of the 80186(80188) and READY of the 8087. The SRO signal is an accumulation of the synchronized ARDY signal, the SRDY signal, and the internally generated wait state signal. |
| $\begin{aligned} & \text { QSOI } \\ & \text { QS11 } \end{aligned}$ | $\begin{aligned} & \hline 1 \\ & 2 \end{aligned}$ | 1 | Queue-Status Inputs QSOI, QS1I are connected to the Queue-Status lines of the 80186(80188) to allow synchronization of the queuestatus signals to 8087 timing requirements. |
| $\begin{aligned} & \hline \text { QS0O } \\ & \text { QS1O } \end{aligned}$ | $\begin{aligned} & 3 \\ & 4 \end{aligned}$ | 0 | Queue-Status Outputs QS0O, QS1O are connected to the queue-status pins of the 8087. The signals produced meet 8087 Queue-Status input requirements. |

82188

## PIN DESCRIPTIONS (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| CSiN | 13 | i | C̄nip-STeieci inpui <br> CSIN is connected to one of the chip-select lines of the 80186(80188). CSIN informs the 82188 that a bank select is taking place. The 82188 routes this signal to the chip-select output (CSOUT). CSIN is active LOW. This line is not used when memory and $\mathrm{I} O$ device addresses are decoded external to the 80186(80188). |
| CSOUT | 12 | 0 | Chip-Select Output <br> This signal is used as a chip-select line for a bank of memory devices. It is active when CSIN is active or when the 8087 has bus control. CSOUT is active LOW. |

## FUNCTIONAL DESCRIPTION

## BUS CONTROLLER

The 82188 Integrated Bus Controller (IBC) generates system control and command signals. The signals generated are determined by the Status Decoding Logic. The bus controller logic interprets status lines $\overline{\mathrm{S} 0}-\overline{\mathrm{S} 2}$ to determine what type of bus cycle is taking place. The appropriate signals are then generated by the Command and Control Signal Generators.

The Address Enable ( $\overline{\mathrm{AEN}}$ ) line allows the command and control signals to be disabled. When AEN is inactive (HIGH), the command signals and $\overline{\text { DEN }}$ will be tri-stated, and ALE will be held low (DT/R will be uneffected). $\overline{A E N}$ inactive will allow other systems to take control of the bus. Control and command signals respond to a change in the $\overline{\text { AEN }}$ signal within 40 ns.

The command signals consist of $\overline{R D}$ and $\overline{W R}$. The 82188's $\overline{R D}$ and $\bar{W}$ signals are similiar to $\overline{R D}$ and WR of the 80186(80188) in the non-Queue-Status Mode. These command signals do not differentiate between memory and I/O devices. $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ can be conditioned by $\overline{\mathrm{S} 2}$ of the $80186(80188)$ to obtain separate signals for I/O and memory devices. $\overline{R D}$ is asserted during INTA cycles, unlike $\overline{R D}$ on the 80186(80188).

The control commands consist of Data Enable ( $\overline{\mathrm{DEN}}$ ), Data Transmit/Receive (DT/保), and Address Latch Enable (ALE). The control commands are similiar to those generated by the 80186(80188). DEN determines when the external bus should be enabled onto the local bus. DT/ $\overline{\mathrm{R}}$ determines the direction of the data transfer, and ALE determines when the address should be strobed into the latches (used for demultiplexing the address bus). $D T / \bar{R}$ does not go to an inactive (high) state at the end of bus cycles, unlike DT/R on the 80186(80188).

## MODE SELECT

The 82188 Integrated Bus Controller (IBC) is configurable. The device has two modes: 80186 Mode and 8086 Mode. Selecting the mode of the device configures the Bus Arbitration Logic (see BUS ARBITRATION section for details). In 80186 Mode, the 82188 IBC may be used as a bus controller/interface device for an 80186(80188), 8087, and optional third processor system. In 8086 Mode, the 82188 IBC may be used as an interface device allowing a maximum mode 8086(8088) to interface with a coprocessor that uses a HOLD-HLDA bus exchange protocol.

The mode of the 82188 is determined during RESET. If the HLDA line is LOW at the falling edge of RESET (as in the case when tied to the HLDA line of the 80186 or 80188 ), the 82188 will enter into 80186 Mode. If the HLDA line is HIGH at the falling edge of RESET, the 82188 will enter 8086 Mode. In 8086 Mode, only the Bus Arbitration Logic is used. The eight pins used in 8086 Mode are: SYSHOLD, SYSHLDA, HLDA, CLK, RESET, $\overline{R Q} / \overline{G T} 1, V_{C C}$, and $\mathrm{V}_{\mathrm{Ss}}$. The other pins may be left unconnected.

## BUS ARBITRATION

The Bus Exchange Logic interfaces up to three sets of bus exchange signals:

- HOLD-HLDA
- SYSHOLD-SYSHLDA
- $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 0$ ( $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ )

This logic executes translating, routing, and arbitrating functions. The logic translates HOLD-HLDA signals to $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ signals and $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ signals to HOLD-HLDA signals. The logic also determines which set of bus exchange signals are to be interfaced. The mode of the 82188 and the priority of the devices requesting the bus determine the routing of the bus exchange signals.

## 80186 MODE

In 80186 Mode, a system may have three potential bus masters: the 80186 or 80188 CPU, the 8087 Numerics Coprocessor, and a third processor (such as the 82586 LAN or 82730 Text Coprocessor). The third processor may have either a HOLD-HLDA or $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ bus exchange protocol. The possible bus exchange signal connections and paths for 80186 Mode are shown in Figures 3 \& 4 and Tables 1 \& 2, respectively. If no HOLD-HLDA type third processor is used, SYSHOLD should be tied LOW to prevent an erroneous SYSHOLD signal. In 80186 mode, the bus priorities are:

Highest Priority. . . . . . . . . . . . . . . . . . Third Processor
Second Highest Priority . . . . . . . . . . . . . . . . . . . . . 8087
Default Priority .................................. . . 80186

## - THREE-PROCESSOR SYSTEM OPERATION (HOLD-HLDA TYPE THIRD PROCESSOR)

In the configuration shown in Figure 3, the third processor requests the bus by sending SYSHOLD HIGH. The 82188 will route (and translate if necessary) the request to the current bus master. This includes routing the request to HOLD if the $80186(80188)$ is the current bus master or routing and translating the request to $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ if the 8087 is in control of the bus. The third processor's request is not passed through the 8087 if the 80186 is the bus master (see Table 1).

The 8087 requests the bus using $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 0$. The request pulse from the 8087 will be translated and routed to HOLD if the 80186 is the bus master. If the third processor has control of the bus, the grant pulse to the 8087 will be delayed until the third processor relinquishes the bus (sending SYSHOLD LOW). In this case, HOLD will remain HIGH during the third processor-to-8087 bus control transfer. The 80186 will not be granted the bus until both coprocessors have released it.

Table 1. Bus Exchange Paths ( 80186 Mode) (HOLD-HLDA Type 3rd Proc)

| Requesting Device | Current Bus Master |  |  |
| :---: | :---: | :---: | :---: |
|  | 80186 | 8087 | 3rd Proc |
| 80186 | n/a | n/a | n/a |
| 8087 | $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}} \stackrel{\text { HOLD }}{\text { HLDA }}$ | n/a | n/a |
| 3rd Proc | $\frac{\text { SYSHOLD }}{\text { SYSHLDA }} \longleftrightarrow \frac{\text { HOLD }}{\text { HLDA }} \quad \frac{\text { S }}{}$ | $\frac{\text { SYSHOLD }}{\text { SYSHLDA }} \longleftrightarrow \overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ | n/a |
|  |  |  |  |

Figure 3.
Bus Exchange Signal Connections ( $\mathbf{8 0 1 8 6}$ Mode) for a Three Local Processor System (HOLD-HLDA Type 3rd Proc)

Table 2. Bus Exchange Paths ( 80186 Mode) ( $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Type 3rd Proc)

| Requesting Device | Current Bus Master |  |  |
| :---: | :---: | :---: | :---: |
|  | ชิ0ิ18ิ | 8087 | 3rá Prôco |
| 80186 | n/a | n/a | $\mathrm{n} / \mathrm{a}$ |
| 8087 | $\overline{\text { RQ/GTO }} \longleftrightarrow \frac{\text { HOLD }}{\text { HLDA }}$ | n/a | $\mathrm{n} / \mathrm{a}$ |
| 3rd Proc |  | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ | n/a |



Figure 4.

## Bus Exchange Signal Connections ( 80186 Mode) for a Three Local Processor System ( $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Type 3rd Proc)

When the bus is requested from the $80186(80188)$, a bus priority decision is made. This decision is made when the HLDA line goes active. Upon receipt of the HLDA signal, the highest-priority requesting device will be acknowledged the bus. For example, if the 8087 initially requested the bus, the bus will be granted to the third processor if SYSHOLD became active before HLDA was received by the 82188. In this case, the grant pulse to the 8087 will be delayed until the third processor relinquishes the bus.

## - THREE-PROCESSOR SYSTEM OPERATION ( $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ TYPE THIRD PROCESSOR)

In the configuration shown in Figure 4, the third processor requests the bus by initiating a request/grant sequence with the 8087's $\overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}$ line. The 8087 will grant the bus if it is the current bus master or will pass the request on if the 80186 is the current bus master (see Table 2). In this configuration, the 82188's Bus Arbitration Logic translates $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} \mathbf{T 0}$ to HOLD-HLDA. The 8087 provides the bus arbitration in this configuration.

## 8086 MODE

The 8086 Mode allows an 8086,8088 system to contain both $\overline{R Q} / \overline{G T}$ and HOLD-HLDA type coprocessors simultaneously. In 8086 Mode, two possible bus masters may be interfaced by the 82188; an 8086 or 8088 CPU and a coprocessor which uses a HOLD-HLDA bus exchange protocol (typically an 82586 LAN Coprocessor or an 82730 Text Coprocessor). The bus exchange signal connections for 8086 Mode are shown in Figure 5. Bus arbitration signals used in the 8086 Mode are:

- $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$
- SYSHOLD
- SYSHLDA

In 8086 Mode, no arbitration is necessary since only two devices are interfaced. The coprocessor has bus priority over the 8086(8088). SYSHOLDSYSHLDA are routed and translated directly to $\overline{\mathrm{RQ}} /$ $\overline{\mathrm{GT}} 1 . \overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ of the 82188 may be tied to either $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ or $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ of the $8086(8088)$.


Figure 5. Bus Exchange Signal Connections ( $\mathbf{8 0 8 6}$ Mode)

## QUEUE-STATUS DELAY

The Queue-Status Delay logic is used to delay the queue-status signals from the 80186(80188) to meet 8087 queue-status timing requirements. QS01, QS11 correspond to the queue-status lines of the 80186(80188). The 82188 delays these signals by one clock phase. The delayed signals are interfaced to the 8087 queue-status lines by QS0O, QS1O.

## CHIP-SELECT

The Chip-Select Logic allows the utilization of the chip select circuitry of the 80186(80188). Normally, this circuitry could not be used in an 80186(80188)8087 system since the 8087 contains no chip select circuitry. The Chip-Select Logic contains two external connections: Chip-Select Input ( $\overline{\mathrm{CSIN}}$ ) and ChipSelect Output (CSOUT). CSOUT is active when either CSIN is active or when the 8087 has control of the bus.

By using CSOUT to select memory containing data structures, no external decoding is necessary. The 80186 may gain access to this memory bank through the CSIN line while the 8087 will automatically obtain access when it becomes the bus master. Note that this configuration limits the amount of memory accessible by the 8087 to the physical memory bank selected by CSOUT. Systems where the 8087 must access the full 1 Megabyte address space must use an external decoding scheme.

## READY

The Ready logic allows two types of Ready signals: a Synchronous Ready Signal (SRDY) and an Asynchronous Ready Signal (ARDY). These signals are similiar to SRDY and ARDY of the 80186. Wait states will be inserted when both SRDY and ARDY are LOW. Inserting wait states allows slower memory and I/O devices to be interfaced to the 80186(80188)-8087 system.

ARDY's LOW-to-HIGH transition is synchronized to the CPU clock by the 82188 . The 82188 samples ARDY at the beginning of T2, T3 and Tw until sampled HIGH. Note that ARDY of the 82188 is sampled one phase earlier than ARDY of the 80186. ARDY's falling edge must be synchronous to the CPU clock. ARDY allows an easy interface with devices that emit an asynchronous ready signal.

The SRDY signal allows direct interface to devices that emit a synchronized ready signal. SRDY must be synchronized to the CPU clock for both of its transitions. SRDY is sampled in the middle of T2, T3 and in the middle of each Tw. An 8218880186(80188)'s SRDY setup time is 30 ns longer than the 80186(80188)'s SRDY setup time. SRDY eliminates the half-clock cycle penalty necessary for ARDY to be internally sychronized.

The sychronized ready output (SRO) is the accumulation of SRDY, ARDY, and the internal wait-state
generator. SRO should be connected to SRDY of the 80186(80188) (with 80186(80188)'s ARDY tied LOW), and READY of the 8087.

| SRDY | ARDY | SRO |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 1 | $X$ | 1 |
| $X$ | 1 | 1 |

The internal wait state generator allows for synchronization between the 80186(80188) and 8087 in 80186 mode. Upon RESET, the 82188 automatically inserts 3 wait-states per 80186(80188) bus cycle, overlapped with any externally produced wait-states created by ARDY and SRDY.

Since the 8087 has no provision for internal waitstate generation, only externally created wait states will be effective. The 82188, upon RESET, will inject 3 wait states for each of the first 256 80186(80188) bus cycles onto the SRO line. This will allow the 8087 to match the 80186(80188)'s timing.

The internally-generated wait states are overlapped with those produced by the SRDY and ARDY lines. Overlapping the injected wait states insures a minimum of three wait states for the first 256 80186(80188) bus cycles after RESET. Systems with a greater number of wait states will not be affected. Internal wait state generation by the 82188 will stop on the 256th 80186(80188) bus cycle after RESET. To maintain sychronization between the 80186(80188) and 8087, the following conditions are necessary:

- The 80186(80188)'s control block must be mapped in 1/O space before it is written to or read from.
- All memory chip-select lines must be set to 0 WAIT STATES, EXTERNAL READY ALSO USED within the first 256 80186(80188) bus cycles after RESET.

An equivalent READY logic diagram is shown in Figure 6.

## SYSTEM CONSIDERATIONS

In any 82188 configuration, clock compatibility must be considered. Depending on the device, a $50 \%$ or a $33 \%$ duty-cycle clock is needed. For example, the 80186 and 80188 (as well as the 82188, 82586, and 82730 ) requires a $50 \%$ duty-cycle clock. The 8086 , 8088 and their 'kit' devices' (8087, 8089, 82C88, and 8289 ) clock requirements, on the other hand, require a $33 \%$ duty-cycle clock signal. The system designer must make sure clock requirements of all the devices in the system are met.

Figure 7 demonstrates the usage of the 82188 in 80186 Mode where it is used to interface an 8087 into an 80186 system. In this case, the clock requirements of the 8087 are met by specifying the 10 MHz (8087-1) device, but clocking the system at a maximum rate of 8 MHz .

Status bit six (S6) from the main processor (8086, 8088,80186 , or 80188 ) is used by the 8087 to track the instruction flow. S 6 is multiplexed with address bit 19 (A19). If the third processor generates only 16 bits of address, S6 is not generated. A19/S6 must be driven high by external circuitry during the status portion of bus cycles controlled by the third processor.


Figure 6. Equivalent $\mathbf{8 2 1 8 8}$ READY Circuit


## ABSOLUTE MAXIMUM RATINGS *

Temperature Under Bias ................ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature. . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Case Temperature . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Voltage on any Pin with
Respect to GND ................... -1.0V to 7.0V
Power Dissipation. . . . . . . . . . . . . . . . . . . . 0.7 Watts

NOTICE: This is a production data sheet. The specifications are subject to change without notice.
*WARNING: Stressing the device beyond the "Absolute Maximum Hatings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device réliability.

DC CHARACTERISTICS
$\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{T}_{\mathrm{CASE}}=0^{\circ} \mathrm{C}$ to $\left.+85^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min | Max | Units | Test Cond. |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | +0.8 | volts |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | volts |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | volts | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | volts | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 100 | mA | $\mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{OV}<\mathrm{V}_{\mathrm{IN}}<\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45<\mathrm{V}_{\mathrm{OUT}}<\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{CLI}}$ | CLK Input Low Voltage | -0.5 | +0.6 | volts |  |
| $\mathrm{V}_{\mathrm{CHI}}$ | CLK Input High Voltage | 3.9 | $\mathrm{~V}_{\mathrm{CC}}+1.0$ | volts |  |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF |  |
| $\mathrm{C}_{\mathrm{IO}}$ | I/O Capacitance |  | 20 | pF |  |

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{T}_{\mathrm{CASE}}=0^{\circ} \mathrm{C}$ to $\left.+85^{\circ} \mathrm{C}\right)$
TIMING REQUIREMENTS

| Symbol | Parameter | Min | Max | Units | Notes |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TCLCL | Clock Period | 125 | 500 | ns |  |
| TCLCH | Clock LOW Time | $1 / 2$ TCLCL-7.5 |  | ns |  |
| TCHCL | Clock HIGH Time | $1 / 2$ TCLCL-7.5 |  | ns |  |
| TARYHCL | ARDY Active Setup Time | 20 |  | ns |  |
| TCHARYL | ARDY Hold Time | 15 |  | ns | 8 |
| TARYLCH | ARDY Inactive Setup Time | 35 |  | ns |  |
| TSRYHCL | SRDY Input Setup Time | 65,50 |  | ns | 1 |
| TSVCH | STATUS Active Setup Time | 55 |  | ns |  |
| TSXCL | STATUS Inactive Setup Time | 50 |  | ns |  |
| TQIVCL | QSOI, QS1I Setup Time | 15 |  | ns |  |
| THAVGV | HLDA Setup Time | 50 |  | ns |  |
| TSHVCL | SYSHOLD Asynchronous Setup Time | 25 |  | ns |  |
| TGVCH | $\overline{R Q} / \overline{G T}$ Input Setup Time | 0 |  | ns | 6 |

TIMING RESPONSES

| Symbol | Parameter | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TSVLH | STATUS Valid to ALE Delay |  | 30 | ns | 4 |
| TCHLL | ALE Inactive Delay |  | 30 | ns |  |
| TCLML | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Active Delay | 10 | 70 | ns |  |
| TCLMH | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Inactive Delay | 10 | 55 | ns |  |
| TSVDTV | STATUS to DT/可 Delay |  | 30 | ns | 3 |
| TCLDTV | DT/可 Active Delay |  | 55 | ns | 3 |
| TCHDNV | $\overline{\text { DEN Active Delay }}$ | 10 | 55 | ns |  |
| TCHDNX | $\overline{\text { DEN }}$ Inactive Delay | 10 | 55 | ns |  |
| TCLQOV | QS00, QS1O Delay | 5 | 50 | ns |  |
| TCHHV | HOLD Delay |  | 50 | ns | 2,6 |
| TCLSAV | SYSHLDA Delay |  | 50 | ns | 6 |
| TCLGV | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Output Delay |  | 40 | ns | 6 |
| TGVHV | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ O To HOLD Delay |  | 50 | ns | 2,6 |
| TCLLH | ALE Active Delay |  | 30 | ns | 4 |
| TAELCV | Command Enable Delay |  | 40 | ns |  |
| TAEHCX | Command Disable Delay |  | 40 | ns |  |
| TCHRO | SRO Output Delay | 5 | 30 | ns | 5,6 |
| TSRYHRO | SRDY To SRO Delay |  | 30 | ns | 5 |
| TCSICSO | $\overline{\text { CSIN To CSOUT Delay }}$ |  | 30 | ns |  |
| TCLCSOV | CLK Low to CSOUT Delay | 10 |  | ns |  |
| TCLCSOH | CLK Low to CSOUT Inactive Delay | 10 |  | ns |  |

NOTES (applicable to both spec listing and timing diagrams):

1. TSRYHOL $=(80186$ 's) TSRYCL $+30 \mathrm{~ns}=65 \mathrm{~ns}$ for 6 MHz operation and 50 ns for 8 MHz operation.
2. Timing not tested.
3. DT/ $\overline{\mathrm{R}}$ will be asserted to the latest of TSVDTV \& TCLDTV.
4. ALE will be asserted to the latest of TSVLH \& TCLLH.
5. SRO will be asserted to the latest of TCHRO \& TSRYHRO.
6. $\mathrm{CL}=20-100 \mathrm{pF}$
7. Address/Data bus shown for reference only.
8. The falling edge of ARDY must be synchronized to CLK.
A.C. TESTING INPUT, OUTPUT WAVEFORM

A.C. TESTING LOAD CIRCUIT



Command and Control Waveforms-80186 Mode


READY Timing-80186 Mode




RQ/GT0 to HOLD-HLDA Timing-80186 Mode


Queue Status, $\overline{\text { ALE }}$, Chip Select Delay Timing-80186 Mode

## REVISION HISTORY

The sections significantly revised since version -004 are:
Bus Controlier Added note describing $\overline{\mathrm{RD}}$ during $\overline{\mathrm{INTA}}$ and $\mathrm{DT} / \overline{\mathrm{R}}$ compared to the $80160 / 00180$.
System Considerations Use of 82188 with 80186 and $8087-1$, all at 8 MHz , is clarified.
The sections significantly revised since version -002 are:
AC Characteristics TQIVCL (min.) changed from 10 ns to 15 ns . Minimum timings for $T_{C L M L}, T_{C L M H}$, and $T_{C H D N V}$ changed from 0 ns to 10 ns . TCHDNX (min.) changed from 5 ns to 10 ns. Minimum timings or TSVDTV, TCLDTV, and TCLLH are no longer indicated (they were $0 \mathrm{~ns})$. Tclcsov and $\mathrm{T}_{\mathrm{CLCSOH}}$ added.

# 80186/80188 Development Support Tools 

ICETM-186/188 FAMILY IN-CIRCUIT EMULATOR


281422-1
INCLUDING PARADIGM DEBUG/ICE WINDOWED INTERFACE

## PRODUCT OVERVIEW

The Intel ICETM-186/188 family of In-Circuit Emulators deliver outstanding 16 MHz and 20 MHz real-time emulation for the $80 \mathrm{C} 186 / 80 \mathrm{C} 188$ family of microprocessors: 80C186EB/C188EB, 80C186XL/C188XL, 80C186EA/C188EA, 80C186EC/C188EC, $80 \mathrm{C} 186 / \mathrm{C} 188$, and $80186 / 188$. The emulator is a versatile and efficient tool for developing, debugging, and testing products designed with Intel microprocessors. Included with the emulator is the standard Intel Windowed Interface and the Paradigm DEBUG/ICE Interface (based on Borland's Turbo Debugger), allowing you to choose the interface best suited for your needs. Both interfaces support Intel, Borland, and Microsoft languages including $\mathrm{C}++$ to meet your embedded design needs and accelerate your time to market.

## FEATURES

- Reliable full speed emulation up to 16 MHz and 20 MHz
- One probe, jumper-configurable for 186 or 188 support
- Two powerful windowed human interfaces with mouse support
- Source level debug with source code window, symbolic debug. and watch window operations
- Supports Intel, Borland, and Microsoft languages including $\mathrm{C}++$


## ICETM-186/188 FAMILY IN-CIRCUIT EMULATOR

- 512K or 1 MB of zero wait-state manped memory
- 4 K frames dynamic trace buffer can be displayed without stopping emulation
- Powerful GO command with two-level breakpoints. event counters and single stepping capability
- 80C187 numberic coprocessor support
- Emulation support for all Intel component packages
- High speed RS-232C and GPIB communication link
- Stand Alone Self Test (SAST) unit for software development and self test
- Complete Intel service and support


## PRODUCT HIGHLIGHTS

- Superior Intel component bondout and advanced cable technology ensures accurate and reliable high speed emulation
- Zero power consumption difference between using the emulator and the component
- Supports debugging target systems with 80C187 numeric coprocessor
- Supports all Intel software products, including C, assembler, and PL/M. Also accepts Microsoft and Borland object code. including $\mathrm{C}++$, when used in conjunction with either Paradigm Systems LOCATE or Systems and Software, Inc. LINK and LOCATE + +
- Paradigm DEBUG/ICE product includes Paradigm LOCATE, OMFCVT and TDCONVRT: everything necessary to support your embedded application
- Includes two powerful windowed human interfaces: the standard Intel interface and the Paradigm DEBUG/ICE interface, based on Borland's Turbo Debugger
- Each windowed interface enables user to open multiple windows simul- taneously, providing source code, watch variables, memory, and trace information
- Display and modify all on-chip peripheral registers
- Powerful GO command permits precise emulation control through versatile event recognition, condi-tional constructs, and internal actions (e.g., full trace buffer, event counters)
- Set software breakpoints easily in source code, hardware breakpoints on execution and bus addresses; memory and I/O cycles
- Break and trace on address and/or data specification based on single value, range, or "don't cares"
- Flexible STFP command, enabling forward/ reverse stepping and into or over function calls
- Define all or sections of map memory as Guarded, ICE, or User
- 4K trace buffer collects both execution and data bus activity in real-time. Display either instructions, cycles, or both
- Stand Alone Self Test (SAST) Unit in conjunction with emulator map mem- ory facilitates early software debug- ging and emulator confidence testing
- 512 K and 1 MB zero wait-state memory modules can be used in place of target memory for code debugging
- Programmable fastbreak for monitoring target system while in emulation
- Refresh, DMA, and HOLD/HOLDA cycles honored when emulator halted
- RS-232C serial link provides transfer rate up to 57.6 Kbytes per second. GPIB driver (in conjunction with a user supplied National Instruments (IEEE-488) GPIB communication board) provides parallel transfers at rates up to 115 Kbytes per second
- Logic analyzer support included via a 60-pin connector to emulator
- All component packages supported, either directly on the probe or through adapters
- World-wide service, support, and training available


## BENEFTTS

- Supports low power application needs. Probe draws low power current, supports true CMOS voltage input/output
- Both the Intel and Paradigm windowed interfaces increase productivity for both expert and casual users. Pull-down menus, on-line help, and mouse support simplify debugging and speeds up learning curve
- Source code window automatically updated when emulator halts, high-lighting next instruction to be executed
- Software and hardware breakpoints may be set directly in the source code window to facilitate precise emulation control
- Emulator can track user-defined program variables using the watch window. Emulator tracks the variable, not the user!
- Intel interface offers "C"-based macro commands to facilitate customized or repeated debug sessions. Extremely useful for automated manufacturing, testing and debugging

ICETM-186/188 FAMILY IN-CIRCUIT EMULATOR

- Powerful trace collection and display commands allow user to collect and display only the trace information pertinent to the debug session; no unwanted trace data filling up trace buffer
- Dynamic trace allows user to view trace buffer or modify trace conditions without stopping emulation
- Software developers may debug application code before target hardware is available using the Stand Alone Self Test (SAST) Unit with emulator map memory
- Early debugging of ROM memory simplified using emulator map memory. Memory addressable in 32 Kbyte increments. Supports debugging ROM-based applications over entire 1 MB addressing range
- Mappable I/O ports, addressable in 4 Kbyte increments, enable user to debug suspect I/O behavior. PC resources allow data 'input" from keyboard and data 'output' to the screen
- Source code window displays source code in original high-level language used to produce the object code. Simplifies and accelerates debug process
- Investigate privileged processor information during emulation using the Fastbreak feature (e.g., PCB, registers, target memory)
- DRAM refresh signals continue even when emulator halted and ensures DRAM memory not lost or corrupted. Also permits emulation in cost-sensitive applications that do not include DRAM controllers
- Continuous timer function while emulator halted allows emulator to respond to on-chip and external interrupts in real-time. Useful for critical applications where continuous interrupt-service is a requirement
- Detailed timing of specific events possible using a logic analyzer connected to the emulator. An external sync signal can
trigger the logic analyzer, enabling complex event triggering


## SERVICE, SUPPORT, AND TRAINING

- Intel offers full array of seminars, classes, workshops, field application engineering expertise, hotline technical support, and onsite service
- Software support contract available, providing technical software information, telephone support, automatic software and manual updates, 'iComments' publication and a development tools Trouble-Shooting Guide
- 90-day software warranty and one year hardware support package are standard. Includes technical hardware information, telephone support, warranty on parts, labor, material, and on-site hardware support
- Intel Development Tools offers a 30-day, money-back guarantee to customers who are dissatisfied with their Intel development tool


## SUMMARY

The ICETM-186/188 family of In-Circuit Emulators provide a versatile and efficient tool for developing, debugging, and testing products designed with the $80 \mathrm{C} 186 / 80 \mathrm{C} 188$ family of micropro- cessors. The emulator includes numerous productivity boosting features to enable you to move your products to market as quickly as possible. Intel, the inventor of the 80C186/80C188 family of micropro- cessors, offers the most complete line of development tools from a single vendor to meet all of your development needs for your embedded design.

## ICETM-186/188 FAMILY IN-CIRCUIT EMULATOR

## PHYSICAL DESCRIPTION AND CHARACTERISTICS

For all the ICE-18x emulators the maximum probe power draw from the target is 90 mA (same as the component).

ICE-18xEAXL
Table 1. ICE-18xEAXL Physical Characteristics

| Unit | Width |  | Height |  | Length |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | In. | Cm | In. | Cm | In. | Cm |
| Emulator Control Unit | 10.4 | 26.4 | 1.7 | 4.32 | 0.7 | 52.6 |
| Power Supply | 7.7 | 19.6 | 4.1 | 10.4 | 11.0 | 27.9 |
| Memory Module | 4.8 | 12.1 | 0.6 | 1.4 | 5.2 | 13.2 |
| User Probe | 4.0 | 10.2 | 0.65 | 1.6 | 7.0 | 17.8 |
| User Probe Adapter Cable |  |  |  |  | 3.4 | 8.6 |
| Stand Alone Self Test | 4.3 | 10.9 | 0.60 | 1.5 | 6.7 | 17.0 |
| Serial Cable |  |  |  |  | 144.0 | 366.0 |

ICE-18xEB:
Table 2. ICE-18xEB Physical Characteristics

| Unit | Width |  | Height |  | Length |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | In. | Cm | In. | Cm | In. | Cm |
| Emulator Control Unit | 10.4 | 26.4 | 1.7 | 4.3 | 20.7 | 52.6 |
| Power Supply | 7.7 | 19.6 | 4.1 | 10.4 | 11.0 | 27.9 |
| Memory Module | 4.8 | 12.1 | 0.6 | 1.4 | 5.2 | 13.2 |
| User Probe | 4.0 | 10.2 | 0.65 | 1.6 | 7.0 | 17.8 |
| User Probe Adapter Cable |  |  |  |  | 3.4 | 8.6 |
| Stand Alone Self Test | 4.3 | 10.9 | 0.60 | 1.5 | 6.7 | 17.0 |
| Serial Cable |  |  |  |  | 144.0 | 366.0 |

## ICETM-186/188 FAMILY IN-CIRCUIT EMULATOR

ICE-18xEC:
Table 3. ICE-18xEC Physical Characteristics

| Unit | Width |  | Height |  | Length |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | In. | Cm | In. | Cm | In. | Cm |
| Emulator Control Unit | 10.4 | 26.4 | 1.7 | 4.3 | 20.7 | 52.6 |
| Power Supply | 7.7 | 19.6 | 4.1 | 10.4 | 11.0 | 27.9 |
| Memory Module | 4.8 | 12.1 | 0.6 | 1.4 | 5.2 | 13.2 |
| User Probe | 4.0 | 10.2 | 0.65 | 1.6 | 7.0 | 17.8 |
| User Probe Adapter Cable |  |  |  | 3.4 | 8.6 |  |
| Stand Alone Self Test | 4.3 | 10.9 | 0.60 | 1.5 | 6.7 | 17.0 |
| Serial Cable |  |  |  |  | 144.0 | 366.0 |

HOST SYSTEM REQUIREMENTS

|  | Intel Interface | Paradigm IDI:BUGiICE <br> Interface |
| :--- | :--- | :--- |
| Computer | IBM PC, PS/2 or compatible, i386 <br> recommended | IBM PC, PS/2 or compatible, i386 <br> recommended |
| Operating System | MS-DOS/PC-DOS 3.3/5.0 | MS-DOS/PC-DOS 3.0 or later |
| System RAM | 520 Kbytes | 384 Kbytes |
| Expanded Memory | $1.5 \mathrm{MB}^{(1)}$ | Recommended for optimal <br> performance |
| Hard Disk | 3 MB | 1 MB |
| Communication | Serial Port (COM1 or COM2) <br> supporting at least 9600 Baud Rate <br> OR | Serial Port (COM1 or COM2) <br> supporting at least 9600 Baud Rate |
| National Instruments GPIB-PCIIA |  |  |
| board | National Instruments GPIB-PCIIA <br> board |  |
| Math Coprocessor | Required $\quad$Not required |  |

[^15]Microsoft Expanded Memory specifications. version 3.2 or later. arc available.

## ORDERING INFORMATION

| Emulator <br> (Host) | Component <br> Support | Speed <br> (MHz) | Description |
| :---: | :---: | :---: | :--- |
| ICE18XEAXLP <br> (DOS) | 80C186XL/C188XL <br> 80C186EA/C188EA <br> 80C186/C188 <br> 80186/188 | 16 | 68-pin PLCC. Includes Control Unit, probe, power <br> supply. SAST, Intel and Paradigm interfaces and <br> PLCC to LCC adapter. Requires MEM512 or <br> MEM1MB memory option. |
| ICE18XEAXLP20 <br> (DOS) | 80C186XL/C188XL <br> 80C186EA/C188EA | 20 | 68-pin PLCC Includes Control Unit, probe, power <br> supply SAST, Intel and Paradigm interfaces. <br> PLCC to LCC adapter and 512K Map Memory. |
| ICE18XEBP <br> (DOS) | 80C186EB/C188EB | 16 | 84-pin PLCC. Includes Control Unit, probe, power <br> supply, SAST and Intel and Paradigm interfaces. <br> Requires MEM512 or MEM1MB memory option. |
| ICE18XEBP20 <br> (DOS) | 80C186EB/C188EB | 20 | 84-pin PLCC includes Control Unit, probe, power <br> supply, SAST and Intel and Paradigm interfaces <br> and 512K Map Memory. |
| ICE18XECQ <br> (DOS) | 80C186EC/C188EC | 16 | 100-pin QFP. Includes Control Unit, probe, power <br> supply, SAST, and Intel and Paradigm interfaces. <br> Requires MEM512 or MEM1MB memory option. |


| Probe <br> (Host) | Component <br> Support | Speed <br> (MHz) | Description |
| :---: | :---: | :---: | :--- |
| UP18XEANLP <br> (DOS) | 80C186XL/C188NL <br> 80C186EA/C188EA <br> $80 \mathrm{C} 186 / \mathrm{C} 188$ <br> $80186 / 188$ | 16 | 68-pin PLCC. Includes probe, SAST, Intel and <br> Paradigm interfaces and PLCC to LCC adapter. |
| UP18XEBP <br> (DOS) | $80 \mathrm{C} 186 \mathrm{~EB} / \mathrm{C} 188 \mathrm{~EB}$ | 16 | 84-pin PLCC. Includes probe. SAST and Intel and <br> Paradigm Interfaces. |
| UP18XECQ <br> (DOS) | $80 \mathrm{C} 186 \mathrm{EC} / \mathrm{C} 188 \mathrm{EC}$ | 16 | 100-pin QFP. Includes probe, SAST, and Intel and <br> Paradigm Interfaces. |


| Memory | Memory Size | Description |
| :---: | :---: | :---: |
| MEM512 | 512 KBytes | 512K Emulator Map Memory for ICE-18x Emulators |
| MEM1MB | 1 MByte | 1 MB Emulator Map Memory for ICE-18x Emulators |

ICETM-186/188 FAMILY IN-CIRCUIT EMULATOR

| Emulator Software <br> (Host) | Description |
| :---: | :--- |
| PDICE18XKIT <br> (DOS) | Paradigm Debug/ICE Software for old ICE186N, ICE188N, ICE18616N and <br> ICE18816N emulators. Based on Borland Turbo Debugger. Supports all <br> Emulator Control Units. |
| PDICE18XEBKIT <br> (DOS) | Paradigm Debug/IcE Software for ICE18XEBP and ICE18XEBP20 <br> emulators. Based on Borland Turbo Debugger. |
| SWICE18XKIT(1) <br> (DOS) | Intel Windowed Human Interface for old ICE186N, ICE188N, ICE18616N <br> and ICE18816N emulators. Supports all Emulator Control Units. |
| SWICE18XEAXLKIT${ }^{(1)}$ |  |
| (DOS) |  |$\quad$| Intel Windowed Human Interface for ICE18XEAXLP and |
| :--- |
| ICE18XEAXLP20 emulators. |

Note 1: Available as S/T update only. Call 1-800-874-6835.

| Adapters | Emulator <br> Support | Description |
| :---: | :---: | :--- |
| ICEXEBONCE | ICE18XEBP <br> ICE18XEBP20 | 84-pin PLCC ONCE adapter for On-Circuit Emulation. |
| ICEXEAXLONCE | ICE18XEAXLP <br> ICE18XEAXL20 | 68-pin PLCC ONCE adapter for On-Circuit Emulation. <br> ICEXLCC <br> ICE18XEAXLP <br> ICE18XEAXLP20 |
| Adapter to convert probe from 68-pin PLCC to 68-pin |  |  |
| LCC. |  |  |

80C86/80C186 SOFTWARE DEVELOPMENT TOOLS


280809-1
Intel supports application development for the $80 \mathrm{C} 86 / 80 \mathrm{C} 186$ family of microprocessors* with a complete set of development languages and utilities. Intel software tools generate fast and efficient code and are designed to give maximum control over the processor. Most importantly they can decrease the design time of an embedded system and accelerate your product's time-to-market.

## FEATURES

- Macro assembler for high-performance code
- ANSI C compiler with numerous processor-specific extensions.
- PL/M compiler for high-level language programs with support for many lowlevel hardware functions
- Linker to link Intel-generated compiler and assembler modules together
- Locator to generate files with absolute addresses for execution from ROM-based systems
- Windowed, interactive source level debugger that works with all Intel languages
- AEDIT Source Code and text editor
- Library manager for creating and maintaining object module libraries
- Complete 8087/80C187 numeric libraries, including software emulator support
- Object-to-hex conversion utility for EPROM support


## ASM-86 MACRO ASSEMBLER

ASM-86 is used to translate symbolic assembly language source into relocatable object code where utmost speed, small code size and hardware control are critical.

## HIGHLIGHTS AND BENEFITS

- Macro facility saves development and maintenance time, since common code sequences need only be developed once.
- Simplified instruction set makes program development easier.
- Saves development time by performing extensive checks on consistent usage of variables and labels. Inconsistencies are detected when the program is assembled, before linking or debugging is started.


## iC-86 COMPILER

Intel's iC-86 brings the full power of the C programming language to embedded applications based on the 80C86/80C186 family of microprocessors. iC-86 can also be used to develop real mode programs to be executed on the 80 C 286 or the Intel 386 TM microprocessors.

## HIGHLIGHTS AND BENEFITS

- Generates compact efficient code - easily loaded into ROM-based systems.
- Highly optimized with four levels of optimization, including a jump optimizer and improved register manipulation via register history.
- Produces ROMable code - can be loaded directly into embedded target systems. Libraries completely ROMable, retargetable, and reentrant.
- Supports small, compact, medium, and large memory segmentation models. Allows memory modules to be mixed using "near" and "far" pointers.
- Extensive debug information, including type information and symbols, increases programming productivity.
- Built-in functions for automatic machine code generation improve compile-time and run-time performance. Eliminates need for in-line assembly code or making calls to assembly functions. Allows registers, I/O ports, interrupts and the numerics chips to be controlled directly in C and not in assembly code.
- ANSI C-conforming. Fully linkable with other Intel 80C86/80C186 languages such as ASM and PL/M. Allows programmers to choose optimal language(s) for application.


## PL/M-86 COMPILER

PL/M-86 is a high-level programming language designed to support the software requirements of advanced 16 -bit microprocessors. The PL/M language provides both the productivity advantages of a highlevel language and access to the low-level hardware features found in the assembly language.

## HIGHLIGHTS AND BENEFITS

- Modular and structured programming support. Final applications easier to understand, maintain, and support.
- Includes extensive list of built-in functions, e.g., TYPE CONVERSION functions, STRING manipulations, and functions for interrogating hardware flags.
- Define interrupt handling procedures using the INTERRUPT attribute. Compiler generates code to save and restore all registers for interrupt procedures.
- Compile-time options to increase flexibility of PL/M compiler. Options include four optimization levels, conditional compilation, inclusion of common PL/M source files from disk, symbol cross-referencing, and optional assembly language code in list file.
- Supports seven data types. Allows compiler to perform signed, unsigned, and floatingpoint arithmetic.
- Object modules compatible with all other object modules generated by Intel 80C86/ 80C186 languages.


## LINK-86 TOOLS

Link-86 combines multiple object modules into a single program and resolve references between independently compiled modules. Both tools can increase productivity by enabling the user to use modular programming, making applications easier to design, test, and maintain.

## HIGHLIGHTS AND BENEFITS

- Incremental linking allows new modules to be easily added to existing software.
- Final linked module can be either a bound load-time- locatable module or a relocatable module.
- .EXE option allows modules to be generated that can be executed directly in a DOS system.
- Standard modules can be reused in different applications, decreasing software development time.


## LOC-86 TOOLS

The LOC-86 tool converts relocatable 80C86/ 80 C 186 object modules into absolute object modules. Both will allow you to assign addresses.

## HIGHLIGHTS AND BENEFITS

- Default address assignment algorithm automatically assigns absolute addresses to object modules prior to loading code into target system. Frees user from concern regarding the final arrangement of the object code in memory.
- User has ability to override the control and specify absolute addresses for various Segments, Classes, and Groups in memory.
- User can reserve various parts of memory.
- Simplifies set up of bootstrap loader and initialization code for ROM-based systems. Very important and beneficial for embedded application development.
- Optional print file containing diagnostic information helpful in debugging may be generated.

LIB-86 TOOLS

Both Lib-86 creates and maintains libraries of software object modules. Standard modules can be placed in a library and linked
to your application using the LINK- 86 tool.

## OH-86 OBJECT-TO-HEXADECIMAL CONVERTER

The OH-86 utiltity converts Intel 80C86/186 object modules into standard hexadecimal format, allowing the code to be loaded directly
into PROM using industry standard PROM programmers.

## NUMERICS SUPPORT LIBRARIES

The 8027/80C187 numerics libraries fully support the 8087 and $80 \mathrm{C187}$ math coprocessors, with or without the math coprocessor in the final system; numeric functions may be processed by the math coprocessor or by the corresponding software emulator.

## Numerics Software Emulator

- For applications without a math coprocessor
- Executes instructions as though coprocessor present; functionality identical to math coprocessor.
- Ideal for prototyping and debugging floating point application code independent of hardware; supports portable code.
Numerics Support Library
- For applications with a math coprocessor
- Provide Intel ASM, C, PL/M, and FORTRAN users with enhanced numeric data processing capability; easy to do floating point math.


## HIGHLIGHTS AND BENEFITS

- 4 functionally distinct libraries support floating point operations.
- Common elementary function library: algebraic, logarithmic, exponential, trignometric and hyperbolic operations on real and complex numbers. Real-tointeger conversions
- Initialization library: Set up the numerics processing environment (math coprocessor or software emulator).
- Decimal conversion library: Converts floating point numbers from one binary storage format to another, from ASCII decimal strings to binary floating point format, or vise- versa.
- Error handling library: Simplifies coding numerics exception handlers.
- All support library modules in OMF-86 format; can be linked with object output of any Intel language.
- All library routines reentrant and ROMable.
- Meets industry standard (ANSI/IEEE standard for binary floating point arithmetic, 754-1985)


## DB-86 SOURCE LEVEL DEBUGGER

DB-86 is a DOS-hosted, high-level source code debugger for programs written in C, PL/M, FORTRAN, and Pascal. Its powerful, sourceoriented interface allows users to focus their efforts on finding bugs, not learning how to use the debug environment.

## HIGHLIGHTS AND FEATURES

- Drop-down menus and on-line help decrease learning time for beginning users.
- Watch windows, conditional breakpoints, trace points and fixed and temporary
breakpoints can be set and modified as needed.
- Browse Source and Call Stack, review processor registers, observe watch window variables - all accessed via a pull down menu or single keystroke.
- Uses extensive debug information available in Intel languages to display program variables in their respective type formats.
- Provides support for overlayed programs and the math coprocessors.


## AEDIT SOURCE CODE AND TEXT EDITOR

Aedit is a full-screen text editing system designed specifically for software engineers and technical writers. The output file is the pure ASCII text (or HEX code) you input - no special characters or proprietary formats. Its numerous features and advanced capabilities make it an excellent tool to support the 80C86/ 80 C 186 development environment.

## HIGHLIGHTS AND BENEFITS

- Complete range of editing support-from document processing to HEX code entry and modification
- Supports system escape for quick execution of PC-DOS System level commands
- Full macro support for complex or repetitive editing tasks
- Supports multiple operating systems including DOS and iRMX
- Dual file support with optional split-screen windowing
- No limit to file size or line length
- Quick response with an easy to use menu driven interface
- Configurable and extensible for complete control of the editing process.


## WORLDWIDE SERVICE, SUPPORT, AND TRAINING

To augment its development tools, Intel offers a full array of seminars, classes, and workshops, field application engineering expertise, hotline technical support and on-site service.

Intel also offers a Software Support package which includes technical software information, telephone support, automatic distribution of software and documentation updates, access to the "Tooltalk" electronic bulletin board. "iComments" publication, remote diagnostic software, and a development tools troubleshooting guide.

Intel's Hardware Support package includes technical hardware information, telephone support, warranty on parts, labor, material, and on-site hardware support.

## SUMMARY

Intel provides a complete software development toolset that delivers full access to the 80C86/80C186 microprocessors. The development tools are easy to use, yet powerful, with productivity boosting features
such as source-level symbolic debugging and an up-to-date user interface. Each tool is designed to help you move quickly your application from the lab to the market.

## ORDERING INFORMATION

## 80C86/80C186

D86ASM86KIT ASM-86

D86EDNL AEDIT
AEDIT

D86C86NL iC-86 Software Package for IBM PC XT/AT running PC DOS 3.0 or higher
D86PLM86NL PL/M-86 Software Package for IBM PC XT/AT running PC DOS 3.0 or higher
Assember for PC XT or AT system (or compatible) running DOS 3.0 or higher

AEDIT Source Code Editor for IBM PC XT/AT running PC DOS 3.0 or higher
(8)

## EV80C186EA/XL Evaluation Board



272049-01

## Low Cost Code Evaluation Tool

Intel's EV80C186EA/XL evaluation board provides a hardware environment for code execution and software debugging. The board features the 80C186EA CHMOS*, 16-bit embedded microprocessor and the necessary peripheral logic to allow you to take full advantage of the -EA and -XL. Powerdown and Idle Modes are a key feature of the 80C186EA/C188EA for those 186 designs which are power consumption sensitive. The 80C186XL/C188XL device is an extension of the highly successful 80C186/C188 device with the added capabilities of a static, low power design and maximum 20 MHz operation. The EV80C186EA/XL provides 20 MHz execution of your code using one wait state. Plus, it can be quickly configured for an 80C188EA, 80 C 186 XL or 80 C 188 XL .
Popular features such as single-step program execution and sixteen software breakpoints are standard on the EV80C186EA/XL. Intel provides a complete code development environment using assembler (ASM-86) as well as high-level languages such as Intel's iC-86, FORTRAN-86, Pascal-86 or PL/M-86 to accelerate your development schedules.
The evaluation board is hosted on an IBM PC* or BIOS-compatible computer. The source code for the on-board monitor (written in ASM-86) is public domain. The program is about 2 K , and can be modified to be included in your target hardware. In this way, the provided PC host software can be used throughout the development phase. In addition, there are retargetable debuggers available from Third Party vendors to further enhance your debug process.

## EV80C186EA/XL Evaluation Board

## EVSOC186EA/XL Features

- 20 MHz , One Wait State Execution Speed
- 32 Kbytes of SRAM/ROMsim (Expandable)
- 512 Kbytes of DRAM
- All-CMOS Board for Low Power
- Supports Intel Flash Memory
- Sixteen Software Breakpoints
- Two Single-Step Modes
- RS-232C Communication Link
- Concurrent Interrogation of Memory and Registers
- Easily Re-configured to Support 80C188EA, 80C186XL, 80C188XL
- High-Level Language Support


## Full Speed Execution

The EV80C186EA/XL executes your code from on-board ROMsim at 20 MHz with one wait state. By changing oscillators on the evaluation board, any execution speed up to 20 MHz can be evaluated. The board's host interface baud rate is not affected by this frequency change.

## 32 Kbytes of ROMsim

The board comes with 32 Kbytes of SRAM to be used as ROMsim for your code and for data memory as needed. The SRAM sockets support up to 128 Kbytes of SRAM.

## 512 Kbytes of DRAM

The EV80C186EA/XL comes with 512 Kbytes of DRAM; the necessary control logic is already there. The monitor utilizes the Refresh Control Unit and will set up the DRAM refresh controller for you.

## Supports Intel Flash Memory

The EPROM sockets optionally accommodate 128 Kbytes of Flash Memory. The EV80C186EA/XL provides switched VPP for program and erase cycles.

## Totally CMOS Board

The EV80C186EA/XL board is built totally with CMOS components, including programmable logic devices. Its power consumption is therefore low, requiring 5 V at 400 mA . The board also requires $\pm 12 \mathrm{~V}$ at 100 mA .

## Concurrent Interrogation of Memory and Registers

The monitor for the EV80C186EA/XL allows you to read and modify external memory and read internal registers while your code is running in the board. You may only modify internal registers while your code is halted.

## Sixteen Software Breakpoints

There are sixteen breakpoints available which automatically subsitute an INT3 instruction for your code instruction at the breakpoint location. The substitution occurs when execution is started. If the processor is halted or a breakpoint is reached, your code is restored in the ROMsim.

## Two Step Modes

There are two single-step modes available. The first stepping mode uses the Trap Flag feature of the X86 architecture. The second mode also uses the Trap Flag except for subroutine calls which are treated as one indivisible instruction by placing an INT3 after them.


## EV80C186EA/XL Evaluation Board

## High-Level Language Support

The host software for the EV80C186EA/XL board is able to load absolute object code generated by ASM-86, iC-86, FORTRAN-86, Pascal-86 or PL/M-86, all of which are available from Intel.

## RS-232C Communication Link

The EV80C186EA/XL communicates with the host using an Intel 82510 Asynchronous Serial Controller provided on board.

## Personal Computer Requirements

The EV80C186EA/XL Evaluation Board is hosted on an IBM PC, XT, AT* or
BIOS-compatible personal computer. The PC must meet the following minimum requirements:

- 512 Kbytes of Memory
- A Serial Port (COM1 or COM2) at 9600 Baud
- One 360 Kbyte Floppy Disk Drive
- ASM-86, iC-86, FORTRAN-86, Pascal 86 or PL/M-86
- PC DOS 3.1 or Later
- A text editor such as AEDIT


## EV80C186EB Evaluation Board



270882-1

## Low Cost Code Evaluation Tool

Intel's EV80C186EB evaluation board provides a hardware environment for code execution and software debugging at a relatively low cost. The board features the 80C186EB CHMOS*, 16-bit embedded processor, a new member of the industry standard 80186 family. The 80C186EB features two independent serial channels providing a serial link for easy interprocessor communications, diagnostic and modem interfacing for today's "Mobile Office." This static design also features power management modes for power consumption sensitive designs. The board allows you to take full advantage of the power of the 80186 family. The EV80C186EB provides zero wait state, 16 MHz execution of your code. Plus, it can be quickly reconfigured to use an 80 C 188 EB , allowing for exact analysis of code execution speeds in a particular application.
Popular features such as single-step program execution and sixteen software breakpoints are standard on the EV80C186EB. Intel provides a complete code development environment using assembler (ASM-86) as well as high-level languages such as Intel's iC-86, FORTRAN-86, Pascal-86 or PL/M-86 to accelerate development schedules.
The evaluation board is hosted on an IBM PC** or BIOS-compatible computer. The source code for the on-board monitor (written in ASM-86) is public domain. The program is about 2 K , and can be modified to be included in your target hardware. In this way, the provided PC host software can be used throughout the development phase. In addition, there are retargetable debuggers available from Third Party vendors to further enhance your debug process.

[^16]
## EV80C186EB Features

- Zero Wait State 16.0 MHz Execution Speed
- 32 Kbytes of SRAM/ROMsim
- 512 Kbytes of DRAM
- All-CMOS board for Low Power
- Concurrent Interrogation of Memory and Registers
- Sixteen Software Breakpoints
- Two Single-Step Modes
- High-Level Language Support
- RS-232C Communication Link
- Easily Re-configured to Support 80C188EB


## Full Speed Execution

The EV80C186EB executes your code from onboard ROMsim at 16.0 MHz with zero wait states. By changing oscillators on the EV80C186EB, any execution speed up to 16 MHz can be evaluated. The board's host interface baud rate is not affected by this frequency change.

## 32 Kbytes of ROMsim

The board comes with 32 Kbytes of SRAM to be used as ROMsim for your code and for data memory as needed.

## 512 Kbytes of DRAM

The EV80C186EB comes with 512 Kbytes of DRAM; the necessary control logic is already there. The monitor utilizes the Refresh Control Unit and will set up the DRAM refresh controller for you.

## Totally CMOS Board

The EV80C186EB board is built totally with CMOS components. Its power consumption is therefore low, requiring 5 V at 400 mA . The board also requires $\pm 12 \mathrm{~V}$ at 15 mA .

## Concurrent Interrogation of Memory and Registers

The monitor for the EV80C186EB allows you to read and modify external memory and read internal registers while your code is running in the board. You may only modify internal registers while your code is halted.

## Sixteen Software Breakpoints

There are sixteen breakpoints available which automatically substitute an INT3 instruction for your code instruction at the breakpoint location. The substitution occurs when execution is started. If processor is halted or a breakpoint is reached, your code is restored in the ROMsim.

## Two Step Modes

There are two single-step modes available. The first stepping mode uses the Trap Flag feature of the X86 architecture.
The second mode also uses the Trap Flag except for subroutine calls which are treated as one indivisible instruction by placing an INT3 after them.


## EV80C186EB Evaluation Board

## High-Level Lañguage Suppofit

The host software for the EV80C186EB board is able to load absolute object code generated by ASM-86, iC86, FORTRAN-86, Pascal-86 or PL/M-86, all of which are available from Intel.

## RS-232C Communication Link

The EV80C186EB communicates with the host using an Intel 82510 Asynchronous Serial Controller provided on board.

## Pérsoñal Cómpüuter Reqüirements

The EV80C186EB Evaluation Board is hosted on an IBM PC XT, AT** or BIOS-compatible personal computer. The PC must meet the following minimum requirements:

- 512 Kbytes of Memory
- One 360 Kbyte Floppy Disk Drive
- PC DOS 3.1 or Later
- A Serial Port (COM1 or COM2) at 9600 Baud
- ASM-86, iC-86, FORTRAN-86, Pascal-86 or PL/M-86
- A text editor such as AEDIT

EV80C186EC Evaluation Board

## Low Cost Code Evaluation Tool

Intel's EV80C186EC evaluation board provides a hardware environment for code execution and software debugging. The board features the 80 C 186 EC CHMOS*, 16 -bit embedded microprocessor and all necessary memory and peripheral logic. The 80C186EC is the highest integration member of the highly successful 80C186/C188 family of embedded microprocessors. The EV80C186EC evaluation board provides 16 MHz , zero wait state, execution of your code. A dip switch configures the EV80C186EC for use with the 80 C 188 EC for applications requiring an 8 -bit data bus.
Popular features such as single-step program execution and software breakpoints are standard on the EV80C186EC. Intel provides a complete code development environment including ASM-86, iC-86, FORTRAN-86, Pascal-86 and PL/M-86.
The evaluation board is hosted on an IBM PC** or compatible computer. The source code for the on-board monitor (written in ASM-86) is public domain. The program is about 2 Kbytes in length and can be modified for inclusion in your target hardware. In addition, there are retargetable debuggers available from third party vendors to further enhance your development process.

## EV80C186EC Features

- 16 MHz , Zero Wait State Execution Speed
- 64 Kbytes of SRAM (Expandable)
- 512 Kbytes of DRAM
- All-CMOS Board for Low Power
- Supports Intel Flash Memory
- Sixteen Software Breakpoints
- Two Single-Step Modes
- RS-232C Communications Link
- Concurrent Interrogation of Memory and Registers
- Easily Reconfigurable to Support 80C188EC
- High-Level Language Support


## Full Speed Execution

The EV80C186EC executes your code from the on-board RAM at 16 MHz with no wait states. By changing oscillators on the evaluation board, any execution speed up to 16 MHz can be evaluated. The boards host interface rate is independent of CPU frequency.

## 32 Kbytes of SRAM

The EV80C186EC comes with 64 Kbytes of SRAM for your code and data. The SRAM sockets will accept up to 128 Kbyte SRAMs when expansion is necesary.

## 512 Kbytes of DRAM

The EV80C186EC comes with 512 Kbytes of DRAM; the necessary control logic is already there. The monitor uses the onchip Refresh Control Unit and sets up the DRAM controller automatically.

## Supports Intel Flash Memory

The EPROM sockets optionally accommodate the 28F001BX-T 128 Kbyte Flash Memory. The EV80C186EC provides an on-board $V_{\text {PP }}$ switching circuit and built in programming procedures.

## Totally CMOS Board

The EV80C186EC is built entirely with CMOS components, including programmable logic devices. Its power consumption is therefore low, requiring 5 V at 500 mA . The board also requires $\pm 12 \mathrm{~V}$ at 100 mA .

## Concurrent Interrogation of Memory and Registers

The monitor for the EV80C186EA/XL allows you to read and modify external memory and read internal registers while your code is running on the board. You may only modify internal registers while your code is halted.

[^17]
## EV80C186EC Evaluation Board

## Sixteen Software Brankpoints

There are sixteen breakpoints available which automatically substitute an INT3 instruction for your code instruction at the breakpoint location. The substitution occurs when execution is started. If the processor is halted or a breakpoint is reached, your code is restored in the RAM.

## Two Step Modes

There are two single-step modes available. The first stepping mode uses the Trap Flag feature of the X86 architecture. The second mode also uses the Trap Flag except for subroutine calls which are treated as one indivisible instruction by placing an INT3 after them.

## High-Level Language Support

The host software for the EV80C186EA/XL board is able to load absolute object code generated by ASM-96, iC-86, FORTRAN-86, Pascal-86 or PL/M-86, all of which are available from Intel.

## RS-232C Communication Link

The EV80C186EA/XL communicates with the host using an Intel 82510 Asynchronous Serial Controller provided on board.

## Personal Computer Requirements

The EV80C186EC Evaluation Board is hosted on an IBM, PC, XT, $\mathrm{AT}^{* *}$ or compatible personal computer. The PC must meet the minimum requirements:

- 512 Kbytes of Memory
-A Serial Port (COM1 and COM2) at 9600 Baud
-One 360 Kbyte Floppy Disk Drive
-ASM-86, iC-86, FORTRAN-86, Pascal-86 or PL/M-86
- PC DOS** 3.1 or Later


## DB86A ARTIC SOFTWARE DEBUGGER



280914-1

## Multitasking Source Level Debugger

The DB86A ARTIC debugger from Intel is a powerful source-level debugger designed to support the development of multitasking applications targeted to run on the full family of IBM* ARTIC cards. The DB86A ARTIC debugger is hosted on an IBM PC/AT*, PS/2* or compatible computer running DOS or OS/2* (DOS compatibility box only). Using an RS232 link to an IBM ARTIC card, the debugger contains control and monitoring capabilities for on-target software debugging. The DB86A debugger delivers an optimum debugging environment for application code generated by IBM C/2*, IBM MASM/2*, Microsoft C*, and Microsoft MASM*.
The DB86A debugger features a contemporary windowed human interface, symbolic source level debug, tasking controls, extensive breakpoint modes, and flexible stepping capabilities. This multitasking debug environment boosts productivitiy by allowing you to focus efforts on finding bugs more quickly, and reducing time-to-market.

## DB86A Debugger Features

- Menu-driven Windowed Human Interface
- Source Level Debug with various Source Window and Watch Window Operations
- Multitasking Debug Support
- High-level and Assembly Language Symbolic Debugging
- Extensive Breakpoint and Stepping Capabilities
- Powerful Procedural Command Language
- On-line Help Facility
- Built-in Assembler and Disassembler
- Memory and Register Manipulations
- Intel Service and Support


## Windowed Human Interface

The DB86A Artic Debugger offers a windowed user interface that is easy for both experienced and new users.
Pull-down menus provide a set of commonly used debug operations, shortening learning curves. Many debugging functions can be executed with a single key stroke. Custom debug commands and the command line interface offer experienced users increased efficiency. Multiple windows simultaneously display source code, watch variables, and registers. Source breakpoints support the point-and-shoot technique of debugging, or breakpoints can be easily set through the source window. When the debugger completes a breakpoint or stepping operation, the various windows are updated. The watch window can track up to six program variables. The on-line help facility provides command syntax and explanation as well as error descriptions.

## Event Monitor Capability

DB86A provides many ways to monitor events. There are four conditional breakpoints, ten source breakpoints, ten temporary breakpoints, and ten passpoints. Each type of breakpoint meets different debugging needs. The stepping commands not only allow execution of one machine-level instruction or one high-level language statement at a time, they also permit stepping over or stepping through a procedure until it returns.

## Procedural Command Language

The command language of the DB86A debugger provides control constructs, procedures, and debug variables allowing the user to extend and customize the functionality of the debugger. Control constructs (e.g. If...else, do...while) facilitate the grouping of a sequence of debugger commands and control the execution of the sequence. For debug sequences that are repeated frequently, the user can define debug procedures containing a sequence of debugger commands, control constructs, and debug variables. DB86A debugger comes with a set of predefined debug procedures that display various ARTIC system data structures such as interface blocks, task tables, and task control block tables.

## Mitltitasking Debug Support

The DB86A debugger delivers control and monitor capabilities to simplify multitasking debug. You can download multiple tasks to the target system, and easily select any task for viewing and debugging.
Corresponding windows are automatically updated when a task hits a breakpoint. Tasks can be suspended and resumed. Breakpoints can be set for all, or for specific tasks. Qualifiers are provided with the debugger commands to facilitate multitasking debug.

## Symbolic Debug Capabilities

The debugger makes full use of the symbolic and typing information passed by the code translators. Source code symbolics are enabled in debugging operations and displays. The debugger supports easy browsing through modules in each task. The Callstack feature creates a snapshot of the active call chain, and call stack browsing lets you navigate through the source code of the procedure call chain. Task memory and registers can be displayed and modified easily. An on-line assembler is provided for in-target code patching.

## Worldwide Service, Support, and Training

To augment its development tools, Intel offers field application engineering expertise, hotline technical support, and on-site service.
Intel also offers software support which includes technical software information, telephone support, automatic distributions of software and documentation updates, iCOMMENTS magazine, remote diagnostic software, and a development tools troubleshooting guide.
Intel Development Tools also offers a 30-day, money-back guarantee to customers who are not satisfied after purchasing any Intel development tool.

## SPECIFICATIONS

## Host System Requirements

IBM PC/AT or IBM PS/ 2 or fully compatible computers with the following minimum configurations:

- Minimum of 900 Kbytes free hard disk space for DB86A
- 640 Kbytes of RAM recommended; DB86A uses a minimum of 360 Kbytes of RAM
- A serial port (COM1 or COM2)
- DOS V3.3 or later, OS/2 V1.2 (DOS Compatibility Box Only)
- One floppy drive capable of reading $5.25^{\prime \prime}$ diskettes or $3.5^{\prime \prime}$ diskettes


## Target System Requirements

- One ARTIC RS232 serial port
- 8 Kbytes free RAM on the target ARTIC Board for DB86A debug support task
- Target system containing one of the following ARTIC cards:
IBM Realtime Interface Coprocessor IBM Realtime Interface Coprocessor Multiport
IBM Realtime Interface Coprocessor Multiport Model 2
IBM X. 25 Interface Coprocessor/2
IBM Realtime Interface Coprocessor Multiport/2
IBM Realtime Interface Coprocessor Portmaster/A


# i376 ${ }^{\text {TM }}$ Processor and Peripherals Data Sheets 

## 376™ ${ }^{\text {T }}$ HIGH PERFORMANCE 32-BIT EMBEDDED PROCESSOR

Full 32-Bit Internal Architecture

- 8-, 16-, 32-Bit Data Types
- 8 General Purpose 32-Bit Registers
- Extensive 32-Bit Instruction Set
- High Performance 16-Bit Data Bus
- 16 or 20 MHz CPU Clock
- Two-Clock Bus Cycles
- 16 Mbytes/Sec Bus Bandwidth
- 16 Mbyte Physical Memory Size
- High Speed Numerics Support with the 80387SX
- Low System Cost with the 82370 Integrated System Peripheral
- On-Chip Debugging Support Including Break Point Registers
- Complete Intel Development Support
- C, PL/M, Assembler
— ICETM-376, In-Circuit Emulator
- iRMKTM Real Time Kernel
—iSDMTM Debug Monitor
- DOS Based Debug
- Extensive Third-Party Support:
- Languages: C, Pascal, FORTRAN, BASIC and ADA*
— Hosts: VMS*, UNIX*, MS-DOS*, and Others
— Real-Time Kernels
■ High Speed CHMOS IV Technology
- Available in $\mathbf{1 0 0}$ Pin Plastic Quad FlatPack Package and 88-Pin Pin Grid Array (See Packaging Outlines and Dimensions \#231369)


## INTRODUCTION

The 376 32-bit embedded processor is designed for high performance embedded systems. It provides the performance benefits of a highly pipelined 32-bit internal architecture with the low system cost associated with 16-bit hardware systems. The 80376 processor is based on the 80386 and offers a high degree of compatibility with the 80386 . All 80386 32-bit programs not dependent on paging can be executed on the 80376 and all 80376 programs can be executed on the 80386 . All 32 -bit 80386 language translators can be used for software development. With proper support software, any 80386-based computer can be used to develop and test 80376 programs. In addition, any 80386 -based PC-AT* compatible computer can be used for hardware prototyping for designs based on the 80376 and its companion product the 82370 .


Intel, iRMK, ICE, 376, 386, Intel386, iSDM, Intel1376 are trademarks of Intel Corp.
*UNIX is a registered trademark of AT\&T.
ADA is a registered trademark of the U.S. Government, Ada Joint Program Office.
PC-AT is a registered trademark of IBM Corporation.
VMS is a trademark of Digital Equipment Corporation.
MS-DOS is a trademark of MicroSoft Corporation.

### 1.0 PIN DESCRIPTION



Figure 1.1. 80376 100-Pin Quad Flat-Pack Pin Out (Top View)

Table 1.1. 100-Pin Plastic Quad Flat-Pack Pin Assignments

| Address |  | Data |  | Control |  | N/C | $V_{\text {cc }}$ | $\mathbf{V}_{\mathbf{S S}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{A}_{1}$ | 18 | $\mathrm{D}_{0}$ | 1 | $\overline{\text { ADS }}$ | 16 | 20 | 8 | 2 |
| $A_{2}$ | 51 | $\mathrm{D}_{1}$ | 100 | BHE | 19 | 27 | 9 | 5 |
| $\mathrm{A}_{3}$ | 52 | $\mathrm{D}_{2}$ | 99 | BLE | 17 |  | 10 | 11 |
| $\mathrm{A}_{4}$ | 53 | $\mathrm{D}_{3}$ | 96 | $\overline{\text { BUSY }}$ | 34 | 29 | 21 | 12 |
| $\mathrm{A}_{5}$ | 54 | $\mathrm{D}_{4}$ | 95 | CLK2 | 15 | 30 | 32 | 13 |
| $A_{6}$ | 55 | $\mathrm{D}_{5}$ | 94 | D/C | 24 | 31 | 39 | 14 |
| $\mathrm{A}_{7}$ | 56 | $\mathrm{D}_{6}$ | 93 | ERROR | 36 | 43 | 42 | 22 |
| $\mathrm{A}_{8}$ | 58 | $\mathrm{D}_{7}$ | 92 | FLT | 28 | 44 | 48 | 35 |
| $\mathrm{A}_{9}$ | 59 | $\mathrm{D}_{8}$ | 90 | HLDA | 3 | 45 | 57 | 41 |
| $\mathrm{A}_{10}$ | 60 | $\mathrm{D}_{9}$ | 89 | HOLD | 4 | 46 | 69 | 49 |
| $\mathrm{A}_{11}$ | 61 | $\mathrm{D}_{10}$ | 88 | INTR | 40 | 47 | 71 | 50 |
| $\mathrm{A}_{12}$ | 62 | $\mathrm{D}_{11}$ | 87 | $\overline{\text { LOCK }}$ | 26 |  | 84 | 63 |
| $\mathrm{A}_{13}$ | 64 | $\mathrm{D}_{12}$ | 86 | M/ $\overline{\mathrm{IO}}$ | 23 |  | 91 | 67 |
| $\mathrm{A}_{14}$ | 65 | $\mathrm{D}_{13}$ | 83 | $\overline{N A}$ | 6 |  | 97 | 68 |
| $\mathrm{A}_{15}$ | 66 | $\mathrm{D}_{14}$ | 82 | NMI | 38 |  |  | 77 |
| $\mathrm{A}_{16}$ | 70 | $\mathrm{D}_{15}$ | 81 | PEREQ | 37 |  |  | 78 |
| $\mathrm{A}_{17}$ | 72 |  |  | READY | 7 |  |  | 85 |
| ${ }_{\text {A }}^{18}$ | 73 |  |  | PECSET | 33 |  |  | 38 |
| $\mathrm{A}_{19}$ | 74 |  |  | $\overline{W / R}$ | 25 |  |  |  |
| $\mathrm{A}_{20}$ | 75 |  |  |  |  |  |  |  |
| $\mathrm{A}_{21}$ | 76 |  |  |  |  |  |  |  |
| $\mathrm{A}_{22}$ | 79 |  |  |  |  |  |  |  |
| $\mathrm{A}_{23}$ | 80 |  |  |  |  |  |  |  |

Top View
(Component Side)

240182-49
Bottom View
(Pin Side)


Figure 1.2. 80376 88-Pin Grid Array Pin Out

Table 1.2. 88-Pin Grid Array Pin Assignments

| Pin | Label | Pin | Label | Pin | Label | Pin | Label |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 2 H | CLK2 | 120 | $\mathrm{A}_{18}$ | 21 | M/ $\overline{\mathrm{O}}$ | 11A | $V_{\text {CC }}$ |
| 9B | $\mathrm{D}_{15}$ | 12E | $\mathrm{A}_{17}$ | 5M | LOCK | 13A | $V_{\text {cc }}$ |
| 8A | $\mathrm{D}_{14}$ | 13E | $\mathrm{A}_{16}$ | 1 J | $\overline{\text { ADS }}$ | 13C | $V_{C C}$ |
| 8B | $\mathrm{D}_{13}$ | 12F | $\mathrm{A}_{15}$ | 1H | READY | 13L | $V_{C C}$ |
| 7A | $\mathrm{D}_{12}$ | 13F | $\mathrm{A}_{14}$ | 2G | $\overline{\mathrm{NA}}$ | 1 N | $\mathrm{V}_{\text {cc }}$ |
| 7B | $\mathrm{D}_{11}$ | 12G | $\mathrm{A}_{13}$ | 1G | HOLD | 13N | $V_{C C}$ |
| 6A | $\mathrm{D}_{10}$ | 13G | $\mathrm{A}_{12}$ | 2F | HLDA | 11B | $V_{S S}$ |
| 6B | $\mathrm{D}_{9}$ | 13H | $\mathrm{A}_{11}$ | 7 N | PEREQ | 2 C | $V_{S S}$ |
| 5A | $\mathrm{D}_{8}$ | 12H | $\mathrm{A}_{10}$ | 7M | BUSY | 1D | $V_{\text {SS }}$ |
| 5B | $\mathrm{D}_{7}$ | 13 J | $\mathrm{A}_{9}$ | 8 N | ERROR | 1M | $V_{S S}$ |
| 4B | $\mathrm{D}_{6}$ | 12 J | $\mathrm{A}_{8}$ | 9M | INTR | 4N | $\mathrm{V}_{\text {SS }}$ |
| 4A | $\mathrm{D}_{5}$ | 12K | $\mathrm{A}_{7}$ | 8M | NMI | 9 N | $V_{\text {SS }}$ |
| 3B | $\mathrm{D}_{4}$ | 13K | $\mathrm{A}_{6}$ | 6M | RESET | 11 N | $V_{S S}$ |
| 2D | $\mathrm{D}_{3}$ | 12L | $\mathrm{A}_{5}$ | 2B | $\mathrm{V}_{\mathrm{CC}}$ | 2A | $V_{S S}$ |
| 1E | $\mathrm{D}_{2}$ | 12M | $\mathrm{A}_{4}$ | 12B | $\mathrm{V}_{\mathrm{CC}}$ | 12A | $V_{S S}$ |
| 2 E | $\mathrm{D}_{1}$ | 11M | $\mathrm{A}_{3}$ | 1 C | $\mathrm{V}_{\mathrm{CC}}$ | 1B | $V_{\text {SS }}$ |
| 1F | $\mathrm{D}_{0}$ | 10M | $\mathrm{A}_{2}$ | 2M | $\mathrm{V}_{\mathrm{CC}}$ | 13B | $V_{S S}$ |
| 9A | $\mathrm{A}_{23}$ | 1K | $\mathrm{A}_{1}$ | 3 N | $\mathrm{V}_{\text {CC }}$ | 13M | $V_{S S}$ |
| 10A | $\mathrm{A}_{22}$ | 2 J | $\overline{\text { BLE }}$ | 5 N | $V_{C C}$ | 2 N | $V_{\text {SS }}$ |
| 10B | $\mathrm{A}_{21}$ | 2K | $\overline{\text { BHE }}$ | 10N | $V_{C C}$ | 6 N | $V_{S S}$ |
| 12C | $\mathrm{A}_{20}$ | 4M | W/ $\overline{\mathrm{R}}$ | 1A | $V_{C C}$ | 12N | $V_{S S}$ |
| 13D | $\mathrm{A}_{19}$ | 3M | D/C | 3A | $\mathrm{V}_{\mathrm{CC}}$ | 1 L | N/C |

The following table lists a brief description of each pin on the 80376. The following definitions are used in these descriptions:

- The named signal is active LOW.

1 Input signal.
O Output signal.
I/O Input and Output signal.

- No electrical connection.

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| CLK2 | 1 | CLK2 provides the fundamental timing for the 80376. For additional information see Clock in Section 4.1. |
| RESET | 1 | RESET suspends any operation in progress and places the 80376 in a known reset state. See Interrupt Signals in Section 4.1 for additional information. |
| $\mathrm{D}_{15}-\mathrm{D}_{0}$ | $1 / 0$ | DATA BUS inputs data during memory, I/O and interrupt acknowledge read cycles and outputs data during memory and I/O write cycles. See Data Bus in Section 4.1 for additional information. |
| $\mathrm{A}_{23}-\mathrm{A}_{1}$ | 0 | ADDRESS BUS outputs physical memory or port I/O addresses. See Address Bus in Section 4.1 for additional information. |
| W/ $\bar{R}$ | 0 | WRITE/READ is a bus cycle definition pin that distinguishes write cycles from read cycles. See Bus Cycle Definition Signals in Section 4.1 for additional information. |
| D/C | 0 | DATA/CONTROL is a bus cycle definition pin that distinguishes data cycles, either memory or I/O, from control cycles which are: interrupt acknowledge, halt, and instruction fetching. See Bus Cycle Definition Signals in Section 4.1 for additional information. |
| M/ $\overline{\mathrm{O}}$ | 0 | MEMORY I/O is a bus cycle definition pin that distinguishes memory cycles from input/output cycles. See Bus Cycle Definition Signals in Section 4.1 for additional information. |
| $\overline{\text { LOCK }}$ | 0 | BUS LOCK is a bus cycle definition pin that indicates that other system bus masters are denied access to the system bus while it is active. See Bus Cycle Definition Signals in Section 4.1 for additional information. |
| $\overline{\text { ADS }}$ | 0 | ADDRESS STATUS indicates that a valid bus cycle definition and address ( $W / \bar{R}, D / \bar{C}, M / \overline{\mathrm{IO}}, \overline{\mathrm{BHE}}, \overline{\mathrm{BLE}}$ and $\mathrm{A}_{23}-\mathrm{A}_{1}$ ) are being driven at the 80376 pins. See Bus Control Signals in Section 4.1 for additional information. |
| $\overline{N A}$ | 1 | NEXT ADDRESS is used to request address pipelining. See Bus Control Signals in Section 4.1 for additional information. |
| $\overline{\text { READY }}$ | 1 | BUS READY terminates the bus cycle. See Bus Control Signals in Section 4.1 for additional information. |
| BHE, BLE | 0 | BYTE ENABLES indicate which data bytes of the data bus take part in a bus cycle. See Address Bus in Section 4.1 for additional information. |
| HOLD | 1 | BUS HOLD REQUEST input allows another bus master to request control of the local bus. See Bus Arbitration Signals in Section 4.1 for additional information. |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| HLDA | 0 | BUS HOLD ACKNOWLEDGE output indicates that the 80376 has suiriendered control of its local bus to another bus master. See Bus Arbitration Signals in Section 4.1 for additional information. |
| INTR | 1 | INTERRUPT REQUEST is a maskable input that signals the 80376 to suspend execution of the current program and execute an interrupt acknowledge function. See Interrupt Signals in Section 4.1 for additional information. |
| NMI | 1 | NON-MASKABLE INTERRUPT REQUEST is a non-maskable input that signals the 80376 to suspend execution of the current program and execute an interrupt acknowledge function. See Interrupt Signals in Section 4.1 for additional information. |
| $\overline{\text { BUSY }}$ | 1 | BUSY signals a busy condition from a processor extension. See Coprocessor Interface Signals in Section 4.1 for additional information. |
| $\overline{\text { ERROR }}$ | 1 | ERROR signals an error condition from a processor extension. See Coprocessor Interface Signals in Section 4.1 for additional information. |
| PEREQ | 1 | PROCESSOR EXTENSION REQUEST indicates that the processor extension has data to be transferred by the 80376. See Coprocessor Interface Signals in Section 4.1 for additional information. |
| $\overline{\text { FLT }}$ | 1 | FLOAT, when active, forces all bidirectional and output signals, including HLDA, to the float condition. FLOAT is not available on the PGA package. See Float for additional information. |
| N/C | - | NO CONNECT should always remain unconnected. Connection of a N/C pin may cause the processor to malfunction or be incompatible with future steppings of the 80376. |
| $V_{C C}$ | 1 | SYSTEM POWER provides the +5 V nominal D.C. supply input. |
| $\mathrm{V}_{\text {SS }}$ | 1 | SYSTEM GROUND provides OV connection from which all inputs and outputs are measured. |

### 2.0 ARCHITECTURE OVERVIEW

The 80376 supports the protection mechanisms needed by sophisticated multitasking embedded systems and real-time operating systems. The use of these protection mechanisms is completely optional. For embedded applications not needing protection, the 80376 can easily be configured to provide a 16 Mbyte physical address space.

Instruction pipelining, high bus bandwidth, and a very high performance ALU ensure short average instruction execution times and high system throughput. The 80376 is capable of execution at sustained rates of 2.5-3.0 million instructions per second.

The 80376 offers on-chip testability and debugging features. Four break point registers allow conditional or unconditional break point traps on code execution or data accesses for powerful debugging of even ROM based systems. Other testability features include self-test and tri-stating of output buffers during RESET.

The Intel 80376 embedded processor consists of a central processing unit, a memory management unit and a bus interface. The central processing unit con-
sists of the execution unit and instruction unit. The execution unit contains the eight 32-bit general registers which are used for both address calculation and data operations and a 64-bit barrel shifter used to speed shift, rotate, multiply, and divide operations. The instruction unit decodes the instruction opcodes and stores them in the decoded instruction queue for immediate use by the execution unit.

The Memory Management Unit (MMU) consists of a segmentation and protection unit. Segmentation allows the managing of the logical address space by providing an extra addressing component, one that allows easy code and data relocatability, and efficient sharing.

The protection unit provides four levels of protection for isolating and protecting applications and the operating system from each other. The hardware enforced protection allows the design of systems with a high degree of integrity and simplifies debugging.

Finaiiy, to faciiitate high periormance sysiem harăware designs, the 80376 bus interface offers address pipelining and direct Byte Enable signals for each byte of the data bus.

### 2.1 Register Set

The 80376 has twenty-nine registers as shown in Figure 2.1. These registers are grouped into the following six categories:


- INTEL RESERVED DO NOT USE

Figure 2.1. 80376 Base Architecture Registers

General Registers: The eight 32-bit general purpose registers are used to contain arithmetic and logical operands. Four of these (EAX, EBX, ECX and EDX) can be used either in their entirety as 32-bit registers, as 16 -bit registers, or split into pairs of separate 8 -bit registers.

Segment Registers: Six 16-bit special purpose registers select, at any given time, the segments of memory that are immediately addressable for code, stack, and data.

Flags and Instruction Pointer Registers: These two 32-bit special purpose registers in Figure 2.1 record or control certain aspects of the 80376 processor state. The EFLAGS register includes status and control bits that are used to reflect the outcome of many instructions and modify the semantics of some instructions. The Instruction Pointer, called EIP, is 32 bits wide. The Instruction Pointer controls instruction fetching and the processor automatically increments it after executing an instruction.

Control Register: The 32-bit control register, CRO, is used to control Coprocessor Emulation.

System Address Registers: These four special registers reference the tables or segments supported by the 80376/80386 protection model. These tables or segments are:

GDTR (Global Descriptor Table Register), IDTR (Interrupt Descriptor Table Register), LDTR (Local Descriptor Table Register), TR (Task State Segment Register).

Debug Registers: The six programmer accessible debug registers provide on-chip support for debugging. The use of the debug registers is described in Section 2.11 Debugging Support.

## EFLAGS REGISTER

The flag Register is a 32-bit register named EFLAGS. The defined bits and bit fields within EFLAGS, shown in Figure 2.2, control certain operations and indicate the status of the 80376 processor. The function of the flag bits is given in Table 2.1.


Figure 2.2. Status and Control Register Bit Functions

Table 2.1. Flag Definitions

| 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 otherwise. |
| 4 | AF | Auxiliary Carry Flag-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). |
| 8 | TF | Single Step Flag-Once set, a single step interrupt occurs after the next instruction executes. TF is cleared by the single step interrupt. |
| 9 | IF | Interrupt-Enable Flag-When set, external interrupts signaled on the INTR pin will cause the CPU to transfer control to an interrupt vector specified location. |
| 10 | DF | Direction Flag-Causes string instructions to auto-increment (default) the appropriate index registers when cleared. Setting DF causes autodecrement. |
| 11 | OF | Overflow Flag-Set if the operation resulted in a carry/borrow into the sign bit (high-order bit) of the result but did not result in a carry/borrow out of the high-order bit or vice-versa. |
| 12,13 | IOPL | I/O Privilege Level-Indicates the maximum CPL permitted to execute I/O instructions without generating an exception 13 fault or consulting the I/O permission bit map. It also indicates the maximum CPL value allowing alteration of the IF bit. |
| 14 | NT | Nested Task-Indicates that the execution of the current task is nested within another task (see Task Switching). |
| 16 | RF | Resume Flag-Used in conjunction with debug register breakpoints. It is checked at instruction boundaries before breakpoint processing. If set, any debug fault is ignored on the next instruction. It is reset at the successful completion of any instruction except IRET, POPF, and those instructions causing task switches. |

## CONTROL REGISTER

The 80376 has a 32-bit control register called CRO that is used to control coprocessor emulation. This register is shown in Figures, 2.1 and 2.2. The defined CRO bits are described in Table 2.2. Bits 0,4 and 31 of CRO have fixed values in the 80376. These values cannot be changed. Programs that load CR0 should always load bits 0,4 and 31 with values previously there to be compatible with the 80386.

Table 2.2. CRO Definitions

| Bit Position | Name | Function |
| :--- | :---: | :--- |
| 1 | MP | Monitor Coprocessor Extension-Allows WAIT instructions to cause <br> a processor extension not present exception (number 7). |
| 2 | EM | Emulate Processor Extension-When set, this bit causes a <br> processor extension not present exception (number 7) on ESC <br> instructions to allow processor extension emulation. |
| 3 | TS | Task Switched-When set, this bit indicates the next instruction using <br> a processor extension will cause exception 7, allowing software to test <br> whether the current processor extension context belongs to the <br> current task (see Task Switching). |

### 2.2 Instruction Set

The instruction set is divided into nine categories of operations:

Data Transfer
Arithmetic
Shift/Rotate
String Manipulation
Bit Manipulation
Control Transfer
High Level Language Support
Operating System Support
Processor Control
These 80376 processor instructions are listed in Ta ble 8.180376 Instruction Set and Clock Count Summary.

All 80376 processor instructions operate on either 0 , 1, 2 or 3 operands; an operand resides in a register, in the instruction itself, or in memory. Most zero operand instructions (e.g. CLI, STI) take only one byte. One operand instructions generally are two bytes long. The average instruction is 3.2 bytes long. Since the 80376 has a 16-byte prefetch instruction queue an average of 5 instructions can be prefetched. The use of two operands permits the following types of common instructions:

Register to Register
Memory to Register
Immediate to Register
Memory to Memory
Register to Memory
Immediate to Memory
The operands are either 8 -, 16 - or 32 -bit long.

### 2.3 Memory Organization

Memory on the 80376 is divided into 8 -bit quantities (bytes), 16 -bit quantities (words), and 32-bit quantities (dwords). Words are stored in two consecutive bytes in memory with the low-order byte at the lowest address. Dwords are stored in four consecutive bytes in memory with the low-order byte at the lowest address. The address of a word or Dword is the byte address of the low-order byte. For maximum performance word and dword values should be at even physical addresses.

In addition to these basic data types the 80376 processor supports segments. Memory can be divided up into one or more variable length segments, which can be shared between programs.

## ADDRESS SPACES

The 80376 has three types of address spaces: logical, linear, and physical. A logical address (also known as a virtual address) consists of a selector and an offset. A selector is the contents of a segment register. An offset is formed by summing all of the addressing components (BASE, INDEX, and DISPLACEMENT), discussed in Section 2.4 Addressing Modes, into an effective address.

Every selector has a logical base address associated with it that can be up to 32 bits in length. This 32bit logical base address is added to either a 32-bit offset address or a 16-bit offset address (by using the address length prefix ) to form a final 32 -bit linear address. This final linear address is then truncated so that only the lower 24 bits of this address are used to address the 16 Mbytes physical memory address space. The logical base address is stored in one of two operating system tables (i.e. the Local Descriptor Table or Global Descriptor Table).

Figure 2.3 shows the relationship between the various address spaces.


Figure 2.3. Address Translation

## SEGMENT REGISTER USAGE

The main data structure used to organize memory is the segment. On the 80376, segments are variable sized blocks of linear addresses which have certain attributes associated with them. There are two main types of segments, code and data. The simplest use of segments is to have one code and data segment. Each segment is 16 Mbytes in size overlapping each other. This allows code and data to be directly addressed by the same offset.

In order to provide compact instruction encoding and increase processor performance, instructions do not need to explicitly specify which segment reg-
ister is used. The segment register is automatically chosen according to the rules of Table 2.3 (Segment Register Selection Rules). In general, data references use the selector contained in the DS register, stack references use the SS register and instruction fetches use the CS register. The contents of the Instruction Pointer provide the offset. Special segment override prefixes allow the explicit use of a given segment register, and override the implicit rules listed in Table 2.3. The override prefixes also allow the use of the ES, FS and GS segment registers.

There are no restrictions regarding the overlapping of the base addresses of any segments. Thus, all 6 segments could have the base address set to zero. Further details of segmentation are discussed in Section 3.0 Architecture.

Table 2.3. Segment Register Selection Rules

| Type of <br> Memory Reference | Implied (Default) <br> Segment Use | Segment Override <br> Prefixes Possible |
| :--- | :---: | :---: |
| Code Fetch | CS | None |
| Destination of PUSH, PUSHF, INT, <br> CALL, PUSHA Instructions | SS | None |
| Source of POP, POPA, POPF, IRET, | SS | None |
| RET Instructions |  |  |
| Destination of STOS, | ES |  |
| MOVS, REP STOS, |  |  |
| REP MOVS Instructions |  |  |
| (DI is Base Register) |  |  |
| Other Data References, |  |  |
| with Effective Address |  |  |
| Using Base Register of: | CS, SS, ES, FS, GS |  |
| [EAX] | DS | CS, SS, ES, FS, GS |
| [EBXX] | DS | CS, SS, ES, FS, GS |
| [ECX] | DS | CS, SS, ES, FS, GS |
| [EDX] | DS | CS, SS, ES, FS, GS |
| [ESI] | DS | CS, SS, ES, FS, GS |
| [EDI] | DS | CS, SS, ES, FS, GS |

### 2.4 Addressing Modes

The 80376 provides a total of 8 addressing modes for instructions to specify operands. The addressing modes are optimized to allow the efficient execution of high level languages such as C and FORTRAN, and they cover the vast majority of data references needed by high-level languages.

Two of the addressing modes provide for instructions that operate on register or immediate operands:

Register Operand Mode: The operand is located in one of the 8 -, 16- or 32-bit general registers.

Immediate Operand Mode: The operand is included in the instruction as part of the opcode.

The remaining 6 modes provide a mechanism for specifying the effective address of an operand. The linear address consists of two components: the seg-
ment base address and an effective address. The effective address is calculated by summing any combination of the following three address elements (see Figure 2.3):

DISPLACEMENT: an 8-, 16- or 32-bit immediate value following the instruction.

BASE: The contents of any general purpose register. The base registers are generally used by compilers to point to the start of the local variable area. Note that if the Address Length Prefix is used, only $B X$ and BP can be used as a BASE register.

INDEX: The contents of any general purpose register except for ESP. The index registers are used to access the elements of an array, or a string of characters. The index register's value can be multiplied by a scale factor, either $1,2,4$ or 8 . The scaled index is especially useful for accessing arrays or structures. Note that if the Address Length Prefix is used, no Scaling is available and only the registers SI and DI can be used to INDEX.

Combinations of these 3 components make up the 6 additional addressing modes. There is no performance penalty for using any of these addressing combinations, since the effective address calculation is pipelined with the execution of other instructions. The one exception is the simultaneous use of BASE and INDEX components which requires one additional clock.

As shown in Figure 2.4, the effective address (EA) of an operand is calculated according to the following formula:

$$
\begin{aligned}
& E A= \text { BASE }_{\text {Register }}+(\text { INDEX } \\
& \text { DISPLACEMENT }
\end{aligned}
$$

1. Direct Mode: The operand's offset is contained as part of the instruction as an 8 -, 16 - or 32 -bit DISPLACEMENT.
2. Register Indirect Mode: A BASE register contains the address of the operand.
3. Based Mode: A BASE register's contents is added to a DISPLACEMENT to form the operand's offset.
4. Scaled Index Mode: An INDEX register's contents is multiplied by a SCALING factor which is added to a DISPLACEMENT to form the operand's offset.
5. Based Scaled Index Mode: The contents of an INDEX register is multiplied by a SCALING factor and the result is added to the contents of a BASE register to obtain the operand's offset.
6. Based Scaled Index Mode with Displacement: The contents of an INDEX register are multiplied by a SCALING factor, and the result is added to the contents of a BASE register and a DISPLACEMENT to form the operand's offset.


Figure 2.4. Addressing Mode Calculations

## GENERATING 16-BIT ADDRESSES

The 80376 executes code with a default length for operands and addresses of 32 bits. The 80376 is also able to execute operands and addresses of 16 bits. This is specified through the use of override prefixes. Two prefixes, the Operand Length Prefix and the Address Length Prefix, override the default 32-bit length on an individual instruction basis. These prefixes are automatically added by assem-
blers. The Operand Length and Address Length Prefixes can be applied separately or in combination to any instruction.

The 80376 normally executes 32 -bit code and uses either 8- or 32-bit displacements, and any register can be used as based or index registers. When executing 16-bit code (by prefix overrides), the displacements are either 8 or 16 bits, and the base and index register conform to the 16 -bit model. Table 2.4 illustrates the differences.

Table 2.4. BASE and INDEX Registers for 16- and 32-Bit Addresses

|  | 16-Bit Addressing | 32-Bit Addressing |
| :--- | :--- | :--- |
| BASE REGISTER | BX, BP | Any 32-Bit GP Register |
| INDEX REGISTER | SI, DI | Any 32-Bit GP Register <br> except ESP |
| SCALE FACTOR | None | $1,2,4,8$ |
| DISPLACMENT | $0,8,16$ Bits | $0,8,32$ Bits |

### 2.5 Data Types

The 80376 supports all of the data types commonly used in high level languages:

## Bit:

Bit Field:

Bit String:

Byte:
Unsigned Byte:
Integer (Word):
Long Integer (Double Word):

Unsigned Integer (Word):
Unsigned Long Integer (Double Word):
Signed Quad Word:
Unsigned Quad Word:
Pointer:

Long Pointer:

Char:
String:

BCD:
Packed BCD:

A single bit quantity.
A group of up to 32 contiguous bits, which spans a maximum of four bytes.
A set of contiguous bits, on the 80376 bit strings can be up to 16 Mbits long.
A signed 8-bit quantity.
An unsigned 8-bit quantity.
A signed 16-bit quantity.
A signed 32-bit quantity. All operations assume a 2's complement representation.
An unsigned 16-bit quantity.

An unsigned 32-bit quantity.
A signed 64-bit quantity.
An unsigned 64-bit quantity.
A 16- or 32-bit offset only quantity which indirectly references another memory location.
A full pointer which consists of a 16-bit segment selector and either a 16- or 32-bit offset.
A byte representation of an ASCII Alphanumeric or control character.
A contiguous sequence of bytes, words or dwords. A string may contain between 1 byte and 16 Mbytes.
A byte (unpacked) representation of decimal digits 0-9.
A byte (packed) representation of two decimal digits 0-9 storing one digit in each nibble.

When the 80376 is coupled with a numerics Coprocessor such as the 80387 SX then the following common Floating Point types are supported.
Floating Point: $\quad$ A signed 32 -, 64- or 80-bit real number representation. Floating point numbers are supported by the 80387SX numerics coprocessor.

Figure 2.5 illustrates the data types supported by the 80376 processor and the 80387 SX coprocessor.


Figure 2.5. 80376 Supported Data Types

### 2.6 I/O Space

The 80376 has two distinct physical address spaces: physical memory and I/O. Generally, peripherals are placed in I/O space although the 80376 also supports memory-mapped peripherals. The I/O space consists of 64 Kbytes which can be divided into 64 K 8 -bit ports, 32 K 16 -bit ports, or any combination of ports which add to no more than 64 Kbytes. The M/IO pin acts as an additional address line, thus allowing the system designer to easily determine which address space the processor is accessing. Note that the I/O address refers to a physical address.

The I/O ports are accessed by the IN and OUT instructions, with the port address supplied as an immediate 8-bit constant in the instruction or in the DX register. All 8 -bit and 16 -bit port addresses are zero extended on the upper address lines. The I/O instructions cause the M/IO pin to be driven LOW. I/O port addresses 00 F 8 H through 00FFH are reserved for use by Intel.

### 2.7 Interrupts and Exceptions

Interrupts and exceptions alter the normal program flow in order to handle external events, report errors or exceptional conditons. The difference between interrupts and exceptions is that interrupts are used to handle asynchronous external events while exceptions handle instruction faults. Although a program can generate a software interrupt via an INT N instruction, the processor treats software interrupts as exceptions.

Hardware interrupts occur as the result of an external event and are classified into two types: maskable or non-maskable. Interrupts are serviced after the execution of the current instruction. After the interrupt handler is finished servicing the interrupt, execution proceeds with the instruction immediately after the interrupted instruction.

Exceptions are classified as faults, traps, or aborts depending on the way they are reported, and whether or not restart of the instruction causing the exception is suported. Faults are exceptions that are detected and serviced before the execution of the faulting instruction. Traps are exceptions that are reported immediately after the execution of the instruction which caused the problem. Aborts are exceptions which do not permit the precise location of the instruction causing the exception to be determined. Thus, when an interrupt service routine has been completed, execution proceeds from the in-
struction immediately following the interrupted instruction. On the other hand the return address from an exception/fault routine will always point at the instruction causing the exception and include any leading instruction prefixes. Table 2.5 summarizes the possible interrupts for the 80376 and shows where the return address points to.

The 80376 has the ability to handle up to 256 different interrupts/exceptions. In order to service the interrupts, a table with up to 256 interrupt vectors must be defined. The interrupt vectors are simply pointers to the appropriate interrupt service routine. The interrupt vectors are 8-byte quantities, which are put in an Interrupt Descriptor Table. Of the 256 possible interrupts, 32 are reserved for use by Intel and the remaining 224 are free to be used by the system designer.

## INTERRUPT PROCESSING

When an interrupt occurs the following actions happen. First, the current program address and the Flags are saved on the stack to allow resumption of the interrupted program. Next, an 8 -bit vector is supplied to the 80376 which identifies the appropriate entry in the interrupt table. The table contains either an Interrupt Gate, a Trap Gate or a Task Gate that will point to an interrupt procedure or task. The user supplied interrupt service routine is executed. Finally, when an IRET instruction is executed the old processor state is restored and program execution resumes at the appropriate instruction.

The 8-bit interrupt vector is supplied to the 80376 in several different ways: exceptions supply the interrupt vector internally; software INT instructions contain or imply the vector; maskable hardware interrupts supply the 8 -bit vector via the interrupt acknowledge bus sequence. Non-Maskable hardware interrupts are assigned to interrupt vector 2.

## Maskable Interrupt

Maskable interrupts are the most common way to respond to asynchronous external hardware events. A hardware interrupt occurs when the INTR is pulled HIGH and the Interrupt Flag bit (IF) is enabled. The processor only responds to interrupts between instructions (string instructions have an "interrupt window" between memory moves which allows interrupts during long string moves). When an interrupt occurs the processor reads an 8 -bit vector supplied by the hardware which identifies the source of the interrupt (one of 224 user defined interrupts).

Table 2.5. Interrupt Vector Assignments

| Function | Interrupt Number | Instruction Which Can Cause Exception | Return Address Points to Faulting Instruction | Type |
| :---: | :---: | :---: | :---: | :---: |
| Divide Error | 0 | DIV, IDIV | Yes | FAULT |
| Debug Exception | 1 | Any Instruction | Yes | TRAP* |
| NMI Interrupt | 2 | INT 2 or NMI | No | NMI |
| One-Byte Interrupt | 3 | INT | No | TRAP |
| Interrupt on Overflow | 4 | INTO | No | TRAP |
| Array Bounds Check | 5 | BOUND | Yes | FAULT |
| Invalid OP-Code | 6 | Any Illegal Instruction | Yes | FAULT |
| Device Not Available | 7 | ESC, WAIT | Yes | FAULT |
| Double Fault | 8 | Any Instruction That Can Generate an Exception |  | ABORT |
| Coprocessor Segment Overrun | 9 | ESC | No | ABORT |
| Invalid TSS | 10 | JMP, CALL, IRET, INT | Yes | FAULT |
| Segment Not Present | 11 | Segment Register Instructions | Yes | FAULT |
| Stack Fault | 12 | Stack References | Yes | FAULT |
| General Protection Fault | 13 | Any Memory Reference | Yes | FAULT |
| Intel Reserved | 14-15 | - | - | - |
| Coprocessor Error | 16 | ESC, WAIT | Yes | FAULT |
| Intel Reserved | 17-32 |  |  |  |
| Two-Byte Interrupt | 0-255 | INT n | No | TRAP |

*Some debug exceptions may report both traps on the previous instruction, and faults on the next instruction.

Interrupts through Interrupt Gates automatically reset IF, disabling INTR requests. Interrupts through Trap Gates leave the state of the IF bit unchanged. Interrupts through a Task Gate change the IF bit according to the image of the EFLAGs register in the task's Task State Segment (TSS). When an IRET instruction is executed, the original state of the IF bit is restored.

## Non-Maskable Interrupt

Non-maskable interrupts provide a method of servicing very high priority interrupts. When the NMI input is pulled HIGH it causes an interrupt with an internally supplied vector value of 2 . Unlike a normal hardware interrupt no interrupt acknowledgement sequence is performed for an NMI.

While executing the NMI servicing procedure, the 80376 will not service any further NMI request, or INT requests, until an interrupt return (IRET) instruc-
tion is executed or the processor is reset. If NMI occurs while currently servicing an NMI, its presence will be saved for servicing after executing the first IRET instruction. The disabling of INTR requests depends on the gate in IDT location 2.

## Software Interrupts

A third type of interrupt/exception for the 80376 is the software interrupt. An INT $n$ instruction causes the processor to execute the interrupt service routine pointed to by the $n^{\text {th }}$ vector in the interrupt table.

A special case of the two byte software interrupt INT $n$ is the one byte INT 3, or breakpoint interrupt. By inserting this one byte instruction in a program, the user can set breakpoints in his program as a debugging tool.

A final type of software interrupt, is the single step interrupt. It is discussed in Single-Step Trap (page 22).

## INTERRUPT AND EXCEPTION PRIORITIES

Interrupts are externally-generated events. Maskable Interrupts (on the INTR input) and Non-Maskable Interrupts (on the NMI input) are recognized at instruction boundaries. When NMI and maskable INTR are both recognized at the same instruction boundary, the 80376 invokes the NMI service routine first. If, after the NMI service routine has been invoked, maskable interrupts are still enabled, then the 80376 will invoke the appropriate interrupt service routine.

As the 80376 executes instructions, it follows a consistent cycle in checking for exceptions, as shown in Table 2.6. This cycle is repeated as each instruction is executed, and occurs in parallel with instruction decoding and execution.

## INSTRUCTION RESTART

The 80376 fully supports restarting all instructions after faults. If an exception is detected in the instruction to be executed (exception categories 4 through 9 in Table 2.6), the 80376 device invokes the appropriate exception service routine. The 80376 is in a state that permits restart of the instruction.

## DOUBLE FAULT

A Double fault (exception 8) results when the processor attempts to invoke an exception service routine for the segment exceptions (10, 11, 12 or 13), but in the process of doing so, detects an exception.

### 2.8 Reset and Initialization

When the processor is Reset the registers have the values shown in Table 2.7. The 80376 will then start executing instructions near the top of physical memory, at location OFFFFFOH. A short JMP should be executed within the segment defined for power-up (see Table 2.7). The GDT should then be initialized for a start-up data and code segment followed by a far JMP that will load the segment descriptor cache with the new descriptor values. The IDT table, after reset, is located at physical address 0 H , with a limit of 256 entries.

RESET forces the 80376 to terminate all execution and local bus activity. No instruction execution or bus activity will occur as long as Reset is active. Between 350 and 450 CLK2 periods after Reset becomes inactive, the 80376 will start executing instructions at the top of physical memory.

Table 2.6. Sequence of Exception Checking

Consider the case of the 80376 having just completed an instruction. It then performs the following checks before reaching the point where the next instruction is completed:

1. Check for Exception 1 Traps from the instruction just completed (single-step via Trap Flag, or Data Breakpoints set in the Debug Registers).
2. Check for external NMI and INTR.
3. Check for Exception 1 Faults in the next instruction (Instruction Execution Breakpoint set in the Debug Registers for the next instruction).
4. Check for Segmentation Faults that prevented fetching the entire next instruction (exceptions 11 or 13).
5. Check for Faults decoding the next instruction (exception 6 if illegal opcode; or exception 13 if instruction is longer than 15 bytes, or privilege violation (i.e. not at IOPL or at CPL $=0$ ).
6. If WAIT opcode, check if TS = 1 and MP $=1$ (exception 7 if both are 1).
7. If ESCape opcode for numeric coprocessor, check if $\mathrm{EM}=1$ or $\mathrm{TS}=1$ (exception 7 if either are 1 ).
8. If WAIT opcode or ESCape opcode for numeric coprocessor, check ERROR input signal (exception 16 if ERROR input is asserted).
9. Check for Segmentation Faults that prevent transferring the entire memory quantity (exceptions 11, 12, 13).

Table 2.7. Register Values after Reset

| Flag Word (EFLAGS) | uuuu0002H | (Note 1) |
| :---: | :---: | :---: |
| Machine Status Word (CRO) | unuunui 1 H | (Note 2) |
| Instruction Pointer (EIP) | 0000FFFOH |  |
| Code Segment (CS) | F000H | (Note 3) |
| Data Segment (DS) | 0000H | (Note 4) |
| Stack Segment (SS) | 0000H |  |
| Extra Segment (ES) | 0000H | (Note 4) |
| Extra Segment (FS) | 0000H |  |
| Extra Segment (GS) | 0000H |  |
| EAX Register | 0000H | (Note 5) |
| EDX Register | Component and Stepping ID | (Note 6) |
| All Other Registers | Undefined | (Note 7) |

## NOTES:

1. EFLAG Register. The upper 14 bits of the EFLAGS register are undefined, all defined flag bits are zero.
2. CRO: The defined 4 bits in the CR0 is equal to 1 H .
3. The Code Segment Register (CS) will have its Base Address set to OFFFFF0000H and Limit set to OFFFFH.
4. The Data and Extra Segment Registers (DS and ES) will have their Base Address set to 000000000 H and Limit set to OFFFFH.
5. If self-test is selected, the EAX should contain a 0 value. If a value of 0 is not found the self-test has detected a flaw in the part.
6. EDX register always holds component and stepping identifier.
7. All unidentified bits are Intel Reserved and should not be used.

### 2.9 Initialization

Because the 80376 processor starts executing in protected mode, certain precautions need be taken during initialization. Before any far jumps can take place the GDT and/or LDT tables need to be setup and their respective registers loaded. Before interrupts can be initialized the IDT table must be setup and the IDTR must be loaded. The example code is shown below:

```
;
;
This is an example of startup code to put either an 80376,
80386SX or 80386 into flat mode. All of memory is treated as
simple linear RAM. There are no interrupt routines. The
Builder creates the GDT-alias and IDT-alias and places them,
by default, in GDT[l] and GDT[2]. Other entries in the GDT
are specified in the Build file. After initialization it jumps
to a C startup routine. To use this template, change this jmp
address to that of your code, or make the label of your code
"c_startup".
This code was assembled and built using version l.2 of the
Intel RLL utilities and Intel 386ASM assembler.
    *** This code was tested
;********************************************************************
```

NAME FLAT

```
; name of the object module
```

EXTRN c_startup:near ; this is the label jmped to after init
pe_flag equ 1
data_selc equ 20h ; assume code is GDT[3], data GDT[4]

INIT_CODE SEGMENT ER PUBLIC USE32 ; Segment base at Offffff80h
PUBLIC GDT_DESC
gdt_desc dq ?
PUBLIC START
start :

```
cld ; clear direction flag
```

smsw bx ; check for processor (80376) at reset
test bl,l ; use SMSW rather than MOV for speed
jnz pestart
realstart
; is an 80386 and in real mode
$\mathrm{db} 66 \mathrm{~h} \quad$; force the next operand into 32 -bit mode.
mov eax,offset gdt_desc ; move address of the GDT descriptor into eax
xor ebx,ebx ; clear ebx
mov bh,ah ; load 8 bits of address into bh
move bl,al ; load 8 bits of address into bl
db 67 h
db 66 h ; use the 32-bit form of LGDT to load
lgdt cs:[ebx] ; the 32-bits of address into the GDTR
smsw ax ; go into protected mode (set PE bit)
or al,pe_flag
lmsw ax
jmp next ; flush prefetch queue
pestart:
mov ebx, offset gdt_desc
xor eax, eax
mov ax,bx ; lower portion of address only
lgdt cs:[eax]
xor ebx,ebx ; initialize data selectors
mov bl,data_selc ; GDT[3]
mov ds,bx
mov ss,bx
mov es,bx
mov fs, bx
mov $g s, b x$
jmp pejump
next:
xor ebx,ebx ; initialize data selectors
mov bl,data_selc ; GDT[3]
mov ds,bx
mov ss,bx
mov es,bx
mov fs, $b x$
mov gs,bx
db 66 h ; for the 80386 , need to make a 32-bit jump
pejump:
jmp far ptr c_startup ; but the 80376 is already 32-bit.
org 70h ; only if segment base is at Offffff80h
jmp short start
INIT_CODE ENDS
END

This code should be linked into your application for boot loadable code. The following build file illustrates how this is accomplished.

FLAT; -- build program id
SEGMENT

```
    *segments ( \(\mathrm{dpl}=0\) ) , -- Give all user segments a DPL of 0.
    _phantom_code_ (dpl=0), -- These two segments are created by
    _phantom_data_ (dpl=0), -- the builder when the FLAT control is used.
    init_code (base=0ffffff80h) ; -- Put startup code at the reset vector area.
```

GATE
gl3 (entry=13, dpl=0, trap), -- trap gate disables interrupts
i32 (entry=32, dpl=0, interrupt), -- interrupt gates doesn't

TABLE
-- create GDT
GDT (LOCATION = GDT_DESC,
-- In a buffer starting at GDT_DESC,
-- BLD386 places the GDT base and
-- GDT limit values. Buffer must be
-- 6 bytes long. The base and limit
-- values are places in this buffer
-- as two bytes of limit plus
-- four bytes of base in the format
-- required for use by the LGDT
-- instruction.
ENTRY $=$ (3:_phantom_code_, -- Explicitly place segment
4:_phantom_data_, -- entries into the GDT. 5: code32, 6 :data, 7:init_code)
) ;
TASK
MAIN_TASK
1
DPL $=0$, -- Task privilege level is 0.
DATA $=$ DATA, $\quad$-- Points to a segment that
-- indicates initial DS value.
CODE = main, -- Entry point is main, which
-- must be a public id.

STACKS $=$ (DATA), -- Segment id points to stack
-- segment. Sets the initial SS:ESP.
NO INTENABLED, -- Disable interrupts.
PRESENT -- Present bit in TSS set to 1.

MEMORY

$$
\begin{aligned}
(\text { RANGE }= & (E P R O M=R O M(0 f f f f 8000 h . \text { Offffffffh }), \\
& \text { DRAM }=\text { RAM }(0 . \text { Offffh })), \\
A L L O C A T E ~ & \left.\left(E P R O M=\left(M A I N \_T A S K\right)\right)\right) ;
\end{aligned}
$$

END
asm386 flatsim.a38 debug
asm386 application.a38 debug
bnd386 application.obj,flatsim.obj nolo debug oj (application.bnd)
bld386 application.bnd bf (flatsim.bld) bl flat
Commands to assemble and build a boot-loadable application named "application.a38". The initialization code is called "flatsim.a38", and build file is called "application.bld".

### 2.10 Self-Test

The 80376 has the capability to perform a self-test. The self-test checks the function of all of the Control ROM and most of the non-random logic of the part. Approximately one-half of the 80376 can be tested during self-test.

Self-Test is initiated on the 80376 when the RESET pin transitions from HIGH to LOW, and the BUSY pin is LOW. The self-test takes about 220 clocks, or approximately 33 ms with a 16 MHz 80376 processor. At the completion of self-test the processor performs reset and begins normal operation. The part has successfully passed self-test if the contents of the EAX register is zero. If the EAX register is not zero then the self-test has detected a flaw in the part. If self-test is not selected after reset, EAX may be non-zero after reset.

### 2.11 Debugging Support

The 80376 provides several features which simplify the debugging process. The three categories of onchip debugging aids are:

1. The code execution breakpoint opcode ( $0 C C H$ ).
2. The single-step capability provided by the TF bit in the flag register, and
3. The code and data breakpoint capability provided by the Debug Registers DR0-3, DR6, and DR7.

## BREAKPOINT INSTRUCTION

A single-byte software interrupt (Int 3) breakpoint instruction is available for use by software debuggers. The breakpoint opcode is OCCh, and generates an exception 3 trap when executed.

## DEBUG REGISTERS



Figure 2.6. Debug Registers

## SINGLE-STEP TRAP

If the single-step flag (TF, bit 8) in the EFLAG register is found to be set at the end of an instruction, a single-step exception occurs. The single-step exception is auto vectored to exception number 1.

The Debug Registers are an advanced debugging feature of the 80376. They allow data access breakpoints as well as code execution breakpoints. Since the breakpoints are indicated by on-chip registers, an instruction execution breakpoint can be placed in ROM code or in code shared by several tasks, neither of which can be supported by the INT 3 breakpoint opcode.

The 80376 contains six Debug Registers, consisting of four breakpoint address registers and two breakpoint control registers. Initially after reset, breakpoints are in the disabled state; therefore, no breakpoints will occur unless the debug registers are programmed. Breakpoints set up in the Debug Registers are auto-vectored to exception 1. Figure 2.6 shows the breakpoint status and control registers.

### 3.0 ARCHITECTURE

The Intel 80376 Embedded Processor has a physical address space of 16 Mbytes ( $2^{24}$ bytes) and allows the running of virtual memory programs of almost unlimited size (16 Kbytes $\times 16$ Mbytes or 256 Gbytes ( $2^{38}$ bytes)). In addition the 80376 provides a sophisticated memory management and a hardware-assisted protection mechanism.

### 3.1 Addressing Mechanism

The 80376 uses two components to form the logical address, a 16-bit selector which determines the linear base address of a segment, and a 32-bit effective address. The selector is used to specify an index into an operating system defined table (see Figure 3.1). The table contains the 32-bit base address of a given segment. The linear address is formed by adding the base address obtained from the table to the 32-bit effective address. This value is truncated to 24 bits to form the physical address, which is then placed on the address bus.


Figure 3.1. Address Calculation

### 3.2 Segmentation

Segmentation is one method of memory management and provides the basis for protection in the 80376. Segments are used to encapsulate regions of memory which have common attributes. For example, all of the code of a given program could be contained in a segment, or an operating system table may reside in a segment. All information about each segment, is stored in an 8-byte data structure called a descriptor. All of the descriptors in a system are contained in tables recognized by hardware.

## TERMINOLOGY

The following terms are used throughout the discussion of descriptors, privilege levels and protection:
PL: Privilege Level-One of the four hierarchical privilege levels. Level 0 is the most privileged level and level 3 is the least privileged.
RPL: Requestor Privilege Level-The privilege level of the original supplier of the selector. RPL is determined by the least two significant bits of a selector.
DPL: Descriptor Privilege Level-This is the least privileged level at which a task may access that descriptor (and the segment associated with that descriptor). Descriptor Privilege Level is determined by bits 6:5 in the Access Right Byte of a descriptor.
CPL: Current Privilege Level-The privilege level at which a task is currently executing, which equals the privilege level of the code segment being executed. CPL can also be determined by examining the lowest 2 bits of the CS register, except for conforming code segments.
EPL: Effective Privilege Level-The effective privilege level is the least privileged of the RPL and the DPL. EPL is the numerical maximum of RPL and DPL.
Task: One instance of the execution of a program. Tasks are also referred to as processes.

## DESCRIPTOR TABLES

The descriptor tables define all of the segments which are used in an 80376 system. There are three types of tables on the 80376 which hold descriptors: the Global Descriptor Table, Local Descriptor Table, and the Interrupt Decriptor Table. All of the tables are variable length memory arrays, they can range in size between 8 bytes and 64 Kbytes. Each table can hold up to 81928 -byte descriptors. The upper 13 bits of a selector are used as an index into the descriptor table. The tables have registers associated with them which hold the 32 -bit linear base address, and the 16-bit limit of each table.

Each of the tables have a register associated with it: GDTR, LDTR and IDTR; see Figure 3.2. The LGDT, LLDT and LIDT instructions load the base and limit of the Global, Local and Interrupt Descriptor Tables into the appropriate register. The SGDT, SLDT and SIDT store these base and limit values. These are privileged instructions.


Figure 3.2. Descriptor Table Registers

## Global Descriptor Table

The Global Descriptor Table (GDT) contains descriptors which are possibly available to all of the tasks in a system. The GDT can contain any type of segment descriptor except for interrupt and trap descriptors. Every 80376 system contains a GDT. A simple 80376 system contains only 2 entries in the GDT; a code and a data descriptor. For maximum performance, descriptor tables should begin on even addresses.

The first slot of the Global Descriptor Table corresponds to the null selector and is not used. The null selector defines a null pointer value.

## Local Descriptor Table

LDTs contain descriptors which are associated with a given task. Generally, operating systems are designed so that each task has a separate LDT. The LDT may contain only code, data, stack, task gate, and call gate descriptors. LDTs provide a mechanism for isolating a given task's code and data segments from the rest of the operating system, while the GDT contains descriptors for segments which are common to all tasks. A segment cannot be accessed by a task if its segment descriptor does not exist in either the current LDT or the GDT. This pro-
vides both isolation and protection for a task's segments, while still allowing global data to be shared among tasks.

Unlike the 6 -byte GDT or IDT registers which contain a base address and limit, the visible portion of the LDT register contains only a 16 -bit selector. This selector refers to a Local Descriptor Table descriptor in the GDT (see Figure 2.1).

## INTERRUPT DESCRIPTOR TABLE

The third table needed for 80376 systems is the Interrupt Descriptor Table. The IDT contains the descriptors which point to the location of up to 256 interrupt service routines. The IDT may contain only task gates, interrupt gates and trap gates. The IDT should be at least 256 bytes in size in order to hold the descriptors for the 32 Intel Reserved Interrupts. Every interrupt used by a system must have an entry in the IDT. The IDT entries are referenced by INT instructions, external interrupt vectors, and exceptions.

## DESCRIPTORS

The object to which the segment selector points to is called a descriptor. Descriptors are eight-byte quantities which contain attributes about a given region of linear address space. These attributes include the 32 -bit logical base address of the seg-
ment, the 20 -bit length and granularity of the segment, the protection level, read, write or execute privileges, and the type of segment. All of the attribute information about a segment is contained in 12 bits in the segment descriptor. Figure 3.3 shows the general format of a descriptor. All segments on the the 80376 have three attribute fields in common: the Present bit (P), the Descriptor Privilege Level bits (DPL) and the Segment bit (S). $\mathrm{P}=1$ if the segment is loaded in physical memory, if $\mathrm{P}=0$ then any attempt to access the segment causes a not present exception (exception 11). The DPL is a two-bit field which specifies the protection level, $0-3$, associated with a segment.

The 80376 has two main categories of segments: system segments, and non-system segments (for code and data). The segment bit, S , determines if a given segment is a system segment, a code segment or a data segment. If the $S$ bit is 1 then the segment is either a code or data segment, if it is 0 then the segment is a system segment.

Note that although the 80376 is limited to a 16-Mbyte Physical address space ( $\mathbf{2}^{24}$ ), its base address allows a segment to be placed anywhere in a 4-Gbyte linear address space. When writing code for the 80376, users should keep code portability to an 80386 processor (or other processors with a larger physical address space) in mind. A segment base address can be placed anywhere in this 4-Gbyte linear address space, but a physical address will be


Figure 3.3. Segment Descriptors

| 31 |  |  |  |  |  |  | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SEGMENT BASE 15... 0 |  |  |  |  |  | SEGMENT LIMIT $15 \ldots 0$ |  |
| $\begin{gathered} \text { BASE } \\ 31 \ldots 24 \end{gathered}$ | G | 1 | 0 | A <br> V <br> L | $\begin{gathered} \text { LIMIT } \\ 19 \ldots 16 \end{gathered}$ | ACCESS RIGHTS BYTE | $\begin{gathered} \text { BASE } \\ 23 \ldots .16 \end{gathered}$ |

[^18]Figure 3.4. Code and Data Descriptors

Table 3.1. Access Rights Byte Definition for Code and Data Descriptors

| Bit Position | Name | Function |
| :---: | :---: | :---: |
| 7 $6-5$ 4 | Present (P) <br> Descriptor Privilege <br> Level (DPL) <br> Segment <br> Descriptor (S) | $P=1$ Segment is mapped into physical memory. <br> $P=0$ No mapping to physical memory exits <br> Segment privilege attribute used in privilege tests. <br> $S=1$ Code or Data (includes stacks) segment descriptor <br> $S=0 \quad$ System Segment Descriptor or Gate Descriptor |
| 3 | Executable (E) <br> Expansion <br> Direction (ED) <br> Writable (W) | $\left.\begin{array}{ll}E=0 & \text { Descriptor type is data segment: } \\ E D=0 & \text { Expand up segment, offsets must be } \leq \text { limit. } \\ E D=1 & \text { Expand down segment, offsets must be }>\text { limit. } \\ W=0 & \text { Data segment may not be written into. } \\ W=1 & \text { Data segment may be written into. }\end{array}\right\}$If <br> Data <br> Segment <br> $(S=1$, <br> $E=0)$ |
| 3 | Executable (E) <br> Conforming (C) <br> Readable (R) | $\left.\left.\begin{array}{ll}E=1 & \text { Descriptor type is code segment: } \\ C=1 & \text { Code segment may only be executed when } \\ R=0 & \text { CPL } 2 D P L \text { and CPL remains unchanged. } \\ R=1 & \text { Code segment may not be read. }\end{array}\right\} \begin{array}{l}\text { Code segment may be read. }\end{array}\right\}$If <br> Code <br> Segment <br> $(S=1$, <br> $E=1)$ |
| 0 | Accessed (A) | $A=0$ Segment has not been accessed. <br> $A=1$ Segment selector has been loaded into segment register or used by selector test instructions. |

generated that is a truncated version of this linear address. Truncation will be to the maximum number of address bits. It is recommended to place EPROM at the highest physical address and DRAM at the lowest physical addresses.

## Code and Data Descriptors ( $\mathbf{S}=1$ )

Figure 3.4 shows the general format of a code and data descriptor and Table 3.1 illustrates how the bits in the Access Right Byte are interpreted.

Code and data segments have several descriptor fields in common. The accessed bit, A , is set whenever the processor accesses a descriptor. The granularity bit, $G$, specifies if a segment length is 1 -bytegranular or 4 -Kbyte-granular. Base address bits $31-24$, which are normally found in 80386 descriptors, are not made externally available on the 80376. They do not affect the operation of the 80376. The $\mathrm{A}_{31}-\mathrm{A}_{24}$ field should be set to allow an 80386 to correctly execute with EPROM at the upper 4096 Mbytes of physical memory.

## System Descriptor Formats ( $\mathbf{S}=\mathbf{0}$ )

System segments describe information about operating system tables, tasks, and gates. Figure 3.5 shows the general format of system segment descriptors, and the various types of system segments.

80376 system descriptors (which are the same as 80386 descriptor types 2, 5, 9, B, C, E and F) contain a 32 -bit logical base address and a 20 -bit segment limit.

## Selector Fields

A selector has three fields: Local or Global Descriptor Table Indicator (TI), Descriptor Entry Index (Index), and Requestor ( the selector's) Privilege Level (RPL) as shown in Figure 3.6. The TI bit selects either the Global Descriptor Table or the Local Descriptor Table. The Index selects one of 8 K descriptors in the appropriate descriptor table. The RPL bits allow high speed testing of the selector's privilege attributes.

## Segment Descriptor Cache

In addition to the selector value, every segment register has a segment descriptor cache register associated with it. Whenever a segment register's contents are changed, the 8 -byte descriptor associated with that selector is automatically loaded (cached) on the chip. Once loaded, all references to that segment use the cached descriptor information instead of reaccessing the descriptor. The contents of the descriptor cache are not visible to the programmer. Since descriptor caches only change when a segment register is changed, programs which modify the descriptor tables must reload the appropriate segment registers after changing a descriptor's value.


Figure 3.5. System Descriptors


Figure 3.6. Example Descriptor Selection

### 3.3 Protection

The 80376 offers extensive protection features. These protection features are particularly useful in sophisticated embedded applications which use multitasking real-time operating systems. For simpler embedded applications these protection capabilities can be easily bypassed by making all applications run at privilege level (PL) 0 .

## RULES OF PRIVILEGE

The 80376 controls access to both data and procedures between levels of a task, according to the following rules.
-Data stored in a segment with privilege level $p$ can be accessed only by code executing at a privilege level at least as privileged as $\mathbf{p}$.
-A code segment/procedure with privilege level $\mathbf{p}$ can only be called by a task executing at the same or a lesser privilege level than $\mathbf{p}$.

## PRIVILEGE LEVELS

At any point in time, a task on the 80376 always executes at one of the four privilege levels. The Current Privilege Level (CPL) specifies what the task's privilege level is. A task's CPL may only be changed
by control transfers through gate descriptors to a code segment with a different privilege level. Thus, an application program running at $\mathrm{PL}=3$ may call an operating system routine at $\mathrm{PL}=1$ (via a gate) which would cause the task's CPL to be set to 1 until the operating system routine was finished.

## Selector Privilege (RPL)

The privilege level of a selector is specified by the RPL field. The selector's RPL is only used to establish a less trusted privilege level than the current privilege level of the task for the use of a segment. This level is called the task's effective privilege level (EPL). The EPL is defined as being the least privileged (numerically larger) level of a task's CPL and a selector's RPL. The RPL is most commonly used to verify that pointers passed to an operating system procedure do not access data that is of higher privilege than the procedure that originated the pointer. Since the originator of a selector can specify any RPL value, the Adjust RPL (ARPL) instruction is provided to force the RPL bits to the originator's CPL.

## I/O Privilege

The I/O privilege level (IOPL) lets the operating system code executing at CPL $=0$ define the least privileged level at which I/O instructions can be used. An exception 13 (General Protection Violation) is generated if an I/O instruction is attempted when the CPL of the task is less privileged than the IOPL. The IOPL is stored in bits 13 and 14 of the EFLAGS register. The following instructions cause an exception 13 if the CPL is greater than IOPL: IN, INS, OUT, OUTS, STI, CLI and LOCK prefix.

## Descriptor Access

There are basically two types of segment accessess: those involving code segments such as control transfers, and those involving data accesses. 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 as described above.

Any time an instruction loads a data segment register (DS, ES, FS, GS) the 80376 makes protection validation checks. Selectors loaded in the DS, ES, FS, GS registers must refer only to data segment or readable code segments.

Finally the privilege validation checks are performed. The CPL is compared to the EPL and if the EPL is more privileged than the CPL, an exception 13 (general protection fault) is generated.

The rules regarding the stack segment are slightly different than those involving data segments. Instructions that load selectors into SS must refer to data segment descriptors for writeable data segments. The DPL and RPL must equal the CPL of all other descriptor types or a privilege level violation will cause an exception 13. A stack not present fault causes an exception 12.

## PRIVILEGE LEVEL TRANSFERS

Inter-segment control transfers occur when a selector is loaded in the CS register. For a typical system most of these transfers are simply the result of a call or a jump to another routine. There are five types of control transfers which are summarized in Table 3.2. Many of these transfers result in a privilege level transfer. Changing privilege levels is done only by control transfers, using gates, task switches, and interrupt or trap gates.

Control transfers can only occur if the operation which loaded the selector references the correct descriptor type. Any violation of these descriptor usage rules will cause an exception 13.

## CALL GATES

Gates provide protected indirect CALLs. One of the major uses of gates is to provide a secure method of privilege transfers within a task. Since the operating system defines all of the gates in a system, it can ensure that all gates only allow entry into a few trusted procedures.

Table 3.2. Descriptor Types Used for Control Transfer

| Control Transfer Types | Operation Types | Descriptor Referenced | Descriptor Table |
| :---: | :---: | :---: | :---: |
| Intersegment within the same privilege level | JMP, CALL, RET, IRET* | Code Segment | GDT/LDT |
| Intersegment to the same or higher privilege level Interrupt within task may change CPL | CALL | Call Gate | GDT/LDT |
|  | Interrupt Instruction, Exception, External Interrupt | Trap or Interrupt Gate | IDT |
| Intersegment to a lower privilege level (changes task CPL) | RET, IRET* | Code Segment | GDT/LDT |
|  | CALL, JMP | Task State Segment | GDT |
| Task Switch | CALL, JMP | Task Gate | GDT/LDT |
|  | IRET** <br> Interrupt Instruction, Exception, External Interrupt | Task Gate | IDT |

${ }^{*}$ NT (Nested Task bit of flag register) $=0$
**NT (Nested Task bit of flag register) $=1$


Figure 3.7. 80376 TSS And TSS Registers

## TASK SWITCHING

A very important attribute of any multi-tasking operating system is its ability to rapidly switch between tasks or processes. The 80376 directly supports this operation by providing a task switch instruction in hardware. The 80376 task switch operation saves the entire state of the machine (all of the registers, address space, and a link to the previous task), loads a new execution state, performs protection checks, and commences execution in the new task. Like transfer of control by 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 a task gate descriptor in the GDT or LDT. An INT $n$ instruction, exception, trap or external interrupt may also invoke the task switch operation if there is a task gate descriptor in the associated IDT descriptor slot. For simple applications, the TSS and task switching may not be used. The TSS or task switch will not be used or occur if no task gates are present in the GDT, LDT or IDT.

The TSS descriptor points to a segment (see Figure 3.7) containing the entire 80376 execution state. A task gate descriptor contains a TSS selector. The limit of an 80376 TSS must be greater than 64H, and can be as large as 16 Mbytes. In the additional TSS space, the operating system is free to store additional information as the reason the task is inactive, the time the task has spent running, and open files belonging to the task. For maximum performance, TSS should start on an even address.

Each Task must have a TSS associated with it. The current TSS is identified by a special register in the 80376 called the Task State Segment Register (TR). This register contains a selector referring to the task state segment descriptor that defines the current TSS. A hidden base and limit register associated with the TSS descriptor is loaded whenever TR is loaded with a new selector. Returning from a task is accomplished by the IRET instruction. When IRET is executed, control is returned to the task which was
interrupted. The current executing task's state is saved in the TSS and the old task state is restored from its TSS.

Several bits in the flag register and CRO register give information about the state of a task which is useful to the operating system. The Nested Task bit, NT, controls the function of the IRET instruction. If NT $=$ 0 the IRET instruction performs the regular return. If NT $=1$, IRET performs a task switch operation back to the previous task. The NT bit is set or reset in the following fashion:

When a CALL or INT instruction initiates a task switch, the 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 (The NT bit will be restored after execution of the interrupt handler). NT may also be set or cleared by POPF or IRET instructions.

The 80376 task state segment is marked busy by changing the descriptor type field from TYPE 9 to TYPE OBH. Use of a selector that references a busy task state segment causes an exception 13.

The coprocessor's state is not automatically saved when a task switch occurs. The Task Switched Bit, TS, in the CRO register helps deal with the coprocessor's state in a multi-tasking environment. Whenever the 80376 switches tasks, it sets the TS bit. The 80376 detects the first use of a processor extension instruction after a task switch and causes the processor extension not available exception 7. The exception handler for exception 7 may then decide whether to save the state of the coprocessor.

The T bit in the 80376 TSS indicates that the processor should generate a debug exception when switching to a task. If $T=1$ then upon entry to a new task a debug exception 1 will be generated.


240182-15

$$
\text { I/O Ports Accessible } 2 \rightarrow 9,12,13,15,20 \rightarrow 24,27,33,34,40,41,48,50,52,53,58 \rightarrow 60,62,63,96 \rightarrow 127
$$

Figure 3.8. Sample I/O Permission Bit Map

## PROTECTION AND I/O PERMISSION BIT MAP

The I/O instructions that directly refer to addresses in the processor's I/O space are IN, INS, OUT and OUTS. The 80376 has the ability to selectively trap references to specific I/O addresses. The structure that enables selective trapping is the //O Permission Bit Map in the TSS segment (see Figures 3.7 and 3.8). The I/O permission map is a bit vector. The size of the map and its location in the TSS segment are variable. The processor locates the 1/O permission map by means of the I/O map base field in the fixed portion of the TSS. The I/O map base field is 16 bits wide and contains the offset of the beginning of the I/O permission map.

If an I/O instruction (IN, INS, OUT or OUTS) is encountered, the processor first checks whether CPL $\leq$ IOPL. If this condition is true, the I/O operation may proceed. If not true, the processor checks the I/O permission map.

Each bit in the map corresponds to an I/O port byte address; for example, the bit for port 41 is found at I/O map base +5 linearly, ( $5 \times 8=40$ ), bit offset 1. The processor tests all the bits that correspond to the I/O addresses spanned by an I/O operation; for example, a double word operation tests four bits corresponding to four adjacent byte addresses. If any tested bit is set, the processor signals a general protection exception. If all the tested bits are zero, the I/O operations may proceed.

It is not necessary for the I/O permission map to represent all the I/O addresses. I/O addresses not spanned by the map are treated as if they had onebits in the map. The I/O map base should be at least one byte less than the TSS limit and the last byte beyond the I/O mapping information must contain all 1's.

Because the I/O permission map is in the TSS segment, different tasks can have different maps. Thus, the operating system can allocate ports to a task by changing the I/O permission map in the task's TSS.

## IMPORTANT IMPLEMENTATION NOTE:

Beyond the last byte of I/O mapping information in the I/O permission bit map must be a byte containing all 1's. The byte of all 1's must be within the limit of the 80376's TSS segment (see Figure 3.7).

### 4.0 FUNCTIONAL DATA

The Intel 80376 embedded processor features a straightforward functional interface to the external hardware. The 80376 has separate parallel buses for data and address. The data bus is 16 bits in width, and bidirectional. The address bus outputs 24 -bit address values using 23 address lines and two-byte enable signals.

The 80376 has two selectable address bus cycles: pipelined and non-pipelined. The pipelining option allows as much time as possible for data access by


Figure 4.1. Functional Signal Groups
starting the pending bus cycle before the present bus cycle is finished. A non-pipelined bus cycle gives the highest bus performance by executing every bus cycle in two processor clock cycles. For maximum design flexibility, the address pipelining option is selectable on a cycle-by-cycle basis.

The processor's bus cycle is the basic mechanism for information transfer, either from system to processor, or from processor to system. 80376 bus cycles perform data transfer in a minimum of only two clock periods. On a 16 -bit data bus, the maximum 80376 transfer bandwidth at 16 MHz is therefore 16 Mbytes $/ \mathrm{sec}$. However, any bus cycle will be extended for more than two clock periods if external hardware withholds acknowledgement of the cycle.

The 80376 can relinquish control of its local buses to allow mastership by other devices, such as direct memory access (DMA) channels. When relinquished, HLDA is the only output pin driven by the 80376, providing near-complete isolation of the
processor from its system (all other output pins are in a float condition).

### 4.1 Signal Description Overview

Ahead is a brief description of the 80376 input and output signals arranged by functional groups.

The signal descriptions sometimes refer to A.C. timing parameters, such as " $t_{25}$ Reset Setup Time" and "t ${ }_{26}$ Reset Hold Time." The values of these parameters can be found in Tables 6.4 and 6.5.

## CLOCK (CLK2)

CLK2 provides the fundamental timing for the 80376. It is divided by two internally to generate the internal processor clock used for instruction execution. The internal clock is comprised of two


Figure 4.2. CLK2 Signal and Internal Processor Clock
phases, "phase one" and "phase two". Each CLK2 period is a phase of the internal clock. Figure 4.2 illustrates the relationship. If desired, the phase of the internal processor clock can be synchronized to a known phase by ensuring the falling edge of the RESET signal meets the applicable setup and hold times $\mathrm{t}_{25}$ and $\mathrm{t}_{26}$.

## DATA BUS ( $\mathbf{D}_{15}-\mathrm{D}_{\mathbf{0}}$ )

These three-state bidirectional signals provide the general purpose data path between the 80376 and other devices. The data bus outputs are active HIGH and will float during bus hold acknowledge. Data bus reads require that read-data setup and hold times $t_{21}$ and $t_{22}$ be met relative to CLK2 for correct operation.

## ADDRESS BUS ( $\overline{B H E}, \overline{B L E}, A_{23}-A_{1}$ )

These three-state outputs provide physical memory addresses or I/O port addresses. $\mathrm{A}_{23}-\mathrm{A}_{16}$ are LOW during I/O transfers except for I/O transfers automatically generated by coprocessor instructions.

During coprocessor I/O transfers, $\mathrm{A}_{22}-\mathrm{A}_{16}$ are driven LOW, and $A_{23}$ is driven HIGH so that this address line can be used by external logic to generate the coprocessor select signal. Thus, the I/O address driven by the 80376 for coprocessor commands is 8000 F 8 H , and the I/O address driven by the 80376 processor for coprocessor data is 8000 FCH or 8000FEH.

The address bus is capable of addressing 16 Mbytes of physical memory space ( 000000 H through OFFFFFFH), and 64 Kbytes of I/O address space ( 000000 H through 00FFFFH) for programmed I/O. The address bus is active HIGH and will float during bus hold acknowledge.

The Byte Enable outputs $\overline{\mathrm{BHE}}$ and $\overline{\mathrm{BLE}}$ directly indicate which bytes of the 16-bit data bus are involved with the current transfer. $\overline{\mathrm{BHE}}$ applies to $\mathrm{D}_{15}-\mathrm{D}_{8}$ and $\overline{B L E}$ applies to $D_{7}-D_{0}$. If both $\overline{B H E}$ and $\overline{B L E}$ are asserted, then 16 bits of data are being transferred. See Table 4.1 for a complete decoding of these signals. The byte enables are active LOW and will float during bus hold acknowledge.

Table 4.1. Byte Enable Definitions

| $\overline{\text { BHE }}$ | $\overline{\text { BLE }}$ |  |
| :---: | :---: | :--- |
| 0 | 0 | Word Transfer |
| 0 | 1 | Byte Transfer on Upper Byte of the Data Bus, $\mathrm{D}_{15}-\mathrm{D}_{8}$ |
| 1 | 0 | Byte Transfer on Lower Byte of the Data Bus, $\mathrm{D}_{7}-\mathrm{D}_{0}$ |
| 1 | 1 | Never Occurs |

## BUS CYCLE DEFINITION SIGNALS (W/R, D/C $, ~ M / \overline{\mathrm{O}}, \overline{\text { LOCK }}$ )

These three-state outputs define the type of bus cycle being performed: $W / \bar{R}$ distinguishes between write and read cycles, $D / \bar{C}$ distinguishes between data and control cycles, $M / \overline{\mathrm{O}}$ distinguishes between memory and I/O cycles, and LOCK distinguishes between locked and unlocked bus cycles. All of these signals are active LOW and will float during bus acknowledge.

The primary bus cycle definition signals are $W / \overline{\mathrm{R}}$, $D / \bar{C}$ and $M / \overline{\mathrm{O}}$, since these are the signals driven valid as $\overline{\text { ADS }}$ (Address Status output) becomes active. The LOCK signal is driven valid at the same time the bus cycle begins, which due to address pipelining, could be after $\overline{A D S}$ becomes active. Exact bus cycle definitions, as a function of $W / \overline{\mathrm{R}}, \mathrm{D} / \overline{\mathrm{C}}$ and $\mathrm{M} / \overline{\mathrm{IO}}$ are given in Table 4.2.
$\overline{\text { LOCK }}$ indicates that other system bus masters are not to gain control of the system bus while it is active. LOCK is activated on the CLK2 edge that begins the first locked bus cycle (i.e., it is not active at the same time as the other bus cycle definition pins) and is deactivated when ready is returned to the end of the last bus cycle which is to be locked. The beginning of a bus cycle is determined when READY is returned in a previous bus cycle and another is pending ( $\overline{\mathrm{ADS}}$ is active) or the clock in which $\overline{\mathrm{ADS}}$ is driven active if the bus was idle. This means that it follows more closely with the write data rules when it is valid, but may cause the bus to be locked longer than desired. The $\overline{\text { LOCK }}$ signal may be explicitly activated by the LOCK prefix on certain instructions. LOCK is always asserted when executing the XCHG instruction, during descriptor updates, and during the interrupt acknowledge sequence.

## BUS CONTROL SIGNALS (ADS, $\overline{\text { READY, }} \overline{\text { NA }})$

The following signals allow the processor to indicate when a bus cycle has begun, and allow other system hardware to control address pipelining and bus cycle termination.

## Address Status ( $\overline{\text { ADS }}$ )

This three-state output indicates that a valid bus cycle definition and address ( $\mathrm{W} / \overline{\mathrm{K}}, \mathrm{D} / \overline{\mathrm{C}}, \mathrm{M} / \overline{\mathrm{O}}, \overline{\mathrm{BHE}}$, $\overline{B L E}$ and $A_{23}-A_{1}$ ) are being driven at the 80376 pins. $\overline{\text { ADS }}$ is an active LOW output. Once $\overline{\text { ADS }}$ is driven active, valid address, byte enables, and definition signals will not change. In addition, $\overline{\text { ADS }}$ will remain active until its associated bus cycle begins (when READY is returned for the previous bus cycle when running pipelined bus cycles). $\overline{\text { ADS }}$ will float during bus hold acknowledge. See sections NonPipelined Bus Cycles and Pipelined Bus Cycles for additional information on how $\overline{\text { ADS }}$ is asserted for different bus states.

## Transfer Acknowledge ( $\overline{\text { READY }})$

This input indicates the current bus cycle is complete, and the active bytes indicated by BHE and BLE are accepted or provided. When READY is sampled active during a read cycle or interrupt acknowledge cycle, the 80376 latches the input data and terminates the cycle. When READY is sampled active during a write cycle, the processor terminates the bus cycle.

Table 4.2. Bus Cycle Definition

| $\mathbf{M} / \overline{\mathbf{I O}}$ | $\mathbf{D} / \overline{\mathbf{C}}$ | $\mathbf{W} / \overline{\mathbf{R}}$ | Bus Cycle Type | Locked? |
| :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | 0 | INTERRUPT ACKNOWLEDGE | Yes |
| 0 | 0 | 1 | Does Not Occur | - |
| 0 | 1 | 0 | I/O DATA READ | No |
| 0 | 1 | 1 | I/O DATA WRITE | No |
| 1 | 0 | 0 | MEMORY CODE READ | No |
| 1 | 0 | 1 | HALT: $\quad$SHUTDOWN: <br> Address $=2 \quad$ Address $=0$ <br> $\overline{\text { BHE }}=1 \quad$ BHE $=1$ | No |
| 1 | 1 | 0 | $\overline{\text { BLE }}=0$ |  |

READY is ignored on the first bus state of all bus cycles, and sampled each bus state thereafter until asserted. READY must eventually be asserted to acknowledge every bus cycle, including Halt Indication and Shutdown Indication bus cycles. When being sampled, READY must always meet setup and hold times $\mathrm{t}_{19}$ and $\mathrm{t}_{20}$ for correct operation.

## Next Address Request ( $\overline{\mathrm{NA}}$ )

This is used to request pipelining. This input indicates the system is prepared to accept new values of $\overline{B H E}, \overline{B L E}, A_{23}-A_{1}, W / \bar{R}, D / \bar{C}$ and $M / \bar{O}$ from the 80376 even if the end of the current cycle is not being acknowledged on READY. If this input is active when sampled, the next bus cycle's address and status signals are driven onto the bus, provided the next bus request is already pending internally. $\overline{N A}$ is ignored in clock cycles in which $\overline{\text { ADS }}$ or READY is activated. This signal is active LOW and must satisfy setup and hold times $t_{15}$ and $t_{16}$ for correct operation. See Pipelined Bus Cycles and Read and Write Cycles for additional information.

## BUS ARBITRATION SIGNALS (HOLD, HLDA)

This section describes the mechanism by which the processor relinquishes control of its local buses when requested by another bus master device. See Entering and Exiting Hold Acknowledge for additional information.

## Bus Hold Request (HOLD)

This input indicates some device other than the 80376 requires bus mastership. When control is granted, the 80376 floats $A_{23}-\mathrm{A}_{1}, \overline{\mathrm{BHE},} \overline{\mathrm{BLE}}$, $D_{15}-D_{0}, \overline{L O C K}, M / \bar{O}, \bar{D} / \bar{C}, W / \bar{R}$ and $\overline{A D S}$, and then activates HLDA, thus entering the bus hold acknowledge state. The local bus will remain granted to the requesting master until HOLD becomes inactive. When HOLD becomes inactive, the 80376 will deactivate HLDA and drive the local bus (at the same time), thus terminating the hold acknowledge condition.

HOLD must remain asserted as long as any other device is a local bus master. External pull-up resistors may be required when in the hold acknowledge state since none of the 80376 floated outputs have internal pull-up resistors. See Resistor Recommendations for additional information. HOLD is not recognized while RESET is active but is recognized during the time between the high-to-low transistion of RESET and the first instruction fetch. If RESET is asserted while HOLD is asserted, RESET has priority and places the bus into an idle state, rather than the hold acknowledge (high-impedance) state.

HOLD is a level-sensitive, active HIGH, synchronous input. HOLD signals must always meet setup and hold times $\mathrm{t}_{23}$ and $\mathrm{t}_{24}$ for correct operation.

## Bus Hold Acknowledge (HLDA)

When active (HIGH), this output indicates the 80376 has relinquished control of its local bus in response to an asserted HOLD signal, and is in the bus Hold Acknowledge state.

The Bus Hold Acknowledge state offers near-complete signal isolation. In the Hold Acknowledge state, HLDA is the only signal being driven by the 80376. The other output signals or bidirectional signals ( $\mathrm{D}_{15}-\mathrm{D}_{0}, \overline{B H E}, \overline{B L E}, \mathrm{~A}_{23}-\mathrm{A}_{1}, \mathrm{~W} / \overline{\mathrm{R}}, \mathrm{D} / \overline{\mathrm{C}}, \mathrm{M} / \overline{\mathrm{IO}}$, LOCK and $\overline{\text { ADS }}$ ) are in a high-impedance state so the requesting bus master may control them. These pins remain OFF throughout the time that HLDA remains active (see Table 4.3). Pull-up resistors may be desired on several signals to avoid spurious activity when no bus master is driving them. See Resistor Recommendations for additional information.

When the HOLD signal is made inactive, the 80376 will deactivate HLDA and drive the bus. One rising edge on the NMI input is remembered for processing after the HOLD input is negated.

Table 4.3. Output Pin State during HOLD

| Pin Value | Pin Names |
| :--- | :--- |
| 1 |  |
| Float | HLDA <br> $\mathrm{LOCK}, ~ M / \overline{\mathrm{O}}, \mathrm{D} / \overline{\mathrm{C}}, \mathrm{W} / \overline{\mathrm{R}}$, |

## Hold Latencies

The maximum possible HOLD latency depends on the software being executed. The actual HOLD latency at any time depends on the current bus activity, the state of the LOCK signal (internal to the CPU) activated by the LOCK prefix, and interrupts. The 80376 will not honor a HOLD request until the current bus operation is complete.

The 80376 breaks 32 -bit data or I/O accesses into 2 internally locked 16 -bit bus cycles; the LOCK signal is not asserted. The 80376 breaks unaligned 16-bit or 32 -bit data or I/O accesses into 2 or 3 internally locked 16 -bit bus cycles. Again the LOCK signal is not asserted but a HOLD request will not be recognized until the end of the entire transfer.

Wait states affect HOLD latency. The 80376 will not honor a HOLD request until the end of the current bus operation, no matter how many wait states are required. Systems with DMA where data transfer is critical must insure that $\overline{R E A D Y}$ returns sufficiently soon.

## COPROCESSOR INTERFACE SIGNALS (PEREQ, BUSY, ERROR)

In the following sections are descriptions of signals dedicated to the numeric coprocessor interface. In addition to the data bus, address bus, and bus cycle definition signals, these following signals control communication between the 80376 and the 80387SX processor extension.

## Coprocessor Request (PEREQ)

When asserted (HIGH), this input signal indicates a coprocessor request for a data operand to be transferred to/from memory by the 80376 . In response, the 80376 transfers information between the coprocessor and memory. Because the 80376 has internally stored the coprocessor opcode being executed, it performs the requested data transfer with the correct direction and memory address.

PEREQ is a level-sensitive active HIGH asynchronous signal. Setup and hold times, $\mathrm{t}_{29}$ and $\mathrm{t}_{30}$, relative to the CLK2 signal must be met to guarantee recognition at a particular clock edge. This signal is provided with a weak internal pull-down resistor of around $20 \mathrm{~K} \Omega$ to ground so that it will not float active when left unconnected.

## Coprocessor Busy (BUSY)

When asserted (LOW), this input indicates the coprocessor is still executing an instruction, and is not yet able to accept another. When the 80376 encounters any coprocessor instruction which operates on the numerics stack (e.g. load, pop, or arithmetic operation), or the WAIT instruction, this input is first automatically sampled until it is seen to be inactive. This sampling of the $\overline{B U S Y}$ input prevents overrunning the execution of a previous coprocessor instruction.

The $F(N) I N I T, F(N) C L E X$ coprocessor instructions are allowed to execute even if $\overline{\mathrm{BUSY}}$ is active, since these instructions are used for coprocessor initialization and exception-clearing.
$\overline{B U S Y}$ is an active LOW, level-sensitive asynchronous signal. Setup and hold times, $\mathrm{t}_{29}$ and $\mathrm{t}_{30}$, relative to the CLK2 signal must be met to guarantee recognition at a particular clock edge. This pin is provided with a weak internal pull-up resistor of around $20 \mathrm{~K} \Omega$ to $\mathrm{V}_{\mathrm{CC}}$ so that it will not float active when left unconnected.
$\overline{B U S Y}$ serves an additional function. If $\overline{B U S Y}$ is sampled LOW at the falling edge of RESET, the 80376 processor performs an internal self-test (see Bus Activity During and Following Reset. If $\overline{B U S Y}$ is sampled HIGH, no self-test is performed.

## Coprocessor Error (ERROR)

When asserted (LOW), this input signal indicates that the previous coprocessor instruction generated a coprocessor error of a type not masked by the coprocessor's control register. This input is automatically sampled by the 80376 when a coprocessor instruction is encountered, and if active, the 80376 generates exception 16 to access the error-handling software.

Several coprocessor instructions, generally those which clear the numeric error flags in the coprocessor or save coprocessor state, do execute without the 80376 generating exception 16 even if ERROR is active. These instructions are FNINIT, FNCLEX, FNSTSW, FNSTSWAX, FNSTCW, FNSTENV and FNSAVE.
$\overline{E R R O R}$ is an active LOW, level-sensitive asynchronous signal. Setup and hold times $\mathrm{t}_{29}$ and $\mathrm{t}_{30}$, relative to the CLK2 signal must be met to guarantee recognition at a particular clock edge. This pin is provided with a weak internal pull-up resistor of around $20 \mathrm{~K} \Omega$ to $\mathrm{V}_{\mathrm{CC}}$ so that it will not float active when left unconnected.

## INTERRUPT SIGNALS (INTR, NMI, RESET)

The following descriptions cover inputs that can interrupt or suspend execution of the processor's current instruction stream.

## Maskable Interrupt Request (INTR)

When asserted, this input indicates a request for interrupt service, which can be masked by the 80376 Flag Register IF bit. When the 80376 responds to the INTR input, it performs two interrupt acknowledge bus cycles and, at the end of the second, latches an 8-bit interrupt vector on $D_{7}-D_{0}$ to identify the source of the interrupt.

INTR is an active HIGH, level-sensitive asynchronous signal. Setup and hold times, $\mathrm{t}_{27}$ and $\mathrm{t}_{28}$, relative to the CLK2 signal must be met to guarantee recognition at a particular clock edge. To assure recognition of an INTR request, INTR should remain active until the first interrupt acknowledge bus cycle begins. INTR is sampled at the beginning of every instruction. In order to be recognized at a particular instruction boundary, INTR must be active at least eight CLK2 clock periods before the beginning of the execution of the instruction. If recognized, the 80376 will begin execution of the interrupt.

## Non-Maskable Interrupt Request (NMI)

This input indicates a request for interrupt service which cannot be masked by software. The nonmaskable interrupt request is always processed according to the pointer or gate in slot 2 of the interrupt table. Because of the fixed NMI slot assignment, no interrupt acknowledge cycles are performed when processing NMI.

NMI is an active HIGH, rising edge-sensitive asynchronous signal. Setup and hold times, $\mathrm{t}_{27}$ and $\mathrm{t}_{28}$, relative to the CLK2 signal must be met to guarantee recognition at a particular clock edge. To assure recognition of NMI; it must be inactive for at least eight CLK2 periods, and then be active for at least eight CLK2 periods before the beginning of the execution of an instruction.

Once NMI processing has begun, no additional NMI's are processed until after the next IRET instruction, which is typically the end of the NMI service routine. If NMI is re-asserted prior to that time, however, one rising edge on NMI will be remembered for processing after executing the next IRET instruction.

## Interrupt Latency

The time that elapses before an interrupt request is serviced (interrupt latency) varies according to several factors. This delay must be taken into account by the interrupt source. Any of the following factors can affect interrupt latency:

1. If interrupts are masked, and INTR request will not be recognized until interrupts are reenabled.
2. If an NMI is currently being serviced, an incoming NMI request will not be recognized until the 80376 encounters the IRET instruction.
3. An interrupt request is recognized only on an instruction boundary of the 80376 Execution Unit except for the following cases:

- Repeat string instructions can be interrupted after each iteration.
- If the instruction loads the Stack Segment register, an interrupt is not processed until after the following instruction, which should be an ESP load. This allows the entire stack pointer to be loaded without interruption.
- If an instruction sets the interrupt flag (enabling interrupts), an interrupt is not processed until after the next instruction.
The longest latency occurs when the interrupt request arrives while the 80376 processor is executing a long instruction such as multiplication, division or a task-switch.

4. Saving the Flags register and CS:EIP registers.
5. If interrupt service routine requires a task switch, time must be allowed for the task switch.
6. If the interrupt service routine saves registers that are not automatically saved by the 80376.

## RESET

This input signal suspends any operation in progress and places the 80376 in a known reset state. The 80376 is reset by asserting RESET for 15 or more CLK2 periods ( 80 or more CLK2 periods before requesting self-test). When RESET is active, all other input pins except FLT are ignored, and all other bus pins are driven to an idle bus state as shown in Table 4.4. If RESET and HOLD are both active at a point in time, RESET takes priority even if the 80376 was in a Hold Acknowledge state prior to RESET active.

RESET is an active HIGH, level-sensitive synchronous signal. Setup and hold times, $\mathrm{t}_{25}$ and $\mathrm{t}_{26}$, must be met in order to assure proper operation of the 80376.

Table 4.4. Pin State (Bus Idle) during RESET

| Pin Name | Signal Level during RESET |
| :--- | :--- |
| $\overline{\mathrm{ADS}}$ | 1 |
| $\mathrm{D}_{15}-\mathrm{D}_{0}$ | Float |
| $\overline{\mathrm{BHE}, \overline{\mathrm{BLE}}}$ | 0 |
| $\mathrm{~A}_{23}-\mathrm{A}_{1}$ | 1 |
| $\mathrm{~W} / \overline{\mathrm{R}}$ | 0 |
| $\mathrm{D} / \overline{\mathrm{C}}$ | 1 |
| $\mathrm{M} / \overline{\mathrm{IO}}$ | 0 |
| $\overline{\mathrm{LOCK}}$ | 1 |
| HLDA | 0 |

### 4.2 Bus Transfer Mechanism

All data transfers occur as a result of one or more bus cycles. Logical data operands of byte and word lengths may be transferred without restrictions on physical address alignment. Any byte boundary may be used, although two physical bus cycles are performed as required for unaligned operand transfers.

The 80376 processor address signals are designed to simplify external system hardware. $\overline{\mathrm{BHE}}$ and $\overline{\mathrm{BLE}}$ provide linear selects for the two bytes of the 16-bit data bus.

Byte Enable outputs $\overline{\mathrm{BHE}}$ and $\overline{\mathrm{BLE}}$ are asserted when their associated data bus bytes are involved with the present bus cycle, as listed in Table 4.5.

Table 4.5. Byte Enables and Associated Data and Operand Bytes

| Byte Enable | Associated Data Bus Signals |
| :--- | :---: |
| $\overline{B H E}$ | $D_{15}-D_{8}$ (Byte 1-Most Significant) |
| $\overline{B L E}$ | $D_{7}-D_{0}$ (Byte 0-Least Significant) |

Each bus cycle is composed of at least two bus states. Each bus state requires one processor clock period. Additional bus states added to a single bus cycle are called wait states. See Bus Functional Description for additional information.

### 4.3 Memory and I/O Spaces

Bus cycles may access physical memory space or I/O space. Peripheral devices in the system may either be memory-mapped, or I/O-mapped, or both. As shown in Figure 4.3, physical memory addresses range from 000000 H to OFFFFFFH ( 16 Mbytes) and 1/O addresses from 000000 H to 00FFFFH (64 Kbytes). Note the I/O addresses used by the automatic I/O cycles for coprocessor communication are 8000 F 8 H to 8000 FFH , beyond the address range of programmed $1 / O$, to allow easy generation of a coprocessor chip select signal using the $A_{23}$ and $\mathrm{M} / \overline{\mathrm{IO}}$ signals.

## OPERAND ALIGNMENT

With the flexibility of memory addressing on the 80376, it is possible to transfer a logical operand that spans more than one physical Dword or word of memory or I/O. Examples are 32-bit Dword or 16-bit word operands beginning at addresses not evenly divisible by 2.

Operand alignment and size dictate when multiple bus cycles are required. Table 4.6 describes the transfer cycles generated for all combinations of logical operand lengths and alignment.

Table 4.6. Transfer Bus Cycles for Bytes, Words and Dwords

|  | Byte-Length of Logical Operand |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 | 2 |  |  |  | 4 |  |  |  |
| Physical Byte Address in Memory (Low-Order Bits) | XX | 00 | 01 | 10 | 11 | 00 | 01 | 10 | 11 |
| Transfer Cycles | b | w | lb, hb | w | hb, I,b | Iw, hw | hb, lb, mw | hw, Iw | mw, hb, lb |
| $\begin{array}{ll} \text { Key: } & b=\text { byte transfer } \\ & \text { w word transfer } \\ & \mathrm{l}=\text { low-order portion } \\ & \mathrm{m}=\text { mid-order portion } \\ & \mathrm{x}=\text { don't care } \\ & \mathrm{h}=\text { high-order portion } \end{array}$ |  |  |  |  |  |  |  |  |  |



240182-18
NOTE:
Since $A_{23}$ is HIGH during automatic communication with coprocessor, $A_{23} \mathrm{HIGH}$ and $\mathrm{M} / \overline{\mathrm{IO}}$ LOW can be used to easily generate a coprocessor select signal.

Figure 4.3. Physical Memory and I/O Spaces

### 4.4 Bus Functional Description

The 80376 has separate, parallel buses for data and address. The data bus is 16 bits in width, and bidirectional. The address bus provides a 24 -bit value using 23 signals for the 23 upper-order address bits and 2 Byte Enable signals to directly indicate the active bytes. These buses are interpreted and controlled by several definition signals.

The definition of each bus cycle is given by three signals: $M / \bar{O}, W / \bar{R}$ and $D / \bar{C}$. At the same time, a valid address is present on the byte enable signals, $\overline{B H E}$ and $\overline{B L E}$, and the other address signals $\mathrm{A}_{23}-\mathrm{A}_{1}$. A status signal, $\overline{\mathrm{ADS}}$, indicates when the 80376 issues a new bus cycle definition and address.

Collectively, the address bus, data bus and all associated control signals are referred to simply as "the bus'. When active, the bus performs one of the bus cycles below:

1. Read from memory space
2. Locked read from memory space
3. Write to memory space
4. Locked write to memory space
5. Read from I/O space (or coprocessor)
6. Write to I/O space (or coprocessor)
7. Interrupt acknowledge (always locked)
8. Indicate halt, or indicate shutdown

Table 4.2 shows the encoding of the bus cycle definition signals for each bus cycle. See Bus Cycle Definition Signals for additonal information.

When the 80376 bus is not performing one of the activities listed above, it is either Idle or in the Hold Acknowledge state, which may be detected by external circuitry. The idle state can be identified by the 80376 giving no further assertions on its address strobe output ( $\overline{\mathrm{ADS}}$ ) since the beginning of its most recent bus cycle, and the most recent bus cycle having been terminated. The hold acknowledge state is identified by the 80376 asserting its hold acknowledge (HLDA) output.

The shortest time unit of bus activity is a bus state. A bus state is one processor clock period (two CLK2 periods) in duration. A complete data transfer occurs during a bus cycle, composed of two or more bus states.


Figure 4.4. Fastest Read Cycles with Non-Pipelined Timing

The fastest 80376 bus cycle requires only two bus states. For example, three consecutive bus read cycles, each consisting of two bus states, are shown by Figure 4.4. The bus states in each cycle are named T1 and T2. Any memory or I/O address may be accessed by such a two-state bus cycle, if the external hardware is fast enough.

Every bus cycle continues until it is acknowledged by the external system hardware, using the 80376 READY input. Acknowledging the bus cycle at the end of the first T2 results in the shortest bus cycle, requiring only T1 and T2. If READY is not immediately asserted however, T2 states are repeated indefinitely until the READY input is sampled active.

The pipelining option provides a choice of bus cycle timings. Pipelined or non-pipelined cycles are
selectable on a cycle-by-cycle basis with the Next Address ( $\overline{\mathrm{NA})}$ input.

When pipelining is selected the address ( $\overline{\mathrm{BHE}, \overline{B L E}}$ and $A_{23}-A_{1}$ ) and definition ( $W / \bar{R}, D / \bar{C}, M / \overline{\mathrm{OO}}$ and $\overline{\text { LOCK }}$ ) of the next cycle are available before the end of the current cycle. To signal their availability, the 80376 address status output ( $\overline{\text { ADS }}$ ) is asserted. Figure 4.5 illustrates the fastest read cycles with pipelined timing.

Note from Figure 4.5 the fastest bus cycles using pipelining require only two bus states, named T1P and T2P. Therefore pipelined cycles allow the same data bandwidth as non-pipelined cycles, but ad-dress-to-data access time is increased by one T-state time compared to that of a non-pipelined cycle.


240182-20
Figure 4.5. Fastest Read Cycles with Pipelined Timing

## READ AND WRITE CYCLES

Data transfers occur as a result of bus cycles, classified as read or write cycles. During read cycles, data is transferred from an external device to the processor. During write cycles, data is transferred from the processor to an external device.

Two choices of bus cycle timing are dynamically selectable: non-pipelined or pipelined. After an idle bus state, the processor always uses non-pipelined timing. However the $\overline{N A}$ (Next Address) input may be asserted to select pipelined timing for the next bus cycle. When pipelining is selected and the 80376 has a bus request pending internally, the address and definition of the next cycle is made available even before the current bus cycle is acknowledged by READY.

Terminating a read or write cycle, like any bus cycle, requires acknowledging the cycle by asserting the READY input. Until acknowledged, the processor inserts wait states into the bus cycle, to allow adjust-
ment for the speed of any external device. External hardware, which has decoded the address and bus cycle type, asserts the READY input at the appropriate time.

At the end of the second bus state within the bus cycle, $\overline{\text { READY }}$ is sampled. At that time, if external hardware acknowledges the bus cycle by asserting READY, the bus cycle terminates as shown in Figure 4.6. If READY is negated as in Figure 4.7, the 80376 executes another bus state (a wait state) and READY is sampled again at the end of that state. This continues indefinitely until the cycle is acknowledged by READY asserted.

When the current cycle is acknowledged, the 80376 terminates it. When a read cycle is acknowledged, the 80376 latches the information present at its data pins. When a write cycle is acknowledged, the write data of the 80376 remains valid throughout phase one of the next bus state, to provide write data hold time.


Idle states are shown here for diagram variety only. Write cycles are not always followed by an idle state. An active bus cycle can immediately follow the write cycle.

Figure 4.6. Various Non-Pipelined Bus Cycles (Zero Wait States)

## Non-Pipelined Bus Cycles

Any bus cycle may be performed with non-pipelined timing. For example, Figure 4.6 shows a mixture of non-pipelined read and write cycles. Figure 4.6 shows that the fastest possible non-pipelined cycles have two bus states per bus cycle. The states are named T1 and T2. In phase one of T1, the address signals and bus cycle definition signals are driven valid and, to signal their availability, address strobe ( $\overline{\mathrm{ADS}}$ ) is simultaneously asserted.

During read or write cycles, the data bus behaves as follows. If the cycle is a read, the 80376 floats its data signals to allow driving by the external device being addressed. The 80376 requires that all data bus pins be at a valid logic state (HIGH or LOW) at the end of each read cycle, when READY is asserted. The system MUST be designed to meet this requirement. If the cycle is a write, data signals are driven by the 80376 beginning in phase two of T1 until phase one of the bus state following

Idle states are shown here for diagram variety only. Write cycles are not always followed by an idle state. An active bus cycle can immediately follow the write cycle.

Figure 4.7. Various Non-Pipelined Bus Cycles (Various Number of Wait States)

Figure 4.7 illustrates non-pipelined bus cycles with one wait state added to Cycles 2 and 3. READY is sampled inactive at the end of the first T2 in Cycles 2 and 3 . Therefore Cycles 2 and 3 have T2 repeated again. At the end of the second T2, READY is sampled active.

When address pipelining is not used, the address and bus cycle definition remain valid during all wait states. When wait states are added and it is desirable to maintain non-pipelined timing, it is necessary to negate $\overline{N A}$ during each T2 state except the
last one, as shown in Figure 4.7, Cycles 2 and 3. If $\overline{N A}$ is sampled active during a T2 other than the last one, the next state would be T2l or T2P instead of another T2.

When address pipelining is not used, the bus states and transitions are completely illustrated by Figure 4.8. The bus transitions between four possible states, $\mathrm{T} 1, \mathrm{~T} 2, \mathrm{~T}_{\mathrm{i}}$, and $\mathrm{T}_{\mathrm{h}}$. Bus cycles consist of T 1 and T2, with T2 being repeated for wait states. Otherwise the bus may be idle, $\mathrm{T}_{\mathrm{i}}$, or in the hold acknowledge state $T_{h}$.


## Bus States:

T1-first clock of a non-pipelined bus cycle ( 80376 drives new address and asserts $\overline{\text { ADS }}$ ).
T2-subsequent clocks of a bus cycle when $\overline{N A}$ has not been sampled asserted in the current bus cycle.
Ti-idle state.
Th—hold acknowledge state (80376 asserts HLDA).
The fastest bus cycle consists of two states: T1 and T2.
Four basic bus states describe bus operation when not using pipelined address.
Figure 4.8. 80376 Bus States (Not Using Pipelined Address)

Bus cycles always begin with T1. T1 always leads to T2. If a bus cycle is not acknowledged during T2 and $\overline{N A}$ is inactive, T2 is repeated. When a cycle is acknowledged during T 2 , the following state will be T1 of the next bus cycle if a bus request is pending internally, or $T_{i}$ if there is no bus request pending, or $T_{h}$ if the HOLD input is being asserted.

Use of pipelining allows the 80376 to enter three additional bus states not shown in Figure 4.8. Figure 4.12 is the complete bus state diagram, including pipelined cycles.

## Pipelined Bus Cycles

Pipelining is the option of requesting the address and the bus cycle definition of the next inter-
nally pending bus cycle before the current bus cycle is acknowledged with READY asserted. $\overline{\text { ADS }}$ is asserted by the 80376 when the next address is issued. The pipelining option is controlled on a cycle-by-cycle basis with the $\overline{N A}$ input signal.

Once a bus cycle is in progress and the current address has been valid for at least one entire bus state, the $\overline{N A}$ input is sampled at the end of every phase one until the bus cycle is acknowledged. During non-pipelined bus cycles $\widehat{N A}$ is sampled at the end of phase one in every T2. An example is Cycle 2 in Figure 4.9, during which $\overline{N A}$ is sampled at the end of phase one of every T2 (it was asserted once during the first T2 and has no further effect during that bus cycle).


Following any idle bus state (Ti), bus cycles are non-pipelined. Within non-pipelined bus cycles, $\overline{\mathrm{NA}}$ is only sampled during wait states. Therefore, to begin pipelining during a group of non-pipelined bus cycles requires a non-pipelined cycle with at least one wait state (Cyicle 2 above).

Figure 4.9. Transitioning to Pipelining during Burst of Bus Cycles

If $\overline{N A}$ is sampled active, the 80376 is free to drive the address and bus cycle definition of the next bus cycle, and assert ADS, as soon as it has a bus request internally pending. It may drive the next address as early as the next bus state, whether the current bus cycle is acknowledged at that time or not.

Regarding the details of pipelining, the 80376 has the following characteristics:

1. The next address and status may appear as early as the bus state after NA was sampled active (see Figures 4.9 or 4.10 ). In that case, state T2P is entered immediately. However, when there is not an internal bus request already pending, the next address and status will not be available immediately after NA is asserted and T21 is entered instead of T2P (see Figure 4.11 Cycle 3). Provided the current bus cycle isn't yet acknow-
ledged by $\overline{\text { READY }}$ asserted, T2P will be entered as soon as the 80376 does drive the next address and status. External hardware should therefore observe the $\overline{A D S}$ output as confirmation the next address and status are actually being driven on the bus.
2. Any address and status which are validated by a pulse on the 80376 ADS output will remain stable on the address pins for at least two processor clock periods. The 80376 cannot produce a new address and status more frequently than every two processor clock periods (see Figures 4.9, 4.10 and 4.11).
3. Only the address and bus cycle definition of the very next bus cycle is available. The pipelining capability cannot look further than one bus cycle ahead (see Figure 4.11, Cycle 1).


Figure 4.10. Fastest Transition to Pipelined Bus Cycle Following Idle Bus State

The complete bus state transition diagram, including pipelining is given by Figure 4.12. Note it is a superset of the diagram for non-pipelined only, and the three additional bus states for pipelining are drawn in bold.

The fastest bus cycle with pipelining consists of just two bus states, T1P and T2P (recall for non-pipelined it is T1 and T2). T1P is the first bus state of a pipelined cycle.

## Initiating and Maintaining Pipelined Bus Cycles

Using the state diagram Figure 4.12, observe the transitions from an idle state, $\mathrm{T}_{\mathrm{i}}$, to the beginning of
a pipelined bus cycle T1P. From an idle state, $\mathrm{T}_{\mathrm{i}}$, the first bus cycle must begin with T1, and is therefore a non-pipelined bus cycle. The next bus cycle will be pipelined, however, provided $\overline{N A}$ is asserted and the first bus cycle ends in a T2P state (the address and status for the next bus cycle is driven during T2P). The fastest path from an idle state to a pipelined bus cycle is shown in bold below:

| $\mathbf{T}_{\mathbf{i}}, \mathbf{T}_{\mathbf{i}}$, | T1-T2-T2P, | T1P-T2P, |
| :--- | :--- | :--- |
| idle <br> states | non-pipelined <br> cycle | pipelined <br> cycle |



Figure 4.11. Details of Address Pipelining during Cycles with Wait States
T1-T2-T2P are the states of the bus cycle that establishes address pipelining for the next bus cycle, which begins with T1P. The same is true after a bus hold state, shown below:
$T_{h}, T_{h}, T_{h}, \quad$ T1-T2-T2P, T1P-T2P,
hold aknowledge non-pipelined states cycle
pipelined cycle

The transition to pipelined address is shown functionally by Figure 4.10, Cycle 1. Note that Cycle 1 is used to transition into pipelined address timing for the subsequent Cycles 2, 3 and 4, which are pipelined. The $\overline{N A}$ input is asserted at the appropriate time to select address pipelining for Cycles 2, 3 and 4.

Once a bus cycle is in progress and the current address and status has been valid for one entire bus state, the $\overline{N A}$ input is sampled at the end of every phase one until the bus cycle is acknowledged.


## Bus States:

T1-first clock of a non-pipelined bus cycle ( 80376 drives new address, status and asserts $\overline{\text { ADS }}$ ).
T2-subsequent clocks of a bus cycle when NA has not been sampled asserted in the current bus cycle.
T2|-subsequent clocks of a bus cycle when $\overline{\mathrm{NA}}$ has been sampled asserted in the current bus cycle but there is not yet an internal bus request pending ( 80376 will not drive new address, status or assert $\overline{\text { ADS }}$ ).
T2P-subsequent clocks of a bus cycle when $\overline{N A}$ has been sampled asserted in the current bus cycle and there is an internal bus request pending ( 80376 drives new address, status and asserts $\overline{\text { ADS }}$ ).
T1P-first clock of a pipelined bus cycle.
Ti-idle state.
Th-hold acknowledge state (80376 asserts HLDA).
Asserting $\overline{N A}$ for pipelined bus cycles gives access to three more bus states: T2I, T2P and T1P. Using pipelining the fastest bus cycle consists of T1P and T2P.

Figure 4.12. 80376 Processor Complete Bus States (Including Pipelining)

Sampling begins in T2 during Cycle 1 in Figure 4.10. Once $\overline{N A}$ is sampled active during the current cycle, the 80376 is free to drive a new address and bus cycle definition on the bus as early as the next bus state. In Figure 4.10, Cycle 1 for example, the next address and status is driven during state T2P. Thus Cycle 1 makes the transition to pipelined timing, since it begins with T1 but ends with T2P. Because the address for Cycle 2 is available before Cycle 2 begins, Cycle 2 is called a pipelined bus cycle, and it begins with T1P. Cycle 2 begins as soon as READY asserted terminates Cycle 1.

Examples of transition bus cycles are Figure 4.10, Cycle 1 and Figure 4.9, Cycle 2. Figure 4.10 shows transition during the very first cycle after an idle bus state, which is the fastest possible transition into address pipelining. Figure 4.9, Cycle 2 shows a transition cycle occurring during a burst of bus cycles. In any case, a transition cycle is the same whenever it occurs: it consists at least of T1, T2 ( $\overline{\mathrm{NA}}$ is asserted at that time), and T2P (provided the 80376 has an internal bus request already pending, which it almost always has). T2P states are repeated if wait states are added to the cycle.

Note that only three states (T1, T2 and T2P) are required in a bus cycle performing a transition from non-pipelined into pipelined timing, for example Figure 4.10, Cycle 1. Figure 4.10, Cycles 2, 3 and 4 show that pipelining can be maintained with twostate bus cycles consisting only of T1P and T2P.

Once a pipelined bus cycle is in progress, pipelined timing is maintained for the next cycle by asserting $\overline{N A}$ and detecting that the 80376 enters T2P during the current bus cycle. The current bus cycle must end in state T2P for pipelining to be maintained in the next cycle. T2P is identified by the assertion of $\overline{\mathrm{ADS}}$. Figures 4.9 and 4.10 however, each show
pipelining ending after Cycle 4 because Cycle 4 ends in T2l. This indicates the 80376 didn't have an internal bus request prior to the acknowledgement of Cycle 4. If a cycle ends with a T2 or T2l, the next cycle will not be pipelined.

Realistically, pipelining is almost always maintained as long as $\overline{N A}$ is sampled asserted. This is so because in the absence of any other request, a code prefetch request is always internally pending until the instruction decoder and code prefetch queue are completely full. Therefore pipelining is maintained for long bursts of bus cycles, if the bus is available (i.e., HOLD inactive) and $\overline{\mathrm{NA}}$ is sampled active in each of the bus cycles.

## INTERRUPT ACKNOWLEDGE (INTA) CYCLES

In repsonse to an interrupt request on the INTR input when interrupts are enabled, the 80376 performs two interrupt acknowledge cycles. These bus cycles are similar to read cycles in that bus definition signals define the type of bus activity taking place, and each cycle continues until acknowledged by READY sampled active.

The state of $A_{2}$ distinguishes the first and second interrupt acknowledge cycles. The byte address driven during the first interrupt acknowledge cycle is $4\left(A_{23}-A_{3}, A_{1}, \overline{B L E}\right.$ LOW, $A_{2}$ and BHE HIGH). The byte address driven during the second interrupt acknowledge cycle is $0\left(\mathrm{~A}_{23}-\mathrm{A}_{1}\right.$, $\overline{\mathrm{BLE}} \mathrm{LOW}$ and $\overline{\mathrm{BHE}}$ HIGH).

The LOCK output is asserted from the beginning of the first interrupt acknowledge cycle until the end of the second interrupt acknowledge cycle. Four idle bus states, $T_{i}$, are inserted by the 80376 between the two interrupt acknowledge cycles for compatibility with the interrupt specification $\mathrm{T}_{\text {RHRL }}$ of the 8259A Interrupt Controller and the 82370 Integrated Peripheral.


Interrupt Vector (0-255) is read on D0-D7 at end of second Interrupt Acknowledge bus cycle.
Because each Interrupt Acknowledge bus cycle is followed by idle bus states, asserting $\overline{N A}$ has no practical effect. Choose the approach which is simplest for your system hardware design.

Figure 4.13. Interrupt Acknowledge Cycles

During both interrupt acknowledge cycles, $\mathrm{D}_{15}-\mathrm{D}_{0}$ float. No data is read at the end of the first interrupt acknowledge cycle. At the end of the second interrupt acknowledge cycle, the 80376 will read an external interrupt vector from $D_{7}-D_{0}$ of the data bus. The vector indicates the specific interrupt number (from 0-255) requiring service.

## HALT INDICATION CYCLE

The 80376 execution unit halts as a result of executing a HLT instruction. Signaling its entrance into the halt state, a halt indication cycle is performed. The halt indication cycle is identified by the state of the bus definition signals and a byte address of 2 . See the Bus Cycle Definition Signals section. The halt indication cycle must be acknowledged by READY asserted. A halted 80376 resumes execution when INTR (if interrupts are enabled), NMI or RESET is asserted.


240182-29
Figure 4.14. Example Halt Indication Cycle from Non-Pipelined Cycle

## SHUTDOWN INDICATION CYCLE

The 80376 shuts down as a result of a protection fault while attempting to process a double fault. Signaling its entrance into the shutdown state, a shutdown indication cycle is performed. The shutdown indication cycle is identified by the state of the bus definition signals shown in Bus Cycle Definition Signals and a byte address of 0 . The shutdown indication cycle must be acknowledged by READY asserted. A shutdown 80376 resumes execution when NMI or RESET is asserted.

## ENTERING AND EXITING HOLD ACKNOWLEDGE

The bus hold acknowledge state, $T_{h}$, is entered in response to the HOLD input being asserted. In the bus hold acknowledge state, the 80376 floats all outputs or bidirectional signals, except for HLDA. HLDA is asserted as long as the 80376 remains in the bus hold acknowledge state. In the bus hold acknowledge state, all inputs except HOLD and RESET are ignored.


240182-30
Figure 4.15. Example Shutdown Indication Cycle from Non-Pipelined Cycle
$T_{h}$ may be entered from a bus idle state as in Figure 4.16 or after the acknowledgement of the current physical bus cycle if the LOCK signal is not asserted, as in Figures 4.17 and 4.18.
$T_{h}$ is exited in response to the HOLD input being negated. The following state will be $T_{i}$ as in Figure 4.16 if no bus request is pending. The following bus
state will be T 1 if a bus request is internally pending, as in Figures 4.17 and 4.18. $\mathrm{T}_{\mathrm{h}}$ is exited in response to RESET being asserted.

If a rising edge occurs on the edge-triggered NMI input while in $T_{h}$, the event is remembered as a nonmaskable interrupt 2 and is serviced when $T_{h}$ is exited unless the 80376 is reset before $T_{h}$ is exited.


NOTE:
For maximum design flexibility the 80376 has no internal pull-up resistors on its outputs. Your design may require an external pullup on $\overline{A D S}$ and other 80376 outputs to keep them negated during float periods.

Figure 4.16. Requesting Hold from Idle Bus

## RESET DURING HOLD ACKNOWLEDGE

RESET being asserted takes priority over HOLD being asserted. If RESET is asserted while HOLD remains asserted, the 80376 drives its pins to defined states during reset, as in Table 4.5, Pin State During Reset, and performs internal reset activity as usual.

If HOLD remains asserted when RESET is inactive, the 80376 enters the hold acknowledge state before performing its first bus cycle, provided HOLD is still asserted when the 80376 processor would otherwise perform its first bus cycle. If HOLD remains asserted when RESET is inactive, the BUSY input is still sampled as usual to determine whether a self test is being requested.

## FLOAT

 and output signals, including HLDA. Asserting FLT isolates the 80376 from the surrounding circuitry.

When an 80376 in a PQFP surface-mount package is used without a socket, it cannot be removed from the printed circuit board. The FLT input allows the 80376 to be electrically isolated to allow testing of external circuitry. This technique is known as ONCETM for "ON-Circuit Emulation".

## ENTERING AND EXITING FLOAT

FLT is an asynchronous, active-low input. It is recognized on the rising edge of CLK2. When recognized, it aborts the current bus cycle and floats the outputs of the 80376 (Figure 4.20). FLT must be held low for a minimum of 16 CLK2 cycles. Reset should be asserted and held asserted until after FLT is deasserted. This will ensure that the 80376 will exit float in a valid state.

Asserting the FLT input unconditionally aborts the current bus cycle and forces the 80376 into the FLOAT mode. Since activating FLT unconditionally forces the 80376 into FLOAT mode, the 80376 is not


240182-32

NOTE:
HOLD is a synchronous input and can be asserted at any CLK2 edge, provided setup and hold ( $\mathrm{t}_{23}$ and $\mathrm{t}_{24}$ ) requirements are met. This waveform is useful for determining Hold Acknowledge latency.

Figure 4.17. Requesting Hold from Active Bus ( $\overline{N A}$ Inactive)
guaranteed to enter FLOAT in a valid state. After deactivating FLT, the 80376 is not guaranteed to exit FLOAT mode in a valid state. This is not a problem as the FLT pin is meant to be used only during ONCE. After exiting FLOAT, the 80376 must be reset to return it to a valid state. Reset should be asserted before FLT is deasserted. This will ensure that the 80376 will exit float in a valid state.

FLT has an internal pull-up resistor, and if it is not used it should be unconnected.

## BUS ACTIVITY DURING AND FOLLOWING RESET

RESET is the highest priority input signal, capable of interrupting any processor activity when it is assert-
ed. A bus cycle in progress can be aborted at any stage, or idle states or bus hold acknowledge states discontinued so that the reset state is established.

RESET should remain asserted for at least 15 CLK2 periods to ensure it is recognized throughout the 80376 , and at least 80 CLK2 periods if a 80376 selftest is going to be requested at the falling edge. RESET asserted pulses less than 15 CLK2 periods may not be recognized. RESET pulses less than 80 CLK2 periods followed by a self-test may cause the selftest to report a failure when no true failure exists.

Provided the RESET falling edge meets setup and hold times $t_{25}$ and $t_{26}$, the internal processor clock phase is defined at that time as illustrated by Figure 4.19 and Figure 6.7.


240182-33

## NOTE:

HOLD is a synchronous input and can be asserted at any CLK2 edge, provided setup and hold ( $\mathrm{t}_{23}$ and $\mathrm{t}_{24}$ ) requirements are met. This waveform is useful for determining Hold Acknowledge latency.

Figure 4.18. Requesting Hold from Idie Bus ( $\overline{N A}$ Active)

An 80376 self-test may be requested at the time RESET goes inactive by having the BUSY input at a LOW level as shown in Figure 4.19. The self-test requires ( $2^{20}+$ approximately 60 ) CLK2 periods to complete. The self-test duration is not affected by the test results. Even if the self-test indicates a
problem, the 80376 attempts to proceed with the reset sequence afterwards.

After the RESET falling edge (and after the self-test if it was requested) the 80376 performs an internal initialization sequence for approximately 350 to 450 CLK2 periods.


240182-34

## NOTES:

1. $\overline{B U S Y}$ should be held stable for 8 CLK2 periods before and after the CLK2 period in which RESET falling edge occurs.
2. If self-test is requested, the 80376 outputs remain in their reset state as shown here.

Figure 4.19. Bus Activity from Reset until First Code Fetch


### 4.5 Self-Test Signature

Upon completion of self-test (if self-test was requested by driving BUSY LOW at the falling edge of RESET) the EAX register will contain a signature of 00000000 H indicating the 80376 passed its self-test of microcode and major PLA contents with no problems detected. The passing signature in EAX, 00000000 H , applies to all 80376 revision levels. Any non-zero signature indicates the 80376 unit is faulty.

### 4.6 Component and Revision Identifiers

To assist 80376 users, the 80376 after reset holds a component identifier and revision identifier in its DX register. The upper 8 bits of DX hold 33H as identification of the 80376 component. (The lower nibble, 03 H , refers to the intel $386^{\mathrm{TM}}$ architecture. The upper nibble, 30 H , refers to the third member of the Intel386 family). The lower 8 bits of DX hold an 8 -bit unsigned binary number related to the component revision level. The revision identifier will, in general, chronologically track those component steppings which are intended to have certain improvements or distinction from previous steppings. The 80376 revision identifier will track that of the 80386 where possible.

The revision identifier is intended to assist 80376 users to a practical extent. However, the revision identifier value is not guaranteed to change with every stepping revision, or to follow a completely uniform numerical sequence, depending on the type or intention of revision, or manufacturing materials required to be changed. Intel has sole discretion over these characteristics of the component.

Table 4.7. Component and Revision Identifier History

| 80376 Stepping Name | Revision Identifier |
| :---: | :---: |
| AO | 05 H |
| B | 08 H |

### 4.7 Coprocessor Interfacing

The 80376 provides an automatic interface for the Intel 80387SX numeric floating-point coprocessor. The 80387SX coprocessor uses an I/O mapped interface driven automatically by the 80376 and assisted by three dedicated signals: BUSY, ERROR and PEREQ.

As the 80376 begins supporting a coprocessor instruction, it tests the BUSY and ERROR signals to determine if the coprocessor can accept its next instruction. Thus, the BUSY and ERROR inputs eliminate the need for any "preamble" bus cycles for communication between processor and coprocessor. The 80387SX can be given its command opcode immediately. The dedicated signals provide instruction synchronization, and eliminate the need of using the 80376 WAIT opcode (9BH) for 80387SX instruction synchronization (the WAIT opcode was required when the 8086 or 8088 was used with the 8087 coprocessor).

Custom coprocessors can be included in 80376 based systems by memory-mapped or 1/O-mapped interfaces. Such coprocessor interfaces allow a completely custom protocol, and are not limited to a set of coprocessor protocol "primitives". Instead, memory-mapped or I/O-mapped interfaces may use all applicable 80376 instructions for high-speed coprocessor communication. The BUSY and ERROR inputs of the 80376 may also be used for the custom coprocessor interface, if such hardware assist is desired. These signals can be tested by the 80376 WAIT opcode (9BH). The WAIT instruction will wait until the BUSY input is inactive (interruptable by an NMI or enabled INTR input), but generates an exception 16 fault if the ERROR pin is active when the BUSY goes (or is) inactive. If the custom coprocessor interface is memory-mapped, protection of the addresses used for the interface can be provided with the segmentation mechanism of the 80376. If the custom interface is I/O-mapped, protection of the interface can be provided with the 80376 IOPL (I/O Privilege Level) mechanism.

The 80387SX numeric coprocessor interface is I/O mapped as shown in Table 4.8. Note that the 80387SX coprocessor interface addresses are beyond the OH-OFFFFH range for programmed I/O. When the 80376 supports the 80387SX coprocessor, the 80376 automatically generates bus cycles to the coprocessor interface addresses.
Table 4.8 Numeric Coprocessor Port Addresses

| Address in 80376 <br> I/O Space | 80387SX <br> Coprocessor Register |
| :---: | :---: |
| 8000 F8H | Opcode Register |
| 8000 FCH | Operand Register |
| 8000FEH | Operand Register |

## SOFTWARE TESTING FOR COPROCESSOR PRESENCE

When software is used to test coprocessor (80387SX) presence, it should use only the following coprocessor opcodes: FNINIT, FNSTCW and FNSTSW. To use other coprocessor opcodes when a coprocessor is known to be not present, first set $E M=1$ in the 80376 CR0 register.

### 5.0 PACKAGE THERMAL SPECIFICATIONS

The Intel 80376 embedded processor is specified for operation when case temperature is within the range of $0^{\circ} \mathrm{C}-115^{\circ} \mathrm{C}$ for both the ceramic 88 -pin PGA package and the plastic 100-pin PQFP package. The case temperature may be measured in any environment, to determine whether the 80376 is within specified operating range. The case temperature should be measured at the center of the top surface.

The ambient temperature is guaranteed as long as $\mathrm{T}_{\mathrm{c}}$ is not violated. The ambient temperature can be calculated from the $\boldsymbol{\theta}_{\mathrm{jc}}$ and $\boldsymbol{\theta}_{\mathrm{ja}}$ from the following equations:

$$
\begin{aligned}
& T_{J}=T_{c}+P^{*} \theta_{j c} \\
& T_{A}=T_{\mathrm{j}}-P^{*} \theta_{\mathrm{ja}} \\
& T_{\mathrm{C}}=\mathrm{T}_{\mathrm{a}}+\mathrm{P}^{*}\left[\theta_{\mathrm{ja}}-\theta_{\mathrm{jc}}\right]
\end{aligned}
$$

Values for $\theta_{\mathrm{ja}}$ and $\boldsymbol{\theta}_{\mathrm{jc}}$ are given in Table 5.1 for the 100 -lead fine pitch. $\theta_{\mathrm{ja}}$ is given at various airflows. Table 5.2 shows the maximum $\mathrm{T}_{\mathrm{a}}$ allowable (without exceeding $T_{c}$ ) at various airflows. Note that $T_{a}$ can be improved further by attaching "fins" or a "heat sink" to the package. $P$ is calculated using the maximum cold $\mathrm{I}_{\mathrm{cc}}$ of 305 mA and the maximum $\mathrm{V}_{\mathrm{CC}}$ of 5.5 V for both packages.

Table 5.1. 80376 Package Thermal Characteristics Thermal Resistances ( ${ }^{\circ} \mathrm{C} /$ Watt) $\theta_{\text {jc }}$ and $\theta_{\text {ja }}$

| Package | $\theta_{\mathrm{jc}}$ | $\theta_{\text {ja }}$ Versus Airflow-ft/min (m/sec) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 <br> (0) | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{gathered} 400 \\ (2.03) \end{gathered}$ | $\begin{gathered} 600 \\ (3.04) \end{gathered}$ | $\begin{gathered} 800 \\ (4.06) \end{gathered}$ | $\begin{gathered} 1000 \\ (5.07) \end{gathered}$ |
| 100-Lead Fine Pitch | 7.5 | 34.5 | 29.5 | 25.5 | 22.5 | 21.5 | 21.0 |
| $\begin{aligned} & \text { 88-Pin } \\ & \text { PGA } \end{aligned}$ | 2.5 | 29.0 | 22.5 | 17.0 | 14.5 | 12.5 | 12.0 |

Table 5.2. 80376
Maximum Allowable Ambient Temperature at Various Airflows

| Package | $\theta_{\text {jc }}$ | $\mathrm{T}_{\mathrm{A}}\left({ }^{\circ} \mathrm{C}\right)$ vs Airflow-ft/min (m/sec) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{\|c} \hline 0 \\ (0) \end{array}$ | $\begin{gathered} 200 \\ (1.01) \end{gathered}$ | $\begin{gathered} 400 \\ (2.03) \end{gathered}$ | $\begin{array}{\|c\|} \hline 600 \\ (3.04) \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 800 \\ (4.06) \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 1000 \\ (5.07) \\ \hline \end{array}$ |
| 100-Lead Fine Pitch | 7.5 | 70 | 78 | 85 | 90 | 92 | 93 |
| $\begin{aligned} & \text { 88-Pin } \\ & \text { PGA } \end{aligned}$ | 2.5 | 70 | 81 | 90 | 95 | 98 | 99 |

### 6.0 ELECTRICAL SPECIFICATIONS

The following sections describe recommended electrical connections for the 80376, and its electrical specifications.

### 6.1 Power and Grounding

The 80376 is implemented in CHMOS IV technology and has modest power requirements. However, its high clock frequency and 47 output buffers (address, data, control, and HLDA) can cause power surges as multiple output buffers drive new signal levels simultaneously. For clean on-chip power distribution at high frequency, $14 \mathrm{~V}_{\mathrm{CC}}$ and $18 \mathrm{~V}_{\mathrm{SS}}$ pins separately feed functional units of the 80376 .

Power and ground connections must be made to all external $V_{C C}$ and GND pins of the 80376. On the circuit board, all $V_{C C}$ pins should be connected on a $V_{\text {CC }}$ plane and all $V_{S S}$ pins should be connected on a GND plane.

## POWER DECOUPLING RECOMMENDATIONS

Liberal decoupling capacitors should be placed near the 80376. The 80376 driving its 24-bit address bus and 16-bit data bus at high frequencies can cause transient power surges, particularly when driving large capacitive loads. Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance can be reduced by shortening circuit board traces between the 80376 and decoupling capacitors as much as possible.

## RESISTOR RECOMMENDATIONS

The ERROR, $\overline{\text { FLT }}$ and $\overline{B U S Y}$ inputs have internal pull-up resistors of approximately $20 \mathrm{~K} \Omega$ and the PEREQ input has an internal pull-down resistor of approximately $20 \mathrm{~K} \Omega$ built into the 80376 to keep these signals inactive when the 80387SX is not present in the system (or temporarily removed from its socket).

In typical designs, the external pull-up resistors shown in Table 6.1 are recommended. However, a particular design may have reason to adjust the resistor values recommended here, or alter the use of pull-up resistors in other ways.

Table 6.1. Recommended
Resistor Pull-Ups to Vcc

| Pin | Signal | Pull-Up Value | Purpose |
| :---: | :--- | :---: | :--- |
| 16 | $\overline{\text { ADS }}$ | $20 \mathrm{~K} \Omega \pm 10 \%$ | Lightly Pull $\overline{\mathrm{ADS}}$ <br> Inactive during 80376 <br> Hold Acknowledge <br> States |
| 26 | $\overline{\mathrm{LOCK}}$ | $20 \mathrm{~K} \Omega \pm 10 \%$ | Lightly Pull $\overline{\text { LOCK }}$ <br> Inactive during 80376 <br> Hold Acknowledge <br> States |

## OTHER CONNECTION RECOMMENDATIONS

For reliable operation, always connect unused inputs to an appropriate signal level. N/C pins should always remain unconnected. Connection of N/C pins to $V_{\text {Cc }}$ or $V_{\text {ss }}$ will result in incompatibility with future steppings of the 80376.

Particularly when not using interrupts or bus hold (as when first prototyping), prevent any chance of spurious activity by connecting these associated inputs to GND:

[^19]If not using address pipelining connect the $\overline{N A}$ pin to a pull-up resistor in the range of $20 \mathrm{~K} \Omega$ to $\mathrm{V}_{\mathrm{CC}}$.

### 6.2 Absolute Maximum Ratings

Table 6.2. Maximum Ratings

| Parameter | Maximum Rating |
| :--- | :--- |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Case Temperature <br> under Bias | $-65^{\circ} \mathrm{C}$ to $+120^{\circ} \mathrm{C}$ |
| Supply Voltage with <br> Respect to $\mathrm{V}_{\text {SS }}$ | -0.5 V to +6.5 V |
| Voltage on Other Pins | -0.5 V to $\left(\mathrm{V}_{\mathrm{CC}}+0.5\right) \mathrm{V}$ |

Table 6.2 gives a stress ratings only, and functional operation at the maximums is not guaranteed. Functional operating conditions are given in Section 6.3, D.C. Specifications, and Section 6.4, A.C. Specifications.

Extended exposure to the Maximum Ratings may affect device reliability. Furthermore, although the 80376 contains protective circuitry to resist damage from static electric discharge, always take precautions to avoid high static voltages or electric fields.

### 6.3 D.C. Specifications

## ADVANCE INFORMATION SUBJECT TO CHANGE

Table 6.3: 80376 D.C. Characteristics
Functional Operating Range: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$; $\mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $115^{\circ} \mathrm{C}$ for 88 -pin PGA or 100 -pin PQFP

| Symbol | Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage | -0.3 | +0.8 | V (1) |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V (1) |
| $\mathrm{V}_{\text {ILC }}$ | CLK2 Input LOW Voltage | -0.3 | +0.8 | $\mathrm{V}(1)$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | CLK2 Input HIGH Voltage | $\mathrm{V}_{\mathrm{CC}}-0.8$ | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V (1) |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  |  |  |
| $\mathrm{l}_{\mathrm{OL}}=4 \mathrm{~mA}$ : | $A_{23}-A_{1}, D_{15}-D_{0}$ |  | 0.45 | V (1) |
| $\mathrm{lOL}=5 \mathrm{~mA}$ : | $\overline{\mathrm{BHE}}, \overline{\mathrm{BLE}}, \mathrm{W} / \overline{\mathrm{R}}$, D/С $, \mathrm{M} / \overline{\mathrm{IO}}, \overline{\mathrm{LOCK}}$, $\overline{\text { ADS }}$, HLDA |  | 0.45 | V (1) |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage |  |  |  |
| $\mathrm{IOH}^{\prime}=-1 \mathrm{~mA}$ : | $\mathrm{A}_{23}-\mathrm{A}_{1}, \mathrm{D}_{15}-\mathrm{D}_{0}$ | 2.4 |  | V (1) |
| $\mathrm{I}_{\mathrm{OH}}=-0.2 \mathrm{~mA}$ : | $A_{23}-A_{1}, D_{15}-D_{0}$ | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V (1) |
| $\mathrm{I}_{\mathrm{OH}}=-0.9 \mathrm{~mA}$ : | $\overline{\mathrm{B}} \mathrm{BE}, \overline{\mathrm{BLE}}, \mathrm{W} / \overline{\mathrm{R}}$, D/С $\overline{\mathrm{C}}, \mathrm{M} / \overline{\mathrm{IO}}, \overline{\mathrm{LOCK}}$, $\overline{\text { ADS }}$, HLDA | 2.4 |  | $V(1)$ |
| $\mathrm{IOH}^{\prime}=-0.18 \mathrm{~mA}$ : | $\overline{B H E}, \overline{B L E}, W / \bar{R}$, D/ $\bar{C}, \mathrm{M} / \overline{\mathrm{O}}, \overline{\mathrm{LOCK}}$ $\overline{\text { ADS, HLDA }}$ | $\mathrm{V}_{\mathrm{CC}}-0.5$ |  | V (1) |
| LI | Input Leakage Current <br> (For All Pins except PEREQ, $\overline{B U S Y}, \overline{\text { FLT }}$ and ERROR) |  | $\pm 15$ | $\mu \mathrm{A}, \mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}{ }^{(1)}$ |
| $\mathrm{I}_{\mathrm{H}}$ | Input Leakage Current (PEREQ Pin) |  | 200 | $\mu \mathrm{A}, \mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}(1,2)$ |
| IIL | Input Leakage Current ( $\overline{B U S Y}$ and $\overline{E R R O R}$ Pins) |  | -400 | $\mu \mathrm{A}, \mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}(3)$ |
| Lo | Output Leakage Current |  | $\pm 15$ | $\mu \mathrm{A}, 0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}{ }^{(1)}$ |
| ICC | Supply Current <br> CLK2 $=32 \mathrm{MHz}$ <br> CLK2 $=40 \mathrm{MHz}$ |  | $\begin{aligned} & 275 \\ & 305 \end{aligned}$ | $\begin{aligned} & \mathrm{mA}, \mathrm{I}_{\mathrm{cc}} \text { typ }=175 \mathrm{~mA}^{(4)} \\ & \mathrm{mA}, \mathrm{I}_{\mathrm{cc}} \text { typ }=200 \mathrm{~mA}^{(4)} \end{aligned}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 10 | $\mathrm{pF}, \mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}{ }^{(5)}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output or I/O Capacitance |  | 12 | $\mathrm{pF}, \mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}{ }^{(5)}$ |
| $\mathrm{C}_{\text {CLK }}$ | CLK2 Capacitance |  | 20 | $\mathrm{pF}, \mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}^{(5)}$ |

## NOTES:

1. Tested at the minimum operating frequency of the device.
2. PEREQ input has an internal pull-down resistor.
3. $\overline{B U S Y}, \overline{F L T}$ and $\overline{E R R O R}$ inputs each have an internal pull-up resistor.
4. $I_{\mathrm{CC}}$ max measurement at worse case load, $\mathrm{V}_{\mathrm{CC}}$ and temperature $\left(0^{\circ} \mathrm{C}\right)$.
5. Not $100 \%$ tested.

The A.C. specifications given in Table 6.4 consist of output delays, input setup requirements and input hold requirements. All A.C. specifications are relative to the CLK2 rising edge crossing the 2.0 V level.
A.C. specification measurement is defined by Figure 6.1. Inputs must be driven to the voltage levels indicated by Figure 6.1 when A.C. specifications are measured. 80376 output delays are specified with minimum and maximum limits measured as shown. The minimum 80376 delay times are hold times provided to external circuitry. 80376 input setup and hold times are specified as minimums, defining the
smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct 80376 processor operation.

Outputs $\overline{\mathrm{NA}}, \mathrm{W} / \overline{\mathrm{R}}, \mathrm{D} / \overline{\mathrm{C}}, \mathrm{M} / \overline{\mathrm{IO}}, \overline{\mathrm{LOCK}}, \overline{\mathrm{BHE}}, \overline{\mathrm{BLE}}$, $A_{23}-A_{1}$ and HLDA only change at the beginning of phase one. $D_{15}-D_{0}$ (write cycles) only change at the beginning of phase two. The READY, HOLD, BUSY, ERROR, PEREQ and $D_{15}-D_{0}$ (read cycles) inputs are sampled at the beginning of phase one. The $\overline{N A}$, INTR and NMI inputs are sampled at the beginning of phase two.


Figure 6.1. Drive Levels and Measurement Points for A.C. Specifications

### 6.4 A.C. Specifications

Table 6.4. 80376 A.C. Characteristics at 16 MHz
Functional Operating Range: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$; $\mathrm{T}_{\mathrm{CASE}}=0^{\circ} \mathrm{C}$ to $115^{\circ} \mathrm{C}$ for 88 -pin PGA or 100 -pin PQFP

| Symbol | Parameter | Min | Max | Unit | Figure | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Operating Frequency | 4 | 16 | MHz |  | Half CLK2 Freq |
| $t_{1}$ | CLK2 Period | 31 | 125 | ns | 6.3 |  |
| $\mathrm{t}_{2 \mathrm{a}}$ | CLK2 HIGH Time | 9 |  | ns | 6.3 | At ${ }^{(3)}$ |
| $\mathrm{t}_{2 \mathrm{~b}}$ | CLK2 HIGH Time | 5 |  | ns | 6.3 | At ( $\left.\mathrm{V}_{\mathrm{CC}}-0.8\right) \mathrm{V}(3)$ |
| $\mathrm{t}_{3}$ | CLK2 LOW Time | 9 |  | ns | 6.3 | At $2 \mathrm{~V}{ }^{(3)}$ |
| $\mathrm{t}_{3 \mathrm{~b}}$ | CLK2 LOW Time | 7 |  | ns | 6.3 | At $0.8 \mathrm{~V}{ }^{(3)}$ |
| $t_{4}$ | CLK2 Fall Time |  | 8 | ns | 6.3 | $\left(\mathrm{V}_{\mathrm{CC}}-0.8\right) \mathrm{V}$ to $0.8 \mathrm{~V}(3)$ |
| $\mathrm{t}_{5}$ | CLK2 Rise Time |  | 8 | ns | 6.3 |  |
| $\mathrm{t}_{6}$ | $A_{23}-A_{1}$ Valid Delay | 4 | 36 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=120 \mathrm{pF}(4)$ |
| $\mathrm{t}_{7}$ | $\mathrm{A}_{23}-\mathrm{A}_{1}$ Float Delay | 4 | 40 | ns | 6.6 | (1) |
| $\mathrm{t}_{8}$ | $\overline{B H E}, \overline{B L E}, \overline{\text { LOCK }}$ Valid Delay | 4 | 36 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}(4)$ |
| $\mathrm{t}_{9}$ | BHE, $\overline{\text { BLE }}$, $\overline{\text { LOCK }}$ Float Delay | 4 | 40 | ns | 6.6 | (1) |
| $\mathrm{t}_{10}$ | W/R, M/ $\overline{\mathrm{I}}, \mathrm{D} / \overline{\mathrm{C}}$, $\overline{\mathrm{ADS}}$ Valid Delay | 6 | 33 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}(4)$ |
| $\mathrm{t}_{11}$ | W/石, M/ $\overline{\mathrm{I}}, \mathrm{D} / \overline{\mathrm{C}}$, $\overline{\mathrm{ADS}}$ Float Delay | 6 | 35 | ns | 6.6 | (1) |
| $\mathrm{t}_{12}$ | $\mathrm{D}_{15}-\mathrm{D}_{0}$ Write Data Valid Delay | 4 | 40 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=120 \mathrm{pF}(4)$ |
| $\mathrm{t}_{13}$ | $\mathrm{D}_{15}-\mathrm{D}_{0}$ Write Data Float Delay | 4 | 35 | ns | 6.6 | (1) |
| $\mathrm{t}_{14}$ | HLDA Valid Delay | 4 | 33 | ns | 6.6 | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}(4)$ |
| $\mathrm{t}_{15}$ | $\overline{\text { NA }}$ Setup Time | 5 |  | ns | 6.4 |  |
| $\mathrm{t}_{16}$ | $\overline{\text { NA }}$ Hold Time | 21 |  | ns | 6.6 |  |
| $\mathrm{t}_{19}$ | READY Setup Time | 19 |  | ns | 6.4 |  |
| $\mathrm{t}_{20}$ | READY Hold Time | 4 |  | ns | 6.4 |  |
| $\mathrm{t}_{21}$ | Setup Time $\mathrm{D}_{15}-\mathrm{D}_{0}$ Read Data | 9 |  | ns | 6.4 |  |
| $\mathrm{t}_{22}$ | Hold Time $\mathrm{D}_{15}-\mathrm{D}_{0}$ Read Data | 6 |  | ns | 6.4 |  |
| $\mathrm{t}_{23}$ | HOLD Setup Time | 26 |  | ns | 6.4 |  |
| $\mathrm{t}_{24}$ | HOLD Hold Time | 5 |  | ns | 6.4 |  |
| $\mathrm{t}_{25}$ | RESET Setup Time | 13 |  | ns | 6.7 |  |
| $\mathrm{t}_{26}$ | RESET Hold Time | 4 |  | ns | 6.7 |  |

Table 6.4. 80376 A.C. Characteristics at 16 MHz (Continued)
Functional Operating Range: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$; $\mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $115^{\circ} \mathrm{C}$ for 88 -pin PGA or 100-pin PQFP

| Symbol | Parameter | Min | Max | Unit | Figure | Notes |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{27}$ | NMI, INTR Setup Time | 16 |  | ns | 6.4 | (2) |
| $\mathrm{t}_{28}$ | NMI, INTR Hold Time | 16 |  | ns | 6.4 | (2) |
| $\mathrm{t}_{29}$ | PEREQ, $\overline{\text { ERROR, }} \mathrm{BUSY}, \overline{\mathrm{FLT}}$ <br> Setup Time | 16 | ns | 6.4 | (2) |  |
| $\mathrm{t}_{30}$ | PEREQ, ERROR, $\overline{\mathrm{BUSY}}, \overline{\mathrm{FLT}}$ <br> Hold Time | 5 |  | ns | 6.4 | (2) |

## NOTES:

1. Float condition occurs when maximum output current becomes less than loo in magnitude. Float delay is not $100 \%$ tested.
2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, tc assure recognition within a specific CLK2 period.
3. These are not tested. They are guaranteed by design characterization.
4. Tested with $C_{L}$ set to 50 pF and derated to support the indicated distributed capacitive load. See Figures 6.8 through 6.10 for capacitive derating curves.
5. The 80376 does not have $t_{17}$ or $t_{18}$ timing specifications.

Table 6.5. 80376 A.C. Characteristics at 20 MHz
Functional Operating Range: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$; $\mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $115^{\circ} \mathrm{C}$ for 88 -pin PGA or 100-pin PQFP

| Symbol | Parameter | Min | Max | Unit | Figure | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Operating Frequency | 4 | 20 | MHz |  | Half CLK2 Frequency |
| $\mathrm{t}_{1}$ | CLK2 Period | 25 | 125 | ns | 6.3 |  |
| $\mathrm{t}_{2 \mathrm{a}}$ | CLK2 HIGH Time | 8 |  | ns | 6.3 | At 2 V (3) |
| $\mathrm{t}_{2 \mathrm{~b}}$ | CLK2 HIGH Time | 5 |  | ns | 6.3 | At ( $\left.\mathrm{C}_{\mathrm{CC}}-0.8\right) \mathrm{V}^{(3)}$ |
| $\mathrm{t}_{3}$ | CLK2 LOW Time | 8 |  | ns | 6.3 | At 2 V (3) |
| $\mathrm{t}_{3 \mathrm{~b}}$ | CLK2 LOW Time | 6 |  | ns | 6.3 | At $0.8 \mathrm{~V}{ }^{(3)}$ |
| $\mathrm{t}_{4}$ | CLK2 Fall Time |  | 8 | ns | 6.3 | $\left(\mathrm{V}_{\mathrm{CC}}-0.8 \mathrm{~V}\right)$ to $0.8 \mathrm{~V}(3)$ |
| $\mathrm{t}_{5}$ | CLK2 Rise Time |  | 8 | ns | 6.3 | 0.8 V to ( $\left.\mathrm{V}_{\mathrm{CC}}-0.8\right)^{(3)}$ |
| $t_{6}$ | $\mathrm{A}_{23}-\mathrm{A}_{1}$ Valid Delay | 4 | 30 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=120 \mathrm{pF}(4)$ |
| $\mathrm{t}_{7}$ | $\mathrm{A}_{23}-\mathrm{A}_{1}$ Float Delay | 4 |  | ns | 6.6 | (1) |
| $\mathrm{t}_{8}$ | $\overline{\text { BHE }}, \overline{B L E}, \overline{\text { LOCK }}$ Valid Delay | 4 | 30 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}(4)$ |
| $\mathrm{t}_{9}$ | $\overline{\text { BHE }}, \overline{\mathrm{BLE}}, \overline{\text { LOCK }}$ Float Delay | 4 | 32 | ns | 6.6 | (1) |
| $\mathrm{t}_{10} \mathrm{a}$ | M/ $\overline{\mathrm{IO}}, \mathrm{D} / \overline{\mathrm{C}}$ <br> Valid Delay | 6 | 28 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}(4)$ |
| $\mathrm{t}_{10} \mathrm{~b}$ | W/ $\overline{\mathrm{R}}, \overline{\mathrm{ADS}}$ Valid Delay | 6 | 26 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}(4)$ |
| $\mathrm{t}_{11}$ | W/R, M/ $\overline{\mathrm{IO}}, \mathrm{D} / \overline{\mathrm{C}}$, $\overline{\mathrm{ADS}}$ Float Delay | 6 | 30 | ns | 6.6 | (1) |
| $t_{12}$ | $\mathrm{D}_{15}-\mathrm{D}_{0}$ Write Data Valid Delay | 4 | 38 | ns | 6.5 | $C_{L}=120 \mathrm{pF}$ |
| $\mathrm{t}_{13}$ | $D_{15}-D_{0}$ Write Data Float Delay | 4 | 27 | ns | 6.6 | (1) |

Table 6.5. 80376 A.C. Characteristics at 20 MHz (Continued) Functional Operating Range: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$; $\mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $115^{\circ} \mathrm{C}$ for 88 -pin PGA or 100 -pin PQFP

| Symbol | Parameter | Min | Max | Unit | Figure | Notes |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{14}$ | HLDA Valid Delay | 4 | 28 | ns | 6.5 | $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}(4)$ |
| $\mathrm{t}_{15}$ | $\overline{\mathrm{NA}}$ Setup Time | 5 |  | ns | 6.4 |  |
| $\mathrm{t}_{16}$ | $\overline{\text { NA }}$ Hold Time | 12 |  | ns | 6.4 |  |
| $\mathrm{t}_{19}$ | $\overline{\text { READY Setup Time }}$ | 12 |  | ns | 6.4 |  |
| $\mathrm{t}_{20}$ | $\overline{\text { READY Hold Time }}$ | 4 |  | ns | 6.4 |  |
| $\mathrm{t}_{21}$ | $\mathrm{D}_{15}$ - $\mathrm{D}_{0}$ Read Data Setup Time | 9 |  | ns | 6.4 |  |
| $\mathrm{t}_{22}$ | $\mathrm{D}_{15}$ - $\mathrm{D}_{0}$ Read Data Hold Time | 6 |  | ns | 6.4 |  |
| $\mathrm{t}_{23}$ | HOLD Setup Time | 17 |  | ns | 6.4 |  |
| $\mathrm{t}_{24}$ | HOLD Hold Time | 5 |  | ns | 6.4 |  |
| $\mathrm{t}_{25}$ | RESET Setup Time | 12 |  | ns | 6.7 |  |
| $\mathrm{t}_{26}$ | RESET Hold Time | 4 |  | ns | 6.7 |  |
| $\mathrm{t}_{27}$ | NMI, INTR Setup Time | 16 |  | ns | 6.4 | (2) |
| $\mathrm{t}_{28}$ | NMI, INTR Hold Time | 16 |  | ns | 6.4 | (2) |
| $\mathrm{t}_{29}$ | PEREQ, ERROR, $\overline{\text { BUSY, }} \overline{\text { FLT }}$ <br> Setup Time | 14 |  | ns | 6.4 | (2) |
| $\mathrm{t}_{30}$ | PEREQ, ERROR, <br> Hold Time | 5 |  | ns | 6.4 | (2) |

## NOTES:

1. Float condition occurs when maximum output current becomes less than ILO in magnitude. Float delay is not $100 \%$ tested.
2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.
3. These are not tested. They are guaranteed by design characterization.
4. Tested with $C_{L}$ set to 50 pF and derated to support the indicated distributed capacitive load. See Figures 6.8 through 6.10 for capacitive derating curves.
5. The 80376 does not have $\mathrm{t}_{17}$ or $\mathrm{t}_{18}$ timing specifications.
A.C. TEST LOADS


Figure 6.2. A.C. Test Loads
A.C. TIMING WAVEFORMS


Figure 6.3. CLK2 Waveform


Figure 6.4. A.C. Timing Waveforms-Input Setup and Hold Timing


Figure 6.5. A.C. Timing Waveforms-Output Valid Delay Timing


Figure 6.6. A.C. Timing Waveforms-Output Float Delay and HLDA Valid Delay Timing


240182-41
The second internal processor phase following RESET high-to-low transition (provided $t_{25}$ and $t_{26}$ are met) is $\Phi 2$.
Figure 6.7. A.C. Timing Waveforms-RESET Setup and Hold Timing, and Internal Phase


Figure 6.8. Typical Output Valid Delay versus Load Capacitance at Maximum Operating Temperature ( $\mathrm{C}_{\mathrm{L}}=\mathbf{1 2 0} \mathrm{pF}$ )


Figure 6.9. Typical Output Valid Delay versus Load Capacitance at Maximum Operating Temperature ( $\mathrm{C}_{\mathrm{L}}=75 \mathrm{pF}$ )


Figure 6.10. Typical Output Rise Time versus Load Capacitance at Maximum Operating Temperature


Figure 6.11. Typical Icc vs Frequency

### 6.5 Designing for the ICETM-376 Emulator

The 376 embedded processor in-circuit emulator product is the ICE-376 emulator. Use of the emulator requires the target system to provide a socket that is compatible with the ICE-376 emulator. The 80376 offers two different probes for emulating user systems: an 88-pin PGA probe and a 100-pin fine pitch flat-pack probe. The 100-pin fine pitch flatpack probe requires a socket, called the 100-pin PQFP, which is available from 3-M Textool (part number 2-0100-07243-000). The ICE-376 emulator probe attaches to the target system via an adapter which replaces the 80376 component in the target system. Because of the high operating frequency of 80376 systems and of the ICE-376 emulator, there is no buffering between the 80376 emulation processor in the ICE-376 emulator probe and the target system. A direct result of the non-buffered interconnect is that the ICE-376 emulator shares the address and data bus with the user's system, and the RESET signal is intercepted by the ICE emulator hardware. In order for the ICE-376 emulator to be functional in the user's system without the Optional Isolation Board (OIB) the designer must be aware of the following conditions:

1. The bus controller must only enable data transceivers onto the data bus during valid read cycles of the 80376, other local devices or other bus masters.
2. Before another bus master drives the local processor address bus, the other master must gain control of the address bus by asserting HOLD and receiving the HLDA response.
3. The emulation processor receives the RESET signal 2 or 4 CLK2 cycles later than an 80376 would, and responds to RESET later. Correct phase of the response is guaranteed.

In addition to the above considerations, the ICE-376 emulator processor module has several electrical and mechanical characteristics that should be taken into consideration when designing the 80376 system.

Capacitive Loading: ICE-376 adds up to 27 pF to each 80376 signal.

Drive Requirements: ICE-376 adds one FAST TTL load on the CLK2, control, address, and data lines. These loads are within the processor module and are driven by the 80376 emulation processor, which has standard drive and loading capability listed in Tables 6.3 and 6.4.

Power Requirements: For noise immunity and CMOS latch-up protection the ICE-376 emulator processor module is powered by the user system. The circuitry on the processor module draws up to 1.4 A including the maximum 80376 ICC from the user 80376 socket.

80376 Location and Orientation: The ICE-376 emulator processor module may require lateral clearance. Figure 6.12 shows the clearance requirements of the iMP adapter and Figure 6.13 shows the clearance requirements of the 88-pin PGA adapter. The


Figure 6.12. Preliminary ICETM-376 Emulator User Cable with PQFP Adapter


Figure 6.13. ICETM-376 Emulator User Cable with 88-Pin PGA Adapter
optional isolation board (OIB), which provides extra electrical buffering and has the same lateral clearance requirements as Figures 6.12 and 6.13, adds an additional 0.5 inches to the vertical clearance requirement. This is illustrated in Figure 6.14.

Optional Isolation Board (OIB) and the CLK2 speed reduction: Due to the unbuffered probe design, the ICE-376 emulator is susceptible to errors
on the user's bus. The OIB allows the ICE-376 emulator to function in user systems with faults (shorted signals, etc.). After electrical verification the OIB may be removed. When the OIB is installed, the user system must have a maximum CLK2 frequency of 20 MHz .


Figure 6.14. ICETM-376 Emulator User Cable with OIB and PQFP Adapter

### 7.0 DIFFERENCES BETWEEN THE 80376 AND THE 80386

The following are the major differences between the 80376 and the 80386.

1. The 80376 generates byte selects on $\overline{\mathrm{BHE}}$ and $\overline{B L E}$ (like the 8086 and 80286 microprocessors) to distinguish the upper and lower bytes on its 16 -bit data bus. The 80386 uses four-byte selects, $\overline{\mathrm{BEO}}-\overline{\mathrm{BE}}$, to distinguish between the different bytes on its 32-bit bus.
2. The 80376 has no bus sizing option. The 80386 can select between either a 32 -bit bus or a 16 -bit bus by use of the $\overline{\mathrm{BS} 16}$ input. The 80376 has a 16-bit bus size.
3. The $\overline{N A}$ pin operation in the 80376 is identical to that of the $\overline{N A}$ pin on the 80386 with one exception: the $\overline{N A}$ pin of the 80386 cannot be activated on 16-bit bus cycles (where $\overline{\mathrm{BS16}}$ is LOW in the 80386 case), whereas $\overline{\mathrm{NA}}$ can be activated on any 80376 bus cycle.
4. The contents of all 80376 registers at reset are identical to the contents of the 80386 registers at reset, except the DX register. The DX register contains a component-stepping identifier at reset, i.e.
in 80386, after reset $\mathrm{DH}=03 \mathrm{H}$ indicates 80386
DL = revision number;
in 80376, after reset $\mathrm{DH}=33 \mathrm{H}$ indicates 80376 $\mathrm{DL}=$ revision number.
5. The 80386 uses $A_{31}$ and $M / \overline{\mathrm{O}}$ as a select for numerics coprocessor. The 80376 uses the $A_{23}$ and $M / \overline{\bar{O}}$ to select its numerics coprocessor.
6. The 80386 prefetch unit fetches code in fourbyte units. The 80376 prefetch unit reads two bytes as one unit (like the 80286 microprocessor). In $\overline{\mathrm{BS} 16}$ mode, the 80386 takes two consecutive bus cycles to complete a prefetch request. If there is a data read or write request after the prefetch starts, the 80386 will fetch all four bytes before addressing the new request.
7. The 80376 has no paging mechanism.
8. The 80376 starts executing code in what corresponds to the 80386 protected mode. The 80386 starts execution in real mode, which is then used to enter protected mode.
9. The 80386 has a virtual- 86 mode that allows the execution of a real mode 8086 program as a task in protected mode. The 80376 has no virtual- 86 mode.
10. The 80386 maps a 48 -bit logical address into a 32-bit physical address by segmentation and paging. The 80376 maps its 48 -bit logical address into a 24-bit physical address by segmentation only.
11. The 80376 uses the 80387 SX numerics coprocessor for floating point operations, while the 80386 uses the 80387 coprocessor.
12. The 80386 can execute from 16 -bit code segments. The 80376 can only execute from 32-bit code Segments.
13. The 80376 has an input called FLT which threestates all bidirectional and output pins, including HLDA, when asserted. It is used with ON Circuit Emulation (ONCE).

### 8.0 INSTRUCTION SET

This section describes the 376 embedded processor instruction set. Table 8.1 lists all instructions along with instruction encoding diagrams and clock counts. Further details of the instruction encoding are then provided in the following sections, which completely describe the encoding structure and the definition of all fields occurring within 80376 instructions.

### 8.1 80376 Instruction Encoding and Clock Count Summary

To calculate elapsed time for an instruction, multiply the instruction clock count, as listed in Table 8.1 below, by the processor clock period (e.g. 50 ns for an 80376 operating at 20 MHz ). The actual clock count of an 80376 program will average $10 \%$ more
than the calculated clock count due to instruction sequences which execute faster than they can be fetched from memory.

## Instruction Clock Count Assumptions:

1. The instruction has been prefetched, decoded, and is ready for execution.
2. Bus cycles do not require wait states.
3. There are no local bus HOLD requests delaying processor acess to the bus.
4. No exceptions are detected during instruction execution.
5. If an effective address is calculated, it does not use two general register components. One register, scaling and displacement can be used within the clock counts showns. However, if the effective address calculation uses two general register components, add 1 clock to the clock count shown.
6. Memory reference instruction accesses byte or aligned 16-bit operands.

## Instruction Clock Count Notation

- If two clock counts are given, the smaller refers to a register operand and the larger refers to a memory operand.
-n $=$ number of times repeated.
$-\mathrm{m}=$ number of components in the next instruction executed, where the entire displacement (if any) counts as one component, the entire immediate data (if any) counts as one component, and all other bytes of the instruction and prefix(es) each count as one component.


## Misaligned or 32-Bit Operand Accesses:

- If instructions accesses a misaligned 16-bit operand or 32-bit operand on even address add:
2* clocks for read or write.
$4^{* *}$ clocks for read and write.
- If instructions accesses a 32-bit operand on odd address add:
4* clocks for read or write.
8** clocks for read and write.


## Wait States:

Wait states add 1 clock per wait state to instruction execution for each data access.

Table 8.1. 80376 Instruction Set Clock Count Summary


Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)

| Instruction | Format |  |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SEGMENT CONTROL |  |  |  |  |  |  |
| LDS = Load Pointer to DS | 11000101 | mod reg r/m |  | 26* | 6* | $a, b, c$ |
| LES = Load Pointer to ES | 11000100 | mod reg r/m |  | 26* | 6* | $a, b, c$ |
| LFS $=$ Load Pointer to FS | 00001111 | 10110100 | mod reg $\quad \mathrm{r} / \mathrm{m}$ | 29* | 6* | $a, b, c$ |
| LGS = Load Pointer to GS | 00001111 | 10110101 | mod reg r/m | 29* | 6* | $a, b, c$ |
| LSS = Load Pointer to SS | 000011.11 | 10110010 | modreg r/m | 26* | 6* | $\mathrm{a}, \mathrm{b}, \mathrm{c}$ |
| FLAG CONTROL |  |  |  |  |  |  |
| CLC = Clear Carry Fiag | 11111000 |  |  | 2 |  |  |
| CLD = Clear Direction Flag | 11111100 |  |  | 2 |  |  |
| $\mathbf{C L I}=$ Clear Interrupt Enable Flag | 11111010 |  |  | 8 |  | $f$ |
| CLTS = Clear Task Switched Flag | 00001111 | 00000110 |  | 5 |  | e |
| CMC = Complement Carry Flag | 11110101 |  |  | 2 |  |  |
| LAHF = Load AH into Flag | 10011111 |  |  | 2 |  |  |
| POPF $=$ Pop Fiags | 10011101 |  |  | 7 |  | a, g |
| PUSHF = Push Flags | 10011100 |  |  | 4 |  | a |
| SAHF $=$ Store AH into Flags | 10011110 |  |  | 3 |  |  |
| STC = Set Carry Flag | 11111001 |  |  | 2 |  |  |
| STD $=$ Set Direction Flag | 11111101 |  |  | 2 |  |  |
| $\mathbf{S T I}=$ Set Interrupt Enable Flag | 11111011 |  |  | 8 |  | f |
| ARITHMETICADD $=$ Add |  |  |  |  |  |  |
| Register to Register | 000000 dw | modreg r/m |  | 2 |  |  |
| Register to Memory | 0000000 w | modreg r/m |  | 7** | 2** | a |
| Memory to Register | 0000001 w | modreg r/m |  | 6* | 1* | a |
| Immediate to Register/Memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | immediate data | 2/7** | 0/2** | a |
| Immediate to Accumulator (Short Form) | 0000010 w | immedia | ate data | 2 |  |  |
| ADC = Add with Carry |  |  |  |  |  |  |
| Register to Register | 000100 dw | modreg r/m |  | 2 |  |  |
| Register to Memory | 0001000 w | mod reg r/m |  | 7** | 2** | a |
| Memory to Register | 0001001 w | modreg r/m |  | 6* | 1* | a |
| Immediate to Register/Memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | immediate data | 2/7** | 0/2** | a |
| Immediate to Accumulator (Short Form) 0001010 w immediate data |  |  |  | 2 |  |  |
| INC = Increment |  |  |  |  |  |  |
| Register/Memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  | 2/6** | 0/2** | a |
| Register (Short Form) | 01000 reg |  |  | 2 | 1 |  |
| SUB $=$ Subtract |  |  |  |  |  |  |
| Register from Register | 001010 dw | modreg r/m |  | 2 |  |  |

Table 8.1. $\mathbf{8 0 3 7 6}$ Instruction Set Clock Count Summary (Continued)


Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)

| Instruction Format |  |  |  | Clock Counts | Number Of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC (Continued) DIV = Divide (Unsigned) |  |  |  |  |  |  |
| Accumulator by Register/Memory | 1111011 w | mod $110 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Divisor-Byte |  |  |  | 14/17 | $0 / 1$ | a, 0 |
| -Word |  |  |  | 22/25* | 0/1* | a, o |
| -Doubleword |  |  |  | 38/43* | 0/2* | a, 0 |
| IDIV $=$ Integer Divide (Signed) |  |  |  |  |  |  |
| Accumulator by Register/Memory | 1111011 w | mod $111 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Divisor-Byte |  |  |  | 19/22 | 0/1 | a, o |
| -Word |  |  |  | 27/30* | $0 / 1$ | a, 0 |
| -Doubleword |  |  |  | 43/48* | 0/2* | a, 0 |
| AAD = ASCII Adjust for Divide | 11010101 | 00001010 |  | 19 |  |  |
| AAM = ASCII Adjust for Multiply | 11010100 | 00001010 |  | 17 |  |  |
| CBW = Convert Byte to Word | 10011000 |  |  | 3 |  |  |
| CWD $=$ Convert Word to Double Word | 10011001 |  |  | 2 |  |  |
| LOGIC |  |  |  |  |  |  |
| Shift Rotate Instructions <br> Not Through Carry (ROL, ROR, SAL, SAR, SHL, and SHR) |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
| Register/Memory by 1 | 1101000 w | $\bmod$ TTT $\mathrm{r} / \mathrm{m}$ |  | 3/7** | 0/2** | a |
| Register/Memory by CL | 1101001 w | $\bmod$ TTT $\mathrm{r} / \mathrm{m}$ |  | 3/7** | 0/2** | a |
| Register/Memory by Immediate Count | 1100000 w | mod TTT $\mathrm{r} / \mathrm{m}$ | immed 8-bit data | 3/7** | 0/2** | a |
| Through Carry (RCL and RCR) |  |  |  |  |  |  |
| Register/Memory by 1 | 1101000 w | mod TTT $\mathrm{r} / \mathrm{m}$ |  | 9/10** | 0/2** | a |
| Register/Memory by CL | 1101001 w | $\bmod$ TTT $\mathrm{r} / \mathrm{m}$ |  | 9/10** | 10/2** | a |
| Register/Memory by Immediate Count | 1100000 w | mod TTT . r/m | immed 8-bit data | 9/10** | 0/2** | a |
|  | TTT | Instruction |  |  |  |  |
|  | 000 | ROL |  |  |  |  |
|  | 001 | ROR |  |  |  |  |
|  | 010 | RCL |  |  |  |  |
|  | 011 | RCR |  |  |  |  |
|  | 100 | SHL/SAL |  |  |  |  |
|  | 101 | SHR |  |  |  |  |
|  | 111 | SAR |  |  |  |  |
| SHLD = Shift Left Double |  |  |  |  |  |  |
| Register/Memory by Immediate | 00001111 | 10100100 | mod reg r/m immed 8-bit data | 3/7** | 0/2** |  |
| Register/Memory by CL | 00001111 | 10100101 | modreg r/m. | 3/7** | 0/2** |  |
| SHRD = Shift Right Double |  |  |  |  |  |  |
| Register/Memory by Immediate | 00001111 | 10101100 | mod reg r/m immed 8-bit data | 3/7** | 0/2** |  |
| Register/Memory by CL | 00001111 | 10101101 | modreg $\mathrm{r} / \mathrm{m}$ | 3/7** | 0/2** |  |
| AND = And |  |  |  |  |  |  |
| Register to Register | 001000 dw | modreg r/m |  | 2 |  | , |

Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)

| Instruction | Format |  |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LOGIC (Continued) |  |  |  |  |  |  |
| Register to Memory | 0010000 w | mod reg r/m |  | 7** | 2** | a |
| Memory to Register | 0010001 w | mod reg r/m |  | 6* | 1* | a |
| Immediate to Register/Memory | 1000000 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ | immediate data | 2/7** | 0/2** | a |
| Immediate to Accumulator (Short Form) | 0010010 w | immediate data |  | 2 |  |  |
| TEST $=$ And Function to Flags, No Result |  |  |  |  |  |  |
| Register/Memory and Register | 1000010w | mod reg r/m |  | 2/5* | 0/1* | a |
| Immediate Data and Register/Memory | 1111011 w | $\bmod 000 \quad \mathrm{r} / \mathrm{m}$ | immediate data | 2/5* | 0/1* | a |
| Immediate Data and Accumulator (Short Form) | 1010100 w | immediate data |  | 2 |  |  |
| $O R=O r$ |  |  |  |  |  |  |
| Register to Register | 000010 dw | modreg r/m |  | 2 |  |  |
| Register to Memory | 0000100 w | modreg r/m |  | 7** | 2** | a |
| Memory to Register | 0000101 w | modreg r/m |  | 6* | 1* | a |
| Immediate to Register/Memory | 1000000 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ | immediate data | 2/7** | 0/2** | a |
| Immediate to Accumulator (Short Form) | 0000110 w | immediate data |  | 2 |  |  |
| XOR = Exclusive Or |  |  |  |  |  |  |
| Register to Register | 001100 dw | modreg r/m |  | 2 |  |  |
| Register to Memory | 0011000 w | mod reg r/m |  | 7** | 2** | a |
| Memory to Register | 0011001 w | modreg r/m |  | 6* | $1 *$ | a |
| Immediate to Register/Memory | 1000000 w | $\bmod 110 \mathrm{r} / \mathrm{m}$ | immediate data | 2/7** | 0/2** | a |
| Immediate to Accumulator (Short Form) | 0011010 w | immediate data |  | 2 |  |  |
| NOT = Invert Register/Memory | 1111011 w | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  | 2/6** | 0/2** | a |
| STRING MANIPULATION |  |  |  |  |  |  |
| CMPS = Compare Byte Word | 1010011 w |  |  | 10* | 2* | a |
| INS = Input Byte/Word from DX Port | 0110110 w |  |  | 9******** 29** | 1*** | $\mathrm{a}, \mathrm{f}, \mathrm{k}$ $\mathrm{a}, \mathrm{f}, \mathrm{l}$ |
| LODS = Load Byte/Word to AL/AX/EAX | 1010110 w |  |  | 5* | 1* | a |
| MOVS = Move Byte Word | 1010010 w |  |  | 7** | 2** | a |
| OUTS = Output Byte/Word to DX Port | 0110111 w |  |  | 8** | 1** | a,f,k <br> a,f,l |
| SCAS = Scan Byte Word | 1010111 w |  |  | 7* | 1* | a |
| STOS $=$ Store Byte/Word from |  |  |  |  |  |  |
| AL/AX/EX | 1010101 w |  |  | 4* | 1* | a |
| XLAT $=$ Translate String | 11010111 |  |  | 5* | 1* | a |
| Repeated by Count in CX or ECX |  |  |  |  |  |  |
| REPE CMPS = Compare String |  |  |  |  |  |  |
| (Find Non-Match) | 11110011 | 1010011 w |  | $5+9 \mathrm{n}^{* *}$ | $2 \mathrm{n}^{* *}$ | a |

Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)

| Instruction | Format |  |  |  |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REPEATED STRING MANIPULATION (Continued) |  |  |  |  |  |  |  |  |
| REPNE CMPS = Compare String |  |  |  |  |  |  |  |  |
| (Find Match) | 11110010 | 1010011 w |  |  |  | $5+9 \mathrm{n}^{* *}$ | $2 n^{* *}$ | a |
| REP INS = Input String | 11110011 | 0110110 w |  |  |  | $7+6 n^{*}$ $27+6 n^{*}$ | $1 n^{*}$ $1 n^{*}$ | $\mathrm{a}, \mathrm{f}, \mathrm{k}$ $\mathrm{a}, \mathrm{f}, \mathrm{l}$ |
| REP LODS $=$ Load String | 11110011 | 1010110 w |  |  |  | $5+6{ }^{*}$ | $1 \mathrm{n}^{*}$ | a |
| REP MOVS = Move String | 11110011 | 1010010 w |  |  |  | $7+4 n^{*}$ | $2 \mathrm{n}^{* *}$ | a |
| REP OUTS = Output String | 11110011 | 0110111 w |  |  |  | $6+5{ }^{*}$ $26+5 n^{*}$ | $\begin{aligned} & 1 n^{*} \\ & 1 n^{*} \end{aligned}$ | $\mathrm{a}, \mathrm{f}, \mathrm{k}$ <br> a,f,l |
| REPE SCAS = Scan String |  |  |  |  |  |  |  |  |
| (Find Non-AL/AX/EAX) | 11110011 | 1010111 w |  |  |  | $5+8{ }^{*}$ | $1{ }^{*}$ | a |
| REPNE SCAS = Scan String |  |  |  |  |  |  |  |  |
| (Find AL/AX/EAX) | 11110010 | 1010111 w |  |  |  | $5+8{ }^{*}$ | $1{ }^{*}$ | a |
| REP STOS = Store String | 11110011 | 1010101 w |  |  |  | $5+5{ }^{*}$ | $1{ }^{*}$ | a |
| BIT MANIPULATION |  |  |  |  |  |  |  |  |
| BSF $=$ Scan Bit Forward | 00001111 | 10111100 | mod reg | $\mathrm{r} / \mathrm{m}$ |  | $10+3{ }^{* *}$ | $2 \mathrm{n}^{* *}$ | a |
| BSR = Scan Bit Reverse | 00001111 | 10111101 | mod reg | $\mathrm{r} / \mathrm{m}$ |  | $10+3 n^{* *}$ | $2 n^{* *}$ | a |
| BT $\sim$ Test Bit |  |  |  |  |  |  |  |  |
| Register/Memory, Immediate | 00001111 | 10111010 | $\bmod 100$ | r/m | immed 8-bit data | 3/6* | 0/1* | a |
| Register/Memory, Register | 00001111 | 10100011 | mod reg | $\mathrm{r} / \mathrm{m}$ |  | 3/12* | 0/1* | a |
| BTC $=$ Test Bit and Complement |  |  |  |  |  |  |  |  |
| Register/Memory, Immediate | 00001111 | 10111010 | mod 111 | r/m | immed 8-bit data | 6/8* | 0/2* | a |
| Register/Memory, Register | 00001111 | 10111011 | mod reg | $\mathrm{r} / \mathrm{m}$ |  | 6/13* | 0/2* | a |
| BTR $=$ Test Blt and Reset |  |  |  |  |  |  |  |  |
| Register/Memory, Immediate | 00001111 | 10111010 | $\bmod 110$ | $\mathrm{r} / \mathrm{m}$ | immed 8-bit data | 6/8* | 0/2* | a |
| Register/Memory, Register | 00001111 | 10110011 | mod reg | $\mathrm{r} / \mathrm{m}$ |  | 6/13* | 0/2* | a |
| BTS $=$ Test Bit and Set |  |  |  |  |  |  |  |  |
| Register/Memory, Immediate | 00001111 | 10111010 | $\bmod 101$ | $\mathrm{r} / \mathrm{m}$ | immed 8-bit data | 6/8* | 0/2* | a |
| Register/Memory, Register | 00001111 | 10101011 | mod reg | $\mathrm{r} / \mathrm{m}$ |  | 6/13* | 0/2* | a |
| CONTROL TRANSFER |  |  |  |  |  |  |  |  |
| CALL $=$ Call |  |  |  |  |  |  |  |  |
| Direct within Segment | 11101000 | full displacement | , |  |  | $9+\mathrm{m}^{*}$ | 2 | I |
| Register/Memory |  |  |  |  |  |  |  |  |
| Indirect within Segment | 11111111 | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  |  |  | $9+m / 12+m$ | $2 / 3$ | a, j |
| Direct Intersegment | 10011010 | unsigned full offse | et, selector |  |  | $42+m$ | 9 | c, d, j |

Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)

| Instruction Format |  |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CONTROL TRANSFER (Continued) (Direct intersegment) |  |  |  |  |  |
| Via Call Gate to Same Privilege Level |  |  | $64+m$ | 13 | a,c,d,j |
| Via Call Gate to Different Privilege Level, (No Parameters) |  |  | $98+m$ | 13 | a,c, d, j |
| Via Call Gate to Different Privilege Level, (x Parameters) |  |  | $106+8 x+m$ | $13+4 x$ | a,c,d, j |
| From 386 Task to 386 TSS |  |  | 392 | 124 | a,c,d,j |
| Indirect Intersegment | 11111111 | mod $011 \quad \mathrm{r} / \mathrm{m}$ | $46+m$ | 10 | a,c,d,j |
| Via Call Gate to Same Privilege Level |  |  | $68+m$ | 14 | a,c,d, ${ }^{\text {d }}$ |
| Via Call Gate to Different Privilege Level, (No Parameters) |  |  | $102+m$ | 14 | a,c,d, j |
| Via Call Gate to Different Privilege Level, (x Parameters) |  |  | $110+8 x+m$ | $14+4 x$ | a,c,d,j |
| From 386 Task to 386 TSS |  |  | 399 | 130 | a,c,d,j |
| JMP = Unconditional Jump |  |  |  |  |  |
| Short | 11101011 | 8-bit displacement | $7+m$ |  | j |
| Direct within Segment | 11101001 | full displacement | $7+m$ |  | j |
| Register/Memory Indirect within Segment | 11111111 | $\bmod 100 \mathrm{r} / \mathrm{m}$ | $9+m / 14+m$ | 2/4 | a, |
| Direct Intersegment | 11101010 | unsigned full offset, selector | $37+m$ | 5 | c,d,j |
| Via Call Gate to Same Privilege Level |  |  | $53+m$ | 9 | a,c, d, j |
| From 386 Task to 386 TSS |  |  | 395 | 124 | a,c,d,j |
| Indirect Intersegment | 11111111 | mod $101 \quad \mathrm{r} / \mathrm{m}$ | $37+m$ | 9 | a,c,d,j |
| Via Call Gate to Same Privilege Level |  |  | $59+m$ | 13 | a,c,d,j |
| From 386 Task to 386 TSS |  |  | 401 | 124 | a,c,d,j |

Table 8.1. $\mathbf{8 0 3 7 6}$ Instruction Set Clock Count Summary (Continued)

| Instruction | Format |  |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CONTROL TRANSFER (Continued) RET = Return from CALL: |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
| Within Segment | 11000011 |  |  | $12+m$ | 2 | a,j,p |
| Within Segment Adding Immediate to SP | 11000010 | 16-bit displ |  | $12+m$ | 2 | a,j,p |
| Intersegment | 11001011 |  |  | $36+m$ | 4 | a,c,d,j, p |
| Intersegment Adding Immediate to SP | 11001010 | 16-bit displ |  | $36+m$ | 4 | a,c,d,j,p |
| to Different Privilege Level <br> Intersegment Intersegment Adding Immediate to SP |  |  |  |  |  |  |
|  |  |  |  | 80 | 4 | c,d,j,p |
|  |  |  |  | 80 | 4 | c,d,j, |
| CONDITIONAL JUMPS |  |  |  |  |  |  |
| NOTE: Times Are Jump "Taken or Not Taken" |  |  |  |  |  |  |
| JO = Jump on Overflow |  |  | full displacement |  |  |  |
| 8-Bit Displacement | 01110000 | 8-bit displ |  | $7+\mathrm{mor} 3$ |  | j |
| Full Displacement | 00001111 | 10000000 |  | $7+\mathrm{m}$ or 3 |  | j |
| JNO = Jump on Not Overfiow |  |  | full displacement |  |  |  |
| 8-Bit Displacement | 01110001 | 8-bit displ |  | $7+m$ or 3 |  | j |
| Full Displacement | 00001111 | 10000001 |  | $7+\operatorname{mor} 3$ |  | j |
| JB/JNAE $=$ Jump on Below/Not Above or Equal |  |  | full displacement |  |  |  |
| 8-Bit Displacement | 01110010 | 8-bit displ |  | $7+m$ or 3 |  | j |
| Full Displacement | 00001111 | 10000010 |  | $7+\mathrm{mor} 3$ |  | ) |
| JNB/JAE = Jump on Not Below/Above or Equal |  |  | full displacement |  |  |  |
| 8-Bit Displacement | 01110011 | 8-bit displ |  | $7+\mathrm{mor} 3$ |  | j |
| Full Displacement | 00001111 | 10000011 |  | $7+\mathrm{mor} 3$ | ; | j |
| JE/JZ = Jump on Equal/Zero |  |  | full displacement |  |  |  |
| 8-Bit Displacement | 01110100 | 8-bit displ |  | $7+\mathrm{mor} 3$ |  | j |
| Full Displacement | 00001111 | 10000100 |  | $7+\mathrm{mor} 3$ |  | j |
| JNE/JNZ = Jump on Not Equal/Not Zero |  |  | full displacement |  |  |  |
| 8-Bit Displacement | 01110101 | 8-bit displ |  | $7+\mathrm{m}$ or 3 |  | j |
| Full Displacement | 00001111 | 10000101 |  | $7+m$ or 3 |  | j |
| JBE/JNA = Jump on Below or Equal/Not Above |  |  | full displacement |  |  |  |
| 8-Bit Displacement | 01110110 | 8-bit displ |  | $7+m$ or 3 |  | j |
| Full Displacement | 00001111 | 10000110 |  | $7+\mathrm{mor} 3$ |  | j |
| JNBE/JA = Jump on Not Below or Equal/Above |  |  | full displacement |  |  | - |
| 8-Bit Displacement | 01110111 | 8-bit displ |  | $7+\mathrm{mor} 3$ |  | j |
| Full Displacement | 00001111 | 10000111 |  | $7+\mathrm{mor} 3$ |  | i |
| JS = Jump on Sign |  |  | full displacement |  |  |  |
| 8-Bit Displacement | 01111000 | 8-bit displ |  | $7+\mathrm{m}$ or 3 |  | j |
| Full Displacement | 00001111 | 10001000 |  | $7+\mathrm{mor} 3$ |  | I |

Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)


Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)

| Instruction Format |  |  |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CONDITIONAL BYTE SET (Continued) <br> SETNB = Set Byte on Not Below/Above or Equal |  |  |  | $4 / 5^{*}$4/5** | 0/1** | a |
|  |  |  |  |  |  |  |
| To Register/Memory | 00001111 | 10010011 |  |  |  |  |
| SETE/SETZ = Set Byte on Equal/Zero |  |  |  |  |  |  |
| To Register/Memory | 00001111 | 10010100 | $\bmod 000 \quad \mathrm{r} / \mathrm{m}$ |  |  | $0 / 1^{*}$$0 / 1^{*}$ | a |
| SETNE/SETNZ = Set Byte on Not Equal/Not Zero |  |  |  |  | 4/5*4/5* |  |  |
| To Register/Memory | 00001111 | 10010101 | $\bmod 000 \mathrm{r} / \mathrm{m}$ | a |  |  |
| SETBE/SETNA = Set Byte on Below or Equal/Not Above |  |  |  | 4/5** | 0/1* | a |
| To Register/Memory | 00001111 | 10010110 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |  |
| SETNBE/SETA = Set Byte on Not Below or Equal/Above |  |  |  |  | 0/1* | a |
| To Register/Memory | 00001111 | 10010111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |  |
| SETS = Set Byte on Sign |  |  |  | 4/5* | 0/1* | a |
| To Register/Memory | 00001111 | 10011000 | $\bmod 000 \mathrm{r} / \mathrm{m}$ | 4/5* |  |  |
| SETNS = Set Byte on Not Sign |  |  |  |  | 0/1* | a |
| - To Register/Memory | 00001111 | 10011001 | $\bmod 000 \mathrm{r} / \mathrm{m}$ | 4/5* |  |  |
| SETP/SETPE $=$ Set Byte on Parity/Parity Even |  |  |  | 4/5* | 0/1* | a |
| To Register/Memory | 00001111 | 10011010 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |  |
| SETNP/SETPO = Set Byte on Not Parity/Parity Odd |  |  |  | 4/5* | 0/1* | a |
| To Register/Memory | 00001111 | 10011011 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |  |
| SETL/SETNGE = Set Byte on Less/Not Greater or Equal |  |  |  | 4/5* | 0/1* | a |
| To Register/Memory | 00001111 | 10011100 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |  |
| SETNL/SETGE $=$ Set Byte on Not Less/Greater or Equal |  |  |  | 4/5* | 0/1* | a |
| To Register/Memory | 00001111 | 01111101 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |  |
| SETLE/SETNG = Set Byte on Less or Equal/Not Greater |  |  |  | 4/5* | 0/1* | a |
| To Register/Memory | 00001111 | 10011110 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |  |
| SETNLE/SETG $=$ Set Byte on Not Less or Equal/Greater |  |  |  | $4 / 5^{*}$ | 0/1* | a |
| To Register/Memory | 00001111 | 10011111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  |  |
| ENTER = Enter Procedure | 11001000 | 16-bit displacement, 8-bit level |  |  |  |  |
| $\mathrm{L}=0$ |  |  |  | 10 | $\begin{gathered} 1 \\ 4(n-1) \end{gathered}$ | a |
| $L=1$ |  |  |  | - 14 |  | a |
| $L>1$ |  |  |  | $17+8(n-1)$ |  | a |
| LEAVE = Leave Procedure | 11001001 |  |  | 6 |  | a |

Table 8.1. $\mathbf{8 0 3 7 6}$ Instruction Set Clock Count Summary (Continued)

| Instruction | Format |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INTERRUPT INSTRUCTIONS |  |  |  |  |  |
| INT = Interrupt: |  |  |  |  |  |
| Type Specified | 11001101 | type |  |  |  |
| Via Interrupt or Trap Gate <br> to Same Privilege Level |  |  |  |  |  |
|  |  | Via Interrupt or Trap Gate | 111 | 14 | c, d,j,p |
| From 386 Task to 386 TSS via Task Gate |  |  | 467 | 140 | c, d, j, p |
| Type 3 | 11001100 |  |  |  |  |
| Via Interrupt or Trap Gate |  |  |  |  |  |
| Via Interrupt or Trap Gate |  |  |  |  | c, d, j, p |
| From 386 Task to 386 TSS via Task Gate |  |  | 308 | 138 | c, d, j.p |
| INTO = Interrupt 4 if Overflow Flag Set 11001110 |  |  |  |  |  |
| If $\mathrm{OF}=1$ : |  |  | 3 |  |  |
| If $\mathrm{OF}=0$ |  |  |  |  |  |
| Via Interrupt or Trap Gate to Same Privilege Level |  |  | 71 | 14 | c, d, j, p |
| Via Interrupt or Trap Gate to Different Privilege Level |  |  | 111 | 14 | c,d,j,p |
| From 386 Task to 386 TSS via Task G |  |  | 413 | 138 | c, d, j, p |

Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)


Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)

| Instruction Format |  |  |  |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PROCESSOR EXTENSION INSTRUCTIONS |  |  |  |  |  |  |  |
| Processor Extension Escape | 11011 T T T | $\operatorname{modLLL} \quad \mathrm{r} / \mathrm{m}$ |  |  | See 80387SX Data Sheet |  | a |
|  | TTT and LLL bits are opcode information for coprocessor. |  |  |  |  |  |  |
| PREFIX BYTES |  |  |  |  | : |  |  |
| Address Size Prefix 01100111 |  |  |  |  | 0 |  |  |
| LOCK $=$ Bus Lock Prefix 1111000 |  |  |  |  | 0 |  | f |
| Operand Size Prefix 01100110 |  |  |  |  | 0 |  |  |
| Segment Override Prefix |  |  |  |  |  |  |  |
| CS: 00101110 |  |  |  |  | 0 |  |  |
| DS: | 00111110 |  |  |  | 0 |  |  |
| ES: | 00100110 |  |  |  | 0 |  |  |
| FS: | 01100100 |  |  |  | 0 |  |  |
| GS: | 01100101 |  |  |  | 0 |  |  |
| SS: | 00110110 |  |  |  | 0 |  |  |
| PROTECTION CONTROL |  |  |  |  |  |  |  |
| $\begin{aligned} \text { ARPL }= & \text { Adjust Requested Privilege Level } \\ & \text { From Register/Memory } 01100011\end{aligned}$ |  |  |  |  |  |  |  |
|  |  |  |  |  | 20/21** | $2^{* *}$ | a |
| LAR = Load Access Rights |  |  |  |  |  |  |  |
| From Register/Memory | 00001111 | 00000010 | mod reg |  | 17/18* | 1* | a,c,i,p |
| LGDT = Load Global Descriptor |  |  |  |  |  |  |  |
| Table Register | 00001111 | 00000001 | $\bmod 010$ |  | 13** | 3* | a,e |
| LIDT $=$ Load Interrupt Descriptor |  |  |  |  |  |  |  |
| Table Register | 00001111 | 00000001 | $\bmod 011$ |  | 13** | 3* | a,e |
| LLDT $=$ Load Local Descriptor |  |  |  |  |  |  |  |
| Table Register to Register/Memory | 00001111 | 00000000 | $\bmod 010$ |  | 24/28* | 5* | a,c,e,p |
| LMSW = Load Machine Status Word |  |  |  |  |  |  |  |
| From Register/Memory | 00001111 | 00000001 | $\bmod 110$ |  | 10/13* | 1* | a,e |
| LSL $=$ Load Segment Limit |  |  |  |  |  |  |  |
| From Register/Memory | 00001111 | 00000011 | mod reg |  |  |  |  |
| Byte-Granular Limit |  |  |  |  | 24/27* | $2^{*}$ | a,c,i,p |
| Page-Granular Limit |  |  |  |  | 29/32* | 2* | a,c,i,p |
| LTR = Load Task Register |  |  |  |  |  |  |  |
| From Register/Memory | 00001111 | 00000000 | $\bmod 001$ |  | 27/31* | 4* | a,c,e,p |
| SGDT = Store Global Descriptor |  |  |  |  |  |  |  |
| Table Register | 00001111 | 00000001 | $\bmod 000$ |  | 11* | 3* | a |
| SIDT $=$ Store Interrupt Descriptor |  |  |  |  |  |  |  |
| Table Register | 00001111 | 00000001 | $\bmod 001$ |  | 11* | 3* | a |
| SLDT $=$ Store Local Descriptor Table Register |  |  |  |  |  |  |  |
| To Register/Memory | 00001111 | 00000000 | $\bmod 000$ | r/m | 2/2* | 4* | a |

Table 8.1. 80376 Instruction Set Clock Count Summary (Continued)

| Instruction | Format |  |  | Clock Counts | Number of Data Cycles | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PROTECTION CONTROL (Continued) <br> SMSW = Store Machine <br> Status Word |  |  |  | 2/2* | 1* | a, c |
|  | 00001111 | 00000001 | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |  |
| $\mathbf{S T R}=$ Store Task Register |  |  |  |  |  |  |
| To Register/Memory | 00001111 | 00000000 | $\bmod 001 \mathrm{r} / \mathrm{m}$ | 2/2* | 1* | a |
| VERR = Verify Read Accesss |  |  |  |  |  |  |
| Register/Memory | 00001111 | 00000000 | $\bmod 100 \mathrm{r} / \mathrm{m}$ | 10/11** | 2** | a,c,i,p |
| VERW = Verify Write Accesss | 00001111 | 00000000 | $\bmod 101 \mathrm{r} / \mathrm{m}$ | 15/16** | 2** | a,c,i,p |

## NOTES:

a. Exception 13 fault (general violation) will occur if the memory operand in CS, DS, ES, FS or GS cannot be used due to either a segment limit violation or access rights violation. If a stack limit is violated, and exception 12 (stack segment limit violation or not present) occurs.
b. For segment load operations, the CPL, RPL and DPL must agree with the privilege rules to avoid an exception 13 fault (general protection violation). The segments's descriptor must indicate "present" or exception 11 (CS, DS, ES, FS, GS not present). If the SS register is loaded and a stack segment not present is detected, an exception 12 (stack segment limit violation or not present occurs).
c. 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.
d. JMP, CALL, INT, RET and IRET instructions referring to another code segment will cause an exception 13 (general protection violation) if an applicable privilege rule is volated.
e. An exception 13 fault occurs if CPL is greater than 0.
f. An exception 13 fault occurs if CPL is greater than IOPL.
g. The IF bit of the flag register is not updated if CPL is greater than IOPL. The IOPL field of the flag register is updated only if $\mathrm{CPL}=0$.
h. Any violation of privelege rules as applied to the selector operand does not cause a protection exception; rather, the zero flag is cleared.
i. If the coprocessor's memory operand violates a segment limit or segment access rights, an exception 13 fault (general protection exception) will occur before the ESC instruction is executed. An exception 12 fault (stack segment limit violation or no present) will occur if the stack limit is violated by the operand's starting address.
j. The destination of a JMP, CALL, INT, RET or IRET must be in the defined limit of a code segment or an exception 13 fault (general protection violation) will occur.
k. If CPL $\leq$ IOPL
l. If CPL > IOPL
$\mathrm{m} . \overline{\text { LOCK }}$ is automatically asserted, regardless of the presence or absence of the $\overline{\text { LOCK }}$ prefix.
n . The 80376 uses an early-out multiply algorithm. The actual number of clocks depends on the position of the most significant bit in the operand (multiplier). Clock counts given are minimum to maximum. To calculate actual clocks use the following formula:

Actual Clock $=$ if $m<>0$ then $\max \left(\left[\log _{2}|\mathrm{~m}|\right], 3\right)+9$ clocks:
if $\mathrm{m}=0$ then 12 clocks (where m is the multiplier)
o. An exception may occur, depending on the value of the operand.
p. LOCK is asserted during descriptor table accesses.

### 8.2 INSTRUCTION ENCODING

## Overview

All instruction encodings are subsets of the general instruction format shown in Figure 8.1. Instructions consist of one or two primary opcode bytes, possibly an address specifier consisting of the "mod $\mathrm{r} / \mathrm{m}$ " byte and "scaled index" byte, a displacement if required, and an immediate data field if required.

Within the primary opcode or opcodes, smaller encoding fields may be defined. These fields vary according to the class of operation. The fields define such information as direction of the operation, size of the displacements, register encoding, or sign extension.

Almost all instructions referring to an operand in memory have an addressing mode byte following the primary opcode byte(s). This byte, the modr/m byte, specifies the address mode to be used. Certain
encodings of the mod $\mathrm{r} / \mathrm{m}$ byte indicate a second addressing byte, the scale-index-base byte, follows the mod $\mathrm{r} / \mathrm{m}$ byte to fully specify the addressing mode.

Addressing modes can include a displacement immediately following the mod r/m byte, or scaled index byte. If a displacement is present, the possible sizes are 8, 16 or 32 bits.

If the instruction specifies an immediate operand, the immediate operand follows any displacement bytes. The immediate operand, if specified, is always the last field of the instruction.

Figure 8.1 illustrates several of the fields that can appear in an instruction, such as the mod field and the $\mathrm{r} / \mathrm{m}$ field, but the Figure does not show all fields. Several smaller fields also appear in certain instructions, sometimes within the opcode bytes themselves. Table 8.2 is a complete list of all fields appearing in the 80376 instruction set. Further ahead, following Table 8.2, are detailed tables for each field.


Figure 8.1. General Instruction Format

Table 8.2. Fields within 80376 Instructions

| Field Name | Description | Number of Bits |
| :---: | :---: | :---: |
| w | Specifies if Data is Byte or Full Size (Full Size is either 16 or 32 Bits | 1 |
| d | Specifies Direction of Data Operation | 1 |
| s | Specifies if an Immediate Data Field Must be Sign-Extended | 1 |
| reg | General Register Specifier | 3 |
| $\bmod \mathrm{r} / \mathrm{m}$ | Address Mode Specifier (Effective Address can be a General Register) | 2 for mod; 3 for $\mathrm{r} / \mathrm{m}$ |
| ss | Scale Factor for Scaled Index Address Mode | 2 |
| index | General Register to be used as Index Register | 3 |
| base | General Register to be used as Base Register | 3 |
| sreg2 | Segment Register Specifier for CS, SS, DS, ES | 2 |
| sreg3 | Segment Register Specifier for CS, SS, DS, ES, FS, GS | 3 |
| ttn | For Conditional Instructions, Specifies a Condition Asserted or a Condition Negated | 4 |

Note: Table 8.1 shows encoding of individual instructions.

## 16-Bit Extensions of the Instruction Set

Two prefixes, the operand size prefix $(66 \mathrm{H})$ and the effective address size prefix (67H), allow overriding individually the default selection of operand size and effective address size. These prefixes may precede any opcode bytes and affect only the instruction they precede. If necessary, one or both of the prefixes may be placed before the opcode bytes. The presence of the operand size prefix $(66 \mathrm{H})$ and the effective address prefix will allow 16-bit data operation and 16-bit effective address calculations.

For instructions with more than one prefix, the order of prefixes is unimportant.

Unless specified otherwise, instructions with 8-bit and 16 -bit operands do not affect the contents of the high-order bits of the extended registers.

## Encoding of Instruction Fields

Within the instruction are several fields indicating register selection, addressing mode and so on.

## ENCODING OF OPERAND LENGTH (w) FIELD

For any given instruction performing a data operation, the instruction will execute as a 32-bit operation. Within the constraints of the operation size, the w field encodes the operand size as either one byte or the full operation size, as shown in the table below.

| w Field | Operand Size <br> with 66H Prefix | Normal <br> Operand Size |
| :---: | :---: | :---: |
| 0 | 8 Bits | 8 Bits |
| 1 | 16 Bits | 32 Bits |

## ENCODING OF THE GENERAL <br> REGISTER (reg) FIELD

The general register is specified by the reg field, which may appear in the primary opcode bytes, or as the reg field of the " $\mathrm{mod} \mathrm{r} / \mathrm{m}$ " byte, or as the $\mathrm{r} / \mathrm{m}$ field of the "mod r/m" byte.

Encoding of reg Field When w Field is not Present in Instruction

| reg Field | Register Selected <br> with 66H Prefix | Register Selected <br> During 32-Bit <br> Data Operations |
| :---: | :---: | :---: |
| 000 | AX | EAX |
| 001 | CX | ECX |
| 010 | DX | EDX |
| 011 | BX | EBX |
| 100 | SP | ESP |
| 101 | BP | EBP |
| 110 | SI | ESI |
| 111 | DI | EDI |

Encoding of reg Field When w Field is Present in Instruction

| Register Specified by reg Field <br> with 66H Prefix |  |  |
| :---: | :---: | :---: |
| reg | Function of w Field |  |
|  | (when w = 0) | (when w = 1) |
| 000 | AL | AX |
| 001 | CL | CX |
| 010 | DL | DX |
| 011 | BL | BX |
| 100 | AH | SP |
| 101 | CH | BP |
| 110 | DH | SI |
| 111 | BH | DI |


| Register Specified by reg Field <br> without 66H Prefix |  |  |
| :---: | :---: | :---: |
| reg | Function of w Field |  |
|  | (when w = 0) | (when w = 1) |
| 000 | AL | EAX |
| 001 | CL | ECX |
| 010 | DL | EDX |
| 011 | BL | EBX |
| 100 | AH | ESP |
| 101 | CH | EBP |
| 110 | DH | ESI |
| 111 | BH | EDI |

## ENCODING OF THE SEGMENT REGISTER (sreg) FIELD

The sreg field in certain instructions is a 2 -bit field allowing one of the CS, DS, ES or SS segment registers to be specified. The sreg field in other instructions is a 3 -bit field, allowing the FS and GS segment registers to be specified also.

## 2-Bit sreg2 Field

| 2-Bit <br> sreg2 Field | Segment <br> Register <br> Selected |
| :---: | :---: |
| 00 | ES |
| 01 | CS |
| 10 | SS |
| 11 | DS |

## 3-Bit sreg3 Field

| 3-Bit <br> sreg3 Field | Segment <br> Register <br> Selected |
| :---: | :---: |
| 000 | ES |
| 001 | CS |
| 010 | SS |
| 011 | DS |
| 100 | FS |
| 101 | GS |
| 110 | do not use |
| 111 | do not use |

## ENCODING OF ADDRESS MODE

Except for special instructions, such as PUSH or POP, where the addressing mode is pre-determined, the addressing mode for the current instruction is specified by addressing bytes following the primary opcode. The primary addressing byte is the "mod r/m" byte, and a second byte of addressing information, the "s-i-b" (scale-index-base) byte, can be specified.

The s-i-b byte (scale-index-base byte) is specified when using 32-bit addressing mode and the "mod $\mathrm{r} / \mathrm{m}$ " byte has $\mathrm{r} / \mathrm{m}=100$ and $\mathrm{mod}=00,01$ or 10. When the sib byte is present, the 32-bit addressing mode is a function of the mod, ss, index, and base fields.

The primary addressing byte, the "modr/m" byte, also contains three bits (shown as TTT in Figure 8.1) sometimes used as an extension of the primary opcode. The three bits, however, may also be used as a register field (reg).

When calculating an effective address, either 16 -bit addressing or 32 -bit addressing is used. 16-bit addressing uses 16 -bit address components to calculate the effective address while 32-bit addressing uses 32 -bit address components to calculate the effective address. When 16 -bit addressing is used, the " $m o d r / m$ " byte is interpreted as a 16 -bit addressing mode specifier. When 32-bit addressing is used, the " $m o d r / m$ " byte is interpreted as a 32-bit addressing mode specifier.

Tables on the following three pages define all encodings of all 16 -bit addressing modes and 32-bit addressing modes.

Encoding of Normal Address Mode with "mod r/m" byte (no "s-i-b" byte present):

| mod r/m | Effective Address |
| :--- | :--- |
| 00000 | DS:[EAX] |
| 00001 | DS:[ECX] |
| 00010 | DS:[EDX] |
| 00011 | DS:[EBX] |
| 00100 | $\mathrm{si-}$-b is present |
| 00101 | DS:d32 |
| 00110 | DS:[ESI] |
| 00111 | DS:[EDI] |
|  |  |
| 01000 | DS:[EAX+d8] |
| 01001 | DS:[ECX+d8] |
| 01010 | DS:[EDX+d8] |
| 01011 | DS:[EBX+d8] |
| 01100 | S-i-b is present |
| 01101 | SS:[EBP+d8] |
| 01110 | DS:[ESI+d8] |
| 01111 | DS:[EDI+d8] |


| mod r/m | Effective Address |
| :--- | :--- |
| 10000 | DS:[EAX+d32] |
| 10001 | DS:[ECX+d32] |
| 10010 | DS:[EDX+d32] |
| 10011 | DS:[EBX+d32] |
| 10100 | s-i-b is present |
| 10101 | SS:[EBP+d32] |
| 10110 | DS:[ESI+d32] |
| 10111 | DS:[EDI+d32] |
|  |  |
| 11000 | register-see below |
| 11001 | register-see below |
| 11010 | register-see below |
| 11011 | register-see below |
| 11100 | register-see below |
| 11101 | register-see below |
| 11110 | register-see below |
| 11111 | register-see below |


| Register Specified by reg or r/m <br> during <br> Normal Data Operations: |  |  |
| :---: | :---: | :---: |
| $\mathbf{m o d} \mathbf{r} / \mathbf{m}$ | function of w field |  |
|  | (when w = 0) | (when $\mathbf{w}=\mathbf{1}$ ) |
| 11000 | AL | EAX |
| 11001 | CL | ECX |
| 11010 | DL | EDX |
| 11011 | BL | EBX |
| 11100 | AH | ESP |
| 11101 | CH | EBP |
| 11110 | DH | ESI |
| 11111 | BH | EDI |


| Register Specified by reg or $\mathrm{r} / \mathrm{m}$ during 16-Bit Data Operations: (66H Prefix) |  |  |
| :---: | :---: | :---: |
| $\bmod \mathbf{r} / \mathrm{m}$ | function of $w$ field |  |
|  | (when w $=0$ ) | (when w=1) |
| 11000 | AL | AX |
| 11001 | CL | CX |
| 11010 | DL | DX |
| 11011 | BL | BX |
| 11100 | AH | SP |
| 11101 | CH | BP |
| 11110 | DH | SI |
| 11111 | BH | DI |

## Encoding of 16-bit Address Mode with "mod r/m" Byte Using 67H Prefix

| mod r/m | Effective Address |
| :---: | :---: |
| 00000 | $D S:[B X+S I]$ |
| 00001 | $D S:[B X+D I]$ |
| 00010 | SS: $[\mathrm{BP}+\mathrm{SI}]$ |
| 00011 | SS:[BP + DI] |
| 00100 | DS:[SI] |
| 00101 | DS:[DI] |
| 00110 | DS:d16 |
| 00111 | DS: [BX] |
| 01000 | DS: $[B X+S I+d 8]$ |
| 01001 | DS: $[B X+D I+d 8]$ |
| 01010 | SS:[BP+SI+d8] |
| 01011 | SS: $[\mathrm{BP}+\mathrm{DI}+\mathrm{d8}]$ |
| 01100 | DS:[SI + d8] |
| 01101 | DS:[DI + d8] |
| 01110 | SS:[BP + d8] |
| 01111 | $D S:[B X+d 8]$ |


| mod r/m | Effective Address |
| :--- | :--- |
| 10000 | DS:[BX+SI+d16] |
| 10001 | DS:[BX+ DI + d16] |
| 10010 | SS:[BP+SI+d16] |
| 10011 | SS:[BP+DI+d16] |
| 10100 | DS:[SI + d16] |
| 10101 | DS:[DI+d16] |
| 10110 | SS:[BP+d16] |
| 10111 | DS:[BX+d16] |
|  |  |
| 11000 | register-see below |
| 11001 | register-see below |
| 11010 | register-see below |
| 11011 | register-see below |
| 11100 | register-see below |
| 11101 | register-see below |
| 11110 | register-see below |
| 11111 | register-see below |

Encoding of 32-bit Address Mode ("mod r/m" byte and "s-i-b" byte present):

| mod base | Effective Address |
| :---: | :---: |
| 00000 | DS:[EAX+ (scaled index)] |
| 00001 | DS:[ECX + (scaled index)] |
| 00010 | DS:[EDX + (scaled index)] |
| 00011 | DS: [EBX + (scaled index)] |
| 00100 | SS:[ESP + (scaled index)] |
| 00101 | DS:[d32 + (scaled index)] |
| 00110 | DS:[ESI + (scaled index)] |
| 00111 | DS:[EDI + (scaled index)] |
| 01000 | DS: [EAX + (scaled index) + d8] |
| 01001 | DS: [ECX + (scaled index) $+\mathrm{d8}$ ] |
| 01010 | DS: [EDX + (scaled index) $+\mathrm{d8}$ ] |
| 01011 | DS: [EBX + (scaled index) + d8] |
| 01100 | SS:[ESP + (scaled index) + d8] |
| 01101 | SS:[EBP + (scaled index) + d8] |
| 01110 | DS:[ESI + (scaled index) + d8] |
| 01111 | DS:[EDI + (scaled index) + d8] |
| 10000 | DS: [EAX + (scaled index) + d32] |
| 10001 | DS: [ECX + (scaled index) + d32] |
| 10010 | DS: [EDX + (scaled index) + d32] |
| 10011 | DS: [EBX + (scaled index) + d32] |
| 10100 | SS:[ESP + (scaled index) + d32] |
| 10101 | SS:[EBP + (scaled index) + d32] |
| 10110 | DS:[ESI + (scaled index) + d32] |
| 10111 | DS: [EDI + (scaled index) + d32] |


| ss | Scale Factor |
| :---: | :---: |
| 00 | $\times 1$ |
| 01 | $\times 2$ |
| 10 | $\times 4$ |
| 11 | $\times 8$ |


| index | Index Register |
| :---: | :---: |
| 000 | EAX |
| 001 | ECX |
| 010 | EDX |
| 011 | EBX |
| 100 | no index reg** |
| 101 | EBP |
| 110 | ESI |
| 111 | EDI |

**IMPORTANT NOTE:
When index field is 100, indicating "no index register," then ss field MUST equal 00. If index is 100 and ss does not equal 00 , the effective address is undefined.

## NOTE:

Mod field in "mod r/m" byte; ss, index, base fields in "s-i-b" byte.

## ENCODING OF OPERATION DIRECTION (d) FIELD

In many two-operand instructions the d field is present to indicate which operand is considered the source and which is the destination.

| $\mathbf{d}$ | Direction of Operation |
| :--- | :--- |
| 0 | Register/Memory <- Register |
|  | "reg" Field Indicates Source Operand; |
|  | "mod r/m" or "mod ss index base" Indicates |
|  | Destination Operand |
| 1 | Register < - Register/Memory <br>  <br> "reg" Field Indicates Destination Operand; <br>  <br>  <br>  "mod r/m" or "mod ss index base" Indicates |
| Source Operand |  |

## ENCODING OF SIGN-EXTEND (s) FIELD

The s field occurs primarily to instructions with immediate data fields. The s field has an effect only if the size of the immediate data is 8 bits and is being placed in a 16-bit or 32-bit destination.

| s | Effect on Immediate Data8 | Effect on Immediate Data 16\|32 |
| :---: | :---: | :---: |
| 0 | None | None |
|  | Sign-Extend Data8 to Fill 16-Bit or 32-Bit Destination | None |

## ENCODING OF CONDITIONAL TEST (tttn) FIELD

For the conditional instructions (conditional jumps and set on condition), tt (n is encoded with n indicating to use the condition $(n=0)$ or its negation $(n=1)$, and ttt giving the condition to test.

| Mnemonic | Condition | tttn |
| :--- | :--- | :--- |
| O | Overflow | 0000 |
| NO | No Overflow | 0001 |
| B/NAE | Below/Not Above or Equal | 0010 |
| NB/AE | Not Below/Above or Equal | 0011 |
| E/Z | Equal/Zero | 0100 |
| NE/NZ | Not Equal/Not Zero | 0101 |
| BE/NA | Below or Equal/Not Above | 0110 |
| NBE/A | Not Below or Equal/Above | 0111 |
| S | Sign | 1000 |
| NS | Not Sign | 1001 |
| P/PE | Parity/Parity Even | 1010 |
| NP/PO | Not Parity/Parity Odd | 1011 |
| L/NGE | Less Than/Not Greater or Equal | 1100 |
| NL/GE | Not Less Than/Greater or Equal | 1101 |
| LE/NG | Less Than or Equal/Greater Than | 1110 |
| NLE/G | Not Less or Equal/Greater Than | 1111 |

## ENCODING OF CONTROL OR DEBUG REGISTER (eee) FIELD

For the loading and storing of the Control and Debug registers.

When Interpreted as Control Register Field

| eee Code | Reg Name |
| :---: | :---: |
| 000 | CR0 |
| 010 | Reserved |
| 011 | Reserved |
| Do not use any other encoding |  |

When Interpreted as Debug Register Field

| eee Code | Reg Name |
| :---: | :---: |
| 000 | DR0 |
| 001 | DR1 |
| 010 | DR2 |
| 011 | DR3 |
| 110 | DR6 |
| 111 | DR7 |
| Do not use any other encoding |  |

### 9.0 REVISION HISTORY

The sections significantly revised since version -003 are:

## Section $1.0 \quad$ Added $\overline{\text { FLT }}$ pin.

Section 4.4 Added description of FLOAT operation and ONCE Mode. Figure 4.20 is new.
Section 4.6 Added revision identifier information for change to CHMOS IV manufacturing process.
Section 5.0 Both packages now specified for $0^{\circ} \mathrm{C}-115^{\circ} \mathrm{C}$ case temperature operation. Thermal resistance values changed.
Section 6.3 ICC Max. specifications changed from 400 mA (cold) and 360 mA (hot) to 275 mA (cold, 16 MHz ) and 305 mA (cold, 20 MHz ).
Section 6.4 HLDA Valid Delay, $\mathrm{t}_{14}$, min. changed from 6 ns to 4 ns . Added 20 MHz A.C. specifications in Table 6.5. Replaced Capacitive Derating Curves in Figures 6.8-6.10 to reflect new manufacturing process. Replaced Icc vs. Frequency data (Figure 6.11) to reflect new specifications.

The sections significantly revised since version -002 are:
Section $1.0 \quad$ Modified table 1.1. to list pins in alphabetical order.
The sections significantly revised since version -001 are:
Section $2.0 \quad$ Figure 2.0 was updated to show the 16 -bit registers SI, DI, BP and SP.
Section 2.1 Figure 2.2 was updated to show the correct bit polarity for bit 4 in the CRO register.
Section 2.1 Tables 2.1 and 2.2 were updated to include additional information on the EFLAGs and CRO registers.
Section 2.3 Figure 2.3 was updated to more accurately reflect the addressing mechanism of the 80376.
Section $2.6 \quad$ In the subsection Maskable Interrupt a paragraph was added to describe the effect of interrupt gates on the IF EFLAGs bit.
Section 2.8 Table 2.7 was updated to reflect the correct power up condition of the CRO register.
Section 2.10 Figure 2.6 was updated to show the correct bit positions of the BT, BS and BD bits in the DR6 register.
Section 3.0 Figure 3.1 was updated to clearly show the address calculation process.
Section 3.2 The subsection DESCRIPTORS was elaborated upon to clearly define the relationship between the linear address space and physical address space of the 80376.
Section 3.2 Figures 3.3 and 3.4 were updated to show the AVL bit field.
Section 3.3 The last sentence in the first paragraph of subsection PROTECTION AND I/O PERMISSION BIT MAP was deleted. This was an incorrect statement.
Section 4.1 In the Subsection ADDRESS BUS (BHE, BLE, $\mathbf{A}_{23}-\mathrm{A}_{1}$ last sentence in the first paragraph was updated to reflect the numerics operand addresses as 8000 FCH and 8000 FEH . Because the 80376 sometimes does a double word I/O access a second access to 8000FEH can be seen.
Section 4.1 The Subsection Hold Lantencies was updated to describe how 32-bit and unaligned accesses are internally locked but do not assert the LOCK signal.
Section 4.2 Table 4.6 was updated to show the correct active data bits during a $\overline{B L E}$ assertion.

### 9.0 REVISION HISTORY (Continued)

| Section 4.4 | This section was updated to correctly reflect the pipelining of the address and status of the 80376 as opposed to "Address Pipelining" which occurs on processors such as the 80286. |
| :---: | :---: |
| Section 4.6 | Table 4.7 was updated to show the correct Revision number, 05H. |
| Section 4.7 | Table 4.8 was updated to show the numerics operand register 8000FEH. This address is seen when the 80376 does a DWORD operation to the port address 8000FCH. |
| Section 5.0 | In the first paragraph the case temperatures were updated to reflect the $0^{\circ} \mathrm{C}-115^{\circ} \mathrm{C}$ for the ceramic package and $0^{\circ} \mathrm{C}-110^{\circ} \mathrm{C}$ for the plastic package. |
| Section 6.2 | Table 6.2 was updated to reflect the Case Temperature under Bias specification of $-65^{\circ}$ $120^{\circ} \mathrm{C}$. |
| Section 6.4 | Figure 6.8 vertical axis was updated to reflect "Output Valid Delay (ns)". |
| Section 6.4 | Figure 6.11 was updated to show typical ICC vs Frequency for the 80376. |
| Section 8.1 | The clock counts and opcodes for various instructions were updated to their correct values. |
| Section 8.2 | The |

## Intel $387^{\text {TM }}$ SX MATH COPROCESSOR

\author{

- New Automatic Power Management - Low Power Consumption <br> - Typically 100 mA in Dynamic Mode, and 4 mA in Idle Mode <br> Socket Compatible with Intel387 Family of Math CoProcessors <br> - Hardware and Software Compatible <br> - Supported by Over 2100 Commercial Software Packages <br> - 10\% to 15\% Performance Increase on Whetstone and Livermore Benchmarks
}

■ Compatible with the Intel386TM SX Microprocessor

- Extends CPU Instruction Set to Include Trigonometric, Logarithmic, and Exponential
- High Performance 80-Bit Internal Architecture
- Implements ANSI/IEEE Standard 754-1985 for Binary Floating-Point Arithmetic
a Available in a 68-Pin PLCC Package
See Intel Packaging Specification, Order \# 231369
The Intel387TM SX Math CoProcessor is an extension to the Intel386TM SX microprocessor architecture. The combination of the Intel387TM SX with the Intel386TM SX microprocessor dramatically increases the processing speed of computer application software that utilizes high performance floating-point operations. An internal Power Management Unit enables the Intel387TM SX to perform these floating-point operations while maintaining very low power consumption for portable and desktop applications. The internal Power Management Unit effectively reduces power consumption by $95 \%$ when the device is idle.

The Intel387TM SX Math CoProcessor is available in a 68 -pin PLCC package, and is manufactured on Intel's advanced 1.0 micron CHMOS IV technology.


240225-22

Intel386 and Intel387 are trademarks of Intel Corporation.

## 82355 <br> BUS MASTER INTERFACE CONTROLLER (BMIC)

Designed for use in 32-Bit EISA Bus Master Expansion Board Designs - Integrates Three Interfaces (EISA, Local CPU, and Transfer Buffer)
Supports 16- and 32-Bit Burst Transfers - 33 Mbytes/Sec Maximum Data Transfers
Supports 32-Bit Non-Burst and Mismatched Data Size Transfers

- Supports 32-Bit EISA Addressability (4 Gigabyte)
- Two independent Data Transfer Channels with 24-Byte FIFOs - Expansion Board Timing and EISA Timing Operate Asynchronously
- Supports Peek/Poke Operation with the Ability to Access Individual Locations in EISA Memory or I/O space
- Automatically Handles Misaligned Doubleword Data Transfers with No Performance Penalty
- Supports Automatic Handling of Complete EISA Bus Master Protocol
- EISA Arbitration/Preemption
- Cycle Timing and Execution
- Byte Alignment
- 1K Boundary Detection
- Supports Local Data Transfer Protocol Similar to Traditional DMA
- Supports a General Purpose Command and Status Interface
- Local and EISA System Interrupt Support
- General Purpose Information Transfers
- Set-and-Test-Functions in I/O Space (Semaphore Function)
- Supports the EISA Expansion Board ID Function
■ Supports Decode of Slot Specific and General I/O Addresses
- 132-Pin JEDEC PQFP Package
(See Packaging Specification Order \#240800, Package Type NG)



# 82370 <br> INTEGRATED SYSTEM PERIPHERAL 

- High Performance 32-Bit DMA Controller for 16-Bit Bus
- 16 MBytes/Sec Maximum Data Transfer Rate at 16 MHz
- 8 Independently Programmable Channels
20-Source Interrupt Controller
- Individually Programmable Interrupt Vectors
- 15 External, 5 Internal Interrupts
- 82C59A Superset

Four 16-Bit Programmable Interval Timers

- 82C54 Compatible

Software Compatible to $\mathbf{8 2 3 8 0}$

- Programmable Wait State Generator - 0 to 15 Wait States Pipelined - 1 to 16 Wait States Non-Pipelined
- DRAM Refresh Controller

■ 80376 Shutdown Detect and Reset Control

- Software/Hardware Reset

■ High Speed CHMOS III Technology

- 100-Pin Plastic Quad Flat-Pack Package and 132-Pin Pin Grid Array Package
(See Packaging Handbook Order \#240800-001, Package Type NG or Package Type A)
- Optimized for Use with the 80376 Microprocessor
- Resides on Local Bus for Maximum Bus Bandwidth
- 16 MHz Clock

The 82370 is a multi-function support peripheral that integrates system functions necessary in an 80376 environment. It has eight channels of high performance 32-bit DMA (32-bit internal, 16-bit external) with the most efficient transfer rates possible on the 80376 bus. System support peripherals integrated into the 82370 provide Interrupt Control, Timers, Wait State generation, DRAM Refresh Control, and System Reset logic.

The 82370's DMA Controller can transfer data between devices of different data path widths using a single channel. Each DMA channel operates independently in any of several modes. Each channel has a temporary data storage register for handling non-aligned data without the need for external alignment logic.


## 82596DX AND 82596SX HIGH-PERFORMANCE 32-BIT LOCAL AREA NETWORK COPROCESSOR

```
- Performs Complete CSMA/CD Medium Access Control (MAC) FunctionsIndependently of CPU — IEEE 802.3 (EOC) Frame Delimiting — HDLC Frame Delimiting
- Supports Industry Standard LANs - IEEE TYPE 10BASE-T (TPE), IEEE TYPE 10BASE5 (Ethernet*), IEEE TYPE 10BASE2 (Cheapernet), IEEE TYPE 1BASE5 (StarLAN), and the Proposed Standard TYPE 10BASE-F
- Proprietary CSMA/CD Networks Up to \(20 \mathrm{Mb} / \mathrm{s}\)
- On-Chip Memory Management
- Automatic Buffer Chaining
- Buffer Reclamation after Receipt of Bad Frames; Optional Save Bad Frames
- 32-Bit Segmented or Linear (Flat) Memory Addressing Formats
- 82586 Software Compatible
- Optimized CPU Interface
- 82596DX Bus Interface Optimized to Intel's 32-Bit i386TMDX
- 82596SX Bus Interface Optimized to Intel's 16-Bit i386TMSX
- Supports Big Endian and Little Endian Byte Ordering
```

■ High-Performance 16-/32-Bit Bus Master Interface

- 66-MB/s Bus Bandwidth
- 33-MHz Clock, Two Clocks Per Transfer
- Bus Throttle Timers
- Transfers Data at 100\% of Serial Bandwidth
- 128-Byte Receive FIFO, 64-Byte Transmit FIFO
- Network Management and Diagnostics - Monitor Mode
— 32-Bit Statistical Counters
- Self-Test Diagnostics
- Configurable Initialization Root for Data Structures
■ High-Speed, 5-V, CHMOS** IV Technology
- 132-Pin Plastic Quad Flat Pack (PQFP) and PGA Package
(See Packaging Specifications Order Number: 240800-001, Package Type KU and A)
i386TM is a trademark of Intel Corporation
*Ethernet is a registered trademark of Xerox Corporation. ${ }^{* *}$ CHMOS is a patented process of Intel Corporation.


Figure 1. 82596DX/SX Block Diagram

# i376 ${ }^{\text {TM }}$ Processor Development Tools 

* 


## INTEL386TM AND INTEL486TM FAMILY DEVELOPMENT SUPPORT



280808-1
COMPREHENSIVE DEVELOPMENT SUPPORT FOR THE INTEL386TM AND INTEL486TM FAMILIES OF MICROPROCESSORS
The perfect complement to the Intel $386{ }^{\mathrm{TM}}$ and i 486 TM microprocessor family is a comprehensive development solution. Intel provides a complete, synergistic hardware and software development toolset, that delivers full access to the power of the Intel386 and i486 microprocessor family architectures.
Intel development tools are easy to use, yet powerful, with an up-date user interface and productivity boosting features such as symbolic debugging. Each tool is designed to help move your application from the lab to the market.
If what interests you is getting the best product to market in as little time as possible, Intel is the choice.

## FEATURES

- Comprehensive support for the full 32 bit Intel386 and Intel486 microprocessor architectures-includes protected mode, 4 gigabyte physical memory addressing, and Intel486 microprocessor on-chip cache and numerics
- In-circuit emulators provide a standard windowed interface that is common across Intel debug tools and architectures
- Emulators also feature a source line display and symbolics to allow debugging in the context of the original program
- Intel high-level languages provide architectural extensions for manipulating hardware directly without assembly language routines
- Languages provide a common object code format (Intel OMF $386{ }^{\text {TM }}$ ) that supports symbolic debug and permits the intermixing of modules written in various languages
- ROM-able code is output directly from the language tools, significantly reducing the effort necessary to integrate software into the final target system
- Extensive support for the Intel family of math coprocessors
- Operation in DOS IBM PC AT and PS/2 Model 60 and 80, running DOS.


Figure 1: Intel Microprocessor Development Environment

## ASM-386/486 MACRO ASSEMBLER

Intel's ASM 386 macro assembler for the Intel386 and Intel486 Families offers many features normally found only in high-level languages. The macro facility in ASM 386 saves development time by allowing common program sequences to be coded only once. The assembly language is strongly typed, performing extensive checks on the usage of variables and labels.
Other Intel ASM 386 features include:

- "High-level" assembler mnemonics to simplify the language
- Structures and records for data representation
- Support for Intel's standard object code format for source-level symbolic debug, and for linking object modules from other Intel386 and Intel486 microprocessor languages
- Full support for processor and math coprocessor instruction sets
- A "MOD486" switch for support of the 1486 microprocessor instructions
- 16 bit or 32 bit address overrides
- Supports development for Virtual 86, Real, 286 Protected, and 386 Protected modes


## iC386/486 COMPILER

Intel's iC-386 compiler combines the power of $C$ programming language with special features for architectural support and code efficiency. The compiler produces code for Intel 386 and Intel486 processors from C source files, and conforms to the 1989 ANSI standard (ANS X3.159-1989) for the C programming language.
Key Intel iC-386 features include:

- Controls to tailor the compilation for each step of your application development process
- In-line versions of many ANSI-standard library functions
- Expanded memory support (LIM Version 3.0 and higher) for large applications
- Object code (including supplied run-time libraries) suitable for ROM
- Three different levels of optimization
- A choice of three segmentation memory models (small, compact, and flat) to create compact and efficient code
- In-line processor-specific functions and timesaving macros that provide access to the special features of the Intel386 and Intel486 processors
- In-line floating-point instructions for the Intel 387 TM numerics coprocessor and Intel486 processor floating-point unit
- Time-saving macros and functions to help assembly language routines interface with Intel's high-level programming languages
- The standard C run-time library plus libraries for floating-point support and the iRMX ${ }^{\circledR}$ III C interface library
- An easy interface to Intel's non-C programming languages
- Support for source-level debugging
- Programming with subsystems, allowing mixed segmentation memory models
- Extensions to the 1989 ANSI C standard for compatibility with previous versions Intel C
- Fast and efficient functions for common programming tasks


## PL/M-386/486 COMPILER

Intel's PL/M-386 is a structured high-level system implementation language for the Intel386 and Intel486 Families. PL/M-386 supports the implementation of protected operating system software by providing builtin procedures and variables to access the Intel386 and Intel486 architectures. For efficient code generation, PL/M-386 features four levels of optimization, a virtual symbol table, and four models of program size and memory usage.

Other Intel PL/M-386 features include:

- The ability to define a procedure as an interrupt handler as well as facilities for generating interrupts
- Direct support of input and output from microprocessor ports
- Upward compatibility with Intel PL/M-86 and PL/M-286 source code
- A "MOD486" compiler switch for Intel486 microprocessor instruction generation
PL/M-386 combines the benefits of a high-level language with the ability to access the Intel386 and Intel 486 architectures. For the development of systems software, PL/M-386 is a costeffective alternative to assembly language programming.


## FORTRAN-386/486 COMPILER

Intel's FORTRAN-386 compiler is a crosscompiler that supports the entire Intel386 family of components and Intel486 microprocessors (when operating in the 386 chip mode) microprocessors.
FORTRAN-386 features high-level support for floating-point calculations, transcendentals, interrupt procedures, and run-time exception handling. FORTRAN-386 meets the ANSI FORTRAN-77 language subset specification and supports extensions endorsed by the Department of Defense (DOD), extensions that support programs written for the ANSI FORTRAN 66 standard, and extensions that support the Intel386 microprocessor and related numerics coprocessors.
To aid in the development and debugging process, the compiler generates warning and error messages and an optional listing file. The listing file can include symbol cross-reference tables and a listing of the generated Intel386 microprocessor assembly-language
instructions. Library routines are reentrant and ROMable.

Other Intel FORTRAN-386 compiler features include:

- Object code can be configured to reside in either RAM or ROM
- The program code can be optimized for execution speed or memory size
- Source-level debugging is supported via the rich symbolics provided in the object module format (Intel OMF386)
- Support for the proposed REALMATH IEEE floating point standard


## RLL-386/486 RELOCATION, LINKAGE, AND LIBRARY TOOLS

The RLL $386^{T M}$ relocation, linkage, and library tools feature comprehensive support of the full Intel 386 and Intel 486 architectures. The tools link separate modules, build object libraries, link in Intel 387 support, build tasks to execute under protected mode, or multitasking, memory protected software. RLL-386 supports loadable, linkable, and bootloadable Intel object module formats; and supports all segmentation models. RLL-386 consists of the following:
Binder - for linking multiple object modules into a single program and resolving references between modules.
Builder - for producing absolute object modules, assigning addresses, and creating protected mode data structures.
Librarian - for creating and maintaining libraries of object modules.

## EMUL-387, NUM-387 NUMERICS SUPPORT LIBRARIES

Intel's EMUL-387 and NUM-387 Numerics Libraries fully support the Intel387TM, Intel 387 DX, Intel 387 SX math coprocessors and the Intel486 internal numerics unit-whether an actual math coprocessor is used in the final system or not.
For Intel386 microprocessor based applications without a math coprocessor, EMUL-387, a numerics software emulator, will execute instructions as though the coprocessor were present. Its functionality is identical to that of the math coprocessor. It is ideal for prototyping and debugging floating-point application software independent of hardware. Further, this permits portability of application code regardless of the presence of math coprocessor hardware in target systems.
For applications with a math coprocessor, NUM-387 numerics support library provides Intel's ASM 386, C-386, PL/M-386, and FORTRAN-386 language users with enhanced numeric data processing capability. With the library, it is easy for programs to do floating point arithmetic. Programmers can bind in library modules to do trigonometric, logarithmic and other numeric functions.

The user is guaranteed accurate, reliable results for all appropriate inputs.

Intel's NUM-387 support library is a collection of four functionally distinct libraries:

- Common elementary function library routines perform algebraic, logarithmic, exponential, trigonometric, and hyperbolic operations on real and complex numbers, as well as real-to-integer conversions; the routines extend the ranges of the coprocessor instructions
- Initialization library routines set up the numerics processing environment for the Intel386 family of processors with an Intel387, DX, or SX or true software emulator
- Decimal conversion library routines convert floating-point numbers from one Intel387, DX, or SX binary storage format to another, or from ASCII decimal strings to Intel387, DX, or SX binary floating-point format and vice versa
- Exception handling library routines make writing numerics exception handlers easier
All support library modules are in Intel386 microprocessor object module format (Intel OMF-386) so they can be linked with the object output of any Intel language. All routines are reentrant and ROMable.
By using Intel's NUM-387, the user is guaranteed that the numeric software meets industry standard (ANSI/IEEE standard for binary floating point arithmetic, 754-1985) and is portable, thus maintaining software investment.


## DB-386 Software Debugger

Intel's DB-386 is a PC-based software development environment with source-level symbolic debug capabilities for object modules produced by Intel's assembler and high-level language compilers. This software debug environment allows Intel386 microprocessor code to be executed and debugged directly on a Intel386 DX or Intel386 SX microprocessor based PC, without any additional target hardware required. With Intel's standard window'ed human interface, users can focus their efforts on finding bugs rather than spending time learning and manipulating the debug environment.
Other Intel DB-386 features include:

- A run-time interface allows protected-mode Intel386 microprocessor programs to be executed directly on a Intel 386 DX or Intel 386 SX microprocessor based PC
- Drop-down menus make the tool easy to learn for new or casual users. A command line interface is also provided for more complex problems
- Watch windows (which display user-specified variables), trace points, and breakpoints (including fixed, temporary, and conditional) can be set and modified as needed
- The user can browse source and callstacks, observe processor registers, and access watch window variables by either pull down menus or by a single keystroke, using function keys
- The user need not know whether a variable is an unsigned integer, a real, or a structure-the debugger uses the wealth of typing information available in Intel languages to display program variables in their respective type formats
- DB-386 supports the Intel486 microprocessor when operated in the Intel386 microprocessor mode


## Intel386 and Intel486 Family In-Circuit Tools

Intel in-circuit emulators are used in many different debug environments including the design and test of: PC BIOS software and motherboard hardware, Intel386 and Intel486 based single board computers, and application and operating system software for DOS-based, ROM-based, and UNIX-based systems.
The Intel386 and Intel486 In-Circuit Emulators (ICETM) take advantage of exclusive Intel technology to provide accurate emulation for Intel's 80386 SX, 80386 DX, 80376 , and 80486 microprocessors. Special access to internal processor states provides information not available to emulators which simply monitor the external buses. Emulators which do not have access to the internal processor conditions cannot guarantee accurate display of instructions executed by the microprocessor. With an Intel In-circuit Emulator you can be certain that the emulator is displaying accurate execution history, even when executing code from the on-chip cache memory of the Intel486.
The DOS hosted Intel386 DX and Intel386 SX emulators feature a windowed, menu-driven, human interface which provides easy access to the powerful features of these emulators. This makes it easy for novice or infrequent users to get the most out of every debug session. This interface features multiple windows which

FEATURES
allow you to simultaneously view source code, assembly code, memory, trace, variables, and registers. This interface is fully symbolic when used with Intel languages.
All of the emulators feature a combination of powerful and flexible breakpoints. The products use a combination of software breakpoints, hardware breakpoints, and onchip debug registers to provide a rich set of recognition logic. Flexible breakpoints make it possible to set breakpoints on instruction execution and/or any possible bus event.
Trace filtering provides the ability to select the information captured in the trace buffer. ICE-386 SX allows capture of solely bus cycle information or both bus cycle and execution information. In addition, the ICE-386 DX can filter wait-state information from the trace buffer. ICE-486 provides the most flexible trace collection by allowing capture of information by any combination of bus cycle type including filtering of wait states, by instructions only, or by both bus cycles and instructions.
Other features of Intel emulators include:

- Unparalleled support of the Intel386 and Intel486 architectures, notably the native protected mode
- Emulation at clock speeds to 33 MHz , and full featured trigger and trace capabilities
- The Intel386 family emulators are convertible using removable probes to support the 80386 DX and 80386 SX microprocessors. The Intel486 processor is also supported via a product upgrade.


## Relocatable Expanded Memory

Designed to enhance your existing ICE-486 and the ICD-486 debugger (REM486 is included with ICE-486 and an option for ICD-486). This optional relocatable expansion memory board adds 2 Mbyte of memory which the ICE or ICD can use in place of memory on the user target board.

## ONCETM-386 and Transmuter Adapters

If you have a surface mount Intel386 SX microprocessor design using 100-pin PQFP parts, Intel ICE emulators have on-circuit emulation (ONCETM) capability. With surface mounted components, the ICE-386 SX emulator cabling clamps over the part, tristating the component, and allowing the emulator to operate. This allows you to debug manufactured boards without resoldering. For early target load development, a transmuter adapter can be used. The transmuter provides a better connection technique for debugging systems where the adapter cable will have to be attached and removed many times (like in prototype development).

## ICD-486 In-Circuit Debugger

The ICD-486 In-circuit Debugger provides a low-cost alternative for full speed in-target Intel486 development. ICD-486 implements a subset of ICE functionality including: symbolic debugging, debug of high-speed cached applications, software and debug register breakpoints, and in-circuit operation.

## Worldwide Service, Support, and Training

To augment its developing tools, Intel offers field application engineering expertise, hotline technical support, and on-site service.
Intel also offers Software Support which includes technical software information, automatic distributions of software and documentation updates, $i C O M M E N T S$ publication, remote diagnostic software, and development tools troubleshooting guide.
Intel's 90-day Hardware Support package includes technical hardware information, telephone support, warranty on parts, labor, material, and on-site hardware support.
Intel Development Tools also offers a 30-day, money-back guarantee to customers who are not satisfied after purchasing any Intel development tool.

FEATURES

## PRODUCT SUPPORT MATRIX

| Product | Component |  |  | Host |
| :--- | :---: | :---: | :---: | :---: |
|  | i486 | $\mathbf{3 8 6}$ <br> DX | $\mathbf{3 8 6}$ <br> SX | DOS <br> 3.x and 5.0 |
|  | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| iC-386 Compiler | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| PL/M-386 Compiler | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| FORTRAN-386 Compiler | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| RLL-386 Relocation, <br> Linkage, Library, Support <br> Tools | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| NUM-387 Libraries | $\checkmark$ |  |  |  |
| EMUL-387 Libraries | NA | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| In-Circuit Emulators | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| In-Circuit Debugger | $\checkmark$ |  |  | $\checkmark$ |
| DB-386 Software Debugger | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |

## ORDERING INFORMATION

## 386TM/i486TM FAMILY DOS HOSTED DEVELOPMENT KIT ORDER CODES

## Software Order Codes

All software supports 386 and 486 microprocessor families except where indicated.

| DKIT386C | Compiler Software <br>  <br>  <br>  <br> Development Kit (See <br> following content list). |
| :--- | :--- |

D86ASM386NL ASM macro assembler for PC-DOS systems.
D86C386NL DOS resident, ANSI standard (ANS X3.159-1989) C compiler.
D86PLM386NL DOS resident PL/M compiler.
D86FOR386NL DOS resident Fortan Compiler.

D86RLL386NL DOS resident software development package. Contains Binder (for linking separately compiled modules), a Builder (for configuring protected multi-tasking systems), a cross reference Mapper, and a Librarian. Use this tool in conjunction with Intel's 80386 compilers and macro assembler.
DB386 DOS S/W debugger.
The Intel Basic Software Development Kit for the DOS hosted environment includes:
iC386 compiler
ASM386 assembler
RLL386 relocation linker and locator
NUM387 numerics library
EMUL387 math coprocessor emulator library
DB386 software debugger
OMF386LOAD loader development object module format documentation

## ORDERING INFORMATION

## IN-CIRCUIT TOOL ORDER CODES

All In-circuit emulator codes include: control unit, power supply, processor module, StandAlone Self Test board, bus Isolation Board, and DOS host software and serial interface cable.
ICE386SX25V ICE-386 SX In-circuit emulator for the Intel386 SX component to 25 MHz .
pICE386SX20D ICE-386 SX In-circuit emulator for the 80386 SX component to 20 MHz .
pICE386DX25DZ ICE-386 DX In-circuit emulator for the 80386 DX component to 25 MHz .

ICE386DX33D ICE-386 DX In-circuit emulator for the 80386 DX component to 33 MHz .
ICD48650D In-circuit debugger for the 80486 microprocessor to 50 MHz .
pICE48633DZ ICE-486 In-circuit emulator for the 80486 component to 33 MHz .

TOICE386SX20D Converts ICE-386 DX to ICE-386 SX 20 MHz .
TOICE386DX25D Converts ICE-386 SX to ICE-386 DX 20 MHz .

TOICE48633D Converts ICE-386 SX or ICE-386 DX to ICE-486 33 MHz .

## ADDITIONAL TOOL ORDER CODES

386SXONCE Kit
REM486A
100 pin PQFP to 132 pin PGA adaptor kit.
2 Mbyte relocatable expansion memory option for ICD-486 (included with ICE-486).
To order your Intel Development Tool product, for more information, or for the number of your nearest sales office or distributor, call 800-874-6835 (North America). For literature on other Intel products call 800-548-4725 (North America). Outside of North America, please contact your local Intel sales office or distributor for more information.

ICE CONVERSION KITS
KBASECONC Converts ICE-486 to ICE376, ICE-386 SX, or ICE-386 DX.

KBASECONV Converts ICE-386 SX or ICE-386 DX to ICE-486.

## TRANS $186 \rightarrow 376$ ASSEMBLY CODE TRANSLATOR



To Order TRANS $186 \rightarrow 376$
Software, contact your
local Intel sales office

## TRANS $186 \rightarrow 376$ PRESERVES YOUR PROGRAMMING

 INVESTMENTWhen your embedded application outgrows the 80C186 family, TRANS $186 \rightarrow 376$ is ready to help you upgrade to the 376 TM Embedded Processor. TRANS $186 \rightarrow 376$ is a DOS-based tool to automate the translation of Intel ASM86 source code to ASM386 source code. This program can actually help protect the man-years of investment in your original 86 software.

## TRANS $186 \rightarrow 376$ LOWERS THE 32-BIT BARRIER

TRANS $186 \rightarrow 376$ accepts 16 -bit source code written for any member of the $8086 / 8088$ and $80 \mathrm{C} 186 / 80 \mathrm{C} 188$ families. The output source code, with its 32 -bit offsets, is suitable for Protected Mode execution on the 376 Embedded Processor or any 386TM, 386SX, or 486TM microprocessor. The time you save by recycling your software can be applied toward system enhancements.
You control TRANS $186 \rightarrow 376$ operation from either the DOS command line or a control file. Major control switches cover:

- Choice of FLAT model or LARGE16 memory environment
- Redefinition of segments
- Optional 32-bit data declaration

TRANS $186 \rightarrow 376$ translates your routines on a line-by-line basis, converting as much code as possible. Whenever the tool does not have enough information to make conversions, it highlights the code section with messages, alerting you to edit by hand. TRANS $186 \rightarrow 376$ can write the ASM86 source code as comments in the ASM386 source file for side-by-side comparison.

[^20]
## TRANS $186 \rightarrow 376$ ASSEMBLY CODE TRANSLATOR

## TRANS $186 \rightarrow 376$ COMPLEMENTS OTHER DEVELOPMENT TOOLS

Upon request, TRANS $186 \rightarrow 376$ generates a build file for the Intel System Builder, BLD386. This allows you to get your software running with only minimal BLD386 experience. A 72-page manual accompanies the TRANS $186 \rightarrow 376$ tool. The manual coverage includes:

- Practical tips on the overall conversion process
- Initializing the CPU and generating Protected Mode data structures
- Producing code for emulators and debuggers

Your 80C186 experience can release the power of the 376 Embedded Processor with the TRANS $186 \rightarrow 376$ Assembly Language Translator as your partner.
System requirements: PC AT* or compatible computer with PC-DOS* or MS-DOS** operating system version 3.0 or later, hard disk, and 512K RAM.

## CAN 82527 Data Sheet

# 82527 <br> SERIAL COMMUNICATIONS CONTROLLER CONTROLLER AREA NETWORK PROTOCOL <br> Automotive 

- Supports CAN Specification 2.0
- Standard Data and Remote Frames
- Extended Data and Remote Frames
- Programmable Global Mask
- Standard Message Identifier
- Extended Message Identifier

15 Message Objects of 8-Byte Data Length

- 14 Tx/Rx Buffers
- 1 Rx Buffer with Programmable Mask

Flexible CPU Interface
-8-Bit Multiplexed

- 16-Bit Multiplexed
-8-Bit Non-Multiplexed (Synchronous/Asynchronous)
- Serial Interface

The 82527 serial communications controller is a highly integrated device that performs serial communication according to the CAN protocol. It performs all serial communication functions such as transmission and reception of messages, message filtering, transmit search, and interrupt search with minimal interaction from the host microcontroller, or CP.U.

The 82527 is Intel's first device to support the standard and extended message frames in CAN Specification 2.0 Part B. It has the capability to transmit, receive, and perform message filtering on extended message frames. Due to the backwardly compatible nature of CAN Specification 2.0, the 82527 also fully supports the standard message frames in CAN Specification 2.0 Part A.

The 82527 features a powerful CPU interface that offers flexibility to directly interface to many different CPUs. It can be configured to interface with CPUs using an 8-bit multiplexed, 16-bit multiplexed, or 8-bit non-multiplexed address/data bus for Intel and non-Intel architectures. A flexible serial interface is also available when a parallel CPU interface is not required.

The 82527 provides storage for 15 message objects of 8 -byte data length. Each message object can be configured as either transmit or receive except for the last message object. The last message object is a receive-only buffer with a special mask design to allow select groups of different message identifiers to be received.

The 82527 also implements a global masking feature for message filtering. This feature allows the user to globally mask any identifier bits of the incoming message. The programmable global mask can be used for both standard and extended messages.
The 82527 offers hardware, or pinout, compatibility with the 82526. It is pin-to-pin compatible with the 82526 except for pins 9,30 , and 44. These pins are used as chip selects on the 82526 and are used as CPU interface mode selection pins on the 82527.
The 82527 is fabricated using Intel's reliable CHMOS III 5 V technology and is available in a 44-lead PLCC for the automotive temperature range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$.

NOTICE:
This is a PREVIEW DATA SHEET. The A.C. and D.C. parameters contained within this data sheet may change after full automotive temperature characterization of the device has been performed. Contact your local sales office before finalizing the Timing and D.C. characteristics of a design to verify you have the latest information.


272250-1
Figure 1. 82527 Block Diagram


Figure 2. 44-Pin PLCC Package

## PIN DESCRIPTION

The 82527 pins are described in this section. Table 1 presents the legend for interpreting the pin types.
Table 1. Pin Type Legend

| Symbol | Description |
| :---: | :--- |
| I | Input only pin |
| O | Output only pin |
| I/O | Pin can be either input or output |

PIN DESCRIPTIONS

| Pin \# | Pin Name | Pin Type | Pin Description |
| :---: | :---: | :---: | :---: |
| 23 | $\mathrm{V}_{\text {SS1 }}$ | Ground | GROUND connection must be shorted externally to a $V_{S S}$ board plane. Provides digital ground. |
| 20 | $V_{S S 2}$ | Ground | GROUND connection must be shorted externally to a VSS board plane. Provides ground for analog comparator. |
| 1 | $\mathrm{V}_{\mathrm{CC}}$ | Power | POWER connection must be shorted externally to +5 V DC. Provides power for entire device. |
| 18 | XTAL1 | 1 | Input for an external clock. XTAL1 (along with XTAL2) are the crystal connections to an internal oscillator. |
| 19 | XTAL2 | 0 | Push-pull output from the internal oscillator. XTAL2 (along with XTAL1) are the crystal connections to an internal oscillator. If an external oscillator is used XTAL2 must be floated, or not be connected. XTAL2 must not be used as a clock output to drive other CPUs. |
| 27 | CLKOUT | 0 | Programmable clock output. This output may be used to drive the oscillator of the host microcontroller. |
| 29 | RESET \# | 1 | A falling edge (high-to-low) transition causes a hardware reset. |
| 8 | CS\# | 1 | A low level on this pin enables CPU access to the 82527 device. |
| 24 | INT\# $\left(V_{D D} / 2\right)$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | The interrupt pin is an open-drain output to the host microcontroller. $\mathrm{V}_{\mathrm{DD}} / 2$ is the power supply for the ISO low speed physical layer. The function of this pin is determined by the MUX bit in the CPU Interface Register (Address 02H) as follows: $\begin{aligned} & \text { MUX }=1: \operatorname{pin} 24=V_{D D} / 2, \text { pin } 11=\mathbb{I N T} \# \\ & M U X=0: \operatorname{pin} 24=I N T \# \end{aligned}$ |
| $\begin{aligned} & 22 \\ & 21 \end{aligned}$ | $\begin{aligned} & \text { RX0 } \\ & \text { RX1 } \end{aligned}$ | $1$ | Inputs from the CAN bus line(s) to the input comparator. A recessive level is read when RX0 > RX1. A dominant level is read when RX1 > RXO. When the CoBy bit (Bus Configuration register) is programmed as a " 1 ", the input comparator is bypassed and RXO is the CAN bus line input. |
| $\begin{aligned} & 26 \\ & 25 \end{aligned}$ | $\begin{aligned} & \text { TX0 } \\ & \text { TX1 } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Serial data push-pull output to the CAN bus line. During a recessive bit TX0 is high and TX1 is low. During a dominant bit TX0 is low and TX1 is high. |



## ELECTRICAL CHARACTERISTICS

D.C. Characteristics $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| Symbol | Parameter | Min | Max | Conditions |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (All except XTAL1, XTAL2, RXO, RX1) | -0.5V | 0.8 V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (All except XTAL1, XTAL2, RXO, RX1, RESET \#) | 3.0 V | $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |  |
| $\mathrm{V}_{\mathrm{H} 1}$ | Input High Voltage (RESET\#) | 3.0 V | $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage (All Outputs except TX0, TX1) |  | 0.45 V | $\mathrm{l} \mathrm{OL}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (All Outputs except TXO, TX1, CLOCKOUT) | $\mathrm{V}_{\mathrm{CC}}-0.8 \mathrm{~V}$ |  | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {OHR1 }}$ | Output High Voltage (CLOCKOUT) | 0.8 V CC |  | $\mathrm{I}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ |
| lLK | Input Leakage Current |  | $\pm 10 \mu \mathrm{~A}$ | $\mathrm{V}_{\text {SS }}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\text {IN }}$ | PIN Capacitance* |  | 10 pF | $\mathrm{f}_{\text {XTAL }}=1 \mathrm{KHz}$ |
| ICC | Supply Current |  | 100 mA | $\mathrm{f}_{\mathrm{XTAL}}=16 \mathrm{MHz}$ |
| Isteep | Sleep Current with $V_{D D} / 2$ Output Enabled, No Load with $\mathrm{V}_{\mathrm{DD}}$ /2 Output Disabled | $\begin{aligned} & 700 \mu \mathrm{~A} \\ & 100 \mu \mathrm{~A} \\ & \hline \end{aligned}$ |  |  |
| IPD | Powerdown Current XTAL1 Driven | $10 \mu \mathrm{~A}$ |  |  |

[^21]PHYSICAL LAYER SPECIFICATIONS Load Condition: 100 pF
D.C. Characteristics $V_{C C}=5 \mathrm{~V} \pm 10 \% ; T_{A}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| RX0/RX1 | Min | Max | Conditions |
| :---: | :---: | :---: | :---: |
| Input Voltage | -0.5V | $\mathrm{V}_{C C}+0.5 \mathrm{~V}$ |  |
| Common Mode Range | $\mathrm{V}_{S S}+1 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{CC}}-1 \mathrm{~V}$ |  |
| Delay Dominant to Recessive |  | 35 ns | -100 mV to +100 mV differential |
| Delay Recessive to Dominant |  | 35 ns | +100 mV to -100 mV differential |
| Differential Input Threshold |  | $\pm 100 \mathrm{mV}$ |  |
| If the comparator is bypassed by setting the CoBy bit to one in the Bus Configuration Register, the Input Delay is: |  | 10 ns |  |
| TX0/TX1 |  |  |  |
| Source Current on Each TX0, TX1 | $-10 \mathrm{~mA}$ |  | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}-1.0 \mathrm{~V}$ |
| Sink Current on Each TX0, TX1 | 10 mA |  | $\mathrm{V}_{\text {OUT }}=1.0 \mathrm{~V}$ |
| Rise Time |  | 25 ns | $\mathrm{C}_{\text {LOAD }}=100 \mathrm{pF}$ |
| Fall Time |  | 25 ns | $\mathrm{C}_{\text {LOAD }}=100 \mathrm{pF}$ |
| $V_{D D} / 2$ |  |  |  |
| $\mathrm{V}_{\mathrm{DD}} / 2$ | 2.38 V | 2.62 V | $\mathrm{l}_{\text {OUT }} \leq 75 \mu \mathrm{~A}, \mathrm{~V}_{\text {CC }}=5 \mathrm{~V}$ |

## CLOCKOUT SPECIFICATIONS

Load Condition: 50 pF

| Parameter | Min | Max |
| :---: | :---: | :---: |
| CLOCKOUT Frequency | XTAL/15 | XTAL |

A.C. Characteristics for $\mathbf{8 / 1 6 - B i t ~ M u l t i p l e x e d ~ I n t e l ~ M o d e s ~ ( M o d e s ~} \mathbf{0}, 1$ )

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

| Symbol | Parameter | Min | Max |
| :---: | :---: | :---: | :---: |
| $1 /$ K $_{\text {XTAL }}$ | Oscillator Frequency | 8 MHz | 16 MHz |
| 1/tsCLK | System Clock Frequency | 4 MHz | 10 MHz |
| 1/tMCLK | Memory Clock Frequency | 2 MHz | 5 MHz |
| $t_{\text {AVLL }}$ | Address Valid to ALE Low | 33 ns |  |
| tLLAX | Address Hold after ALE Low | 22.5 ns |  |
| $t_{\text {RHDZ }}$ | Data Float after RD\# High | 0 ns | 45 ns |
| tridv | RD\# Low to Data Valid (Only for Registers 02H, 04H, 05H) | 0 ns | 45 ns |
| $\mathrm{t}_{\text {RLRH }}$ | RD \# Pulse Width <br> This time is long enough to initiate a double read cycle by loading the High Speed Registers ( 04 H , 05 H ), but is too short to READ from 04 H and 05 H (See tridv) | 40 ns |  |
| $\mathrm{t}_{\text {RLY }}$ | RD \# Low to READY High (for registers except 02H, 04H, 05H) for Read Cycle without a Previous Write for Read Cycle with a Previous Write |  | $\begin{aligned} & 2 \text { t}_{\text {MCLK }}+145 \mathrm{~ns} \\ & 4 \mathrm{~m}_{\text {MCLK }}+145 \mathrm{~ns} \end{aligned}$ |
| tavwh | Data Setup to WR\# High | 30 ns |  |
| ${ }^{\text {twhax }}$ | Input Data Hold after WR \# High | 20 ns |  |
| twHDV | WR \# High to Output Data Valid on Port 1/2 | $\mathrm{t}_{\text {MCLK }}$ | $2 \mathrm{t}_{\text {MCLK }}+100 \mathrm{~ns}$ |
| $t_{\text {WHLH }}$ | WR\# High to Next ALE High | 0 ns |  |
| twLWH | WR \# Pulse Width | 40 ns |  |
| tLHLL | ALE High Time | 30 ns |  |
| tclyv | CS \# Low to READY Setup <br> Condition: Load Capacitance on the READY <br> Output: 50 pF |  | 32 ns |
| ${ }^{\text {tWLYH }}$ | WR \# Low to READY High for a Write Cycle if No Previous Write is Pending |  | 145 ns |
| ${ }^{\text {tWHYH }}$ | End of Last Write to READY High for a Write Cycle if a Previous Write Cycle is Active | $3 \mathrm{t}_{\text {MCLK }}+145 \mathrm{~ns}$ | $4 \mathrm{t}_{\text {MCLK }}+145 \mathrm{~ns}$ |
| tLLRL | ALE Low to RD\# Low | 0 ns |  |

A.C. Characteristics for 8/16-Bit Multiplexed Intel Modes (Modes 0, 1)


## A.C. Characteristics for 8/16-Bit Multiplexed Intel Modes (Modes 0, 1)



Ready Output Timing for a Write Cycle if a Previous Write Cycle is Active


A.C. Characteristics for 8-Bit Multiplexed Non-Intel Mode (Mode 2)

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

| Symbol | Parameter | Min | Max |
| :---: | :---: | :---: | :---: |
| 1/txtal | Oscillator Frequency | 8 MHz | 16 MHz |
| $1 / \mathrm{t}$ SCLK | System Clock Frequency | 4 MHz | 10 MHz |
| $1 /{ }_{\text {m M LK }}$ | Memory Clock Frequency | 2 MHz | 5 MHz |
| $t_{\text {AVSL }}$ | Address Valid to AS Low | 33 ns |  |
| tsLAX | Address Hold after AS Low | 22.5 ns |  |
| teldz | Data Float after E Low | 0 ns | 45 ns |
| $t_{\text {EHDV }}$ | E High to Data Valid | 0 ns | 45 ns |
|  | for Read Cycle without a Previous Write for Ready Cycle with a Previous Write (for Registers except for 02H, 04H, 05H) |  | $\begin{aligned} & 2 \text { t }_{\text {MCLK }}+145 \mathrm{~ns} \\ & 4 \text { t }_{\text {MCLK }}+145 \mathrm{~ns} \end{aligned}$ |
| $t_{\text {QVEL }}$ | Data Setup to E Low | 30 ns |  |
| telox | Input Data Hold after E Low | 20 ns |  |
| telov | E Low to Output Data Valid on Port 1/2 | $\mathrm{t}_{\text {MCLK }}+100 \mathrm{~ns}$ | $2 \mathrm{t}_{\text {MCLK }}+100 \mathrm{~ns}$ |
| tehel | E High Time (only for Registers 02H, 04H, 05H) | 45 ns |  |
|  | for Write Cycle with Previous Write (for Registers except for 02H, 04H, 05H) | $4 \mathrm{t}_{\text {MCLK }}+145 \mathrm{~ns}$ |  |
| tshSL | AS High Time | 30 ns |  |
| $t_{\text {RSEH }}$ | Setup Time of R/W \# to E High | 30 ns |  |
| tsLEH | AS Low to E High | 0 ns |  |

A.C. Characteristics for 8-Bit Multiplexed Non-Intel Mode (Mode 2) (Continued)


## A.C. Characteristics for 8-Bit Non-Multiplexed Asynchronous (Mode 3)

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

| Symbol | Parameter | Min | Max |
| :---: | :---: | :---: | :---: |
| $1 / t_{\text {XTAL }}$ | Osciliator Frequency | 8 MHz | 16 MHz |
| $1 /{ }^{\text {SCLK }}$ | System Clock Frequency | 4 MHz | 10 MHz |
| 1/tMCLK | Memory Clock Frequency | 2 MHz | 5 MHz |
| $\mathrm{t}_{\text {AVCL }}$ | Address or R/W \# Valid to CS \# Low Setup | 3 ns |  |
| tclov | CS\# Low to Data Valid for High Speed Registers (02H, 04H, 05H) | 0 ns | 65 ns |
|  | For Low Speed Registers (Read Cycle without Previous Write) | 0 ns | $2 \mathrm{t}_{\text {MCLK }}+145 \mathrm{~ns}$ |
|  | For Low Speed Registers (Read Cycle with Previous Write) | 0 ns | $4 \mathrm{t}_{\text {MCLK }}+145 \mathrm{~ns}$ |
| tKLDV | DSACKO\# Low to Output Data Valid | $<0 \mathrm{~ns}$ | 23 ns |
| tCHDV | 82527 Input Data Hold after CS \# High | 25 ns |  |
| $\mathrm{t}_{\text {CHDH }}$ | 82527 Output Data Hold after CS\# High | 0 ns |  |
| $\mathrm{t}_{\text {CHDZ }}$ | CS \# High to Output Data Float | 0 ns | 35 ns |
| $\mathrm{t}_{\text {CHKH }}$ | CS \# High to DSACKO\# $=\mathrm{V}_{1 \mathrm{H}}$ (with $3.3 \mathrm{~K} \Omega$ Pullup and 100 pF Load) | 0 ns | 55 ns |
| $\mathrm{t}_{\text {CHKZ }}$ | CS\# High to DSACKO\# Float | 0 ns | 100 ns |
| $\mathrm{t}_{\mathrm{CHCL}}$ | CS\# Width between Successive Cycles | 25 ns |  |
| $\mathrm{t}_{\mathrm{CHAI}}$ | CS \# High to Address or R/W\# Invalid | 5 ns |  |
| telch | CS\# Width Low | 65 ns |  |
| $t_{\text {DVCH }}$ | CPU Write Data Valid to CS\# High | 32 ns |  |
| ${ }_{\text {t CLKL }}$ | CS\# Low to DSACKO \# Low for High Speed Registers and Low Speed Registers Write Access without Previous Write | 0 ns | 65 ns |
|  | for Write Access with a Previous Write | 0 ns | $2 \mathrm{t}_{\text {MCLK }}+145 \mathrm{~ns}$ |

A.C. Characteristics for 8-Bit Non-Multiplexed Asynchronous (Mode 3) (Continued)

A.C. Characteristics for 8-Bit Non-Multiplexed Asynchronous (Mode 3)


## A.C. Characteristics for 8-Bit Non-Multiplexed Synchronous Mode (Mode 3)

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$, $\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

| Symbol | Parameter | Min | Max |
| :---: | :---: | :---: | :---: |
| 1/t ${ }_{\text {XTAL }}$ | Oscillator Frequency | 8 MHz | 16 MHz |
| 1/tsCLK | System Clock Frequency | 4 MHz | 10 MHz |
| 1/tMCLK | Memory Clock Frequency | 2 MHz | 5 MHz |
| tehdv | E High to Data Valid out of High Speed Register (02H, 04H, 05H) |  | 65 ns |
|  | Read Cycle without Previous Write for Low Speed Registers |  | $2 \mathrm{t}_{\text {MCLK }}+145 \mathrm{~ns}$ |
|  | Read Cycle with Previous Write for Low Speed Registers |  | $4 \mathrm{t}_{\text {MCLK }}+145 \mathrm{~ns}$ |
| $t_{\text {ELD }}$ | Data Hold after E Low for a Read Cycle | 5 ns |  |
| teLDZ | Data Float after E Low | 0 ns | 35 ns |
| telov | Data Hold after E Low for a Write Cycle | 25 ns |  |
| $\mathrm{t}_{\text {AVEH }}$ | Address and R/W\# to E Setup | 25 ns |  |
| telav | Address and R/W \# Valid after E Falls | 15 ns |  |
| tcver | CS\# Valid to E High | 0 ns |  |
| telcv | CS \# Valid after E Low | 0 ns |  |
| $\mathrm{t}_{\text {DVEL }}$ | Data Setup to E Low | 55 ns |  |
| $\mathrm{t}_{\text {EHEL }}$ | E Active Width | 100 ns |  |
| $t_{\text {AVAL }}$ | Start of a Write Cycle after a Previous Write Access | 2 tmalk |  |

## A.C. Characteristics for 8-Bit Non-Multiplexed Synchronous Mode (Mode 3)



## A.C. Characteristics for 8-Bit Non-Multiplexed Synchronous Mode (Mode 3)



## A.C. Characteristics for Serial Interface Mode

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.

| Symbol | Parameter | Min | Max |
| :---: | :---: | :---: | :---: |
| SCLK | SPI Clock | 0.5 MHz | 4.2 MHz |
| $\mathrm{t}_{\mathrm{CYC}}$ | 1/SCLK | 238 ns | 2000 ns |
| tSKHI | Minimum Clock High Time | 119 ns |  |
| tSKLO | Minimum Clock Low Time | 119 ns |  |
| tead | ENABLE Lead Time | 70 ns |  |
| tLAG | Enable Lag Time | 109 ns |  |
| $t_{\text {ACC }}$ | Access Time |  | 60 ns |
| tpDo | Maximum Data Out Delay Time |  | 84 ns |
| $\mathrm{t}_{\mathrm{HO}}$ | Minimum Data Out Hold Time | 0 ns |  |
| tois | Maximum Data Out Disable Time |  | 665 ns |
| tsetup | Minimum Data Setup Time | 59 ns |  |
| thold | Minimum Data Hold Time | 109 ns |  |
| $t_{\text {RISE }}$ | Maximum Time for Input to go from $V_{O L}$ to $V_{\mathrm{OH}}$ |  | 100 ns |
| $t_{\text {FALL }}$ | Maximum Time for Input to go from $\mathrm{V}_{\mathrm{OH}}$ to $\mathrm{V}_{\mathrm{OL}}$ |  | 100 ns |
| $\mathrm{t}_{\mathrm{CS}}$ | Minimum Time between Consecutive CS\# Assertions | 670 ns |  |

## A.C. Characteristics for Serial Interface Mode




## A.C. TESTING INPUT



## NOTE:

AC Inputs during testing are driven at $\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$ for a Logic " 1 " and 0.1 V for a Logic " 0 ". Timing measurements are made at $\mathrm{V}_{\mathrm{IH}}$ Min for a Logic " 1 " and $\mathrm{V}_{\mathrm{OL}}$ Max for a Logic " 0 ".

## CAN 82527 Development Tool

## intel

## EV82527 EVALUATION KIT



The EV82527 evaluation kit demonstrates the capabilities of the 82527 serial communications controller and the Controller Area Network (CAN) protocol. This evaluation kit represents a quick approach to learning the features of the 82527 device and CAN Specification 2.0 29-bit message identifiers.

## DESCRIPTION

The EV82527 evaluation kit features the 82527 device and the CAN protocol, Specification 2.0. The 82527 device implements CAN Specification 2.0 and is optimized to allow the host microcontroller to remain dedicated to its application control function. The host microcontroller interface to the 82527 is analogous to that of a RAM. The transmission, reception and error confinement routines are hardwired in the 82527 and are transparent to the user.

## FEATURES

The EV82527 evaluation kit consists of three boards: an EV87C196KR motherboard, an 82527 daughterboard and a DV82527 satellite board, plus a software
monitor that assembles $\mathrm{MCS}^{\circledR}-96$ code online.

- The motherboard is a fully functional evaluation board which contains the host microcontroller, the Intel 87C196KR.
- The daughterboard is configured with an RS-485 CAN bus interface and can be easily adapted to other physical layer implementations.
- The daughterboard communicates with a DV82527 satellite board acting as an additional network node. The satellite board requires no host-CPU programming and uses dip switches to choose various communication options.


## BENEFITS

- Quick setup and installation
- Interfaces to high performance 16-bit host-CPU


## EV82527 EVALUATION KIT

- Assists the development of CAN application software
- Demonstrates CAN Specification 2.0 protocol and features
- Uses standard Personal Computer host


## 87C196KR MOTHERBOARD

Assembly language programs for the 87C196KR motherboard may be downloaded to the microcontroller and executed. The monitor program has the following features:

- Program loading
- Program disassembly
- In-monitor assembler that allows program to be written on-line
- 16 breakpoints
- Single-stepping
- Specific commands to interrogate 82527 messages and status
The 87 C 916 KR is a powerful 16 -bit microcontroller with high speed I/O, an A/D converter, full duplex serial I/O (synchronous and asynchronous), 768 bytes of RAM and 16 Kbytes of EPROM.


## 82527 DAUGHTERBOARD

The interface between the 82527 CAN device and the 87 C 196 KR microcontroller is completed by connecting the mother and daughterboards together. The 82527 device interfaces to the 87C196KR using either an 8 - or 16 -bit multiplexed address/data bus.
CAN bus communication utilizes the on-board RS-485 interface or connects to a user defined physical interface.

The two 8-bit I/O ports of the 82527 device connect to dip switches or LED displays allowing the user to change or monitor the operation of the 82527 and the 87 C 196 KR devices.

## DV82527 SATELLITE BOARD

The daughterboard connects to a satellite board via a cable serving as the CAN bus. It executes a series of fixed programs which are user-selected dip switches. The satellite board receives and transmits one-byte messages of either 11- or 29-bit message identifier format. Messages may use one of four possible message identifiers. The satellite sends remote frames as well.
The reception and transmission of satellite board messages is monitored on LED displays.

## PERSONAL COMPUTER REQUIREMENTS

The EV82527 evaluation kit is hosted on an IBM PC AT, XT or BIOS-compatible clone. The PC must meet the following requirements:

- 512 Kbytes of memory
- One 1.2 Meg floppy Disk Drive
- MS-DOS 3.0 or later
- A serial (COM1 or COM2) at 9600 baud
- ASM-96, iC-96 or PL/M-96 or any 8096 Assembler/Compiler that generates Object Module Format code
- A text editor such as AEDIT


## NORTH AMERICAN SALES OFFICES

ALABAMA
Intel Corp. Suite 104-1
Huntsville 35802
Tel: (800) 628-8686
FAX: (205) 883-3511
ARIZONA
tintel Corp.
410 North 44th Street Suite 500
Phoenix 85008
Tel: (800) 628-8686
FAX: (602) 244-0446

## CALIFORNIA

Intel Corp.
Sierra Gate Plaza
Suite 280 C
Suite 280 C
Tel: (800) 628-8686
FAX: (916) 782-8153
tintel Corp.
9665 Chesapeake Dr.
Suite 325
San Diego 92123
Tel: (800) 628-8686
FAX: (619) 292-0628
*tIntel Corp.
400 N. Tustin Avenue
Suite 450
Suite 450
Santa Ana 92705
Tel: (800) 628-8686
TWX: 910-595-1114
FAX: (714) 541-9157
*tintel Corp.
San Tomas 4
2700 San Tomas Expressway 2nd Floor
Santa Clara 95051
Tel: (800) 628-8686
TWX: 910-338-0255
tintel Corp.
15260 Ventura Boulevard
Suite 360
Sherman Oaks 91403
Tel: (800) 628-8686
FAX: (818) 995-6624
COLORADO
*tintel Corp.
600 S. Cherry St.
Suite 700
Denver 80222
Tel: (800) 628-8686
TWX: 910-931-2289
FAX: (303) 322-8670

## CONNECTICUT

tintel Corp.
103 Mill Plain Road
Danbury 06811
Tel: (800) 628-8686
FAX: (203) 794-0339

## FLORIDA

$\dagger$ Intel Corp.
800 Fairway Drive
Suite 160
Deerfield Beach 33441
Tel: (800) 628-8686
FAX: (305) 421-2444
$\dagger$ Intel Corp.
5850 T.G. Lee Blvd.
Suite 340
Orlando 32822
Tel: (800) 628-8686
FAX: (407) 240-8097
georgia
tintel Corp.
20 Technology Parkway
Suite 150
Norcross 30092
FAX. (404) 605
ILLINOIS

* Intel Corp.

Woodfield Corp. Center III
300 N. Martingale Road
Suite 400
Schaumburg 60173
FAX: (708) 706-9762

## INDIANA

tintel Corp.
8910 Purdue Road
Suite 350
Indianapolis 46268
Tel: (800) 628-8686
FAX: (317) 875-8938

## MARYLAND

* Intei Corp.

10010 Junction Dr.
Suite 200
Annapolis Junction 20701
Tel: (800) 628-8686
FAX: (410) 206-3678

## MASSACHUSETTS

*+Intel Corp.
Westtord Corp. Center
5 Carisisle Road
2nd Floor
Westford 01886
Tel: (800) 628-8686
TWX: 710-343-6333
FAX: (508) 692-7867

## MICHIGAN

tintel Corp.
7071 Orchard Lake Road
Suite 100
West Bloomfield 48322
Tel: (800) 628-8686
FAX: (313) 851-8770

## MINNESOTA

tintel Corp.
3500 W. 80th St.
Suite 360
Bloomington 55431
Tel: (800) 628-8686
TWX: 910-576-2867
FAX: (612) 831-6497
NEW JERSEY

* $\dagger$ Intel Corp.

Lincroft Office Center
125 Half Mile Road
Red Bank 07701
Tel: (800) 628-8686
FAX: (908) 747-0983

## NEW YORK

*Intel Corp.
850 Crosskeys Office Park
Fairport 14450
Tel: (800) 628-8686
TWX: 510-253-7391
FAX: (716) 223-2561
*tintel Corp.
2950 Express Dr., South
Suite 130
Isiandia 11722
Tel: (800) 628-8686
TWX: 510-227-6236
FAX: (516) 348-7939
tintel Corp.
300 Westage Business Center
Suite 230
Tel: (800) 628-8686
FAX: (\$14) 897-3125

## OHIO

*tIntel Corp.
3401 Park Center Drive
Suite 220
Dayton 45414
Tel: (800) 628-8686
TWX: 810-450-2528
FAX: (513) 890-8658
*Intel Corp.
Four Commerce Park Square
23200 Chagrin Blvd., Suite 600
Beachwood 44122
Tel: (800) 628-8686
OKLAHOMA
Intel Corp.
6801 N. Broadway
Suite 115
Oklahoma City 73162
Tel. (800)
FAX: (405) 840-9819

## OREGON

tintel Corp.
15254 N.W. Greenbrier Pkwy.
Building B
Beaverton 97006
Tel: (800) 628-8686
TWX: 910-467-8741
FAX: (503) 645-8181

## PENNSYLVANIA

*tintel Corp.
925 Harvest Drive
Sulte 200
Blue Bell 19422
Tel: (800) 628-8686
FAX: (215) 641-0785

* $\dagger$ Intel Corp.

400 Penn Center Blva
Suite 610
Plttsburgh 15235
Tel: (800) 628-8686
FAX: (412) 829-7578
SOUTH CAROLINA
Intel Corp.
100 Executive Center Drive
Suite 109, 8183
Greenville 29615
Tel: (800) 628-8686
FAX: (803) 297-3401

## TEXAS

tintel Corp.
8911 N. Capital of Texas Hwy.
Suite 4230
Austin 78759
Tel: (800) 628-8686
FAX: (512) 338-9335
*tintel Corp.
12000 Ford Road
Suite 400
Dallas 75234
Tel: (800) 628-8686
FAX: (214) 484-1180
*†Intel Corp.
20515 SH 249
Suite 401
Suite 401
Houston 77070
Tel: (800) 628-8686
TWX: 910 -881-2490
FAX: (713) 988-3660
UTAH
tintel Corp.
428 East 6400 South
Suite 104
Murray 84107
Tel: (800) 628-8686
FAX: (801) 268-1457
WASHINGTON
†Intel Corp.
2800 156th Avenue S.E
Suite 105
Bellevue 98007
Tel: (800) 628-8686
FAX: (206) 746-4495
Intel Corp.
408 N. Mullan Road
Suite 105
Spokane 99206
Tel: (800) 628-8686
FAX: (509) 928-9467
WISCONSIN
Intel Corp.
400 N. Executive Dr.
Suite 401
Brookfield 53005
Tel: (800) 628-8686
FAX: (414) 789-2746

## CANADA

BRITISH COLUMBIA
Intel Semiconductor of
Canada, Ltd.
999 Canada Place
Suite 404, \#11
Vancouver V6C 3E2
Tel: (800) 628-8686
FAX: (604) 844-2813

## ONTARIO

tintel Semiconductor of
Canada, Ltd.
2650 Queensview Drive
Suite 250
Ottawa K2B 8 H 6
FAX: (613) 820-593
tintel Semiconductor of
Canada, Ltd.
190 Attwell Drive
Suite 500
Rexdale M9W 6 H 8
Tel: (800) 628-8686
FAX: (416) 675-2438

## QUEBEC

tintel Semiconductor of
Canada, Ltd.
1 Rue Holiday
Suite 115
Tour East
Pt. Claire H9R 5N3
Tel: (800) 628-8686
FAX: 514-694-0064

ALABAMA
Arrow/Schweber Electronics
1015 Henderson Road
Huntsville 35816
Tel: (205) 837-6955
FAX: (205) 895-0126
Hamilton/Avnet
4960 Corporate Drive, \#135
Huntsville 35805
Tel: (205) 837-7210
FAX: (205) 830-8404
MTI Systems Sales
4950 Corporate Dr., \#120
Huntsville 35805
Tel: (205) 830-9526
FAX: (205) 830-9557
Pioneer Technologies Group 4835 University Square, \#5 Huntsville 35816
Tel: (205) 837-9300
FAX: (205) 837-9358

## ARIZONA

Arrow/Schweber Electronics
2415 W. Erie Drive
Tempe 85282
Tel: (602) 431-0030
FAX: (602) 431-9555
Avnet Computer
1626 S. Edwards Drive
Tempe 85281
Tel: (602) 902-4642
FAX: (602) 902-4646
Hamilton/Avnet
1626 S . Edwards Drive
Tempe 85281
Tel: (602) 902-4700
FAX: (602) 902-4747
Wyle Laboratories
Phoenix 85040
Tel: (602) 437-2088
FAX: (602) 437-2124

## CALIFORNIA

Arrow Commercial Systems Group
1502 Crocker Avenue
Hayward 94544
Tel: (510) 489-5371
FAX: (510) 391-1742
Arrow Commercial Systems Group 14242 Chambers Road
Tustin 92680
Tel: (714) 544-0200
Arrow/Schweber Electronics
26707 W. Agoura Road
Calabasas 91302
Tel: (818) 880-9686
FAX: (818) 880-4687
Arrow/Schweber Electronics
9511 Ridgehaven Court
San Diego 92123
Tel: (619) 565-4800
FAX: (619) 279-0862
Arrow/Schweber Electronics
1180 Murphy Avenue
San Jose 95131
Tel: (408) 441-9700
FAX: (408) 453-4810
Arrow/Schweber Electronics
48834 Kato Rd., Suite 103
Fremont 94538
Tel: (510) 440-2681
FAX: (510) 490-1084
Arrow/Schweber Electronics
6 Cromwell, Suite 100
Irvine 92718
FAX: (714) 454-420
Avnet Computer
3170 Pullman Street
Costa Mesa 92626
FAX: (714) 641-4170

NORTH AMERICAN DISTRIBUTORS

Avnet Computer
1361 B West 190th Street
Gardena 90248
Tel: (310) 217-6830
FAX: (310) 327-5389
Avnet Computer
1175 Bordeaux Drive
Sunnyvale 94089
Tel: (408) 743-3454
FAX: (408) 743-3348
Hamilton/Avnet
3170 Pullman Street
Costa Mesa 92626
Tel: (714) 641-4182
FAX: $(714) 641-4149$
Hamilton/Avnet
1175 Bordeaux Drive
Sunnyvale 94089
Tel: (408) 743-3300
FAX: (408) 745-6679
Hamilton/Avnet
4545 Viewridge Avenue
San Diego 92123
Tel: (619) 571-7540
FAX: (619) 277-6136
Hamilton/Avnet
21150 Califa St.
Woodland Hills 91367
Tel: (818) 594-0404
FAX: (818) 594-8233
Hamilton/Avnet
755 Sunrise Avenue, \#150
Roseville 95661
Tel: (916) 925-2216
FAX: (916) 925-3478
Pioneer Technologies Group
134 Rio Robles
San Jose 95134
Tel: (408) 954-9100
FAX: (408) 954-9113
Pioneer Standard
217 Technology Dr., \#110
Irvine 92718
Tel: (714) 753-5090
FAX: (714) 753-5074
Pioneer Standard
5850 Canoga Ave., \#400
Woodland Hills 91367
Tel: (818) 883-4640
FAX: (818) 883-9721
Wyle Laboratories
2951 Sunrise Blva., \#175
Rancho Cordova 95742
Tel: (916) 638-5282
FAX: (916) 638-1491
Wyle Laboratories
9525 Chesapeake Drive
San Diego 92123
Tel: (619) 565-9171
FAX: (619) 365-0512
Wyle Laboratories
3000 Bowers Avenue
Santa Clara 95051
Tel: (408) 727-2500
FAX: (408) 727.7359
Wyle Laboratories
17872 Cowan Avenue
Irvine 92714
Tel: (714) 863-9953
FAX: (714) 251-0365
Wyle Laboratories
26010 Mureau Road, \#150
Calabasas 91302
Tel: (818) 880-9000

## COLORADO

Arrow/Schweber Electronics
61 Inverness Dr. East, \#105
Englewood 80112
FAX: (303) 799-4303
Hamilton/Avnet
9605 Maroon Circle, \#200
Englewood 80112
Tel: (303) 799-7800
FAX: (303) 799-7801

Wyle Laboratories
451 E. 124th Avenue
Thornton 80241
Tel: (303) 457-9953
CONNECTICUT
Arrow/Schweber Electronics
12 Beaumont Road
Wallingford 06492
Tel: (203) 265-7741
FAX: (203) 265-7988
Avnet Computer
55 Federal Road, \#103
Danbury 06810
FAX: (203) 791-2896
Hamilton/Avnet
55 Federal Road, \#103
Danbury 06810
Tel: (203) 743-9799
FAX: (203) 797-0373
Pioneer-Standard
2 Trap Falls Rd., \#101
Shelton 06484
FAX:- (203) 929

## FLORIDA

Arrow/Schweber Electronics
400 Fainway Drive \#102
Deerfield Beach 33441
Tel: (305) 429-8200
FAX: (305) 428-3991
Arrow/Schweber Electronics
37 Skyline Drive, \#3101
Lake Mary 32746
Tel: (407) 333-9300
FAX: (407) 333-9320
Avnet Computer
541 S. Orlando Ave., \#203
Maitlan 32751
Tel: (407) 539-2888
FAX: (407) 539-2085
Hamilton/Avnet
5371 N.W. 33rd Ave., \#204
Ft. Lauderdale 33309
Tel: (305) 733-6300
FAX: (305) 484-8369
Hamilton/Avnet
3247 Tech Drive
St. Petersburg 35805
Tel: (813) 573-4346
FAX: (813) 572-0833
Hamilton/Avnet
7079 University Boulevard
Winter Park 32792
Tel: (407) 657-3300
FAX: (407) 678-4414
Pioneer Technologies Group
337 Northlake Blvd., \#1000
Alta Monte Springs 32701
FAX: (407) 834-080
Pioneer Technologies Group
674 S. Military Trail
Deerfield Beach 33442
Tel: (305) 428-8877
FAX: (305) 481-2950

## GEORGIA

Arrow Commercial Systems Group
3400 C. Corporate Way
Duluth 30136
Tel: (404) 623-8825
FAX: (404) 623-8802
Arrow/Schweber Electronics
4250 E. Rivergreen Pkwy., \#E
Duluth 30136
FAX: (404) 476-1400
Avnet Computer
3425 Corporate Way, \#G
Duluth 30136
Tel: (404) 623-5400
FAX: (404) 476-0125

Hamilton/Avnet
3425 Corporate Way, \#G
Duluth 30136
Tel: (404) 623-5475
FAX: (404) 623-5490
Pioneer Technologies Group
4250 C. Rivergreen Parkway
Duluth 30136
Tel: (404) 623-1003
FAX: (404) 623-0665

## ILLINOIS

Arrow/Schweber Electronics
1140 W. Thorndale Rd.
Itasca 60143
Tel: (708) 250-0500
FAX: 708-250-0916
Avnet Computer
1124 Thorndale Avenue
Bensenville 60106
Tel: (708) 860-8573
FAX: (708) 773-7978
Hamilton/Avnet
1130 Thorndale Avenue
Bensenville 60106
Tel: (708) $860-7700$
FAX: (708) 860-8532
MTI Systems
1140 W. Thorndale Avenue
Itasca 60143
Tel: (708) 250-8222
FAX: (708) 250-8275
Pioneer-Standard
2171 Executive Dr., \#200
Addison 60101
Tel: (708) 495-9680
FAX: (708) 495-9831

## INDIANA

Arrow/Schweber Electronics
7108 Lakeview Parkway West Dr.
Indianapolis 46268
Tel: (317) 299-2071
FAX: (317) 299-2379
Avnet Computer
655 W. Carmel Dr., \#120
Carmel 46032
Tel: (317) 575-8029
FAX: (317) 844-4964

## Hamilton/Avnet

485 Gradle Drive
Carmel 46032
Tel: (317) 844-9533
FAX: (317) 844-5921
Pioneer-Standard
9350 Priority Way West Dr.
Indianapolis 46250
Tel: (317) 573-0880
FAX: (317) 573-0979

## IOWA

Hamilton/Avnet
2335A Blairsferry Rd., N.E.
Cedar Rapids 52402
Tel: (319) 362-4757
FAX: (319) 393-7050

## KANSAS

Arrow/Schweber Electronics
9801 Legler Road
enexa 66219
FAX: (913) 752

Avnet Computer
15313 W. 95th Street
15313 W. 95th
Tel: (913) 541-7989
FAX: (913) 541-7904

## Hamilton/Avnet

15313 W. 95th Street
Overland Park 66215
Tel: (913) 888-1055
FAX: (913) 541-7951

NORTH AMERICAN DISTRIBUTORS (Contd.)

## KENTUCKY

Hamilton/Avnet 1847 Mercer Rd., \#G
eexington 40511 FAX: (606) 288-4936

## MARYLAND

Arrow/Schweber Electronics
9800J Patuxent Woods Dr.
Columbia 21046
Tel: (301) 596-7800
FAX: (301) 596-7821
Arrow Commercial Systems Group
200 Perry Parkway
Gaithersburg 20877
FAX: (301) 670-0188
Avnet Computer
7172 Columbia Gateway Dr.
Columbia 21046
Tel: (301) 995-3571
FAX: (301) 995-3515

## Hamilton/Avnet

7172 Columbia Gateway Dr., \#F
Columbia 21046
Tel: (301) 995-3554
FAX: (301) 995-3553
*North Atlantic Industries
Systems Division
7125 River Wood Dr.
Columbia 21046
Tel: (301) 312-5800
FAX: (301) 312-5850
Pioneer Technologies Group
9100 Gaither Road
Gaithersburg 20877
Tel: (301) 921-0660
FAX: (301) 921-4255

## MASSACHUSETTS

Arrow Commercial Systems Group
250 Upton Drive
Wimington 01887
Tel: (508) 658-7100
FAX: (508) 658-0977
Arrow/Schweber Electronics
25 Upton Dr.
Wilmington 01887
Tel: (508) 658-0900
FAX: (508) 694-1754
Avnet Computer
10 D Centennial Drive
Peabody 01960
FAX: (508) 532-9887
Hamilton/Avnet
10 D Centennial Drive
Peabody 01960
Tel: (508) 531-7430
FAX: (508) 532-9802
Pioneer-Standard
44 Hartwell Avenue
Lexington (617) 861-9200
FAX: (617) 863-1547
Wyle Laboratories
15 Third Avenue
Burlington 01803
Tel: (617) 272-7300
FAX: (617) 272-6809

## MICHIGAN

Arrow/Schweber Electronics
19880 Haggerty Road
Livonia 48152
Tel: (800) 231-7902
FAX: (313) 462-2686
Avnet Computer
41650 Garden Brook Rd. \#120
Novi 48375
Tel: (313) 347-4067
FAX: (313) 347-1820
Hamilton/Avnet
2876 28th Street, S.W., \#5
Grandville 49418
fel: (616) 531-0345
FAX: (616) 531-0059

Hamilton/Avnet
41650 Garden Brook Rd., \#100
Novi 48375
Tel: (313) 347-4270
FAX: (313) 347-402
Pioneer-Standard
13485 Stamford Ct
Livonia 48150
Tel: (313) 525-1800
FAX: (313) 427-3720

## MINNESOTA

Arrow/Schweber Electronics
10100 Viking Drive, \#100
Eden Prairie 55344
Tel: (612) 941-5280
FAX: (612) 829-8007
Avnet Computer
9800 Bren Road, East
Minnetonka 55343
Tel: (612) 829-0025
FAX: (612) 944-0638

## Hamilton/Avnet

9800 Bren Road, East, \#41
Minnetonka 55343
Tel: (612) 932-0600
FAX: (612) 932-0613
Pioneer-Standard
7625 Golden Triange Dr., \#G
Eden Prairie 55344
Tel: (612) 944-3355
FAX: (612) 944-3794

## MISSOURI

Arrow/Schweber Electronics
2380 Schuetz Road
St. Louis 63146
Tel: (314) 567-6888
FAX: (314) 567-1164
Avnet Computer
741 Goddard Avenue
Chesterfield 63005
Tel: (314) 537-2725
FAX: (314) 537-4248

## Hamilton/Avnet

741 Goddard
Chesterfield 63005
Tel: (314) 537-4265
FAX: (314) 537-4248

## NEW HAMPSHIRE

Avnet Computer
2 Executive Park Drive
Bedford 03102
Tel: (800) 442-8638
FAX: (603) 624-2402

## NEW JERSEY

Arrow/Schweber Electronics
4 East Stow Rd., Unit 1 Marlton 08053
Tel: (609) 596-8000
FAX: (609) 596-9632
Arrow/Schweber Electronics
43 Route 46 East
Tel: (201) 227-7880
FAX: (201) 227-2064

## Avnet Computer

1B Keystone Ave., Bldg. 36
Cherry Hill 08003
Tel: (609) 424-8962
FAX: (609) 751-2502
Hamilton/Avnet
1 Keystone Ave., Bidg. 36
1 Keystone Ave., B
Cherry Hill 08003
Tel: (609) 424-0110
FAX: (609) 751-2611
Hamilton/Avnet
10 Lanidex Plaza West
Parsippany 07054 Tel: (201) 515-5300 FAX: (201) 515-1600
MTI Systems Sales
43 US Rt. 46
Pinebrook 07058
Tel: (201) 882-8780
Tel: (201) 882-8780

Pioneer-Standard
14A Madison Rd.
Fairfield 07004
Tel: (201) 575-3510
FAX: (201) 575-3454

## NEW MEXICO

Alliance Electronics, Inc.
10510 Research Ave., SE
Albuquerque 87123
Tel: (505) 292-3360
FAX: (505) 275-6392
Avnet Computer
7801 Academy Rd., SE
Bldg. 1, Suite 204
Albuquerque 87109
Tel: (505) 828-9722
FAX: (505) 828-0364
Hamilton/Avnet
7801 Academy Rd., NE
Bldg. 1, Suite 204
Tel: (505) $828-1058$
FAX: (505) 828-0360

## NEW YORK

Arrow/Schweber Electronics
3375 Brighton Henrietta Townline Rd
Rochester 14623
Tel: (716) 427-0300
FAX: (716) 427-0735
Arrow/Schweber Electronics
20 Oser Avenue
Hauppauge 11788
FAX: (516) 231-107
Avnet Computer
933 Motor Parkw
Hauppauge 11788
Tel: (516) 434-7443
FAX: (516) 434-7459
Avnet Computer
2060 Townline Rd.
Rochester 14623
Tel: (716) 272-9110
FAX: (716) 272-9685
Hamilton/Avnet
933 Motor Parkway
Hauppauge 11788
FAX: (516) 434-7426
Arrow Commercial Systems Group
120 Commerce
Hauppauge 11788
Tel: (516) $231-1175$
FAX: (516) 435-2389
Hamilton/Avnet
2060 Townline Rd.
Rochester 14623
FAX: (716) 475-9119

## Hamilton/Avnet

103 Twin Oaks Drive
Syracuse 13120
Tel: (315) 453-4000
FAX: (315) 453-4010
MTI Systems
1 Penn Plaza
250 W. 34th Street
New York 10119
Tel: (212) 643-1280
FAX: (212) 643-1288
Pioneer-Standard
68 Corporate Drive
Binghamton 13904
Tel: (607) 722-9300
FAX: (607) $722-9562$

## Pioneer-Standard

60 Crossway Park West
Woodbury, Long Island 11797
Tel: (516) 921-8700
FAX: (516) 921-2143
Pioneer-Standard
840 Fairport Park
Fairport 14450
FAX: (716) 381-7070

NORTH CAROLINA
Arrow/Schweber Electronics
5240 Greensdairy Road
5240 Greensdai
Raleigh 27604
Rel: (919) 876-3132
FAX: (919) 878-9517
Avnet Computer
2725 Millbrook Rd., \#123
Raleigh 27604
Tel: (919) 790-1735
FAX: (919) 872-4972
Hamilton/Avnet
5250-77 Center Dr. \#350
Charlotte 28217
Tel: (704) 527-2485
FAX: (704) 527-8058
Hamilton/Avnet
3510 Spring Forest Drive
Raleigh 27604
Tel: (919) 878-0819
FAX: (919) 954-0940
Pioneer Technologies Group 9401 L-Southern Fine Blvd.
9401 L-Southern
Tel: (704) 527-818
FAX: (704) 522-8564
Pioneer Technologies Group
2810 Meridian Parkway, \#148
Durham 27713
Tel: (919) 544-5400
FAX: (919) 544-5885

## OHIO

Arrow Commercial Systems Group
284 Cramer Creek Court
284 Cramer C
Tel: (614) 889-9347
FAX. (614) 889 -9680

Arrow/Schweber Electronics
6573 Cochran Road, \#E
Solon 44139
Tel: (216) 248-3990
FAX: (216) 248-1106
Arrow/Schweber Electronics
8200 Washington Village Dr
Centerville 45458
Tel: (513) 435-5563
FAX: (513) 435-2049
Avnet Computer
7764 Washington Village Dr.
Dayton 45459
Tel: (513) 439-6756
FAX: (513) 439-6719
Avnet Computer
2 Summit Park Dr., \#520
Independence 44131
FAX: (216) 573-7404
Hamilton/Avnet
7760 Washington Village Dr
7760 Washingt
Dayton 45459
Tel: (513) 439-6633
FAX: (513) 439-6711
Hamilton/Avnet
2 Summit Park Dr., \#520
Independence 44131
Tel: (216) 573-7400
FAX: (216) 573-7404
MTI Systems Sales
23404 Commerce Park Rd.
Beachwood 44122
Tel: (216) 464-6688
FAX: (216) 464-3564
Pioneer-Standard
4433 interpoint Boulevard
Dayton 45424
FAX: (513)
Pioneer-Standard
4800 E. 131 st Street
Tel: (216) 587-3600
FAX:- (216) 663-3906

## NORTH AMERICAN DISTRIBUTORS (Contd.)

OKLAHOMA
Arrow/Schweber Electronics 12111 East 51st Street, \#101 Tulsa 74146
FAX: (918) 254
Hamilton/Avnet
12121 E. 51st St., \#102A
Tulsa 74146
Tel: (918) 252-7297
FAX: (918) 250-8763

## OREGON

Almac/Arrow Electronics
1885 N.W. 169th Place, \#106
Beaverton 97006
FAX: (503) 645-061
Arrow Commercial Systems Group
1885 N.W. 169th Place
Beaverton 97006-7312
Tel: (503) 629-8090
FAX: (503) 645-061
Avnet Computer
9150 Southwest Nimbus Ave
Beaverton 97005
FAX: (503)
FAX: (503) 526-6242

## Hamilton/Avnet

9409 Southwest Nimbus Ave
Beaverton 97005
FAX: (503) 641-4012
Wyle Laboratories
9640 Sunshine Court
Bldg. G, Suite 200
Beaverton 97005
Tel: (503) 643-7900
FAX: $(503)$ 646-5466

## PENNSYLVANIA

Avnet Computer
213 Executive Drive, \#320
Mars 16046
Tel: (412) 772-1888 FAX: (412) 772-1890
Hamilton/Avne
213 Executive, \#320
Mars 16046
Tel: (412) 772-1881
FAX: (412) 772-1890
Pioneer-Standard
259 Kappa Drive
Pittsburgh 15238
Tel: (412) 782-2300
FAX: (412) 963-8255
Pioneer Technologies Group
500 Enterprise Road Keith Valley Business Cente Horsham 19044
Tel: (215) 674-4000

## TEXAS

Arrow/Schweber Electronics
3220 Commander Drive
Carrollton 75006
Tel: (214) 380-6464
FAX: (214) 248-7208
Arrow/Schweber Electronics
10899 Kinghurst Dr., \#100
Houston 77099
FAX: (713) 530-4700
FAX: (713) 568-8518
Avnet Computer
4004 Beltline, Suite 200
Dallas 75244
Tel: (214) 308-8168
FAX: (214) 308-8129

Avnet Computer
1235 North Loop West, \#525
Houston 77008
Tel: (713) 867-7580
FAX: (713) 861-6851
Hamilton/Avnet
1826-F Kramer Lane
Austin 78758
FAX: (512) $232-4306$
Hamilton/Avnet
4004 Beltline, Suite 200
Dallas 75244
Tel: (214) 308-8105
FAX: (214) 308-814
Hamilton/Avnet
1235 North Loop West, \#521
Houston 77008
FAX:
Pioneer-Standard
1826D Kramer Lane
Austin 78758
Tel: (512) 835-4000
FAX: (512) 835-9829
Pioneer-Standard
13735 Beta Road
Dallas 75244
Tel: (214) 263-3168
FAX: (214) 490-6419
Pioneer-Standard
10530 Rockley Road, \#100
Houston 77099
Tel: (713) 495-4700
FAX: (713) 495-5642
Wyle Laboratories
1810 Greenville Avenue
Richardson 75081
Tel: (214) 235-9953
FAX: (214) 644-5064
Wyle Laboratories
4030 West Braker Lane, \#420
Austin 78759
Tel: (512) 345-8853
FAX: (512) 345-9330
Wyle Laboratories
11001 South Wilcrest, \#100
Houston 77099
Tel: (713) 879-9953
FAX: (713) 879-4069
UTAH
Arrow/Schweber Electronics
1946 W. Parkway Blvd.
Salt Lake City 84119
Tel: (801) 973-6913
FAX: (801) 972-0200
Avnet Computer
1100 E. 6600 South, \#150
Salt Lake City 84121
Tel: (801) 266-1115
FAX: (801) 266-0362
Hamilton/Avnet
1100 East 6600 South, \#120
Salt Lake City 84121
Tel: (801) 972-2800
FAX: (801) 263-0104
Wyle Laboratories
1325 West 2200 South, \#E
West Valley 84119
Tel: (801) 974-9953
FAX: (801) 972-2524

## WASHINGTON

Almac/Arrow Electronics
14360 S.E. Eastgate Way
Bellevue 98007
Tel: (206) 643-9992
FAX: (206) 643-9709

Arrow Commercial Systems Group 14360 S.E. Eastgate Way
Bellevue 98007
Tel: (206) 643-9992
FAX: (206) 643-9709
Hamilton/Avnet
17761 N.E. 78th Place, \#C
Redmond 98052
Tel: (206) 241-8555
FAX: (206) 241-5472
Avnet Computer
17761 N.E. 78th Place
Redmond 98052
Tel: (206) 867-0160
FAX: (206) 867-0161
Wyle Laboratories
15385 N.E. 90th Street
Redmond 98052
Tel: (206) 881-1150
FAX: (206) 881-1567

## WISCONSIN

Arrow/Schweber Electronics
200 N. Patrick Blvd., \#100
Brookfield 53045
Tel: (414) 792-0150
FAX: (414) 792-0156
Avnet Computer
20875 Crossroads Circle, \#400
Waukesha 53186
Tel: (414) 784-8205
FAX: (414) 784-6006
Hamilton/Avnet
28875 Crossroads Circle, \#400
Waukesha 53186
Tel: (414) 784-4511
FAX: (414) 784-9509
Pioneer-Standard
120 Bishop Way \#163
Brookfield 53005
Tel: (414) 784-3480
FAX: (414) 784-8207

## ALASKA

Avnet Computer
1400 West Benson Blvd., \#400
Anchorage 99503
Tel: (907) 274-9899
FAX: (907) 277-2639

## CANADA

## alberta

Avnet Computer
1081144 29th Ave., NE
Calgary T2E 7P1
Tel: (403) 291-3284
Zentronics
6815 8th Street N.E., \#100
Calgary T2E 7H7
Calgary T2E 7H7
FAX: (403) 295-8714
BRITISH COLUMBIA
Almac-Arrow Electronics
8544 Baxter Place
Burnaby V5A 418
FAX: (604) 421-5030
Hamilton/Avnet
8610 Commerce Court
Burnaby V5A 4N6
Tel: (604) 420-4101
FAX: (604) 420-5376

Zentronics
11400 Bridgeport Rd., \#108
Richmond V6X 1 T2
Tel: (604) 273-5575
FAX: (604) 273-2413

## ONTARIO

Arrow Commercial Systems Group
1093 Meyerside Dr., Unit 2
Mississauga, Ontario
L5T 1M4
Tel: (416) 670-7784
FAX: (416) 670-7781
Arrow/Schweber Electronics
36 Antares Dr., Unit 100
Nepean K2E 7W5
FAX: (613) 226-6903
FAX: (613) 723-2018
Arrow/Schweber Electronics
1093 Meyerside, Unit 2
Mississauga L5T 1M4
Tel: (416) 670-7769
FAX: (416) 670-7781
Avnet Computer
151 Superior Blvd
Mississuaga L5T 2 L1 FAX. (416) 795-3855

Avnet Computer
190 Colonnade Road
Nepean K2E 7 J 5
Tel: (613) 727-2000
FAX: (613) 727-2020
Hamilton/Avnet
151 Superior Blvd.
Tel: (416) 795-3835
FAX: (416) 564-6036
Hamilton/Avnet
190 Colonnade Road
Nepean K2E 7J5
Tel: (613) 226-1700
FAX: (6.13) 226-1184
Zentronics
1355 Meyerside Drive
Mississauga L5T 1C9
Tel: (416) 564-9600
FAX: (416) 564-8320
Zentronics
155 Colonnade Rd., South
Unit 17/18
Nepean K2E 7K1
FAX. (613) 220.6352

## QUEBEC

Arrow/Schweber Electronics
1100 St. Regis Blvd.
Dorval H9P 2 T5
Tel: (514) 421-7411
FAX: (514) 421-7430
Arrow Commercial Systems Group
500 Ave Street Jean Baptiste
Quebec City 2GE 5R9
Tel: (418) 871-7500
FAX: (418) 871-6816
Avnet Computer
2795 Rue Halpern
Tel: (514) 335 -2483
FAX: (514) 335-2490
Hamilton/Avnet
2795 Rue Halpern
St. Laurent H4S 1P8
Tel: (514) 335-1000
FAX: (514) 335-2481
Zentronics
520 McCaffrey Street
St. Laurent H4T 1N1
Tel: (514) 737-9700
FAX: (514) 737-5212

## EUROPEAN SALES OFFICES

FINLAND
Intel Finland OY
00390 Helsink
Tel: (358) 0544644
FAX: (358) 0544030

## FRANCE

Intel Corporation S.A.R.L
1, Rue Edison-BP 303
78054 St. Quentin-en-Yvelines
Cedex
Tel: (33) (1) 30577000
FAX: (33) (1) 30646032

## GERMANY

Intel GmbH
Dornacher Strasse 1
8016 Feldkirchen bei Muenchen Tel: (49) 089/90992-0
FAX: (49) 089/9043948

## ISRAEL

Intel Semiconductor Lid.
Atidim Industrial Park-Neve Sharet P.O. Box 43202

Tel-Aviv 61430
Tel: (972) 03498080
FAX: (972) 03491870

ITALY
Intel Corporation Italia S.p.A Milanofiori Palazzo E 20094 Assago
Milano
Tel: (39) (2) 575441
FAX: (39) (2) 3498464

## NETHERLANDS

Intel Semiconductor B.V.
Postbus 84130
3009 CC Rotterdam
Tel: (31) 104071111
FAX: (31) 104554688

RUSSIA
Intel Technologies, Inc. Krementshugskaya 6/7 21357 Moscow
el: 007-095-4439785
TLX: 612092 smail su.

## SPAIN

Intel Iberia S.A.
Zubaran, 28
28010 Madrid
Tel: (34) (1) 3082552
FAX: (34) (1) 4107570

SWEDEN
Intel Sweden A.B.
Dalvagen 24
Tel: (46) 87055600
FAX: (46) 8278085

## UNITED KINGDOM

Intel Corporation (U.K.) L.td. Pipers Way
Swindon, Wiltshire SN3 1RJ
Tel: (44) (0793) 696000
FAX: (44) (0793) 641440

# EUROPEAN DISTRIBUTORS/REPRESENTATIVES 

## AUSTRIA

$\dagger$ *Bacher Electronics GmbH Rotenmuehlgasse 26
A-1120 Wien
2281356460
FAX: (43) 222834276
BELGIUM
†*inelco Distribution
Avenue des Croix de Guerre 94
1120 Bruxelles
Tel: (32) 22442811
FAX: (32) 22163304
*Diode Belgium
Keiberg II, Minervastraat, 14/B2
1930 Zaventem
FAX: (32) 725

## DENMARK

*Nortec Electronics AS
Transformervej 17
DK-2730 Herlev
Tel: (45) 42842000
FAX: (45) 44921552
$\dagger^{*}$ ITT Multikomponent AS
Naverland 29
TK-2600 Giostrup
Tel: (45) 42456645
$\dagger$ *OY Fintronic AB
Heikkilantie 2a
SF-00210 Helsinki
Tel: (358) 06926022
FAX: (358) 06821251

## FRANCE

*Almex
48, Rue de l'Aubepine B.P. 102

92164 Antony Cedex
FAX: (33) (1) 46666028
*Arrow Electronique
${ }^{73}-79$ Rue des Solets
Silic 585
94663 Rungis Cedex Tel: (33) (1) 49784978 FAX: (33) (1) 49780596
$\dagger$ Metrologie
Tour d'Asnieres
4, Avenue Laurent Cely
Tel: (33) (1) 40809000 FAX: (33) (1) 47910561
*Tekelec
Cite des Bruyeres
5, Rue Carle Vernet-BP 2 92310 Sevres
Tel: (33) (1) 46232425
FAX: (33) (1) 45072191

GERMANY
Electronic 2000 Bauelemente GmbH Stahigruberring 12 8000 Muenchen 82 Tel: (49) $8942110-01$ FAX: (49) 8942110209
*Jermyn GmbH
Im Dachsstueck 9
6250 Limburg
FAX. (49) 643
Metrologie GmbH
Steinerstrasse 15
8000 Muenchen 70
Tel: (49) 89724470
FAX: (49) 8972447111
*Proelectron Vertriebs GmbH Max-Planck-Strasse 1-3 6072 Dreieich
Tel: (49) 6103304343
FAX: (49) 6103304425
$\dagger$ Rein Elektronik GmbH
Loetscher Weg 66
4054 Nettetal 1
Tel: (4) 2153

## GREECE

$\dagger$ Ergodata
Aigiroupoleos 2A
17676 Kalithea
Tel: (30) 19510922
FAX: (30) 19593160
*Pouliadis Associates Corp.
Koumbari Street 5
Kolonaki Square
Tel (30) 136
FAX: (30) 1360741

## IRELAND

$\dagger^{*}$ Micro Marketing
Taney Hall
Eglinton Terrace
Dundrum
Tel: (353) (1) 2989400
FAX: (353) (1) 2989828

## ISRAEL

†*Eastronics Limited
Rozanis 11
P.O.B. 39300

Tel Baruch
Tel-Aviv 61392
Tel: (972) 36458777
FAX: (972) 36458666

ITALY
*intesi Div. Della Deutsche
Divisione ITT Industries GmbH
.I. 06550110156
Milanotiori Palazzo e5
20094 Assago (Milano)
FAX: (39) 2824263
*Lasi Elettronica
P.I. 0083900015

Viale Fulvio Testi, N. 280
20126 Milano
Tel: (39) 2661431
FAX: (39) 266101385
tTelcom
Via Trombetta
20090 Segrate-Milano
Tel: (39) 2216061
FAX: (39) 22138010
NETHERLANDS
$\dagger$ Datelcom
Computerweg 10-16
360 BD Maarsen
Tel: (31) 346595222
FAX: (39) 346571245
*Diode Components
Coltbaan 17
3439 NG Nieuwegein
Tel: (31) 340291234
FAX: (31) 340235924
$\dagger$ *Koning en Hartman
Energieweg 1
2627 AP Delft
Tel: (31) 15609906
FAX: (31) 15619194

## NORWAY

tComputer System Integration A/S
Postbox 198
N-2013 skjetten
Tel: (47) 6845411
*Nortec Electronics A/S
Postboks 123
Smedsvingen 4
$\mathrm{N}-1364$ Hvalstad
Tel: (47) 2846210
FAX: (47) 2846545

## PORTUGAL

*ATD Electronica LDA
Rua dr. Faria de Vasconcelos, 3a 1900 Lisboa
Tel: (351) (1) 8472200
FAX: (351) (1) 8472197
$\dagger$ Metrologia Iberica Portugal Rua Dr. Faria de Vasconcelos 3A 1900 Lisboa
Tel: (351) (1) 8472202
FAX: (351) (1) 8472197

SOUTH AFRICA
†*EBE
PO Box 912-1222
Silverton 0127
178 Erasmus Street
Meyerspark
Tel: (27) $128037680-93$
FAX: (27) 128038294

## SPAIN

ATD Electronica
Avenue de la Industria, 32, 2B
28100 Alcobendas

## Madrid

Tel: (34) (1) 6616551
FAX: (34) (1) 6616300
$\dagger$ Metrologia lberica
Avda. Industria, 32-2
28100 Alcobendas
Madric
Tel: (34) (1) 6611142

## SWEDEN

*ITT Multikomponent AB
Ankdammsgatan 32
Box 1330
S-171 26 Solna
Tel: (46) 8830020
FAX: (46) 8271303
*Nortec Elektronics AB
Box 1830
S-171 27 Solna
Tel: (46) 87051800
FAX: (46) 8836918
$\dagger$ Nortelco AB
Box 184
S-123 23 Farsta
Tel: (46) 87051800
FAX: (46) 87352373

## SWITZERLAND

tIMIC Microcomputer
Zurichstrasse
CH-8185 Winkel-Ruti
Tel: (41) (1) 8620055
†*Industrade A.G.
Hertistrasse 31
$\mathrm{CH}-8304$ Wallisellen
Tel: (41) (1) 8328111
FAX: (41) (1) 8307550

## TURKEY

Empa Electronic
34630 Besyol Londra Asfalti
Florya Is Merkezi Sefakoy
stanbul
Tel: (90) (1) 5993050
FAX: (90) (1) 5985353

UNITED KINGDOM
*Arrow Electronics
St. Martins Business Centre
Cambridge Road
Cambridge Road
Tel: (44) 234270272
FAX: (44) 234211434
*Avnet EMG Ltd
Jubilee House
Jubilee Road
Letchworth
Hertsfordshire - SG6 1QH
FAX• (44) 462488567
*Bytech Components
12a Cedarwood
Chineham Business Park
Crockford Lane
Basingstoke
Hants RG12 1RW
Tel: (44) 256707107
FAX: (44) 256707162
$\dagger$ Bytech Systems
5 The Sterling Centre
Eastern Road
Bracknell
Berks - RG12 2PW
Tel: (44) 34455333
FAX: (44) 344867270
*Jermyn Electronics
Vestry Estate
Otford Road
Sevenoaks
Kent TN14 5EU
Tel: (44) 732743743
FAX: (44) 732451251
$\dagger$ Metrologie VA
Rapid House
Oxford Road
High Wycombe
Bucks - HP11
Bucks - HP11 2E
FAX: (44) 494452144
*MMD/Rapid Ltd.
Rapid Silicon
3 Bennet Court
Bennet Road
Reading
Berks -RG2 0QX
Tel: (44) 734750697
FAX: (44) 734313255

AUSTRALIA
Intel Australia Pty. Ltd.
Unit 13
Allambie Grove Business Park
25 Frenchs Forest Road East
Frenchs Forest, NSW, 2086
Sydney
Tel: 61-2-975-3300
FAX: 61-2-975-3375
Intel Australia Pty. Ltd.
711 High Street
1st Floor
East Kw. Vic., 3102
Melbourne
Tel: 61-3-810-2141
FAX: 61-3-819 7200

## BRAZIL

Intel Semiconductores do Brazil LTDA Avenida Paulista, 1159-CJS 404/405 CEP 01311 - Sao Paulo - S.P
Tel: 55-11-287-5899
FAX: 55-11-287-5119
CHINA/HONG KONG
Intel PRC Corporation
15/F, Office 1, Citic Bldg.
Jian Guo Men Wai Street
Beijing, PRC
Tel: (1) 500-4850
TLX: 22947 INTEL CN
FAX: (1) 500-2953

INTERNATIONAL SALES OFFICES

Intel Semiconductor Ltd.*
10/F East Tower
Bond Center
Queensway, Central
Hong Kong
Tel: (852) 844-4555
FAX: (852) 868-1989

## INDIA

Intel Asia Electronics, Inc
4/2, Samrah Plaza
St. Mark's Road
Bangalore 560001
TLX: : $953-845-2646$ INTEL IN
FAX: $091-812-215067$

## JAPAN

Intel Japan K.K.
5-6 Tokodai, Tsukuba-shi
Ibaraki, 300-26
Tel: 0298-47-851
FAX: 0298-47-8450
Intel Japan K.K.*
Hachioji ON Bldg.
4-7-14 Myojin-machi
Hachioji-shi, Tokyo 192
Tel: 0426-48-8770
FAX: 0426-48-8775

Intel Japan K.K.*
Kawa-asa Bldg.
2-11-5 Shin-Yokohama
Kohoku-ku, Yokohama-shi
Kanagawa, 222
Tel: 045-474-7660
FAX: 045-471-4394
Intel Japan K.K.*
Ryokuchi-Eki Bldg
2-4-1 Terauchi
Toyonaka-shi, Osaka 560
Tel: 06-863-1091
FAX: 06-863-1084
Intel Japan K.K.
Shinmaru Bldg.
1-5-1 Marunouchi
Chiyoda-ku, Tokyo 100
Tel: 03-3201-3621
FAX: 03-3201-6850
intel Japan K.K.*
TK Gotanda Bldg. 9F
8-3-6 Nishi Gotanda
Shinagawa, Tokyo 141
Tel: 03-3493-6081
FAX: 03-3493-5951

KOREA
Intel Korea, Ltd
16th Floor, Life BIdg
61 Yoido-dong, Youngdeungpo-Ku
Seoul 150-010
Tel: (2) 784-8186
FAX: (2) 784-8096

## MEXICO

Intel Technologica de Mexico
S.A. de C.V.

Av. Mexico No. 2798-9B, S.H.
44620 Guadalajara, Jal.
Tel. \& FAX: 523-640-1259

## SINGAPORE

Intel Singapore Technology, Ltd.
101 Thomson Road \#08-03/06
United Square
Tel: (65) 250-781
FAX: (65) 250-9256
TAIWAN
Intel Technology Far East Ltd.
Taiwan Branch Office
8th Floor, No. 205
Bank Tower Bldg.
Tung Hua N. Road
Taipei
Tel: 886-2-5144202
FAX: 886-2-717-2455

## INTERNATIONAL DISTRIBUTORS/REPRESENTATIVES

## ARGENTINA

Dafsys S.R.L.
Chacabuco, 90-6 Piso
1069-Buenos Aires
Tel. \& FAX: 54.1334.1871

## AUSTRALIA

Email Electronics
15-17 Hume Street
Huntingdale, 3166
Tel: 011-61-3-544-8244
TLX: AA 30895
FAX: 011-61-3-543-8179
NSD-Australia
205 Middleborough Rd.
Box Hill, Victoria 3128
FAX. 038990819

## BRAZIL

Microlinear
Largo do Arouche, 24
01219 Sao Paulo, SP
Tel: 5511-220-2215
FAX: 5511-220-5750

## CHILE

Sisteco
Vecinal 40-Las Condes
Santiago
Tel: 562-234-1644
FAX: 562-233-9895

## CHINA/HONG KONG

Novel Precision Machinery Co., Ltd.
Room 728 Trade Square
681 Cheung Sha Wan Road
Tel: (852) $360-8999$
TWX. 32032 NVTN HX
FAX. (852) 725-3695

## GUATEMALA

Abinitio
11 Calle 2-Zona 9
Guatemala City
Tel: 5022-32-4104
FAX: 5022-32-4123

## INDIA

Priya International Limited
D-6, Il Floor
Devatha Plaza, 131/132 Residency Rd.
Bangalore 560025
Tel: (91) 812-214027, 812-214395
FAX: (91) 812-214105

Priya International Limited
Podar Chambers, 4th Floor
109, S.A. Brelvi Road, Fort
Bombay 400001
Tel: (91) 22-2863611, 22-2863676,
22-2863900, 22-2864026
FAX: (91) 22-2619935
Priya International Limited
Flat No. 8, 10th Floo
Akashdeep Building, Barakhamba Rd.
New Delhi 110001
Tel: (91) 11-3314512, 11-3310413
FAX: (91) 11-3719107
FAX: (91) 11-3719107
Priya International Limited
5-J, Century Plaza
560-562 Mount Road, Teynampet
Madras 600018
Tel: (91) 44-451031, 44-451597
Priya International Limited
No. 10, I Floor
Minerva House, 94 Sarojini Devi Rd.
Secunderabad 500003
Tel: (91) 842-70220, 842-77059
SES Computers and Technologies Pvt. Ltd.
14, SNS Chambers
239 Palace Upper Orchards
Sankey Road, Sadashivanagar
S\&S Corporation
1587 Kooser Road
San Jose, CA 95118
Tel: (408) 978-6216
TLX: 820281
FAX: (408) 978-8635

## JAMAICA

MC Systems
10-12 Grenada Crescent
Kingston 5
Tel: (809) 926-0104
FAX: (809) 929-5678

## JAPAN

Asahi Electronics Co. Ltd.
KMM Bldg. 2-14-1 Asano
Kokurakita-ku
Kitakyushu-shi 802
FAX: 093-551-7861
CTC Components Systems Co., Ltd.
4.8-1 Dobashi, Miyamae-ku

Kawasaki-shi, Kanagawa 213
Tel: 044-852-5121
FAX: 044-877-4268

Dia Semicon Systems, Inc.
Flower Hill Shinmachi Higashi-kan
1-23 Shinmachi, Setagaya-ku
Tokyo 154
Tel: 03-3439-1600
FAX: 03-3439-1601
Okaya Koki
2-4-18 Sakae
Naka-ku, Nagoya-shi 460
FAX. 052
Ryoyo Electro Corp.
Konwa Bidg.
1-12-22 Tsukiji
Chuo-ku, Tokyo 104
Tel: 03-3546-5011
FAX: 03-3546-5044

## KOREA

J -Tek Corporation
ong Sung Bldg. 9/F
158-24, Samsung-Dong, Kangnam-Ku
Seoul 135-090
Tel: (822) 557-8039
FAX: (822) 557-8304
Samsung Electronics
Samsung Main Bldg
150 Taepyung-Ro-2KA, Chung-Ku
Seoul 100-102
C.P.O. Box 8780

Tel: (822) 751-3680
TWX: KORSST K 27970
FAX: (822) 753-9065

## mexico

PSI S.A. de C.V
Fco. Villa esq. Ajusco $\mathrm{s} / \mathrm{n}$
Cuernavaca, MOR 62130
Tel: 52-73-11-1994/5

## NEW ZEALAND

Email Electronics
36 Olive Road
Penrose, Auckland
Tel: 011-64-9-591-155
FAX: 011-64-9-592-681

## SAUDI ARABIA

AAE Systems, Inc.
642 N. Pastoria Ave
Sunnyvale, CA 94086
U.S.A.

Tel: (408) 732-1710
FAX: (408) 732-3095
TLX: 494-3405 AAE SYS

## SINGAPORE

Electronic Resources Pte, Ltd.
17 Harvey Road
\#03-01 Singapore 1336
TWX: RS 56541 RR
FAX: (65) 289-5327

SOUTH AFRICA
Electronic Building Elements
178 Erasmus St. (off Watermeyet St.)
178 Erasmus St. (off Waterm
Tel: 011-2712-803-7680
FAX: 011-2712-803-8294

TAIWAN
Micro Electronics Corporation
12th Floor, Section 3
285 Nanking East Road
Taipei, R.O.C.
Tel: (886) 2-7198419
FAX: (886) 2-7197916
Acer Sertek Inc.
15th Floor, Section 2
Chien Kuo North Rd
Thien Kuo North Rd.
Taipei 18479 R.O.C.
TWX: 23756 SERTEK
FAX: (886) 2-5012521

URUGUAY
Interfase
Blvr. Espana 2094
11200 Montevide
Tel: 5982-49-4600
FAX: 5982-49-3040

## VENEZUELA

Unixel C.A.
4 Transversal de Monte Cristo
Edf. AXXA, Piso 1, of. 1\&2
Centro Empresarial Boleita
Caracas
Tel: 582-238-7749
FAX: 582-238-1816

## inted.

UNITED STATES
Intel Corporation
2200 Mission College Boulevard
P.O. Box 58119

Santa Clara, CA 95052-8119
JAPAN
Intel Japan K.K.
5-6 Tokodai, Tsukuba-shi
Ibaraki, 300-26
FRANCE
Intel Corporation S.A.R.L.
1, Rue Edison, BP 303
78054 Saint-Quentin-en-Yvelines Cedex
UNITED KINGDOM
Intel Corporation (U.K.) Ltd.
Pipers Way
Swindon
Wiltshire, England SN3 1RJ
GERMANY
Intel GmbH
Dornacher Strasse 1
8016 Feldkirchen bei Muenchen
HONG KONG
Intel Semiconductor Ltd.
10/F East Tower
Bond Center
Queensway, Central
CANADA
Intel Semiconductor of Canada, Ltd.
190 Attwell Drive, Suite 500
Rexdale, Ontario M9W 6H8

## Embedded Microcontrollers and Processors Vol.II

For 8-bit price performance in an embedded controller, the MCS -51 controller is the popular choice. If you need the performance of 16 bits, the MCS-96 product line or industry standard 186 family may be the answer.

We have combined all of the technical information for these three world-standard architectures into two comprehensive volumes.
These handbooks contain complete product specifications, data sheets and architecture descriptions.
(The i960 microprocessor family information can be found in the $i 750$, i860, i960 Processors \& Related Products handbook.)

## intel

Order Number: 270646-005
ISBN: 1-55512-177-2
Printed in USA/193/36K/RRD DM
Embedded Microcontrollers


[^0]:    *Specifications within these data sheets are subject to change without notice. Verify with your local Intel sales office that you have the latest data sheet before finalizing a design.

[^1]:    Temperature Range:
    ESR (Equivalent Series Resistance):
    $\mathrm{C}_{0}$ (Shunt Capacitance of Crystal):
    $\mathrm{C}_{1}$ (Load Capacitance):
    0 to $70^{\circ} \mathrm{C}$
    $30 \Omega$ max
    7.0 pf max

    Drive Level:
    $20 \mathrm{pf} \pm 2 \mathrm{pf}$
    1 mW max

[^2]:    *For extended temperature parts only.

[^3]:    Timing Waveforms
    Section rearranged to show waveforms on same or facing page relative to corresponding tabular data. TCLSRY drawn to same clock edge as TSRYCL. Drawing changed to indicate one less clock between HOLD inactive and HLDA inactive.
    Specification Level Markings New Section.

[^4]:    Shaded areas indicate instructions not available in 8086/8088 microsystems.

[^5]:    Shaded areas indicate instructions not available in 8086/8088 microsystems.

[^6]:    Shaded areas indicate instructions not available in 8086/8088 microsystems

[^7]:    Shaded areas indicate instructions not available in 8086/8088 microsystems.

[^8]:    Shaded areas indicate instructions not available in 8086/8088 microsystems.

[^9]:    Temperature Range:
    ESR (Equivalent Series Resistance):
    0 to $70^{\circ} \mathrm{C}$
    $\mathrm{C}_{0}$ (Shunt Capacitance of Crystal):
    $\mathrm{C}_{\mathrm{L}}$ (Load Capacitance):
    $30 \Omega$ max

    Drive Level:
    $7.0 \mathrm{pf} \max$

[^10]:    *For extended temperature parts only.

[^11]:    A.C. Characteristics

    Several timings changed in anticipation of test change (all listed in ns): TClav (min.) at 10 MHz from 50 to 44; Tcvctv (min.) at 8 MHz from 10 to 5; TCvCTv (max.) from 70 to 50 at 8 MHz and 56 to 40 at 10 MHz .

[^12]:    Shaded areas indicate instructions not available in 8086, 8088 microsystems.

[^13]:    *except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then EA $=$ disp-high: disp-low.

[^14]:    Shaded areas indicate instructions not available in 8086/8088 microsystems.

[^15]:    Note 1: Above Board managed by EMM.slts driver recommended. otber memory managers conforming to the Lotus/Intel/

[^16]:    *CHMOS is a patented Intel process.
    **IBM PC, XT, AT and DOS are registered trademarks of International Business Machines Corporation.

[^17]:    *CMOS is a patented Intel process.
    **IBM PC, XT, AT and DOS are registered trademarks of International Business Machines Corporation.
    MCS is a registered trademark of Intel Corporation.

[^18]:    G Granularity Bit $1=$ Segment length is 4 Kbyte granular $0=$ Segment length is byte granular
    0 Bit must be zero (0) for compatibility with future processors
    AVL Available field for user or OS

[^19]:    -INTR
    -NMI
    -HOLD

[^20]:    * PC AT and PC-DOS are trademarks of IBM.
    **MS-DOS is a trademark of Microsoft Corporation.

[^21]:    NOTE:
    *Typical value based on characterization data.

